diff options
author | Jesse Plamondon-Willard <Pathoschild@users.noreply.github.com> | 2022-11-10 21:52:00 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-11-10 21:52:00 -0500 |
commit | 2a8cb8c636f0b672284b8daffcfdd5bec36c00f9 (patch) | |
tree | 3fe6fb993c498e82c96c1101a683be4bfa1621fd /src/SMAPI.Tests/Core | |
parent | 76e5588f02b247204969efb488c3fb293601faeb (diff) | |
parent | 303b3924ae3ef905d77b9d7ef0f9efc70e58c2b8 (diff) | |
download | SMAPI-2a8cb8c636f0b672284b8daffcfdd5bec36c00f9.tar.gz SMAPI-2a8cb8c636f0b672284b8daffcfdd5bec36c00f9.tar.bz2 SMAPI-2a8cb8c636f0b672284b8daffcfdd5bec36c00f9.zip |
Merge pull request #878 from atravita-mods/develop
Rewrite asset name comparison to stop at the first mismatch
Diffstat (limited to 'src/SMAPI.Tests/Core')
-rw-r--r-- | src/SMAPI.Tests/Core/AssetNameTests.cs | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/SMAPI.Tests/Core/AssetNameTests.cs b/src/SMAPI.Tests/Core/AssetNameTests.cs index 655e9bae..fdaa2c01 100644 --- a/src/SMAPI.Tests/Core/AssetNameTests.cs +++ b/src/SMAPI.Tests/Core/AssetNameTests.cs @@ -151,6 +151,12 @@ namespace SMAPI.Tests.Core // with locale codes [TestCase("Data/Achievements.fr-FR", "Data/Achievements", ExpectedResult = true)] + + // prefix ends with path separator + [TestCase("Data/Events/Boop", "Data/Events/", ExpectedResult = true)] + [TestCase("Data/Events/Boop", "Data/Events\\", ExpectedResult = true)] + [TestCase("Data/Events", "Data/Events/", ExpectedResult = false)] + [TestCase("Data/Events", "Data/Events\\", ExpectedResult = false)] public bool StartsWith_SimpleCases(string mainAssetName, string prefix) { // arrange @@ -243,6 +249,22 @@ namespace SMAPI.Tests.Core return result; } + [TestCase("Mods/SomeMod/SomeSubdirectory", "Mods/Some", true, ExpectedResult = true)] + [TestCase("Mods/SomeMod/SomeSubdirectory", "Mods/Some", false, ExpectedResult = false)] + [TestCase("Mods/Jasper/Data", "Mods/Jas/Image", true, ExpectedResult = false)] + [TestCase("Mods/Jasper/Data", "Mods/Jas/Image", true, ExpectedResult = false)] + public bool StartsWith_PartialMatchInPathSegment(string mainAssetName, string otherAssetName, bool allowSubfolder) + { + // arrange + mainAssetName = PathUtilities.NormalizeAssetName(mainAssetName); + + // act + AssetName name = AssetName.Parse(mainAssetName, _ => null); + + // assert value + return name.StartsWith(otherAssetName, allowPartialWord: true, allowSubfolder: allowSubfolder); + } + /**** ** GetHashCode |