keyserver/test/unit/email-test.js

108 lines
2.5 KiB
JavaScript
Raw Normal View History

'use strict';
const log = require('npmlog');
2016-05-31 16:50:28 +02:00
const Email = require('../../src/email/email');
const nodemailer = require('nodemailer');
2016-05-31 13:52:18 +02:00
describe('Email Unit Tests', () => {
let email, sendFnStub;
2016-05-31 16:50:28 +02:00
let template = {
subject: 'foo',
text: 'bar',
html: '<strong>bar</strong>'
};
let sender = {
name: 'Foo Bar',
email: 'foo@bar.com'
};
let userId1 = {
name: 'name1',
email: 'email1',
nonce: 'qwertzuioasdfghjkqwertzuio'
};
2016-06-09 11:38:00 +02:00
let keyId = '0123456789ABCDF0';
let origin = {
protocol: 'http',
host: 'localhost:8888'
};
let mailOptions = {
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(() => {
sendFnStub = sinon.stub();
sinon.stub(nodemailer, 'createTransport').returns({
2016-05-31 13:52:18 +02:00
templateSender: () => { return sendFnStub; }
});
sinon.stub(log, 'warn');
sinon.stub(log, 'error');
email = new Email(nodemailer);
email.init({
host: 'host',
auth: { user:'user', pass:'pass' },
sender: sender
});
expect(email._sender).to.equal(sender);
});
2016-05-31 13:52:18 +02:00
afterEach(() => {
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(() => {
2016-05-31 16:50:28 +02:00
sinon.stub(email, '_sendHelper').returns(Promise.resolve({ response:'250' }));
});
2016-05-31 13:52:18 +02:00
afterEach(() => {
2016-05-31 16:50:28 +02:00
email._sendHelper.restore();
});
it('should work', function *() {
2016-06-09 11:38:00 +02:00
let info = yield email.send({ template, userId:userId1, keyId, origin});
expect(info.response).to.match(/^250/);
});
});
2016-05-31 16:50:28 +02:00
describe("_sendHelper", () => {
it('should work', function *() {
sendFnStub.returns(Promise.resolve({ response:'250' }));
2016-05-31 16:50:28 +02:00
let info = yield email._sendHelper(mailOptions);
expect(info.response).to.match(/^250/);
});
it('should log warning for reponse error', function *() {
sendFnStub.returns(Promise.resolve({ response:'554' }));
2016-05-31 16:50:28 +02:00
let info = yield email._sendHelper(mailOptions);
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);
} catch(e) {
expect(log.error.calledOnce).to.be.true;
expect(e.status).to.equal(500);
expect(e.message).to.match(/failed/);
}
});
});
});