JUnit5 Docker
JUnit5-Docker
is a JUnit5
extension that start docker containers before running tests and stop them afterwards.
This is the documentation for the version 1.0.1-SNAPSHOT.
The last released version can be found at https://faustxvi.github.io/junit5-docker/current and the documentation of the under developpment version can be found at https://faustxvi.github.io/junit5-docker/snapshot
Dependency ———-
Since this is a SNAPSHOT version, you can’t find it on maven central so you’ll need to add the repository to your pom.xml
like this :
<repositories>
<repository>
<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
<id>ossrh</id>
</repository>
</repositories>
To use JUnit5-Docker
, you first need to declare it as a dependency. Add these lines to your pom.xml
if you are using maven.
<dependency>
<groupId>com.github.faustxvi</groupId>
<artifactId>junit5-docker</artifactId>
<version>1.0.1-SNAPSHOT</version>
<scope>test</scope>
</dependency>
Usage —–
The entrypoint is the @Docker
annotation.
Please refer to the Javadoc for more details.
The container is started before each test method is called; and stopped afterward.
This mean that the container is already started when the @BeforeEach
methods are called and destroyed after the @AfterEach
methods.
By default, you are guaranteed that a new container is created for each tests.
Simple Example
Given that you have a test like :
@Docker(image = "faustxvi/simple-two-ports", ports = @Port(exposed = 8801, inner = 8080))
public class MyAwesomeTest {
@Test
void checkMyCode() {
// Add your test content here
}
@Test
void checkMyCodeWithAnotherContainer() {
// Add your test content here
}
}
When you run your tests :
* a new container `faustxvi/simple-two-ports` is started before running each tests using the version `latest`
* the port `8801` is bound to the container's port `8080` so you can exchange through this port
* this container is stopped and removed after usage
Real life exemple
Given that you have a test like :
@Docker(image = "mysql", ports = @Port(exposed = 8801, inner = 3306),
environments = {
@Environment(key = "MYSQL_ROOT_PASSWORD", value = "root"),
@Environment(key = "MYSQL_DATABASE", value = "testdb"),
@Environment(key = "MYSQL_USER", value = "testuser"),
@Environment(key = "MYSQL_PASSWORD", value = "s3cr3t"),
},
waitFor = @WaitFor("mysqld: ready for connections"))
public class MyAwesomeTest {
@Test
void checkMyCode() {
// Add your test content here
}
@Test
void checkMyCodeWithAnotherContainer() {
// Add your test content here
}
}
When you run your tests :
* the container is started with the given environment variables
* the tests are started only after the string `mysqld: ready for connections` is found in the container's logs
Keep the container for all tests of a class
The container is started once for the whole class and before any test method is called; and stopped afterward.
This mean that the container is already started when the @BeforeEach
and @BeforeAll
methods are called and destroyed after the @AfterEach
and @AfterAll
methods.
Be aware that the container is not restarted between tests so changing the state of the container in one test may affect other tests.
Given that you have a test like :
@Docker(image = "faustxvi/simple-two-ports", ports = @Port(exposed = 8801, inner = 8080), newForEachCase = false)
public class MyAwesomeTest {
@Test
void checkMyCode() {
// Add your test content here
}
@Test
void checkMyCodeWithTheSameContainer() {
// Add your test content here
}
}
When you run your tests :
* the container `faustxvi/simple-two-ports` is started before running your tests using the version `latest`
* the container is stopped and removed after your tests