'use strict';
const log = require('npmlog');
const Email = require('../../src/email/email');
const nodemailer = require('nodemailer');
describe('Email Unit Tests', () => {
let sandbox;
let email;
let sendFnStub;
const template = {
subject: 'foo',
text: 'bar',
html: 'bar'
};
const sender = {
name: 'Foo Bar',
email: 'foo@bar.com'
};
const userId1 = {
name: 'name1',
email: 'email1',
nonce: 'qwertzuioasdfghjkqwertzuio'
};
const keyId = '0123456789ABCDF0';
const origin = {
protocol: 'http',
host: 'localhost:8888'
};
const mailOptions = {
from: sender,
to: sender,
subject: 'Hello ✔', // Subject line
text: 'Hello world 🐴', // plaintext body
html: 'Hello world 🐴' // html body
};
beforeEach(() => {
sandbox = sinon.sandbox.create();
sendFnStub = sinon.stub();
sandbox.stub(nodemailer, 'createTransport').returns({
templateSender: () => sendFnStub
});
sandbox.stub(log);
email = new Email(nodemailer);
email.init({
host: 'host',
auth: {user: 'user', pass: 'pass'},
sender
});
expect(email._sender).to.equal(sender);
});
afterEach(() => {
sandbox.restore();
});
describe("send", () => {
beforeEach(() => {
sandbox.stub(email, '_sendHelper').resolves({response: '250'});
});
it('should work', async() => {
const info = await email.send({template, userId: userId1, keyId, origin});
expect(info.response).to.match(/^250/);
});
});
describe("_sendHelper", () => {
it('should work', async() => {
sendFnStub.resolves({response: '250'});
const info = await email._sendHelper(mailOptions);
expect(info.response).to.match(/^250/);
});
it('should log warning for reponse error', async() => {
sendFnStub.resolves({response: '554'});
const info = await email._sendHelper(mailOptions);
expect(info.response).to.match(/^554/);
expect(log.warn.calledOnce).to.be.true;
});
it('should fail', async() => {
sendFnStub.rejects(new Error('boom'));
try {
await email._sendHelper(mailOptions);
} catch (e) {
expect(log.error.calledOnce).to.be.true;
expect(e.status).to.equal(500);
expect(e.message).to.match(/failed/);
}
});
});
});