Testcontainers
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.