log4js-node/test/vows/clusteredAppender-test.js
e-cloud 3e4f3a66f3 style: format test code
a error occur in `loggin-test.js` - 'invalid configuration'.

It may reveal some internal defects of this library.

Another problem occurs in `configureNoLevels-test.js`. I mark a
**todo** there.
2016-12-12 22:23:39 +08:00

164 lines
4.8 KiB
JavaScript

'use strict';
const assert = require('assert');
const vows = require('vows');
const sandbox = require('sandboxed-module');
const LoggingEvent = require('../../lib/logger').LoggingEvent;
vows.describe('log4js cluster appender').addBatch({
'when in master mode': {
topic: function () {
const registeredClusterEvents = [];
const loggingEvents = [];
let onChildProcessForked;
let onMasterReceiveChildMessage;
// Fake cluster module, so no real cluster listeners be really added
const fakeCluster = {
on: function (event, callback) {
registeredClusterEvents.push(event);
onChildProcessForked = callback;
},
isMaster: true,
isWorker: false,
};
const fakeWorker = {
on: function (event, callback) {
onMasterReceiveChildMessage = callback;
},
process: {
pid: 123
},
id: 'workerid'
};
const fakeActualAppender = function (loggingEvent) {
loggingEvents.push(loggingEvent);
};
// Load appender and fake modules in it
const appenderModule = sandbox.require('../../lib/appenders/clustered', {
requires: {
cluster: fakeCluster,
}
});
const masterAppender = appenderModule.appender({
actualAppenders: [fakeActualAppender, fakeActualAppender, fakeActualAppender],
appenders: [{}, { category: 'test' }, { category: 'wovs' }]
});
// Actual test - log message using masterAppender
masterAppender(new LoggingEvent('wovs', 'Info', ['masterAppender test']));
// Simulate a 'fork' event to register the master's message handler on our fake worker.
onChildProcessForked(fakeWorker);
// Simulate a cluster message received by the masterAppender.
const simulatedLoggingEvent = new LoggingEvent(
'wovs',
'Error',
[
'message deserialization test',
{ stack: 'my wrapped stack' }
]
);
onMasterReceiveChildMessage({
type: '::log-message',
event: JSON.stringify(simulatedLoggingEvent)
});
const returnValue = {
registeredClusterEvents: registeredClusterEvents,
loggingEvents: loggingEvents,
};
return returnValue;
},
"should register 'fork' event listener on 'cluster'": function (topic) {
assert.equal(topic.registeredClusterEvents[0], 'fork');
},
'should log using actual appender': function (topic) {
assert.equal(topic.loggingEvents.length, 4);
assert.equal(topic.loggingEvents[0].data[0], 'masterAppender test');
assert.equal(topic.loggingEvents[1].data[0], 'masterAppender test');
assert.equal(topic.loggingEvents[2].data[0], 'message deserialization test');
assert.equal(topic.loggingEvents[2].data[1], 'my wrapped stack');
assert.equal(topic.loggingEvents[3].data[0], 'message deserialization test');
assert.equal(topic.loggingEvents[3].data[1], 'my wrapped stack');
},
},
'when in worker mode': {
topic: function () {
const registeredProcessEvents = [];
// Fake cluster module, to fake we're inside a worker process
const fakeCluster = {
isMaster: false,
isWorker: true,
};
const fakeProcess = {
send: function (data) {
registeredProcessEvents.push(data);
},
env: process.env
};
// Load appender and fake modules in it
const appenderModule = sandbox.require('../../lib/appenders/clustered', {
requires: {
cluster: fakeCluster,
},
globals: {
process: fakeProcess,
}
});
const workerAppender = appenderModule.appender();
// Actual test - log message using masterAppender
workerAppender(new LoggingEvent('wovs', 'Info', ['workerAppender test']));
workerAppender(new LoggingEvent('wovs', 'Info', [new Error('Error test')]));
const returnValue = {
registeredProcessEvents: registeredProcessEvents,
};
return returnValue;
},
'worker appender should call process.send': function (topic) {
assert.equal(topic.registeredProcessEvents[0].type, '::log-message');
assert.equal(
JSON.parse(topic.registeredProcessEvents[0].event).data[0],
'workerAppender test'
);
},
'worker should serialize an Error correctly': function (topic) {
assert.equal(topic.registeredProcessEvents[1].type, '::log-message');
assert(JSON.parse(topic.registeredProcessEvents[1].event).data[0].stack);
const actual = JSON.parse(topic.registeredProcessEvents[1].event).data[0].stack;
const expectedRegex = /^Error: Error test/;
assert(
actual.match(expectedRegex),
`Expected: \n\n ${actual}\n\n to match ${expectedRegex}`
);
}
}
}).exportTo(module);