blob: 2564f7970631114ac8eb0026cf325ce6b11694bc [file] [log] [blame]
/*
* helpers.js: Test helpers for winston
*
* (C) 2010 Charlie Robbins
* MIT LICENSE
*
*/
var assert = require('assert'),
fs = require('fs'),
path = require('path'),
spawn = require('child_process').spawn,
util = require('util'),
vows = require('vows'),
winston = require('../lib/winston');
var helpers = exports;
helpers.size = function (obj) {
var size = 0, key;
for (key in obj) {
if (obj.hasOwnProperty(key)) {
size++;
}
}
return size;
};
helpers.tryUnlink = function (file) {
try { fs.unlinkSync(file) }
catch (ex) { }
};
helpers.assertDateInfo = function (info) {
assert.isNumber(Date.parse(info));
};
helpers.assertProcessInfo = function (info) {
assert.isNumber(info.pid);
assert.isNumber(info.uid);
assert.isNumber(info.gid);
assert.isString(info.cwd);
assert.isString(info.execPath);
assert.isString(info.version);
assert.isArray(info.argv);
assert.isObject(info.memoryUsage);
};
helpers.assertOsInfo = function (info) {
assert.isArray(info.loadavg);
assert.isNumber(info.uptime);
};
helpers.assertTrace = function (trace) {
trace.forEach(function (site) {
assert.isTrue(!site.column || typeof site.column === 'number');
assert.isTrue(!site.line || typeof site.line === 'number');
assert.isTrue(!site.file || typeof site.file === 'string');
assert.isTrue(!site.method || typeof site.method === 'string');
assert.isTrue(!site.function || typeof site.function === 'string');
assert.isTrue(typeof site.native === 'boolean');
});
};
helpers.assertLogger = function (logger, level) {
assert.instanceOf(logger, winston.Logger);
assert.isFunction(logger.log);
assert.isFunction(logger.add);
assert.isFunction(logger.remove);
assert.equal(logger.level, level || "info");
Object.keys(logger.levels).forEach(function (method) {
assert.isFunction(logger[method]);
});
};
helpers.assertConsole = function (transport) {
assert.instanceOf(transport, winston.transports.Console);
assert.isFunction(transport.log);
};
helpers.assertFile = function (transport) {
assert.instanceOf(transport, winston.transports.File);
assert.isFunction(transport.log);
}
helpers.assertWebhook = function (transport) {
assert.instanceOf(transport, winston.transports.Webhook);
assert.isFunction(transport.log);
};
helpers.assertCouchdb = function (transport) {
assert.instanceOf(transport, winston.transports.Couchdb);
assert.isFunction(transport.log);
};
helpers.assertHandleExceptions = function (options) {
return {
topic: function () {
var that = this,
child = spawn('node', [options.script]);
helpers.tryUnlink(options.logfile);
child.on('exit', function () {
fs.readFile(options.logfile, that.callback);
});
},
"should save the error information to the specified file": function (err, data) {
assert.isTrue(!err);
data = JSON.parse(data);
assert.isObject(data);
helpers.assertProcessInfo(data.process);
helpers.assertOsInfo(data.os);
helpers.assertTrace(data.trace);
}
}
}
helpers.testNpmLevels = function (transport, assertMsg, assertFn) {
return helpers.testLevels(winston.config.npm.levels, transport, assertMsg, assertFn);
};
helpers.testSyslogLevels = function (transport, assertMsg, assertFn) {
return helpers.testLevels(winston.config.syslog.levels, transport, assertMsg, assertFn);
};
helpers.testLevels = function (levels, transport, assertMsg, assertFn) {
var tests = {};
Object.keys(levels).forEach(function (level) {
var test = {
topic: function () {
transport.log(level, 'test message', {}, this.callback.bind(this, null));
}
};
test[assertMsg] = assertFn;
tests['with the ' + level + ' level'] = test;
});
var metadatatest = {
topic: function () {
transport.log('info', 'test message', { metadata: true }, this.callback.bind(this, null));
}
};
metadatatest[assertMsg] = assertFn;
tests['when passed metadata'] = metadatatest;
var primmetadatatest = {
topic: function () {
transport.log('info', 'test message', 'metadata', this.callback.bind(this, null));
}
};
primmetadatatest[assertMsg] = assertFn;
tests['when passed primitive metadata'] = primmetadatatest;
var circmetadata = { };
circmetadata['metadata'] = circmetadata;
var circmetadatatest = {
topic: function () {
transport.log('info', 'test message', circmetadata, this.callback.bind(this, null));
}
};
circmetadatatest[assertMsg] = assertFn;
tests['when passed circular metadata'] = circmetadatatest;
return tests;
};