-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #57 from andy840119/refactor-text-index-test
Refactor the TextIndexTest.cs
- Loading branch information
Showing
4 changed files
with
75 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
// Copyright (c) karaoke.dev <[email protected]>. Licensed under the MIT Licence. | ||
// See the LICENCE file in the repository root for full licence text. | ||
|
||
using System.Text.RegularExpressions; | ||
using LrcParser.Extension; | ||
using LrcParser.Model; | ||
|
||
namespace LrcParser.Tests.Helper; | ||
|
||
public static class TestCaseTextIndexHelper | ||
{ | ||
public static TextIndex ParseTextIndex(string str) | ||
{ | ||
var regex = new Regex("(?<index>[-0-9]+),(?<state>start|end)"); | ||
var result = regex.Match(str); | ||
if (!result.Success) | ||
throw new RegexMatchTimeoutException(nameof(str)); | ||
|
||
int index = result.GetGroupValue<int>("index"); | ||
var state = result.GetGroupValue<string>("state") == "start" ? IndexState.Start : IndexState.End; | ||
|
||
return new TextIndex(index, state); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,74 +1,66 @@ | ||
// Copyright (c) karaoke.dev <[email protected]>. Licensed under the MIT Licence. | ||
// See the LICENCE file in the repository root for full licence text. | ||
|
||
using System; | ||
using LrcParser.Model; | ||
using LrcParser.Tests.Helper; | ||
using NUnit.Framework; | ||
|
||
namespace LrcParser.Tests.Model; | ||
|
||
[TestFixture] | ||
public class TextIndexTest | ||
{ | ||
[TestCase(1, 1)] | ||
[TestCase(1.5, 1.5)] | ||
[TestCase(-1.5, -1.5)] | ||
public void TestOperatorEqual(double tone1, double tone2) | ||
[TestCase("1,start")] | ||
[TestCase("1,end")] | ||
[TestCase("-1,start")] | ||
public void TestOperatorEqual(string textIndex1) | ||
{ | ||
Assert.AreEqual(numberToTextIndex(tone1), numberToTextIndex(tone2)); | ||
Assert.AreEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1), TestCaseTextIndexHelper.ParseTextIndex(textIndex1)); | ||
} | ||
|
||
[TestCase(-1, 1)] | ||
[TestCase(1, -1)] | ||
[TestCase(1.5, -1.5)] | ||
[TestCase(1.5, 1)] | ||
[TestCase(-1.5, -1)] | ||
[TestCase(-1.5, -2)] | ||
public void TestOperatorNotEqual(double tone1, double tone2) | ||
[TestCase("-1,start", "1,start")] | ||
[TestCase("1,start", "-1,start")] | ||
[TestCase("1,end", "-1,end")] | ||
[TestCase("1,end", "1,start")] | ||
[TestCase("-2,end", "-1,start")] | ||
[TestCase("-2,end", "-2,start")] | ||
public void TestOperatorNotEqual(string textIndex1, string textIndex2) | ||
{ | ||
Assert.AreNotEqual(numberToTextIndex(tone1), numberToTextIndex(tone2)); | ||
Assert.AreNotEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1), TestCaseTextIndexHelper.ParseTextIndex(textIndex2)); | ||
} | ||
|
||
[TestCase(1, 0, true)] | ||
[TestCase(1, 0.5, true)] | ||
[TestCase(1, 1, false)] | ||
[TestCase(1, 1.5, false)] | ||
public void TestOperatorGreater(double tone1, double tone2, bool match) | ||
[TestCase("1,start", "0,start", true)] | ||
[TestCase("1,start", "0,end", true)] | ||
[TestCase("1,start", "1,start", false)] | ||
[TestCase("1,start", "1,end", false)] | ||
public void TestOperatorGreater(string textIndex1, string textIndex2, bool match) | ||
{ | ||
Assert.AreEqual(numberToTextIndex(tone1) > numberToTextIndex(tone2), match); | ||
Assert.AreEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1) > TestCaseTextIndexHelper.ParseTextIndex(textIndex2), match); | ||
} | ||
|
||
[TestCase(1, 0, true)] | ||
[TestCase(1, 0.5, true)] | ||
[TestCase(1, 1, true)] | ||
[TestCase(1, 1.5, false)] | ||
public void TestOperatorGreaterOrEqual(double tone1, double tone2, bool match) | ||
[TestCase("1,start", "0,start", true)] | ||
[TestCase("1,start", "0,end", true)] | ||
[TestCase("1,start", "1,start", true)] | ||
[TestCase("1,start", "1,end", false)] | ||
public void TestOperatorGreaterOrEqual(string textIndex1, string textIndex2, bool match) | ||
{ | ||
Assert.AreEqual(numberToTextIndex(tone1) >= numberToTextIndex(tone2), match); | ||
Assert.AreEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1) >= TestCaseTextIndexHelper.ParseTextIndex(textIndex2), match); | ||
} | ||
|
||
[TestCase(-1, 0, true)] | ||
[TestCase(-1, -0.5, true)] | ||
[TestCase(-1, -1, false)] | ||
[TestCase(-1, -1.5, false)] | ||
public void TestOperatorLess(double tone1, double tone2, bool match) | ||
[TestCase("-1,start", "0,start", true)] | ||
[TestCase("-1,start", "-1,end", true)] | ||
[TestCase("-1,start", "-1,start", false)] | ||
[TestCase("-1,start", "-2,end", false)] | ||
public void TestOperatorLess(string textIndex1, string textIndex2, bool match) | ||
{ | ||
Assert.AreEqual(numberToTextIndex(tone1) < numberToTextIndex(tone2), match); | ||
Assert.AreEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1) < TestCaseTextIndexHelper.ParseTextIndex(textIndex2), match); | ||
} | ||
|
||
[TestCase(-1, 0, true)] | ||
[TestCase(-1, -0.5, true)] | ||
[TestCase(-1, -1, true)] | ||
[TestCase(-1, -1.5, false)] | ||
public void TestOperatorLessOrEqual(double tone1, double tone2, bool match) | ||
[TestCase("-1,start", "0,start", true)] | ||
[TestCase("-1,start", "-1,end", true)] | ||
[TestCase("-1,start", "-1,start", true)] | ||
[TestCase("-1,start", "-2,end", false)] | ||
public void TestOperatorLessOrEqual(string textIndex1, string textIndex2, bool match) | ||
{ | ||
Assert.AreEqual(numberToTextIndex(tone1) <= numberToTextIndex(tone2), match); | ||
} | ||
|
||
private static TextIndex numberToTextIndex(double tone) | ||
{ | ||
var half = Math.Abs(tone) % 1 == 0.5; | ||
var scale = tone < 0 ? (int)tone - (half ? 1 : 0) : (int)tone; | ||
return new TextIndex(scale, half ? IndexState.End : IndexState.Start); | ||
Assert.AreEqual(TestCaseTextIndexHelper.ParseTextIndex(textIndex1) <= TestCaseTextIndexHelper.ParseTextIndex(textIndex2), match); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters