Provides idiomatic, easy-to-use ZLayers for Testcontainers-scala.
- Make sure your test configuration has the following settings
Test / fork := true
. Without this the Docker container created by the test will NOT be cleaned up until you exit SBT/the JVM process. This could quickly run your machine out of resources as you will end up with a ton of orphaned containers running. - Use
provideLayerShared({container}.live)
on your suite so that each test case isn't spinning up and down the container.
The testcontainer runtime can get pretty noisy when it comes to logging. To reduce this noise in your test cases, I recommend creating (or updating) the src/test/resources/logback-test.xml
file in your project based on the following sample:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} %msg%n</Pattern>
</layout>
</encoder>
</appender>
<root level="WARN">
<appender-ref ref="STDOUT" />
</root>
<logger name="org.testcontainers" level="WARN" />
<logger name="com.github.dockerjava" level="WARN" />
<logger name="ch.qos.logback" level="WARN" />
<!-- Only relevant if you are using the db migration aspect -->
<logger name="org.flywaydb" level="WARN" />
</configuration>
Provides a managed ZLayer that starts and stops a com.dimafeng.testcontainers.CassandraContainer
as well as also providing a managed com.datastax.oss.driver.api.core.CqlSession
.
libraryDependencies += "io.github.scottweaver" %% "zio-testcontainers-cassandra" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-testcontainers-cassandra" % "0.8.0"
See test cases for example usage.
Provides a managed ZLayer that starts and stops a com.dimafeng.testcontainers.MySQLTestContainer
as well as also providing a managed java.sql.Connection
and a javax.sql.DataSource
.
libraryDependencies += "io.github.scottweaver" %% "zio-testcontainers-mysql" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-testcontainers-mysql" % "0.8.0"
See test cases for example usage.
Provides a managed ZLayer that starts and stops a com.dimafeng.testcontainers.PostgreSQLContainer
as well as also providing a managed java.sql.Connection
and a javax.sql.DataSource
.
libraryDependencies += "io.github.scottweaver" %% "zio-testcontainers-postgresql" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-testcontainers-postgresql" % "0.8.0"
See test cases for example usage.
Provides a managed ZLayer that starts and stops a com.dimafeng.testcontainers.KafkaContainer
.
You also have easy access to:
zio.kafka.consumer.ConsumerSettings
viaZKafkaContainer.defaultConsumerSettings
.zio.kafka.consumer.ProducerSettings
viaZKafkaContainer.defaultProducerSettings
.
You can use these to create a zio.kafka.consumer.Consumer
and/or zio.kafka.producer.Producer
that can be used to interact with the Kafka container instance.
libraryDependencies += "io.github.scottweaver" %% "zio-testcontainers-kafka" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-testcontainers-kafka" % "0.8.0"
See test cases for example usage.
Not really a test container, useful none the less.
The io.github.scottweaver.zio.aspect.DatabaseMigrationsAspect
provides a ZIO TestAspect for running database migrations via Flyway. It seamlessly integrates with the ZMySQLContainer
or ZPostrgeSQLContainer
by using the io.github.scottweaver.zio.models.JdbcInfo
provided by ZMySQLContainer.live
or ZPostrgeSQLContainer.live
to run your migrations.
If you are not using ZMySQLContainer
or ZPostrgeSQLContainer
you can just manually provide an appropriate JdbcInfo
as a ZLayer
to your tests that are using the DbMigrationAspect
.
libraryDependencies += "io.github.scottweaver" %% "zio-db-migration-aspect" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-db-migration-aspect" % "0.8.0"
An alternative to the Flyway-based DbMigrationsAspect
that uses Liquibase instead.
The io.github.scottweaver.zio.aspect.LiquibaseAspect
provides a ZIO TestAspect for running database migrations via Liquibase. It seamlessly integrates with the ZMySQLContainer
or ZPostrgeSQLContainer
by using the io.github.scottweaver.zio.models.JdbcInfo
provided by ZMySQLContainer.live
or ZPostrgeSQLContainer.live
to run your Changelog migrations.
If you are not using ZMySQLContainer
or ZPostgreSQLContainer
you can just manually provide an appropriate JdbcInfo
as a ZLayer
to your tests that are using the LiquibaseAspect
.
libraryDependencies += "io.github.scottweaver" %% "zio-2.0-liquibase-aspect" % "0.8.0"
Not really a test container, useful none the less.
The io.github.scottweaver.zio.aspect.CassandraMigrationsAspect
provides a ZIO TestAspect for running database migrations via Cassandra Schema Migration. It seemlessly integrates with the ZCassandraContainer
by using the com.datastax.oss.driver.api.core.CqlSession
provided by ZCassandraContainer.live
to run your migrations.
If you are not using ZCassandraContainer
you can just manually provide an appropriate com.datastax.oss.driver.api.core.CqlSession
as a ZLayer
to your tests that are using the CassandraMigrationAspect
.
libraryDependencies += "io.github.scottweaver" %% "zio-cassandra-migration-aspect" % "0.8.0"
libraryDependencies += "io.github.scottweaver" %% "zio-2-0-cassandra-migration-aspect" % "0.8.0"