Sha256: b4ceb0c2a6905856d5c257beb84988932e5598c2b944243f1bda01302146799b

Contents?: true

Size: 1.38 KB

Versions: 324

Compression:

Stored size: 1.38 KB

Contents

if !System.get_env("EXERCISM_TEST_EXAMPLES") do
  Code.load_file("binary_search.exs", __DIR__)
end

ExUnit.start
ExUnit.configure exclude: :pending, trace: true

defmodule BinarySearchTest do
  use ExUnit.Case

  test "returns :not_found on empty tuple" do
    assert BinarySearch.search({}, 2) == :not_found
  end

  @tag :pending
  test "returns :not_found when key is not in the tuple" do
    assert BinarySearch.search({2, 4, 6}, 3) == :not_found
  end

  @tag :pending
  test "returns :not_found when key is too high" do
    assert BinarySearch.search({2, 4, 6}, 9) == :not_found
  end

  @tag :pending
  test "finds key in a tuple with a single item" do
    assert BinarySearch.search({3}, 3) == {:ok, 0}
  end

  @tag :pending
  test "finds key when it is the first element in tuple" do
    assert BinarySearch.search({1, 2, 4, 5, 6}, 1) == {:ok, 0}
  end

  @tag :pending
  test "finds key when it is in the middle of the tuple" do
    assert BinarySearch.search({1, 2, 4, 5, 6}, 4) == {:ok, 2}
  end

  @tag :pending
  test "finds key when it is the last element in tuple" do
    assert BinarySearch.search({1, 2, 4, 5, 6}, 6) == {:ok, 4}
  end

  @tag :pending
  test "finds key in a tuple with an even number of elements" do
    tuple = {1, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377}
    assert BinarySearch.search(tuple, 21) == {:ok, 5}
    assert BinarySearch.search(tuple, 34) == {:ok, 6}
  end
end

Version data entries

324 entries across 324 versions & 1 rubygems

Version Path
trackler-2.2.1.109 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.108 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.107 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.106 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.105 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.104 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.103 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.102 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.101 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.100 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.99 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.98 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.97 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.96 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.95 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.94 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.93 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.92 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.91 tracks/elixir/exercises/binary-search/binary_search_test.exs
trackler-2.2.1.90 tracks/elixir/exercises/binary-search/binary_search_test.exs