This harness has the MailService
class to assist test scenarios that involve Jenkins sending out emails and the test
script asserting its contents.
This class encapsulates where the mail server runs and how to retrieve emails sent from Jenkins.
To obtain an instance of a properly configured MailService
, just inject that into your test.
@Inject
MailService mail;
First, its setup
method must be called to set up Jenkins global configuration correctly.
You can then interact with Jenkins to induce it to send out emails, then you can use methods
on MailService
to inspect and assert on emails that have been sent to the server.
void testFoo() {
mail.setup(new MailerGlobalConfig(jenkins));
...
mail.assertMail(
Pattern.compile("^Modified "),
"dev@example.com",
Pattern.compile("\nwith amendment$"));
}
See MailerPluginTest
for a concrete example of how to write such tests.
The harness comes with the Mailtrap
class that uses a shared account of the Jenkins project.
This account does allow multiple people to independently run tests without colliding with each other,
but beware that the contents of those emails are visible to the world.
If for some reason this is problematic, you can create a separate account and use the wiring
script or additoinal Module
to bind MailService
to an instance of Mailtrap
.
A similar mechanism allows you to replace Mailtrap with another service or your own email server.