keyserver/test/unit/email-test.js

103 lines
2.4 KiB
JavaScript

'use strict';
const log = require('winston');
const Email = require('../../src/email/email');
const nodemailer = require('nodemailer');
describe('Email Unit Tests', () => {
const sandbox = sinon.createSandbox();
let email;
let sendFnStub;
const template = () => ({
subject: 'foo',
text: 'bar',
html: '<strong>bar</strong>'
});
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: '<b>Hello world 🐴</b>' // html body
};
beforeEach(() => {
sendFnStub = sandbox.stub();
sandbox.stub(nodemailer, 'createTransport').returns({
sendMail: 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').returns(Promise.resolve({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.returns(Promise.resolve({response: '250'}));
const info = await email._sendHelper(mailOptions);
expect(info.response).to.match(/^250/);
});
it('should log warning for reponse error', async () => {
sendFnStub.returns(Promise.resolve({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.returns(Promise.reject(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/);
}
});
});
});