mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Create DatTools test project; move Cleaning tests
This commit is contained in:
89
SabreTools.DatTools.Test/CleaningTests.cs
Normal file
89
SabreTools.DatTools.Test/CleaningTests.cs
Normal file
@@ -0,0 +1,89 @@
|
||||
using SabreTools.DatItems;
|
||||
using SabreTools.DatItems.Formats;
|
||||
using Xunit;
|
||||
|
||||
namespace SabreTools.DatTools.Test
|
||||
{
|
||||
public class CleaningTests
|
||||
{
|
||||
[Fact]
|
||||
public void CleanDatItem_Normalize()
|
||||
{
|
||||
var datItem = new Rom();
|
||||
datItem.SetName("name");
|
||||
|
||||
var machine = new Machine();
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "\"ÁБ\"");
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.DescriptionKey, "ä|/Ж");
|
||||
|
||||
var cleaner = new Cleaner { Normalize = true };
|
||||
cleaner.CleanDatItem(datItem, machine);
|
||||
|
||||
Assert.Equal("name", datItem.GetName());
|
||||
Assert.Equal("'AB'", machine.GetStringFieldValue(Models.Metadata.Machine.NameKey));
|
||||
Assert.Equal("ae-Zh", machine.GetStringFieldValue(Models.Metadata.Machine.DescriptionKey));
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void CleanDatItem_RemoveUnicode()
|
||||
{
|
||||
var datItem = new Rom();
|
||||
datItem.SetName("nam诶");
|
||||
|
||||
var machine = new Machine();
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "nam诶-2");
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.DescriptionKey, "nam诶-3");
|
||||
|
||||
var cleaner = new Cleaner { RemoveUnicode = true };
|
||||
cleaner.CleanDatItem(datItem, machine);
|
||||
|
||||
Assert.Equal("nam", datItem.GetName());
|
||||
Assert.Equal("nam-2", machine.GetStringFieldValue(Models.Metadata.Machine.NameKey));
|
||||
Assert.Equal("nam-3", machine.GetStringFieldValue(Models.Metadata.Machine.DescriptionKey));
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void CleanDatItem_Single()
|
||||
{
|
||||
var datItem = new Rom();
|
||||
datItem.SetName("name");
|
||||
|
||||
var machine = new Machine();
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "name-2");
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.DescriptionKey, "name-3");
|
||||
|
||||
var cleaner = new Cleaner { Single = true };
|
||||
cleaner.CleanDatItem(datItem, machine);
|
||||
|
||||
Assert.Equal("name", datItem.GetName());
|
||||
Assert.Equal("!", machine.GetStringFieldValue(Models.Metadata.Machine.NameKey));
|
||||
Assert.Equal("!", machine.GetStringFieldValue(Models.Metadata.Machine.DescriptionKey));
|
||||
}
|
||||
|
||||
[Theory]
|
||||
[InlineData(null, "name")]
|
||||
[InlineData("", "name")]
|
||||
[InlineData("C:\\Normal\\Depth\\Path", "name")]
|
||||
[InlineData("C:\\AbnormalFolderLengthPath\\ThatReallyPushesTheLimit\\OfHowLongYou\\ReallyShouldNameThings\\AndItGetsEvenWorse\\TheMoreSubfoldersThatYouTraverse\\BecauseWhyWouldYouStop\\AtSomethingReasonable\\LikeReallyThisIsGettingDumb\\AndIKnowItsJustATest\\ButNotAsMuchAsMe", "nam")]
|
||||
public void CleanDatItem_TrimRoot(string? root, string expected)
|
||||
{
|
||||
var datItem = new Rom();
|
||||
datItem.SetName("name");
|
||||
|
||||
var machine = new Machine();
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.NameKey, "name-2");
|
||||
machine.SetFieldValue<string?>(Models.Metadata.Machine.DescriptionKey, "name-3");
|
||||
|
||||
var cleaner = new Cleaner
|
||||
{
|
||||
Trim = true,
|
||||
Root = root,
|
||||
};
|
||||
cleaner.CleanDatItem(datItem, machine);
|
||||
|
||||
Assert.Equal(expected, datItem.GetName());
|
||||
Assert.Equal("name-2", machine.GetStringFieldValue(Models.Metadata.Machine.NameKey));
|
||||
Assert.Equal("name-3", machine.GetStringFieldValue(Models.Metadata.Machine.DescriptionKey));
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user