From 9e27ec6bad6f211182561efdbeea4d402af93486 Mon Sep 17 00:00:00 2001 From: "Simeon L." Date: Mon, 14 Oct 2024 13:30:08 +0200 Subject: [PATCH] fix: Added @Ignore to the tests & refactored code a bit --- .../src/test/kotlin/ScaleTest.kt | 43 +++++++++++++------ 1 file changed, 30 insertions(+), 13 deletions(-) diff --git a/exercises/practice/scale-generator/src/test/kotlin/ScaleTest.kt b/exercises/practice/scale-generator/src/test/kotlin/ScaleTest.kt index 6881d21d..12ccd4a7 100644 --- a/exercises/practice/scale-generator/src/test/kotlin/ScaleTest.kt +++ b/exercises/practice/scale-generator/src/test/kotlin/ScaleTest.kt @@ -1,3 +1,4 @@ +import kotlin.test.Ignore import kotlin.test.asserter import kotlin.test.Test @@ -10,6 +11,7 @@ class ScaleTest { assertScalesEqual(expected, Scale("C").chromatic()) } + @Ignore @Test fun `chromatic scale with flats`() { val expected = listOf("F", "Gb", "G", "Ab", "A", "Bb", "B", "C", "Db", "D", "Eb", "E") @@ -17,124 +19,139 @@ class ScaleTest { } // Test scales with specified intervals + @Ignore @Test fun `simple major scale`() { val expected = listOf("C", "D", "E", "F", "G", "A", "B") assertScalesEqual(expected, Scale("C").interval("MMmMMMm")) } + @Ignore @Test fun `major scale with sharps`() { val expected = listOf("G", "A", "B", "C", "D", "E", "F#") assertScalesEqual(expected, Scale("G").interval("MMmMMMm")) } + @Ignore @Test fun `major scale with flats`() { val expected = listOf("F", "G", "A", "Bb", "C", "D", "E") assertScalesEqual(expected, Scale("F").interval("MMmMMMm")) } + @Ignore @Test fun `minor scale with sharps`() { val expected = listOf("F#", "G#", "A", "B", "C#", "D", "E") assertScalesEqual(expected, Scale("f#").interval("MmMMmMM")) } + @Ignore @Test fun `minor scale with flats`() { val expected = listOf("Bb", "C", "Db", "Eb", "F", "Gb", "Ab") assertScalesEqual(expected, Scale("bb").interval("MmMMmMM")) } + @Ignore @Test fun `dorian mode`() { val expected = listOf("D", "E", "F", "G", "A", "B", "C") assertScalesEqual(expected, Scale("d").interval("MmMMMmM")) } + @Ignore @Test fun `mixolydian mode`() { val expected = listOf("Eb", "F", "G", "Ab", "Bb", "C", "Db") assertScalesEqual(expected, Scale("Eb").interval("MMmMMmM")) } + @Ignore @Test fun `lydian mode`() { val expected = listOf("A", "B", "C#", "D#", "E", "F#", "G#") assertScalesEqual(expected, Scale("a").interval("MMMmMMm")) } + @Ignore @Test fun `phrygian mode`() { val expected = listOf("E", "F", "G", "A", "B", "C", "D") assertScalesEqual(expected, Scale("e").interval("mMMMmMM")) } + @Ignore @Test fun `locrian mode`() { val expected = listOf("G", "Ab", "Bb", "C", "Db", "Eb", "F") assertScalesEqual(expected, Scale("g").interval("mMMmMMM")) } + @Ignore @Test fun `harmonic minor`() { val expected = listOf("D", "E", "F", "G", "A", "Bb", "Db") assertScalesEqual(expected, Scale("d").interval("MmMMmAm")) } + @Ignore @Test fun octatonic() { val expected = listOf("C", "D", "D#", "F", "F#", "G#", "A", "B") assertScalesEqual(expected, Scale("C").interval("MmMmMmMm")) } + @Ignore @Test fun hexatonic() { val expected = listOf("Db", "Eb", "F", "G", "A", "B") assertScalesEqual(expected, Scale("Db").interval("MMMMMM")) } + @Ignore @Test fun pentatonic() { val expected = listOf("A", "B", "C#", "E", "F#") assertScalesEqual(expected, Scale("A").interval("MMAMA")) } + @Ignore @Test fun enigmatic() { val expected = listOf("G", "G#", "B", "C#", "D#", "F", "F#") assertScalesEqual(expected, Scale("G").interval("mAMMMmm")) } - fun assertScalesEqual(expected: List, actual: List) { + private fun assertScalesEqual(expected: List, actual: List) { asserter.assertTrue( { "Scales should be equal. Expected <$expected>, actual <$actual>" }, scalesAreEqual(expected, actual)) } - fun scalesAreEqual(expected: List, actual: List): Boolean { + private fun scalesAreEqual(expected: List, actual: List): Boolean { if (expected.size != actual.size) return false return expected.zip(actual, this::notesEqual).all { it } } // Few enough equal notes that we can just list them all - fun notesEqual(left: String, right: String) = left.equals(right) || when(left) { + fun notesEqual(left: String, right: String) = left == right || when(left) { // A# == Bb - "A#" -> right.equals("Bb") - "Bb" -> right.equals("A#") + "A#" -> right == "Bb" + "Bb" -> right == "A#" // C# == Db - "C#" -> right.equals("Db") - "Db" -> right.equals("C#") + "C#" -> right == "Db" + "Db" -> right == "C#" // D# == Eb - "D#" -> right.equals("Eb") - "Eb" -> right.equals("D#") + "D#" -> right == "Eb" + "Eb" -> right == "D#" // F# == Gb - "F#" -> right.equals("Gb") - "Gb" -> right.equals("F#") + "F#" -> right == "Gb" + "Gb" -> right == "F#" // G# == Ab - "G#" -> right.equals("Ab") - "Ab" -> right.equals("G#") + "G#" -> right == "Ab" + "Ab" -> right == "G#" else -> false } }