2016-05-30 15:36:32 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const log = require('npmlog');
|
2016-05-31 16:50:28 +02:00
|
|
|
const Email = require('../../src/email/email');
|
2016-05-30 15:36:32 +02:00
|
|
|
const nodemailer = require('nodemailer');
|
|
|
|
|
2016-05-31 13:52:18 +02:00
|
|
|
describe('Email Unit Tests', () => {
|
2017-08-15 16:03:06 +08:00
|
|
|
let email;
|
|
|
|
let sendFnStub;
|
2016-05-30 15:36:32 +02:00
|
|
|
|
2017-08-15 16:03:06 +08:00
|
|
|
const template = {
|
2016-05-31 16:50:28 +02:00
|
|
|
subject: 'foo',
|
|
|
|
text: 'bar',
|
|
|
|
html: '<strong>bar</strong>'
|
|
|
|
};
|
2017-08-15 16:03:06 +08:00
|
|
|
const sender = {
|
2016-05-30 15:36:32 +02:00
|
|
|
name: 'Foo Bar',
|
|
|
|
email: 'foo@bar.com'
|
|
|
|
};
|
2017-08-15 16:03:06 +08:00
|
|
|
const userId1 = {
|
2016-05-30 15:36:32 +02:00
|
|
|
name: 'name1',
|
|
|
|
email: 'email1',
|
|
|
|
nonce: 'qwertzuioasdfghjkqwertzuio'
|
|
|
|
};
|
2017-08-15 16:03:06 +08:00
|
|
|
const keyId = '0123456789ABCDF0';
|
|
|
|
const origin = {
|
2016-05-30 15:36:32 +02:00
|
|
|
protocol: 'http',
|
|
|
|
host: 'localhost:8888'
|
|
|
|
};
|
2017-08-15 16:03:06 +08:00
|
|
|
const mailOptions = {
|
2016-05-30 15:36:32 +02:00
|
|
|
from: sender,
|
|
|
|
to: sender,
|
|
|
|
subject: 'Hello ✔', // Subject line
|
|
|
|
text: 'Hello world 🐴', // plaintext body
|
|
|
|
html: '<b>Hello world 🐴</b>' // html body
|
|
|
|
};
|
|
|
|
|
2016-05-31 13:52:18 +02:00
|
|
|
beforeEach(() => {
|
2016-05-30 15:36:32 +02:00
|
|
|
sendFnStub = sinon.stub();
|
|
|
|
sinon.stub(nodemailer, 'createTransport').returns({
|
2017-08-15 16:03:06 +08:00
|
|
|
templateSender: () => sendFnStub
|
2016-05-30 15:36:32 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
sinon.stub(log, 'warn');
|
|
|
|
sinon.stub(log, 'error');
|
|
|
|
|
|
|
|
email = new Email(nodemailer);
|
|
|
|
email.init({
|
|
|
|
host: 'host',
|
2017-08-15 16:03:06 +08:00
|
|
|
auth: {user: 'user', pass: 'pass'},
|
|
|
|
sender
|
2016-05-30 15:36:32 +02:00
|
|
|
});
|
|
|
|
expect(email._sender).to.equal(sender);
|
|
|
|
});
|
|
|
|
|
2016-05-31 13:52:18 +02:00
|
|
|
afterEach(() => {
|
2016-05-30 15:36:32 +02:00
|
|
|
nodemailer.createTransport.restore();
|
|
|
|
log.warn.restore();
|
|
|
|
log.error.restore();
|
|
|
|
});
|
|
|
|
|
2016-05-31 16:50:28 +02:00
|
|
|
describe("send", () => {
|
2016-05-31 13:52:18 +02:00
|
|
|
beforeEach(() => {
|
2017-08-15 16:03:06 +08:00
|
|
|
sinon.stub(email, '_sendHelper').returns(Promise.resolve({response: '250'}));
|
2016-05-30 15:36:32 +02:00
|
|
|
});
|
|
|
|
|
2016-05-31 13:52:18 +02:00
|
|
|
afterEach(() => {
|
2016-05-31 16:50:28 +02:00
|
|
|
email._sendHelper.restore();
|
2016-05-30 15:36:32 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should work', function *() {
|
2017-08-15 16:03:06 +08:00
|
|
|
const info = yield email.send({template, userId: userId1, keyId, origin});
|
2016-05-30 15:36:32 +02:00
|
|
|
|
|
|
|
expect(info.response).to.match(/^250/);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2016-05-31 16:50:28 +02:00
|
|
|
describe("_sendHelper", () => {
|
2016-05-30 15:36:32 +02:00
|
|
|
it('should work', function *() {
|
2017-08-15 16:03:06 +08:00
|
|
|
sendFnStub.returns(Promise.resolve({response: '250'}));
|
2016-05-30 15:36:32 +02:00
|
|
|
|
2017-08-15 16:03:06 +08:00
|
|
|
const info = yield email._sendHelper(mailOptions);
|
2016-05-30 15:36:32 +02:00
|
|
|
|
|
|
|
expect(info.response).to.match(/^250/);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should log warning for reponse error', function *() {
|
2017-08-15 16:03:06 +08:00
|
|
|
sendFnStub.returns(Promise.resolve({response: '554'}));
|
2016-05-30 15:36:32 +02:00
|
|
|
|
2017-08-15 16:03:06 +08:00
|
|
|
const info = yield email._sendHelper(mailOptions);
|
2016-05-30 15:36:32 +02:00
|
|
|
|
|
|
|
expect(info.response).to.match(/^554/);
|
|
|
|
expect(log.warn.calledOnce).to.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should fail', function *() {
|
|
|
|
sendFnStub.returns(Promise.reject(new Error('boom')));
|
|
|
|
|
|
|
|
try {
|
2016-05-31 16:50:28 +02:00
|
|
|
yield email._sendHelper(mailOptions);
|
2017-08-15 16:03:06 +08:00
|
|
|
} catch (e) {
|
2016-05-30 15:36:32 +02:00
|
|
|
expect(log.error.calledOnce).to.be.true;
|
|
|
|
expect(e.status).to.equal(500);
|
|
|
|
expect(e.message).to.match(/failed/);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2017-08-15 16:03:06 +08:00
|
|
|
});
|