Sha256: 2907a04fa0ce4fb767786ee85b9be323558a40452f034417c33c1adc8f84cce9

Contents?: true

Size: 1.17 KB

Versions: 89

Compression:

Stored size: 1.17 KB

Contents

import org.junit.Test
import kotlin.test.assertEquals

class BinarySearchTest {

    @Test(expected = IllegalArgumentException::class)
    fun unsortedListCannotBeSearched() {
        BinarySearch.search(listOf(1, 2, 4, 3), 1)
    }

    @Test
    fun shouldReturnMinus1ForAValueNotPresentInTheList() {
        assertEquals(-1, BinarySearch.search(listOf(1, 2, 3, 4), 5))
    }

    @Test
    fun shouldFindTheItemInASingleElementList() {
        assertEquals(0, BinarySearch.search(listOf(3), 3))
    }

    @Test
    fun shouldFindTheFirstItemInATwoElementList() {
        assertEquals(0, BinarySearch.search(listOf(4, 11), 4))
    }

    @Test
    fun shouldFindTheLastItemInATwoElementList() {
        assertEquals(1, BinarySearch.search(listOf(4, 11), 11))
    }

    @Test
    fun shouldFindTheMidItemInAnOddLengthList() {
        assertEquals(2, BinarySearch.search(listOf(4, 4, 7, 9, 11), 7))
    }

    @Test
    fun shouldFindThePreMidItemInAnEvenLengthList() {
        assertEquals(1, BinarySearch.search(listOf(4, 5, 9, 11), 5))
    }

    @Test
    fun shouldFindThePostMidItemInAnEvenLengthList() {
        assertEquals(2, BinarySearch.search(listOf(4, 5, 17, 29), 17))
    }
}

Version data entries

89 entries across 89 versions & 1 rubygems

Version Path
trackler-2.0.6.33 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.32 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.31 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.30 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.29 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.28 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.27 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.26 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.25 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.24 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.23 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.22 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.21 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.20 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.19 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.18 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.17 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.16 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.15 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt
trackler-2.0.6.14 tracks/kotlin/exercises/binary-search/src/test/kotlin/BinarySearchTest.kt