123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- "use strict";
- var vows = require('vows')
- , assert = require('assert')
- , log4js = require('../lib/log4js')
- , sandbox = require('sandboxed-module')
- ;
- function setupLogging(category, options) {
- var msgs = [];
-
- var fakeMailer = {
- createTransport: function (name, options) {
- return {
- config: options,
- sendMail: function (msg, callback) {
- msgs.push(msg);
- callback(null, true);
- },
- close: function() {}
- };
- }
- };
- var fakeLayouts = {
- layout: function(type, config) {
- this.type = type;
- this.config = config;
- return log4js.layouts.messagePassThroughLayout;
- },
- basicLayout: log4js.layouts.basicLayout,
- messagePassThroughLayout: log4js.layouts.messagePassThroughLayout
- };
- var fakeConsole = {
- errors: [],
- error: function(msg, value) {
- this.errors.push({ msg: msg, value: value });
- }
- };
- var smtpModule = sandbox.require('../lib/appenders/smtp', {
- requires: {
- 'nodemailer': fakeMailer,
- '../layouts': fakeLayouts
- },
- globals: {
- console: fakeConsole
- }
- });
- log4js.addAppender(smtpModule.configure(options), category);
-
- return {
- logger: log4js.getLogger(category),
- mailer: fakeMailer,
- layouts: fakeLayouts,
- console: fakeConsole,
- results: msgs
- };
- }
- function checkMessages (result, sender, subject) {
- for (var i = 0; i < result.results.length; ++i) {
- assert.equal(result.results[i].from, sender);
- assert.equal(result.results[i].to, 'recipient@domain.com');
- assert.equal(result.results[i].subject, subject ? subject : 'Log event #' + (i+1));
- assert.ok(new RegExp('.+Log event #' + (i+1) + '\n$').test(result.results[i].text));
- }
- }
- log4js.clearAppenders();
- vows.describe('log4js smtpAppender').addBatch({
- 'minimal config': {
- topic: function() {
- var setup = setupLogging('minimal config', {
- recipients: 'recipient@domain.com',
- transport: "SMTP",
- SMTP: {
- port: 25,
- auth: {
- user: 'user@domain.com'
- }
- }
- });
- setup.logger.info('Log event #1');
- return setup;
- },
- 'there should be one message only': function (result) {
- assert.equal(result.results.length, 1);
- },
- 'message should contain proper data': function (result) {
- checkMessages(result);
- }
- },
- 'fancy config': {
- topic: function() {
- var setup = setupLogging('fancy config', {
- recipients: 'recipient@domain.com',
- sender: 'sender@domain.com',
- subject: 'This is subject',
- transport: "SMTP",
- SMTP: {
- port: 25,
- auth: {
- user: 'user@domain.com'
- }
- }
- });
- setup.logger.info('Log event #1');
- return setup;
- },
- 'there should be one message only': function (result) {
- assert.equal(result.results.length, 1);
- },
- 'message should contain proper data': function (result) {
- checkMessages(result, 'sender@domain.com', 'This is subject');
- }
- },
- 'config with layout': {
- topic: function() {
- var setup = setupLogging('config with layout', {
- layout: {
- type: "tester"
- }
- });
- return setup;
- },
- 'should configure layout': function(result) {
- assert.equal(result.layouts.type, 'tester');
- }
- },
- 'separate email for each event': {
- topic: function() {
- var self = this;
- var setup = setupLogging('separate email for each event', {
- recipients: 'recipient@domain.com',
- transport: "SMTP",
- SMTP: {
- port: 25,
- auth: {
- user: 'user@domain.com'
- }
- }
- });
- setTimeout(function () {
- setup.logger.info('Log event #1');
- }, 0);
- setTimeout(function () {
- setup.logger.info('Log event #2');
- }, 500);
- setTimeout(function () {
- setup.logger.info('Log event #3');
- }, 1050);
- setTimeout(function () {
- self.callback(null, setup);
- }, 2100);
- },
- 'there should be three messages': function (result) {
- assert.equal(result.results.length, 3);
- },
- 'messages should contain proper data': function (result) {
- checkMessages(result);
- }
- },
- 'multiple events in one email': {
- topic: function() {
- var self = this;
- var setup = setupLogging('multiple events in one email', {
- recipients: 'recipient@domain.com',
- sendInterval: 1,
- transport: "SMTP",
- SMTP: {
- port: 25,
- auth: {
- user: 'user@domain.com'
- }
- }
- });
- setTimeout(function () {
- setup.logger.info('Log event #1');
- }, 0);
- setTimeout(function () {
- setup.logger.info('Log event #2');
- }, 500);
- setTimeout(function () {
- setup.logger.info('Log event #3');
- }, 1050);
- setTimeout(function () {
- self.callback(null, setup);
- }, 2100);
- },
- 'there should be two messages': function (result) {
- assert.equal(result.results.length, 2);
- },
- 'messages should contain proper data': function (result) {
- assert.equal(result.results[0].to, 'recipient@domain.com');
- assert.equal(result.results[0].subject, 'Log event #1');
- assert.equal(result.results[0].text.match(new RegExp('.+Log event #[1-2]$', 'gm')).length, 2);
- assert.equal(result.results[1].to, 'recipient@domain.com');
- assert.equal(result.results[1].subject, 'Log event #3');
- assert.ok(new RegExp('.+Log event #3\n$').test(result.results[1].text));
- }
- },
- 'error when sending email': {
- topic: function() {
- var setup = setupLogging('error when sending email', {
- recipients: 'recipient@domain.com',
- sendInterval: 0,
- transport: 'SMTP',
- SMTP: { port: 25, auth: { user: 'user@domain.com' } }
- });
- setup.mailer.createTransport = function() {
- return {
- sendMail: function(msg, cb) {
- cb({ message: "oh noes" });
- },
- close: function() { }
- };
- };
-
- setup.logger.info("This will break");
- return setup.console;
- },
- 'should be logged to console': function(cons) {
- assert.equal(cons.errors.length, 1);
- assert.equal(cons.errors[0].msg, "log4js.smtpAppender - Error happened");
- assert.equal(cons.errors[0].value.message, 'oh noes');
- }
- }
- }).export(module);
|