This repo is abandoned. Please use https://github.com/captbaritone/codeception-mailcatcher-module instead or any other similar project.
This module will let you test emails that are sent during your Codeception acceptance tests.
It was inspired by the https://github.com/captbaritone/codeception-mailcatcher-module and https://github.com/fetch/zend-mail-codeception-module/.
It supports several mail testing tools:
- MailCatcher
- MailDump
- ZendMail
- LatherMail
- MailHog
- Mailtrap
- [Imap Server] included
Add the packages into your composer.json
. For example we add Guzzle lib for MailCatcher
for MailDump provider:
{
"require-dev": {
"codeception/codeception": "*",
"johnatannvmd/mailchecker-codeception-module": "1.*"
}
}
Tell Composer to download the package:
php composer.phar update
Then enable it in your acceptance.suite.yml
configuration and set the url and
port of your site's MailCatcher installation:
class_name: WebGuy
modules:
enabled:
- MailChecker
config:
MailChecker:
provider: MailCatcher
options:
url: 'http://project.dev'
port: '1080'
If you need to specify some special options (e.g. SSL verification or authentication headers), you can set all of the allowed Guzzle request options:
class_name: WebGuy
modules:
enabled:
- MailChecker
config:
MailChecker:
provider: MailDump
options:
url: 'http://project.dev'
port: '1080'
guzzleOptions:
auth: ['yo', 'yo']
<?php
$I = new WebGuy($scenario);
$I->wantTo('Get a password reset email');
// Cleared old emails from MailCatcher
$I->clearMailbox();
// Reset
$I->amOnPage('forgotPassword.php');
$I->fillField("input[name='email']", '[email protected]');
$I->click("Submit");
$I->see("Please check your email");
$I->seeInLastEmail("Please click this link to reset your password");
Clears the emails in providers's list. This is prevents seeing emails sent during a previous test. You probably want to do this before you trigger any emails to be sent
Example:
<?php
// Clears all emails
$I->clearMailbox();
?>
Checks that an email contains a value. It searches the full raw text of the email: headers, subject line, and body.
Example:
<?php
$I->seeInLastEmail('Thanks for signing up!');
?>
- Param $text
Checks that the last email sent to an address contains a value. It searches the full raw text of the email: headers, subject line, and body.
This is useful if, for example a page triggers both an email to the new user, and to the administrator.
Example:
<?php
$I->seeInLastEmailTo('[email protected]', 'Thanks for signing up!');
$I->seeInLastEmailTo('[email protected]', 'A new user has signed up!');
?>
- Param $email
- Param $text
Checks that an email does NOT contain a value. It searches the full raw text of the email: headers, subject line, and body.
Example:
<?php
$I->dontSeeInLastEmail('Hit me with those laser beams');
?>
- Param $text
Checks that the last email sent to an address does NOT contain a value. It searches the full raw text of the email: headers, subject line, and body.
Example:
<?php
$I->dontSeeInLastEmailTo('[email protected]', 'But shoot it in the right direction');
?>
- Param $email
- Param $text
Checks that the last email have attachment with following filename.
Example:
<?php
$I->seeAttachmentFilenameInLastEmail('expected_journey.ext');
?>
- Param $expectedFilename
Checks that the last email does NOT have attachment with following filename.
Example:
<?php
$I->dontSeeAttachmentFilenameInLastEmail('unexpected_journey.ext');
?>
- Param $unexpectedFilename
Checks that the last sent to an address have attachment with following filename.
Example:
<?php
$I->seeAttachmentFilenameInLastEmailTo('[email protected]', 'expected_journey.ext');
?>
- Param $address
- Param $expectedFilename
Checks that the last sent to an address does NOT have attachment with following filename.
Example:
<?php
$I->dontSeeAttachmentFilenameInLastEmailTo('[email protected]', 'unexpected_journey.ext');
?>
- Param $address
- Param $unexpectedFilename
Asserts that a certain number of attachments found in the last email.
Example:
<?php
$I->seeAttachmentsCountInLastEmail(1);
?>
- Param $exected
Asserts that a certain number of attachments found in the last email to a given address.
Example:
<?php
$I->seeAttachmentsCountInLastEmailTo('[email protected]', 1);
?>
- Param $address
- Param $expected
Look for the expected CC address in the last sent email.
Example:
<?php
$I->seeCcInLastEmail('[email protected]');
?>
- Param $expectedAddress
Look for the expected CC address in the last sent email to a given address.
Example:
<?php
$I->seeCcInLastEmailTo('[email protected]', '[email protected]');
?>
- Param $address
- Param $expectedAddress
Extracts an array of matches and sub-matches from the last email based on
a regular expression. It searches the full raw text of the email: headers,
subject line, and body. The return value is an array like that returned by
preg_match()
.
Example:
<?php
$matches = $I->grabMatchesFromLastEmail('@<strong>(.*)</strong>@');
?>
- Param $regex
Extracts a string from the last email based on a regular expression. It searches the full raw text of the email: headers, subject line, and body.
Example:
<?php
$match = $I->grabFromLastEmail('@<strong>(.*)</strong>@');
?>
- Param $regex
Extracts an array of matches and sub-matches from the last email to a given
address based on a regular expression. It searches the full raw text of the
email: headers, subject line, and body. The return value is an array like that
returned by preg_match()
.
Example:
<?php
$matchs = $I->grabMatchesFromLastEmailTo('[email protected]', '@<strong>(.*)</strong>@');
?>
- Param $email
- Param $regex
Extracts a string from the last email to a given address based on a regular expression. It searches the full raw text of the email: headers, subject line, and body.
Example:
<?php
$match = $I->grabFromLastEmailTo('[email protected]', '@<strong>(.*)</strong>@');
?>
- Param $email
- Param $regex
Asserts that a certain number of emails have been sent since the last time
clearMailbox()
was called.
Example:
<?php
$match = $I->seeEmailCount(2);
?>
- Param $count
Now you can build all modules at once by:
docker-compose build
Released under the same licence as Codeception: MIT