Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions lib/elixir/test/elixir/calendar/duration_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -432,4 +432,8 @@ defmodule DurationTest do
) ==
"1year-2month-3day-4h-5min-6s"
end

test "inspect/1" do
assert inspect(%Duration{hour: 5, minute: 3}) == "%Duration{hour: 5, minute: 3}"
end
end
1 change: 1 addition & 0 deletions lib/elixir/test/elixir/json_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ defmodule JSONTest do
end

test "atoms" do
assert protocol_encode(:another) == "\"another\""
assert protocol_encode([nil, false, true, :another]) == "[null,false,true,\"another\"]"
end

Expand Down
4 changes: 4 additions & 0 deletions lib/elixir/test/elixir/stream_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -1464,6 +1464,10 @@ defmodule StreamTest do
assert Enum.zip(list, list) == Enum.zip(stream, stream)
end

test "inspect/1" do
"#Stream<[enum: 1..10, funs: " <> _ = Stream.map(1..10, & &1) |> inspect()
end

defp lazy?(stream) do
match?(%Stream{}, stream) or is_function(stream, 2)
end
Expand Down
38 changes: 24 additions & 14 deletions lib/elixir/test/elixir/version_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,14 @@ defmodule VersionTest do
assert %Version{major: 1, minor: 0, patch: 0} |> Version.to_string() == "1.0.0"
end

test "to_string/1 via protocol" do
assert Version.parse!("1.0.0") |> to_string() == "1.0.0"
end

test "inspect/1" do
assert Version.parse!("1.0.0") |> inspect() == "%Version{major: 1, minor: 0, patch: 0}"
end

test "match?/2 with invalid versions" do
assert_raise Version.InvalidVersionError, fn ->
Version.match?("foo", "2.3.0")
Expand Down Expand Up @@ -317,22 +325,24 @@ defmodule VersionTest do
assert Version.match?("0.7.0", req)
end

test "compile_requirement/1" do
{:ok, req} = Version.parse_requirement("1.2.3")
assert req == Version.compile_requirement(req)
end
describe "requirement" do
test "compile_requirement/1" do
{:ok, req} = Version.parse_requirement("1.2.3")
assert req == Version.compile_requirement(req)

test "compile requirement" do
{:ok, req} = Version.parse_requirement("1.2.3")
req = Version.compile_requirement(req)
assert Version.match?("1.2.3", req)
refute Version.match?("1.2.4", req)

assert Version.match?("1.2.3", req)
refute Version.match?("1.2.4", req)
assert Version.parse_requirement("1 . 2 . 3") == :error
assert Version.parse_requirement("== >= 1.2.3") == :error
assert Version.parse_requirement("1.2.3 and or 4.5.6") == :error
assert Version.parse_requirement(">= 1") == :error
assert Version.parse_requirement("1.2.3 >=") == :error
end

assert Version.parse_requirement("1 . 2 . 3") == :error
assert Version.parse_requirement("== >= 1.2.3") == :error
assert Version.parse_requirement("1.2.3 and or 4.5.6") == :error
assert Version.parse_requirement(">= 1") == :error
assert Version.parse_requirement("1.2.3 >=") == :error
test "inspect/1" do
assert Version.parse_requirement!("1.0.0") |> inspect() ==
"Version.parse_requirement!(\"1.0.0\")"
end
end
end
6 changes: 6 additions & 0 deletions lib/iex/test/iex/info_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,12 @@ defmodule IEx.InfoTest do
assert get_key(info, "Reference modules") == "Range"
end

test "maps" do
info = Info.info(%{foo: "bar"})
assert get_key(info, "Data type") == "Map"
assert get_key(info, "Reference modules") == "Map"
end

test "structs" do
info = Info.info(%Foo{})
assert get_key(info, "Data type") == "IEx.InfoTest.Foo"
Expand Down
Loading