Skip to content

A Testcontainer implementation for Mailcatcher (a simple SMTP server which catches any message sent to it)

License

Notifications You must be signed in to change notification settings

skydrinker-tox/testcontainers-mailcatcher

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MailCatcher Testcontainer

A Testcontainers implementation for Mailcatcher.

CI build Maven Central

How to use

The @Container annotation used here in the readme is from the JUnit 5 support of Testcontainers. Please refer to the Testcontainers documentation for more information.

Default

Simply spin up a default MailCatcherContainer instance:

@Container
MailCatcherContainer mailcatcherContainer = new MailCatcherContainer();

Custom image

Use another MailCatcher Docker image/version than used in this Testcontainer:

@Container
MailCatcherContainer mailcatcherContainer = new MailCatcherContainer("dockage/mailcatcher:0.9.0");

Use mailCatcher testContainer as SMTP server

Get MailCatcher Testcontainer host and port for stubbing your STMP server:

String smtpHost = mailcatcherContainer.getHost();
int smtpPort = mailcatcherContainer.getSmtpPort();

Get received emails

You can get all received emails directly from the container, using

List<MailcatcherMail> emailList = mailcatcherContainer.getAllEmails();

You can get only the last received email and access its content using

MailcatcherMail email = mailcatcherContainer.getLastEmail();
String htmlEmailBody = email.getHtmlBody();
String plainTextEmailBody = email.getPlainTextBody();

Extending MailCatcherContainer

In case you need a custom implementation of the default MailCatcherContainer, you should inherit from ExtendableMailCatcherContainer. This allows to set the generics and use your custom implementation without the need for type casts.

public class MyCustomMailCatcherContainer extends ExtendableMailCatcherContainer<MyCustomMailCatcherContainer> {

	public MyCustomMailCatcherContainer() {
		super();
	}

	public MyCustomMailCatcherContainer(String dockerImageName) {
		super(dockerImageName);
	}
	
}

Setup

The release versions of this project are available at Maven Central. Simply put the dependency coordinates to your pom.xml (or something similar, if you use e.g. Gradle or something else):

<dependency>
  <groupId>com.github.skydrinker-tox</groupId>
  <artifactId>testcontainers-mailcatcher</artifactId>
  <version>VERSION</version>
  <scope>test</scope>
</dependency>

JUnit4 Dependency

The testcontainers project itself has a dependency on JUnit4 although it is not needed for this project in order to run (see this issue for more details). To avoid pulling in JUnit4 this project comes with a dependency on the quarkus-junit4-mock library which includes all needed classes as empty stubs. If you need JUnit4 in your project you should exclude this mock library when declaring the dependency to testcontainers-mailcatcher to avoid issues. Example for maven:

<dependency>
    <!-- ... see above -->
    <exclusions>
        <exclusion>
            <groupId>io.quarkus</groupId>
            <artifactId>quarkus-junit4-mock</artifactId>
        </exclusion>
    </exclusions>
</dependency>

Usage in your application framework tests

This info is not specific to the MailCatcher Testcontainer, but using Testcontainers generally.

I mention it here, as I see people asking again and again on how to use it in their test setup, when they think they need to specify a fixed port in their properties or YAML files...
You don't have to!
But you have to read the Testcontainers docs and the docs of your application framework on testing resources!!

Spring (Boot)

Dynamic context configuration with context initializers is your friend. In particular, look for @ContextConfiguration and ApplicationContextInitializer<ConfigurableApplicationContext>:

Quarkus

Read the docs about the Quarkus Test Resources and use @QuarkusTestResource with QuarkusTestResourceLifecycleManager

Others

Consult the docs of your application framework testing capabilities on how to dynamically configure your stack for testing!

About

A Testcontainer implementation for Mailcatcher (a simple SMTP server which catches any message sent to it)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages