Test cases
defmodule MyTest do
  use ExUnit.Case
  use ExUnit.Case, async: true  # for async
  test "the truth" do
    assert 1 + 1 == 2
  end
end
Capture IO
import ExUnit.CaptureIO
test "capture io" do
  result = capture_io(fn ->
    IO.puts "sup"
  end)
  assert result == "sup\n"
end
Capture logs
config :ex_unit, capture_logs: true
Async
defmodule AssertionTest do
  # run concurrently with other test cases
  use ExUnit.Case, async: true
end
Assertions
assert x == y
refute x == y
assert_raise ArithmeticError, fn ->
  1 + "test"
end
assert_raise ArithmeticError, "message", fn -> ...
assert_raise ArithmeticError, ~r/message/, fn -> ...
flunk "This should've been an error"
See: Assertions
Setup
Pattern matching
setup do
  {:ok, name: "John"}
end
test "it works", %{name: name} do
  assert name == "John"
end
Setup
defp my_hook(_context) do
  # Invoked in every block in "a block"
  {:ok, name: "John", age: 54}
end
describe "a block" do
  setup [:my_hook]
  
  test "John's age", context do
    assert context[:name] == "John"
    assert context[:age] == 54
  end
end
0 Comments for this cheatsheet. Write yours!