nodemailer-stub
Nodemailer-stub comes with a stub transport for Nodemailer. The Stub stores the messages in memory but mimics real mail behaviour. It also contains a smart testing class called InteractsWithMail, which allows users to access, read, count and flush the messages in memory in their testing environment.
Installation
$ yarn add nodemailer-stub -D#... or via npm$ npm install nodemailer-stub --save-dev
Usage
This is an example use case for the Stub.
let transport = nodeMailer let mail = await transport
For testing purposes, there is also a transport called errorTransport
, where
the transport throws an error during execution, to help with testing the
robustness of your mail service logic.
We've also included a testing utility class, called interactsWithMail
. You can use it in your tests like this:
const exampleMail = to: 'john@domain.com' from: 'jimmy@domain.com' subject: 'testing' content: 'foo' contents: 'foo' contentType: 'text/plain'
Available methods for interactsWithMail
:
lastMail()
Retrieves last mail. Accessible properties:
- from
- to
- subject
- content
- contents
- contentType
newMail (Object)
Adds a new mail to the list of all mails.
Available properties:
- from (required)
- to (required)
- subject
- text (required)
flushMails ()
Flushes all messages. Useful when testing multiple occurrences of mailer, and should be used in afterAll or afterEach hooks in your tests.
sentMailsCount ()
Retrieves a count of how many emails were sent in the last mailer call.
Testing
All tests can be executed with the following command:
$ yarn test
License
See LICENSE file.