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));
|
||||
}
|
||||
}
|
||||
}
|
||||
28
SabreTools.DatTools.Test/SabreTools.DatTools.Test.csproj
Normal file
28
SabreTools.DatTools.Test/SabreTools.DatTools.Test.csproj
Normal file
@@ -0,0 +1,28 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFrameworks>net6.0;net8.0;net9.0</TargetFrameworks>
|
||||
<IsPackable>false</IsPackable>
|
||||
<LangVersion>latest</LangVersion>
|
||||
<Nullable>enable</Nullable>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\SabreTools.DatItems\SabreTools.DatItems.csproj" />
|
||||
<ProjectReference Include="..\SabreTools.DatTools\SabreTools.DatTools.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="coverlet.collector" Version="6.0.3">
|
||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||
<PrivateAssets>all</PrivateAssets>
|
||||
</PackageReference>
|
||||
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.12.0" />
|
||||
<PackageReference Include="xunit" Version="2.9.2" />
|
||||
<PackageReference Include="xunit.runner.visualstudio" Version="3.0.0">
|
||||
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||
<PrivateAssets>all</PrivateAssets>
|
||||
</PackageReference>
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
Reference in New Issue
Block a user