Testcontainers

Hex.pm

Testcontainers is an Elixir library that supports ExUnit tests, providing lightweight, throwaway instances of common databases, Selenium web browsers, or anything else that can run in a Docker container.

Usage

For automatic cleanup of docker containers created in tests, for example if testcontainers fails to stop and remove the container, its suggested to register a reaper genserver in test_helper.exs like this:

test/test_helper.exs

{:ok, _} = Testcontainers.Reaper.start_link()
ExUnit.start()

test/mysql_container_test.exs

defmodule MySqlContainerTest do
use ExUnit.Case, async: true
import Testcontainers.ExUnit
alias Testcontainers.Container.MySqlContainer
describe "with default configuration" do
container(:mysql, MySqlContainer.new())
test "provides a ready-to-use mysql container", %{mysql: mysql} do
assert true
# if you want to test like below, add
# {:myxql, "~> 0.6.0", only: [:dev, :test]},
# to mix.exs and run mix deps.get
#{:ok, pid} = MyXQL.start_link(MySqlContainer.connection_parameters(mysql))
#assert %{num_rows: 1} = MyXQL.query!(pid, "SELECT 1", [])
end
end

Configure logging

Testcontainers will not log anything, unless the global log level is set to debug, which is the default log level for new mix projects.

You can suppress this debug logging globally for tests in config/test.exs like this:

import Config
config :logger, level: :warning

If you want to bring back the logs of Testcontainers later, you can change log level specifically like this in config/test.exs:

config :testcontainers,
log_level: :warning

If you have a lot of libraries and code that have different log levels, your config/test.exs could look like this if you use Testcontainers:

import Config
config :logger, level: :warning
config :testcontainers,
log_level: :warning

This will set everything to :warning, including Testcontainers default log level.

Contribution

Do you want to contribute? Find spots to improve on, fire up an issue and get the discussion going.