using Elwig.Helpers; namespace Tests.Helpers { [TestFixture] public class UtilsTest { private static readonly double[,] Gradation = new double[,] { { 14.0, 68.0 }, { 15.0, 73.0 }, { 17.1, 84.0 }, { 19.0, 94.0 }, { 21.0, 105.0 }, { 25.0, 127.0 }, { 27.1, 139.0 }, { 30.0, 156.0 }, }; [Test] public void Test_KmwToOe() { Assert.Multiple(() => { for (int i = 0; i < Gradation.GetLength(0); i++) { Assert.That(Utils.KmwToOe(Gradation[i, 0]), Is.EqualTo(Gradation[i, 1])); } }); } [Test] public void Test_OeToKmw() { Assert.Multiple(() => { for (int i = 0; i < Gradation.GetLength(0); i++) { Assert.That(Utils.OeToKmw(Gradation[i, 1]), Is.EqualTo(Gradation[i, 0])); } }); } [Test] public void Test_DecFromDb() { Assert.Multiple(() => { Assert.That(Utils.DecFromDb(10670, 3), Is.EqualTo(10.67M)); Assert.That(Utils.DecFromDb(-1009999, 4), Is.EqualTo(-100.9999M)); Assert.That(Utils.DecFromDb(1, 2), Is.EqualTo(0.01M)); }); } [Test] public void Test_DecToDb() { Assert.Multiple(() => { Assert.That(Utils.DecToDb(219.48M, 2), Is.EqualTo(21948)); Assert.That(Utils.DecToDb(-1.2345M, 4), Is.EqualTo(-12345)); Assert.That(Utils.DecToDb(99190, 0), Is.EqualTo(99190)); Assert.That(Utils.DecToDb(817.9099M, 3), Is.EqualTo(817910)); Assert.That(Utils.DecToDb(-5618.944M, 2), Is.EqualTo(-561894)); }); } [Test] public void Test_Modulo() { Assert.Multiple(() => { Assert.That(Utils.Modulo("1", 2), Is.EqualTo(1)); Assert.That(Utils.Modulo("12", 11), Is.EqualTo(1)); Assert.That(Utils.Modulo("65", 16), Is.EqualTo(1)); Assert.That(Utils.Modulo("91746381048364", 10), Is.EqualTo(4)); Assert.That(Utils.Modulo("210501700012345678131468", 97), Is.EqualTo(1)); Assert.Throws(() => Utils.Modulo("", 4)); Assert.Throws(() => Utils.Modulo("1ab", 5)); Assert.Throws(() => Utils.Modulo("123", 1)); Assert.Throws(() => Utils.Modulo("456", 0)); Assert.Throws(() => Utils.Modulo("789", -1)); }); } [Test] public void Test_SplitAddress() { Assert.Multiple(() => { Assert.That(Utils.SplitAddress("Winzerstraße 1"), Is.EqualTo(("Winzerstraße", "1"))); Assert.That(Utils.SplitAddress("Auf dem Feld 12"), Is.EqualTo(("Auf dem Feld", "12"))); Assert.That(Utils.SplitAddress("Winzerstraße 5a"), Is.EqualTo(("Winzerstraße", "5a"))); Assert.That(Utils.SplitAddress("Winzerstraße 1-3/2"), Is.EqualTo(("Winzerstraße", "1-3/2"))); Assert.That(Utils.SplitAddress("Winzerstraße 3/4/5"), Is.EqualTo(("Winzerstraße", "3/4/5"))); Assert.That(Utils.SplitAddress("Winzerstraße 7/2/4/77"), Is.EqualTo(("Winzerstraße", "7/2/4/77"))); Assert.That(Utils.SplitAddress("Winzerstraße 95b"), Is.EqualTo(("Winzerstraße", "95b"))); Assert.That(Utils.SplitAddress("Winzerstraße 1, TOP 3"), Is.EqualTo(("Winzerstraße", "1, TOP 3"))); }); } [Test] public void Test_SplitName() { Assert.Multiple(() => { Assert.That(Utils.SplitName("Max Bauer", "Bauer"), Is.EqualTo(("Bauer", "Max"))); Assert.That(Utils.SplitName("Bauer Max", "Bauer"), Is.EqualTo(("Bauer", "Max"))); Assert.That(Utils.SplitName("Max und Moritz Bauer", "Bauer"), Is.EqualTo(("Bauer", "Max und Moritz"))); Assert.That(Utils.SplitName("Bauer Max und Moritz", "Bauer"), Is.EqualTo(("Bauer", "Max und Moritz"))); Assert.That(Utils.SplitName("Bauer GesbR", "Bauer"), Is.EqualTo(("Bauer", "GesbR"))); Assert.That(Utils.SplitName("Max und Moritz Bauer GesbR", "Bauer"), Is.EqualTo(("Bauer", "Max und Moritz GesbR"))); Assert.That(Utils.SplitName("Bauer Max und Moritz GesbR", "Bauer"), Is.EqualTo(("Bauer", "Max und Moritz GesbR"))); Assert.That(Utils.SplitName("Weingut Bauer", "Bauer"), Is.EqualTo(("Bauer", "Weingut"))); Assert.That(Utils.SplitName("Bauer Weingut", "Bauer"), Is.EqualTo(("Bauer", "Weingut"))); Assert.That(Utils.SplitName("Max und Moritz Bauer und Mustermann", "Bauer"), Is.EqualTo(("Bauer und Mustermann", "Max und Moritz"))); Assert.That(Utils.SplitName("Bauer und Mustermann Max und Moritz", "Bauer"), Is.EqualTo(("Bauer und Mustermann", "Max und Moritz"))); Assert.That(Utils.SplitName("ABC GesbR", "Bauer"), Is.EqualTo(((string, string?))("ABC GesbR", null))); }); } } }