style: 4-space indents

This commit is contained in:
Trent Mick 2013-03-28 17:42:32 -07:00
parent 7a6c3f5ce6
commit f616276dc6
31 changed files with 2988 additions and 2988 deletions

View file

@ -108,7 +108,7 @@ test06:
.PHONY: check-jsstyle .PHONY: check-jsstyle
check-jsstyle: $(JSSTYLE_FILES) check-jsstyle: $(JSSTYLE_FILES)
./tools/jsstyle -o indent=2,doxygen,unparenthesized-return=0,blank-after-start-comment=0,leading-right-paren-ok $(JSSTYLE_FILES) ./tools/jsstyle -o indent=4,doxygen,unparenthesized-return=0,blank-after-start-comment=0,leading-right-paren-ok $(JSSTYLE_FILES)
.PHONY: check .PHONY: check
check: check-jsstyle check: check-jsstyle

2202
bin/bunyan

File diff suppressed because it is too large Load diff

View file

@ -5,25 +5,25 @@ var Logger = require('../lib/bunyan');
var util = require('util'); var util = require('util');
var log = new Logger({ var log = new Logger({
name: 'myserver', name: 'myserver',
serializers: { serializers: {
err: Logger.stdSerializers.err, // <--- use this err: Logger.stdSerializers.err, // <--- use this
} }
}); });
try { try {
throw new TypeError('boom'); throw new TypeError('boom');
} catch (err) { } catch (err) {
log.warn({err: err}, 'operation went boom: %s', err) // <--- here log.warn({err: err}, 'operation went boom: %s', err) // <--- here
} }
log.info(new TypeError('how about this?')) // <--- alternatively this log.info(new TypeError('how about this?')) // <--- alternatively this
try { try {
throw 'boom string'; throw 'boom string';
} catch (err) { } catch (err) {
log.error(err) log.error(err)
} }
/* BEGIN JSSTYLED */ /* BEGIN JSSTYLED */

View file

@ -10,19 +10,19 @@ var S_IWUSR = 00200; // mask for owner write permission in stat mode
console.warn('- Log file is "%s".', FILENAME); console.warn('- Log file is "%s".', FILENAME);
if (!path.existsSync(FILENAME)) { if (!path.existsSync(FILENAME)) {
console.warn('- Touch log file.'); console.warn('- Touch log file.');
fs.writeFileSync(FILENAME, 'touch\n'); fs.writeFileSync(FILENAME, 'touch\n');
} }
if (fs.statSync(FILENAME).mode & S_IWUSR) { if (fs.statSync(FILENAME).mode & S_IWUSR) {
console.warn('- Make log file read-only.'); console.warn('- Make log file read-only.');
fs.chmodSync(FILENAME, 0444); fs.chmodSync(FILENAME, 0444);
} }
console.warn('- Create logger.') console.warn('- Create logger.')
var log = new Logger({name: 'handle-fs-error', streams: [{path: FILENAME}]}); var log = new Logger({name: 'handle-fs-error', streams: [{path: FILENAME}]});
log.on('error', function (err) { log.on('error', function (err) {
console.warn('- The logger emitted an error:', err); console.warn('- The logger emitted an error:', err);
}); });
console.warn('- Call log.info(...).') console.warn('- Call log.info(...).')
@ -30,7 +30,7 @@ log.info('info log message');
console.warn('- Called log.info(...).') console.warn('- Called log.info(...).')
setTimeout(function () { setTimeout(function () {
console.warn('- Call log.warn(...).') console.warn('- Call log.warn(...).')
log.warn('warn log message'); log.warn('warn log message');
console.warn('- Called log.warn(...).') console.warn('- Called log.warn(...).')
}, 1000); }, 1000);

View file

@ -19,12 +19,12 @@ log.info({foo:'bar', multiline:'one\ntwo\nthree'}, 'hi %d', 1, 'two', 3);
console.log('\n') console.log('\n')
function Wuzzle(options) { function Wuzzle(options) {
this.log = options.log; this.log = options.log;
this.log.info('creating a wuzzle') this.log.info('creating a wuzzle')
} }
Wuzzle.prototype.woos = function () { Wuzzle.prototype.woos = function () {
this.log.warn('This wuzzle is woosey.') this.log.warn('This wuzzle is woosey.')
} }
var wuzzle = new Wuzzle({log: log.child({component: 'wuzzle'})}); var wuzzle = new Wuzzle({log: log.child({component: 'wuzzle'})});

View file

@ -3,25 +3,25 @@
// TODO: put this in a damn test suite // TODO: put this in a damn test suite
var Logger = require('../lib/bunyan'), var Logger = require('../lib/bunyan'),
DEBUG = Logger.DEBUG, DEBUG = Logger.DEBUG,
INFO = Logger.INFO, INFO = Logger.INFO,
WARN = Logger.WARN; WARN = Logger.WARN;
var assert = require('assert'); var assert = require('assert');
// Basic usage. // Basic usage.
var log = new Logger({ var log = new Logger({
name: 'example-level', name: 'example-level',
streams: [ streams: [
{ {
name: 'stdout', name: 'stdout',
stream: process.stdout, stream: process.stdout,
level: 'debug' level: 'debug'
}, },
{ {
name: 'stderr', name: 'stderr',
stream: process.stderr stream: process.stderr
} }
] ]
}); });
assert.equal(log.level(), DEBUG); assert.equal(log.level(), DEBUG);
@ -32,9 +32,9 @@ assert.equal(log.levels(1), INFO);
assert.equal(log.levels('stdout'), DEBUG) assert.equal(log.levels('stdout'), DEBUG)
try { try {
log.levels('foo') log.levels('foo')
} catch (e) { } catch (e) {
assert.ok(e.message.indexOf('name') !== -1) assert.ok(e.message.indexOf('name') !== -1)
} }
log.trace('no one should see this') log.trace('no one should see this')

View file

@ -21,11 +21,11 @@ var bunyan = require('../lib/bunyan');
function randint(n) { function randint(n) {
return Math.floor(Math.random() * n); return Math.floor(Math.random() * n);
} }
function randchoice(array) { function randchoice(array) {
return array[randint(array.length)]; return array[randint(array.length)];
} }
@ -40,18 +40,18 @@ var log = bunyan.createLogger({name: 'lr', level: 'debug'});
// We're logging to stdout. Let's exit gracefully on EPIPE. E.g. if piped // We're logging to stdout. Let's exit gracefully on EPIPE. E.g. if piped
// to `head` which will close after N lines. // to `head` which will close after N lines.
process.stdout.on('error', function (err) { process.stdout.on('error', function (err) {
if (err.code === 'EPIPE') { if (err.code === 'EPIPE') {
process.exit(0); process.exit(0);
} }
}) })
function logOne() { function logOne() {
var level = randchoice(levels); var level = randchoice(levels);
var msg = [randchoice(words), randchoice(words)].join(' '); var msg = [randchoice(words), randchoice(words)].join(' ');
var delay = randint(300); var delay = randint(300);
//console.warn('long-running about to log.%s(..., "%s")', level, msg) //console.warn('long-running about to log.%s(..., "%s")', level, msg)
log[level]({'word': randchoice(words), 'delay': delay}, msg); log[level]({'word': randchoice(words), 'delay': delay}, msg);
timeout = setTimeout(logOne, delay); timeout = setTimeout(logOne, delay);
} }
log.info('hi, this is the start'); log.info('hi, this is the start');

View file

@ -1,16 +1,16 @@
var Logger = require('../lib/bunyan'); var Logger = require('../lib/bunyan');
log = new Logger({ log = new Logger({
name: 'amon', name: 'amon',
streams: [ streams: [
{ {
level: 'info', level: 'info',
stream: process.stdout, stream: process.stdout,
}, },
{ {
level: 'error', level: 'error',
path: 'multi.log' path: 'multi.log'
} }
] ]
}); });

View file

@ -11,25 +11,25 @@ var Logger = require('../lib/bunyan');
*/ */
function MyRawStream() {} function MyRawStream() {}
MyRawStream.prototype.write = function (rec) { MyRawStream.prototype.write = function (rec) {
if (typeof (rec) !== 'object') { if (typeof (rec) !== 'object') {
console.error('error: raw stream got a non-object record: %j', rec) console.error('error: raw stream got a non-object record: %j', rec)
} else { } else {
rec.yo = 'yo'; rec.yo = 'yo';
process.stdout.write(JSON.stringify(rec) + '\n'); process.stdout.write(JSON.stringify(rec) + '\n');
} }
} }
// A Logger using the raw stream. // A Logger using the raw stream.
var log = new Logger({ var log = new Logger({
name: 'raw-example', name: 'raw-example',
streams: [ streams: [
{ {
level: 'info', level: 'info',
stream: new MyRawStream(), stream: new MyRawStream(),
type: 'raw' type: 'raw'
}, },
] ]
}); });

View file

@ -2,12 +2,12 @@
var bunyan = require('..'); var bunyan = require('..');
var ringbuffer = new bunyan.RingBuffer({ limit: 100 }); var ringbuffer = new bunyan.RingBuffer({ limit: 100 });
var log = new bunyan({ var log = new bunyan({
name: 'foo', name: 'foo',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: ringbuffer, stream: ringbuffer,
level: 'debug' level: 'debug'
} ] } ]
}); });
log.info('hello world'); log.info('hello world');

View file

@ -4,37 +4,37 @@ var http = require('http');
var Logger = require('../lib/bunyan'); var Logger = require('../lib/bunyan');
var log = new Logger({ var log = new Logger({
name: 'myserver', name: 'myserver',
serializers: { serializers: {
req: Logger.stdSerializers.req, req: Logger.stdSerializers.req,
res: Logger.stdSerializers.res res: Logger.stdSerializers.res
} }
}); });
var server = http.createServer(function (req, res) { var server = http.createServer(function (req, res) {
log.info({req: req}, 'start request'); // <-- this is the guy we're testing log.info({req: req}, 'start request'); // <-- this is the guy we're testing
res.writeHead(200, {'Content-Type': 'text/plain'}); res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World\n'); res.end('Hello World\n');
log.info({res: res}, 'done response'); // <-- this is the guy we're testing log.info({res: res}, 'done response'); // <-- this is the guy we're testing
}); });
server.listen(1337, '127.0.0.1', function () { server.listen(1337, '127.0.0.1', function () {
log.info('server listening'); log.info('server listening');
var options = { var options = {
port: 1337, port: 1337,
hostname: '127.0.0.1', hostname: '127.0.0.1',
path: '/path?q=1#anchor', path: '/path?q=1#anchor',
headers: { headers: {
'X-Hi': 'Mom' 'X-Hi': 'Mom'
} }
}; };
var req = http.request(options); var req = http.request(options);
req.on('response', function (res) { req.on('response', function (res) {
res.on('end', function () { res.on('end', function () {
process.exit(); process.exit();
}) })
}); });
req.write('hi from the client'); req.write('hi from the client');
req.end(); req.end();
}); });

View file

@ -8,16 +8,16 @@ var log = new Logger({name: 'src-example', src: true});
log.info('one'); log.info('one');
log.info('two'); log.info('two');
function doSomeFoo() { function doSomeFoo() {
log.info({foo:'bar'}, 'three'); log.info({foo:'bar'}, 'three');
} }
doSomeFoo(); doSomeFoo();
function Wuzzle(options) { function Wuzzle(options) {
this.log = options.log; this.log = options.log;
this.log.info('creating a wuzzle') this.log.info('creating a wuzzle')
} }
Wuzzle.prototype.woos = function () { Wuzzle.prototype.woos = function () {
this.log.warn('This wuzzle is woosey.') this.log.warn('This wuzzle is woosey.')
} }
var wuzzle = new Wuzzle({log: log.child({component: 'wuzzle'})}); var wuzzle = new Wuzzle({log: log.child({component: 'wuzzle'})});

View file

@ -5,7 +5,7 @@ var log = new Logger({src: true, name: 'foo'});
// Make a circular object (cannot be JSON-ified). // Make a circular object (cannot be JSON-ified).
var myobj = { var myobj = {
foo: 'bar' foo: 'bar'
}; };
myobj.myobj = myobj; myobj.myobj = myobj;

File diff suppressed because it is too large Load diff

View file

@ -6,13 +6,13 @@
*/ */
var util = require('util'), var util = require('util'),
inspect = util.inspect, inspect = util.inspect,
format = util.format; format = util.format;
var bunyan = require('../lib/bunyan'); var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -21,45 +21,45 @@ var test = tap4nodeunit.test;
function Catcher() { function Catcher() {
this.records = []; this.records = [];
} }
Catcher.prototype.write = function (record) { Catcher.prototype.write = function (record) {
this.records.push(record); this.records.push(record);
} }
var catcher = new Catcher(); var catcher = new Catcher();
var log = new bunyan.createLogger({ var log = new bunyan.createLogger({
name: 'buffer.test', name: 'buffer.test',
streams: [ streams: [
{ {
type: 'raw', type: 'raw',
stream: catcher, stream: catcher,
level: 'trace' level: 'trace'
} }
] ]
}); });
test('log.info(BUFFER)', function (t) { test('log.info(BUFFER)', function (t) {
var b = new Buffer('foo'); var b = new Buffer('foo');
['trace', 'debug', 'info', 'warn', 'error', 'fatal'].forEach(function (lvl) { ['trace', 'debug', 'info', 'warn', 'error', 'fatal'].forEach(function (lvl) {
log[lvl].call(log, b); log[lvl].call(log, b);
var rec = catcher.records[catcher.records.length - 1]; var rec = catcher.records[catcher.records.length - 1];
t.equal(rec.msg, inspect(b), t.equal(rec.msg, inspect(b),
format('log.%s msg is inspect(BUFFER)', lvl)); format('log.%s msg is inspect(BUFFER)', lvl));
t.ok(rec['0'] === undefined, t.ok(rec['0'] === undefined,
'no "0" array index key in record: ' + inspect(rec['0'])); 'no "0" array index key in record: ' + inspect(rec['0']));
t.ok(rec['parent'] === undefined, t.ok(rec['parent'] === undefined,
'no "parent" array index key in record: ' + inspect(rec['parent'])); 'no "parent" array index key in record: ' + inspect(rec['parent']));
log[lvl].call(log, b, 'bar'); log[lvl].call(log, b, 'bar');
var rec = catcher.records[catcher.records.length - 1]; var rec = catcher.records[catcher.records.length - 1];
t.equal(rec.msg, inspect(b) + ' bar', t.equal(rec.msg, inspect(b) + ' bar',
format('log.%s(BUFFER, "bar") msg is inspect(BUFFER) + " bar"', lvl)); format('log.%s(BUFFER, "bar") msg is inspect(BUFFER) + " bar"', lvl));
}); });
t.end(); t.end();
}); });

View file

@ -8,7 +8,7 @@ var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -17,120 +17,120 @@ var test = tap4nodeunit.test;
function CapturingStream(recs) { function CapturingStream(recs) {
this.recs = recs || []; this.recs = recs || [];
} }
CapturingStream.prototype.write = function (rec) { CapturingStream.prototype.write = function (rec) {
this.recs.push(rec); this.recs.push(rec);
} }
test('child can add stream', function (t) { test('child can add stream', function (t) {
var dadStream = new CapturingStream(); var dadStream = new CapturingStream();
var dad = bunyan.createLogger({ var dad = bunyan.createLogger({
name: 'surname', name: 'surname',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: dadStream, stream: dadStream,
level: 'info' level: 'info'
} ] } ]
}); });
var sonStream = new CapturingStream(); var sonStream = new CapturingStream();
var son = dad.child({ var son = dad.child({
component: 'son', component: 'son',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: sonStream, stream: sonStream,
level: 'debug' level: 'debug'
} ] } ]
}); });
dad.info('info from dad'); dad.info('info from dad');
dad.debug('debug from dad'); dad.debug('debug from dad');
son.debug('debug from son'); son.debug('debug from son');
var rec; var rec;
t.equal(dadStream.recs.length, 1); t.equal(dadStream.recs.length, 1);
rec = dadStream.recs[0]; rec = dadStream.recs[0];
t.equal(rec.msg, 'info from dad'); t.equal(rec.msg, 'info from dad');
t.equal(sonStream.recs.length, 1); t.equal(sonStream.recs.length, 1);
rec = sonStream.recs[0]; rec = sonStream.recs[0];
t.equal(rec.msg, 'debug from son'); t.equal(rec.msg, 'debug from son');
t.end(); t.end();
}); });
test('child can set level of inherited streams', function (t) { test('child can set level of inherited streams', function (t) {
var dadStream = new CapturingStream(); var dadStream = new CapturingStream();
var dad = bunyan.createLogger({ var dad = bunyan.createLogger({
name: 'surname', name: 'surname',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: dadStream, stream: dadStream,
level: 'info' level: 'info'
} ] } ]
}); });
// Intention here is that the inherited `dadStream` logs at 'debug' level // Intention here is that the inherited `dadStream` logs at 'debug' level
// for the son. // for the son.
var son = dad.child({ var son = dad.child({
component: 'son', component: 'son',
level: 'debug' level: 'debug'
}); });
dad.info('info from dad'); dad.info('info from dad');
dad.debug('debug from dad'); dad.debug('debug from dad');
son.debug('debug from son'); son.debug('debug from son');
var rec; var rec;
t.equal(dadStream.recs.length, 2); t.equal(dadStream.recs.length, 2);
rec = dadStream.recs[0]; rec = dadStream.recs[0];
t.equal(rec.msg, 'info from dad'); t.equal(rec.msg, 'info from dad');
rec = dadStream.recs[1]; rec = dadStream.recs[1];
t.equal(rec.msg, 'debug from son'); t.equal(rec.msg, 'debug from son');
t.end(); t.end();
}); });
test('child can set level of inherited streams and add streams', function (t) { test('child can set level of inherited streams and add streams', function (t) {
var dadStream = new CapturingStream(); var dadStream = new CapturingStream();
var dad = bunyan.createLogger({ var dad = bunyan.createLogger({
name: 'surname', name: 'surname',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: dadStream, stream: dadStream,
level: 'info' level: 'info'
} ] } ]
}); });
// Intention here is that the inherited `dadStream` logs at 'debug' level // Intention here is that the inherited `dadStream` logs at 'debug' level
// for the son. // for the son.
var sonStream = new CapturingStream(); var sonStream = new CapturingStream();
var son = dad.child({ var son = dad.child({
component: 'son', component: 'son',
level: 'trace', level: 'trace',
streams: [ { streams: [ {
type: 'raw', type: 'raw',
stream: sonStream, stream: sonStream,
level: 'debug' level: 'debug'
} ] } ]
}); });
dad.info('info from dad'); dad.info('info from dad');
dad.trace('trace from dad'); dad.trace('trace from dad');
son.trace('trace from son'); son.trace('trace from son');
son.debug('debug from son'); son.debug('debug from son');
t.equal(dadStream.recs.length, 3); t.equal(dadStream.recs.length, 3);
t.equal(dadStream.recs[0].msg, 'info from dad'); t.equal(dadStream.recs[0].msg, 'info from dad');
t.equal(dadStream.recs[1].msg, 'trace from son'); t.equal(dadStream.recs[1].msg, 'trace from son');
t.equal(dadStream.recs[2].msg, 'debug from son'); t.equal(dadStream.recs[2].msg, 'debug from son');
t.equal(sonStream.recs.length, 1); t.equal(sonStream.recs.length, 1);
t.equal(sonStream.recs[0].msg, 'debug from son'); t.equal(sonStream.recs[0].msg, 'debug from son');
t.end(); t.end();
}); });

View file

@ -11,7 +11,7 @@ var debug = console.warn;
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -31,285 +31,285 @@ var BUNYAN = path.resolve(__dirname, '../bin/bunyan');
//}); //});
test('--version', function (t) { test('--version', function (t) {
var version = require('../package.json').version; var version = require('../package.json').version;
exec(BUNYAN + ' --version', function (err, stdout, stderr) { exec(BUNYAN + ' --version', function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, 'bunyan ' + version + '\n'); t.equal(stdout, 'bunyan ' + version + '\n');
t.end(); t.end();
}); });
}); });
test('--help', function (t) { test('--help', function (t) {
exec(BUNYAN + ' --help', function (err, stdout, stderr) { exec(BUNYAN + ' --help', function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.ok(stdout.indexOf('General options:') !== -1); t.ok(stdout.indexOf('General options:') !== -1);
t.end(); t.end();
}); });
}); });
test('-h', function (t) { test('-h', function (t) {
exec(BUNYAN + ' -h', function (err, stdout, stderr) { exec(BUNYAN + ' -h', function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.ok(stdout.indexOf('General options:') !== -1); t.ok(stdout.indexOf('General options:') !== -1);
t.end(); t.end();
}); });
}); });
test('--bogus', function (t) { test('--bogus', function (t) {
exec(BUNYAN + ' --bogus', function (err, stdout, stderr) { exec(BUNYAN + ' --bogus', function (err, stdout, stderr) {
t.ok(err, 'should error out') t.ok(err, 'should error out')
t.equal(err.code, 1, '... with exit code 1') t.equal(err.code, 1, '... with exit code 1')
t.end(); t.end();
}); });
}); });
test('simple.log', function (t) { test('simple.log', function (t) {
exec(_('%s %s/corpus/simple.log', BUNYAN, __dirname), exec(_('%s %s/corpus/simple.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: ' '[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: '
+ 'My message\n'); + 'My message\n');
t.end(); t.end();
}); });
}); });
test('cat simple.log', function (t) { test('cat simple.log', function (t) {
exec(_('cat %s/corpus/simple.log | %s', __dirname, BUNYAN), exec(_('cat %s/corpus/simple.log | %s', __dirname, BUNYAN),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: ' '[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: '
+ 'My message\n'); + 'My message\n');
t.end(); t.end();
} }
); );
}); });
test('simple.log with color', function (t) { test('simple.log with color', function (t) {
exec(_('%s --color %s/corpus/simple.log', BUNYAN, __dirname), exec(_('%s --color %s/corpus/simple.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] \u001b[36m INFO\u001b[39m: myservice/123 ' '[2012-02-08T22:56:52.856Z] \u001b[36m INFO\u001b[39m: myservice/123 '
+ 'on example.com: \u001b[36mMy message\u001b[39m\n\u001b[0m'); + 'on example.com: \u001b[36mMy message\u001b[39m\n\u001b[0m');
t.end(); t.end();
}); });
}); });
test('extrafield.log', function (t) { test('extrafield.log', function (t) {
exec(_('%s %s/corpus/extrafield.log', BUNYAN, __dirname), exec(_('%s %s/corpus/extrafield.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: ' '[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: '
+ 'My message (extra=field)\n'); + 'My message (extra=field)\n');
t.end(); t.end();
}); });
}); });
test('extrafield.log with color', function (t) { test('extrafield.log with color', function (t) {
exec(_('%s --color %s/corpus/extrafield.log', BUNYAN, __dirname), exec(_('%s --color %s/corpus/extrafield.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] \u001b[36m INFO\u001b[39m: myservice/123 ' '[2012-02-08T22:56:52.856Z] \u001b[36m INFO\u001b[39m: myservice/123 '
+ 'on example.com: \u001b[36mMy message\u001b[39m' + 'on example.com: \u001b[36mMy message\u001b[39m'
+ '\u001b[90m (extra=field)\u001b[39m\n\u001b[0m'); + '\u001b[90m (extra=field)\u001b[39m\n\u001b[0m');
t.end(); t.end();
}); });
}); });
test('bogus.log', function (t) { test('bogus.log', function (t) {
exec(_('%s %s/corpus/bogus.log', BUNYAN, __dirname), exec(_('%s %s/corpus/bogus.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, 'not a JSON line\n{"hi": "there"}\n'); t.equal(stdout, 'not a JSON line\n{"hi": "there"}\n');
t.end(); t.end();
}); });
}); });
test('bogus.log -j', function (t) { test('bogus.log -j', function (t) {
exec(_('%s -j %s/corpus/bogus.log', BUNYAN, __dirname), exec(_('%s -j %s/corpus/bogus.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err) t.ifError(err)
t.equal(stdout, 'not a JSON line\n{"hi": "there"}\n'); t.equal(stdout, 'not a JSON line\n{"hi": "there"}\n');
t.end(); t.end();
}); });
}); });
test('all.log', function (t) { test('all.log', function (t) {
exec(_('%s %s/corpus/all.log', BUNYAN, __dirname), exec(_('%s %s/corpus/all.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
// Just make sure don't blow up on this. // Just make sure don't blow up on this.
t.ifError(err) t.ifError(err)
t.end(); t.end();
}); });
}); });
test('simple.log doesnotexist1.log doesnotexist2.log', function (t) { test('simple.log doesnotexist1.log doesnotexist2.log', function (t) {
exec(_('%s %s/corpus/simple.log doesnotexist1.log doesnotexist2.log', exec(_('%s %s/corpus/simple.log doesnotexist1.log doesnotexist2.log',
BUNYAN, __dirname), BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ok(err) t.ok(err)
t.equal(err.code, 2) t.equal(err.code, 2)
t.equal(stdout, t.equal(stdout,
'[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: ' '[2012-02-08T22:56:52.856Z] INFO: myservice/123 on example.com: '
+ 'My message\n'); + 'My message\n');
// Note: node v0.6.10: // Note: node v0.6.10:
// ENOENT, no such file or directory 'asdf.log' // ENOENT, no such file or directory 'asdf.log'
// but node v0.6.14: // but node v0.6.14:
// ENOENT, open 'asdf.log' // ENOENT, open 'asdf.log'
// Somewhat annoying change. // Somewhat annoying change.
t.equal(stderr, t.equal(stderr,
'bunyan: ENOENT, open \'doesnotexist1.log\'\nbunyan: ENOENT, ' 'bunyan: ENOENT, open \'doesnotexist1.log\'\nbunyan: ENOENT, '
+ 'open \'doesnotexist2.log\'\n'); + 'open \'doesnotexist2.log\'\n');
t.end(); t.end();
} }
); );
}); });
test('multiple logs', function (t) { test('multiple logs', function (t) {
exec(_('%s %s/corpus/log1.log %s/corpus/log2.log', BUNYAN, __dirname, __dirname), exec(_('%s %s/corpus/log1.log %s/corpus/log2.log', BUNYAN, __dirname, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, [ t.equal(stdout, [
'[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T16:58:55.586Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T16:58:55.586Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:01:49.339Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:01:49.339Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:02:47.404Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:02:47.404Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:57.404Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:02:57.404Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:08:01.105Z] INFO: agent2/76156 on headnode: message\n', '[2012-05-08T17:08:01.105Z] INFO: agent2/76156 on headnode: message\n',
].join('')); ].join(''));
t.end(); t.end();
}); });
}); });
test('multiple logs, bunyan format', function (t) { test('multiple logs, bunyan format', function (t) {
exec(_('%s -o bunyan %s/corpus/log1.log %s/corpus/log2.log', BUNYAN, __dirname, __dirname), exec(_('%s -o bunyan %s/corpus/log1.log %s/corpus/log2.log', BUNYAN, __dirname, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, [ t.equal(stdout, [
'{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T16:57:55.586Z","v":0}', '{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T16:57:55.586Z","v":0}',
'{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T16:58:55.586Z","v":0}', '{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T16:58:55.586Z","v":0}',
'{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:01:49.339Z","v":0}', '{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:01:49.339Z","v":0}',
'{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:47.404Z","v":0}', '{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:47.404Z","v":0}',
'{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.339Z","v":0}', '{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.339Z","v":0}',
'{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.404Z","v":0}', '{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.404Z","v":0}',
'{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.404Z","v":0}', '{"name":"agent1","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:49.404Z","v":0}',
'{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:57.404Z","v":0}', '{"name":"agent2","pid":73267,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:02:57.404Z","v":0}',
'{"name":"agent2","pid":76156,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:08:01.105Z","v":0}', '{"name":"agent2","pid":76156,"hostname":"headnode","level":30,"msg":"message","time":"2012-05-08T17:08:01.105Z","v":0}',
'' ''
].join('\n')); ].join('\n'));
t.end(); t.end();
}); });
}); });
test('log1.log.gz', function (t) { test('log1.log.gz', function (t) {
exec(_('%s %s/corpus/log1.log.gz', BUNYAN, __dirname), exec(_('%s %s/corpus/log1.log.gz', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, [ t.equal(stdout, [
'[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
].join('')); ].join(''));
t.end(); t.end();
}); });
}); });
test('mixed text and gzip logs', function (t) { test('mixed text and gzip logs', function (t) {
exec(_('%s %s/corpus/log1.log.gz %s/corpus/log2.log', BUNYAN, __dirname, __dirname), exec(_('%s %s/corpus/log1.log.gz %s/corpus/log2.log', BUNYAN, __dirname, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, [ t.equal(stdout, [
'[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T16:57:55.586Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T16:58:55.586Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T16:58:55.586Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:01:49.339Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:01:49.339Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:02:47.404Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:02:47.404Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.339Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n', '[2012-05-08T17:02:49.404Z] INFO: agent1/73267 on headnode: message\n',
'[2012-05-08T17:02:57.404Z] INFO: agent2/73267 on headnode: message\n', '[2012-05-08T17:02:57.404Z] INFO: agent2/73267 on headnode: message\n',
'[2012-05-08T17:08:01.105Z] INFO: agent2/76156 on headnode: message\n', '[2012-05-08T17:08:01.105Z] INFO: agent2/76156 on headnode: message\n',
].join('')); ].join(''));
t.end(); t.end();
}); });
}); });
test('--level 40', function (t) { test('--level 40', function (t) {
expect = [ expect = [
'# levels\n', '# levels\n',
'[2012-02-08T22:56:53.856Z] WARN: myservice/123 on example.com: My message\n', '[2012-02-08T22:56:53.856Z] WARN: myservice/123 on example.com: My message\n',
'[2012-02-08T22:56:54.856Z] ERROR: myservice/123 on example.com: My message\n', '[2012-02-08T22:56:54.856Z] ERROR: myservice/123 on example.com: My message\n',
'[2012-02-08T22:56:55.856Z] LVL55: myservice/123 on example.com: My message\n', '[2012-02-08T22:56:55.856Z] LVL55: myservice/123 on example.com: My message\n',
'[2012-02-08T22:56:56.856Z] FATAL: myservice/123 on example.com: My message\n', '[2012-02-08T22:56:56.856Z] FATAL: myservice/123 on example.com: My message\n',
'\n', '\n',
'# extra fields\n', '# extra fields\n',
'\n', '\n',
'# bogus\n', '# bogus\n',
'not a JSON line\n', 'not a JSON line\n',
'{"hi": "there"}\n' '{"hi": "there"}\n'
].join(''); ].join('');
exec(_('%s -l 40 %s/corpus/all.log', BUNYAN, __dirname), exec(_('%s -l 40 %s/corpus/all.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
exec(_('%s --level 40 %s/corpus/all.log', BUNYAN, __dirname), exec(_('%s --level 40 %s/corpus/all.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
t.end(); t.end();
});
}); });
});
}); });
test('--condition "level === 10 && pid === 123"', function (t) { test('--condition "level === 10 && pid === 123"', function (t) {
var expect = [ var expect = [
'# levels\n', '# levels\n',
'[2012-02-08T22:56:50.856Z] TRACE: myservice/123 on example.com: My message\n', '[2012-02-08T22:56:50.856Z] TRACE: myservice/123 on example.com: My message\n',
'\n', '\n',
'# extra fields\n', '# extra fields\n',
'\n', '\n',
'# bogus\n', '# bogus\n',
'not a JSON line\n', 'not a JSON line\n',
'{"hi": "there"}\n' '{"hi": "there"}\n'
].join(''); ].join('');
exec(_('%s -c "level === 10 && pid === 123" %s/corpus/all.log', BUNYAN, __dirname), exec(_('%s -c "level === 10 && pid === 123" %s/corpus/all.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
exec(_('%s --condition "level === 10 && pid === 123" %s/corpus/all.log', BUNYAN, __dirname), exec(_('%s --condition "level === 10 && pid === 123" %s/corpus/all.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
t.end(); t.end();
});
}); });
});
}); });
// multiple // multiple
// not sure if this is a bug or a feature. let's call it a feature! // not sure if this is a bug or a feature. let's call it a feature!
test('multiple --conditions', function (t) { test('multiple --conditions', function (t) {
var expect = [ var expect = [
'# levels\n', '# levels\n',
'[2012-02-08T22:56:53.856Z] WARN: myservice/1 on example.com: My message\n', '[2012-02-08T22:56:53.856Z] WARN: myservice/1 on example.com: My message\n',
'\n', '\n',
'# extra fields\n', '# extra fields\n',
'\n', '\n',
'# bogus\n', '# bogus\n',
'not a JSON line\n', 'not a JSON line\n',
'{"hi": "there"}\n' '{"hi": "there"}\n'
].join(''); ].join('');
exec(_('%s %s/corpus/all.log ' + exec(_('%s %s/corpus/all.log ' +
'-c "if (level === 40) pid = 1; true" ' + '-c "if (level === 40) pid = 1; true" ' +
'-c "pid === 1"', BUNYAN, __dirname), '-c "pid === 1"', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
t.end(); t.end();
}); });
}); });
// https://github.com/trentm/node-bunyan/issues/30 // https://github.com/trentm/node-bunyan/issues/30
@ -317,43 +317,43 @@ test('multiple --conditions', function (t) {
// One of the records in corpus/withreq.log has a 'req' // One of the records in corpus/withreq.log has a 'req'
// field with no 'headers'. Ditto for the 'res' field. // field with no 'headers'. Ditto for the 'res' field.
test('robust req handling', function (t) { test('robust req handling', function (t) {
var expect = [ var expect = [
'[2012-08-08T10:25:47.636Z] DEBUG: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: headAgentProbes respond (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, route=HeadAgentProbes, contentMD5=11FxOYiYfpMxmANj4kGJzg==)', '[2012-08-08T10:25:47.636Z] DEBUG: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: headAgentProbes respond (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, route=HeadAgentProbes, contentMD5=11FxOYiYfpMxmANj4kGJzg==)',
'[2012-08-08T10:25:47.637Z] INFO: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: HeadAgentProbes handled: 200 (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, audit=true, remoteAddress=10.2.207.2, remotePort=50394, latency=3, secure=false, _audit=true, req.version=*)', '[2012-08-08T10:25:47.637Z] INFO: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: HeadAgentProbes handled: 200 (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, audit=true, remoteAddress=10.2.207.2, remotePort=50394, latency=3, secure=false, _audit=true, req.version=*)',
' HEAD /agentprobes?agent=ccf92af9-0b24-46b6-ab60-65095fdd3037 HTTP/1.1', ' HEAD /agentprobes?agent=ccf92af9-0b24-46b6-ab60-65095fdd3037 HTTP/1.1',
' accept: application/json', ' accept: application/json',
' content-type: application/json', ' content-type: application/json',
' host: 10.2.207.16', ' host: 10.2.207.16',
' connection: keep-alive', ' connection: keep-alive',
' --', ' --',
' HTTP/1.1 200 OK', ' HTTP/1.1 200 OK',
' content-md5: 11FxOYiYfpMxmANj4kGJzg==', ' content-md5: 11FxOYiYfpMxmANj4kGJzg==',
' access-control-allow-origin: *', ' access-control-allow-origin: *',
' access-control-allow-headers: Accept, Accept-Version, Content-Length, Content-MD5, Content-Type, Date, X-Api-Version', ' access-control-allow-headers: Accept, Accept-Version, Content-Length, Content-MD5, Content-Type, Date, X-Api-Version',
' access-control-allow-methods: HEAD', ' access-control-allow-methods: HEAD',
' access-control-expose-headers: X-Api-Version, X-Request-Id, X-Response-Time', ' access-control-expose-headers: X-Api-Version, X-Request-Id, X-Response-Time',
' connection: Keep-Alive', ' connection: Keep-Alive',
' date: Wed, 08 Aug 2012 10:25:47 GMT', ' date: Wed, 08 Aug 2012 10:25:47 GMT',
' server: Amon Master/1.0.0', ' server: Amon Master/1.0.0',
' x-request-id: cce79d15-ffc2-487c-a4e4-e940bdaac31e', ' x-request-id: cce79d15-ffc2-487c-a4e4-e940bdaac31e',
' x-response-time: 3', ' x-response-time: 3',
' --', ' --',
' route: {', ' route: {',
' "name": "HeadAgentProbes",', ' "name": "HeadAgentProbes",',
' "version": false', ' "version": false',
' }', ' }',
'[2012-08-08T10:25:47.637Z] INFO: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: HeadAgentProbes handled: 200 (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, audit=true, remoteAddress=10.2.207.2, remotePort=50394, latency=3, secure=false, _audit=true, req.version=*)', '[2012-08-08T10:25:47.637Z] INFO: amon-master/12859 on 9724a190-27b6-4fd8-830b-a574f839c67d: HeadAgentProbes handled: 200 (req_id=cce79d15-ffc2-487c-a4e4-e940bdaac31e, audit=true, remoteAddress=10.2.207.2, remotePort=50394, latency=3, secure=false, _audit=true, req.version=*)',
' HEAD /agentprobes?agent=ccf92af9-0b24-46b6-ab60-65095fdd3037 HTTP/1.1', ' HEAD /agentprobes?agent=ccf92af9-0b24-46b6-ab60-65095fdd3037 HTTP/1.1',
' --', ' --',
' route: {', ' route: {',
' "name": "HeadAgentProbes",', ' "name": "HeadAgentProbes",',
' "version": false', ' "version": false',
' }' ' }'
].join('\n') + '\n'; ].join('\n') + '\n';
exec(_('%s %s/corpus/withreq.log', BUNYAN, __dirname), exec(_('%s %s/corpus/withreq.log', BUNYAN, __dirname),
function (err, stdout, stderr) { function (err, stdout, stderr) {
t.ifError(err); t.ifError(err);
t.equal(stdout, expect); t.equal(stdout, expect);
t.end(); t.end();
}); });
}); });

View file

@ -5,11 +5,11 @@
*/ */
var bunyan = require('../lib/bunyan'), var bunyan = require('../lib/bunyan'),
Logger = bunyan; Logger = bunyan;
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -18,109 +18,109 @@ var test = tap4nodeunit.test;
test('ensure Logger creation options', function (t) { test('ensure Logger creation options', function (t) {
t.throws(function () { new Logger(); }, t.throws(function () { new Logger(); },
'options (object) is required', 'options (object) is required',
'no options should throw'); 'no options should throw');
t.throws(function () { new Logger({}); }, t.throws(function () { new Logger({}); },
'options.name (string) is required', 'options.name (string) is required',
'no options.name should throw'); 'no options.name should throw');
t.doesNotThrow(function () { new Logger({name: 'foo'}); }, t.doesNotThrow(function () { new Logger({name: 'foo'}); },
'just options.name should be sufficient'); 'just options.name should be sufficient');
var options = {name: 'foo', stream: process.stdout, streams: []}; var options = {name: 'foo', stream: process.stdout, streams: []};
t.throws(function () { new Logger(options); }, t.throws(function () { new Logger(options); },
'cannot use "stream" and "streams"'); 'cannot use "stream" and "streams"');
// https://github.com/trentm/node-bunyan/issues/3 // https://github.com/trentm/node-bunyan/issues/3
options = {name: 'foo', streams: {}}; options = {name: 'foo', streams: {}};
t.throws(function () { new Logger(options); }, t.throws(function () { new Logger(options); },
'invalid options.streams: must be an array', 'invalid options.streams: must be an array',
'"streams" must be an array'); '"streams" must be an array');
options = {name: 'foo', serializers: 'a string'}; options = {name: 'foo', serializers: 'a string'};
t.throws(function () { new Logger(options); }, t.throws(function () { new Logger(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be a string'); '"serializers" cannot be a string');
options = {name: 'foo', serializers: [1, 2, 3]}; options = {name: 'foo', serializers: [1, 2, 3]};
t.throws(function () { new Logger(options); }, t.throws(function () { new Logger(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be an array'); '"serializers" cannot be an array');
t.end(); t.end();
}); });
test('ensure Logger creation options (createLogger)', function (t) { test('ensure Logger creation options (createLogger)', function (t) {
t.throws(function () { bunyan.createLogger(); }, t.throws(function () { bunyan.createLogger(); },
'options (object) is required', 'options (object) is required',
'no options should throw'); 'no options should throw');
t.throws(function () { bunyan.createLogger({}); }, t.throws(function () { bunyan.createLogger({}); },
'options.name (string) is required', 'options.name (string) is required',
'no options.name should throw'); 'no options.name should throw');
t.doesNotThrow(function () { bunyan.createLogger({name: 'foo'}); }, t.doesNotThrow(function () { bunyan.createLogger({name: 'foo'}); },
'just options.name should be sufficient'); 'just options.name should be sufficient');
var options = {name: 'foo', stream: process.stdout, streams: []}; var options = {name: 'foo', stream: process.stdout, streams: []};
t.throws(function () { bunyan.createLogger(options); }, t.throws(function () { bunyan.createLogger(options); },
'cannot use "stream" and "streams"'); 'cannot use "stream" and "streams"');
// https://github.com/trentm/node-bunyan/issues/3 // https://github.com/trentm/node-bunyan/issues/3
options = {name: 'foo', streams: {}}; options = {name: 'foo', streams: {}};
t.throws(function () { bunyan.createLogger(options); }, t.throws(function () { bunyan.createLogger(options); },
'invalid options.streams: must be an array', 'invalid options.streams: must be an array',
'"streams" must be an array'); '"streams" must be an array');
options = {name: 'foo', serializers: 'a string'}; options = {name: 'foo', serializers: 'a string'};
t.throws(function () { bunyan.createLogger(options); }, t.throws(function () { bunyan.createLogger(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be a string'); '"serializers" cannot be a string');
options = {name: 'foo', serializers: [1, 2, 3]}; options = {name: 'foo', serializers: [1, 2, 3]};
t.throws(function () { bunyan.createLogger(options); }, t.throws(function () { bunyan.createLogger(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be an array'); '"serializers" cannot be an array');
t.end(); t.end();
}); });
test('ensure Logger child() options', function (t) { test('ensure Logger child() options', function (t) {
var log = new Logger({name: 'foo'}); var log = new Logger({name: 'foo'});
t.doesNotThrow(function () { log.child(); }, t.doesNotThrow(function () { log.child(); },
'no options should be fine'); 'no options should be fine');
t.doesNotThrow(function () { log.child({}); }, t.doesNotThrow(function () { log.child({}); },
'empty options should be fine too'); 'empty options should be fine too');
t.throws(function () { log.child({name: 'foo'}); }, t.throws(function () { log.child({name: 'foo'}); },
'invalid options.name: child cannot set logger name', 'invalid options.name: child cannot set logger name',
'child cannot change name'); 'child cannot change name');
var options = {stream: process.stdout, streams: []}; var options = {stream: process.stdout, streams: []};
t.throws(function () { log.child(options); }, t.throws(function () { log.child(options); },
'cannot use "stream" and "streams"'); 'cannot use "stream" and "streams"');
// https://github.com/trentm/node-bunyan/issues/3 // https://github.com/trentm/node-bunyan/issues/3
options = {streams: {}}; options = {streams: {}};
t.throws(function () { log.child(options); }, t.throws(function () { log.child(options); },
'invalid options.streams: must be an array', 'invalid options.streams: must be an array',
'"streams" must be an array'); '"streams" must be an array');
options = {serializers: 'a string'}; options = {serializers: 'a string'};
t.throws(function () { log.child(options); }, t.throws(function () { log.child(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be a string'); '"serializers" cannot be a string');
options = {serializers: [1, 2, 3]}; options = {serializers: [1, 2, 3]};
t.throws(function () { log.child(options); }, t.throws(function () { log.child(options); },
'invalid options.serializers: must be an object', 'invalid options.serializers: must be an object',
'"serializers" cannot be an array'); '"serializers" cannot be an array');
t.end(); t.end();
}); });

View file

@ -8,7 +8,7 @@ var Logger = require('../lib/bunyan.js');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -20,71 +20,71 @@ var outstr = new Stream;
outstr.writable = true; outstr.writable = true;
var output = []; var output = [];
outstr.write = function (c) { outstr.write = function (c) {
output.push(JSON.parse(c + '')); output.push(JSON.parse(c + ''));
}; };
outstr.end = function (c) { outstr.end = function (c) {
if (c) this.write(c); if (c) this.write(c);
this.emit('end'); this.emit('end');
}; };
// these are lacking a few fields that will probably never match // these are lacking a few fields that will probably never match
var expect = var expect =
[ [
{ {
'name': 'blammo', 'name': 'blammo',
'level': 30, 'level': 30,
'msg': 'bango { bang: \'boom\', KABOOM: [Circular] }', 'msg': 'bango { bang: \'boom\', KABOOM: [Circular] }',
'v': 0 'v': 0
}, },
{ {
'name': 'blammo', 'name': 'blammo',
'level': 30, 'level': 30,
'msg': 'kaboom { bang: \'boom\', KABOOM: [Circular] }', 'msg': 'kaboom { bang: \'boom\', KABOOM: [Circular] }',
'v': 0 'v': 0
}, },
{ {
'name': 'blammo', 'name': 'blammo',
'level': 30, 'level': 30,
'bang': 'boom', 'bang': 'boom',
'KABOOM': { 'KABOOM': {
'bang': 'boom', 'bang': 'boom',
'KABOOM': '[Circular]' 'KABOOM': '[Circular]'
}, },
'msg': '', 'msg': '',
'v': 0 'v': 0
} }
]; ];
var log = new Logger({ var log = new Logger({
name: 'blammo', name: 'blammo',
streams: [ streams: [
{ {
type: 'stream', type: 'stream',
level: 'info', level: 'info',
stream: outstr stream: outstr
} }
] ]
}); });
test('cycles', function (t) { test('cycles', function (t) {
outstr.on('end', function () { outstr.on('end', function () {
output.forEach(function (o, i) { output.forEach(function (o, i) {
// Drop variable parts for comparison. // Drop variable parts for comparison.
delete o.hostname; delete o.hostname;
delete o.pid; delete o.pid;
delete o.time; delete o.time;
// Hack object/dict comparison: JSONify. // Hack object/dict comparison: JSONify.
t.equal(JSON.stringify(o), JSON.stringify(expect[i]), t.equal(JSON.stringify(o), JSON.stringify(expect[i]),
'log item ' + i + ' matches'); 'log item ' + i + ' matches');
});
t.end();
}); });
t.end();
});
var obj = { bang: 'boom' }; var obj = { bang: 'boom' };
obj.KABOOM = obj; obj.KABOOM = obj;
log.info('bango', obj); log.info('bango', obj);
log.info('kaboom', obj.KABOOM); log.info('kaboom', obj.KABOOM);
log.info(obj); log.info(obj);
outstr.end(); outstr.end();
t.ok('did not throw'); t.ok('did not throw');
}); });

View file

@ -11,7 +11,7 @@ var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -22,55 +22,55 @@ var test = tap4nodeunit.test;
var dtracePlats = ['sunos', 'darwin', 'freebsd']; var dtracePlats = ['sunos', 'darwin', 'freebsd'];
var runDtraceTests = true; var runDtraceTests = true;
try { try {
require('dtrace-provider') require('dtrace-provider')
} catch (e) { } catch (e) {
console.log('# skip dtrace tests: no dtrace-provider module'); console.log('# skip dtrace tests: no dtrace-provider module');
runDtraceTests = false; runDtraceTests = false;
} }
if (!runDtraceTests) { if (!runDtraceTests) {
/* pass through */ /* pass through */
} else if (dtracePlats.indexOf(process.platform) === -1) { } else if (dtracePlats.indexOf(process.platform) === -1) {
console.log('# skip dtrace tests: not on a platform with dtrace'); console.log('# skip dtrace tests: not on a platform with dtrace');
runDtraceTests = false; runDtraceTests = false;
} else if (process.env.SKIP_DTRACE) { } else if (process.env.SKIP_DTRACE) {
console.log('# skip dtrace tests: SKIP_DTRACE envvar set'); console.log('# skip dtrace tests: SKIP_DTRACE envvar set');
runDtraceTests = false; runDtraceTests = false;
} else if (process.getgid() !== 0) { } else if (process.getgid() !== 0) {
console.log('# skip dtrace tests: gid is not 0, run with `sudo`'); console.log('# skip dtrace tests: gid is not 0, run with `sudo`');
runDtraceTests = false; runDtraceTests = false;
} }
if (runDtraceTests) { if (runDtraceTests) {
test('basic dtrace', function (t) { test('basic dtrace', function (t) {
var argv = ['dtrace', '-Z', '-x', 'strsize=4k', '-qn', var argv = ['dtrace', '-Z', '-x', 'strsize=4k', '-qn',
'bunyan$target:::log-*{printf("%s", copyinstr(arg0))}', 'bunyan$target:::log-*{printf("%s", copyinstr(arg0))}',
'-c', format('node %s/log-some.js', __dirname)]; '-c', format('node %s/log-some.js', __dirname)];
var dtrace = spawn(argv[0], argv.slice(1)); var dtrace = spawn(argv[0], argv.slice(1));
//console.error('ARGV: %j', argv); //console.error('ARGV: %j', argv);
var traces = []; var traces = [];
dtrace.stdout.on('data', function (data) { dtrace.stdout.on('data', function (data) {
//console.error('DTRACE STDOUT:', data.toString()); //console.error('DTRACE STDOUT:', data.toString());
traces.push(data.toString()); traces.push(data.toString());
}); });
dtrace.stderr.on('data', function (data) { dtrace.stderr.on('data', function (data) {
console.error('DTRACE STDERR:', data.toString()); console.error('DTRACE STDERR:', data.toString());
}); });
dtrace.on('exit', function (code) { dtrace.on('exit', function (code) {
t.notOk(code, 'dtrace exited cleanly'); t.notOk(code, 'dtrace exited cleanly');
traces = traces.join('').split('\n') traces = traces.join('').split('\n')
.filter(function (t) { return t.trim().length }) .filter(function (t) { return t.trim().length })
.map(function (t) { return JSON.parse(t) }); .map(function (t) { return JSON.parse(t) });
t.equal(traces.length, 2, 'got 2 log records'); t.equal(traces.length, 2, 'got 2 log records');
if (traces.length) { if (traces.length) {
t.equal(traces[0].level, bunyan.DEBUG); t.equal(traces[0].level, bunyan.DEBUG);
t.equal(traces[0].foo, 'bar'); t.equal(traces[0].foo, 'bar');
t.equal(traces[1].level, bunyan.TRACE); t.equal(traces[1].level, bunyan.TRACE);
t.equal(traces[1].msg, 'hi at trace'); t.equal(traces[1].msg, 'hi at trace');
} }
t.end(); t.end();
}); });
}); });

View file

@ -9,7 +9,7 @@ var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -17,16 +17,16 @@ var test = tap4nodeunit.test;
test('error event on log write', function (t) { test('error event on log write', function (t) {
LOG_PATH = '/this/path/is/bogus.log' LOG_PATH = '/this/path/is/bogus.log'
var log = bunyan.createLogger( var log = bunyan.createLogger(
{name: 'error-event', streams: [ {path: LOG_PATH} ]}); {name: 'error-event', streams: [ {path: LOG_PATH} ]});
log.on('error', function (err, stream) { log.on('error', function (err, stream) {
t.ok(err, 'got err in error event: ' + err); t.ok(err, 'got err in error event: ' + err);
t.equal(err.code, 'ENOENT', 'error code is ENOENT'); t.equal(err.code, 'ENOENT', 'error code is ENOENT');
t.ok(stream, 'got a stream argument'); t.ok(stream, 'got a stream argument');
t.equal(stream.path, LOG_PATH); t.equal(stream.path, LOG_PATH);
t.equal(stream.type, 'file'); t.equal(stream.type, 'file');
t.end(); t.end();
}); });
log.info('info log message'); log.info('info log message');
}); });

View file

@ -5,8 +5,8 @@
var bunyan = require('../lib/bunyan'); var bunyan = require('../lib/bunyan');
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'play', name: 'play',
serializers: bunyan.stdSerializers serializers: bunyan.stdSerializers
}); });
log.debug({foo: 'bar'}, 'hi at debug') log.debug({foo: 'bar'}, 'hi at debug')
log.trace('hi at trace') log.trace('hi at trace')

View file

@ -8,7 +8,7 @@ var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -16,45 +16,45 @@ var test = tap4nodeunit.test;
var log1 = bunyan.createLogger({ var log1 = bunyan.createLogger({
name: 'log1', name: 'log1',
streams: [ streams: [
{ {
path: __dirname + '/log.test.log1.log', path: __dirname + '/log.test.log1.log',
level: 'info' level: 'info'
} }
] ]
}); });
var log2 = bunyan.createLogger({ var log2 = bunyan.createLogger({
name: 'log2', name: 'log2',
streams: [ streams: [
{ {
path: __dirname + '/log.test.log2a.log', path: __dirname + '/log.test.log2a.log',
level: 'error' level: 'error'
}, },
{ {
path: __dirname + '/log.test.log2b.log', path: __dirname + '/log.test.log2b.log',
level: 'debug' level: 'debug'
} }
] ]
}) })
test('log.LEVEL() -> boolean', function (t) { test('log.LEVEL() -> boolean', function (t) {
t.equal(log1.trace(), false, 'log1.trace() is false') t.equal(log1.trace(), false, 'log1.trace() is false')
t.equal(log1.debug(), false) t.equal(log1.debug(), false)
t.equal(log1.info(), true) t.equal(log1.info(), true)
t.equal(log1.warn(), true) t.equal(log1.warn(), true)
t.equal(log1.error(), true) t.equal(log1.error(), true)
t.equal(log1.fatal(), true) t.equal(log1.fatal(), true)
// Level is the *lowest* level of all streams. // Level is the *lowest* level of all streams.
t.equal(log2.trace(), false) t.equal(log2.trace(), false)
t.equal(log2.debug(), true) t.equal(log2.debug(), true)
t.equal(log2.info(), true) t.equal(log2.info(), true)
t.equal(log2.warn(), true) t.equal(log2.warn(), true)
t.equal(log2.error(), true) t.equal(log2.error(), true)
t.equal(log2.fatal(), true) t.equal(log2.fatal(), true)
t.end(); t.end();
}); });
//TODO: //TODO:

View file

@ -8,7 +8,7 @@ var bunyan = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -16,27 +16,27 @@ var test = tap4nodeunit.test;
test('bunyan.<LEVEL>s', function (t) { test('bunyan.<LEVEL>s', function (t) {
t.ok(bunyan.TRACE, 'TRACE'); t.ok(bunyan.TRACE, 'TRACE');
t.ok(bunyan.DEBUG, 'DEBUG'); t.ok(bunyan.DEBUG, 'DEBUG');
t.ok(bunyan.INFO, 'INFO'); t.ok(bunyan.INFO, 'INFO');
t.ok(bunyan.WARN, 'WARN'); t.ok(bunyan.WARN, 'WARN');
t.ok(bunyan.ERROR, 'ERROR'); t.ok(bunyan.ERROR, 'ERROR');
t.ok(bunyan.FATAL, 'FATAL'); t.ok(bunyan.FATAL, 'FATAL');
t.end(); t.end();
}); });
test('bunyan.resolveLevel()', function (t) { test('bunyan.resolveLevel()', function (t) {
t.equal(bunyan.resolveLevel('trace'), bunyan.TRACE, 'TRACE'); t.equal(bunyan.resolveLevel('trace'), bunyan.TRACE, 'TRACE');
t.equal(bunyan.resolveLevel('TRACE'), bunyan.TRACE, 'TRACE'); t.equal(bunyan.resolveLevel('TRACE'), bunyan.TRACE, 'TRACE');
t.equal(bunyan.resolveLevel('debug'), bunyan.DEBUG, 'DEBUG'); t.equal(bunyan.resolveLevel('debug'), bunyan.DEBUG, 'DEBUG');
t.equal(bunyan.resolveLevel('DEBUG'), bunyan.DEBUG, 'DEBUG'); t.equal(bunyan.resolveLevel('DEBUG'), bunyan.DEBUG, 'DEBUG');
t.equal(bunyan.resolveLevel('info'), bunyan.INFO, 'INFO'); t.equal(bunyan.resolveLevel('info'), bunyan.INFO, 'INFO');
t.equal(bunyan.resolveLevel('INFO'), bunyan.INFO, 'INFO'); t.equal(bunyan.resolveLevel('INFO'), bunyan.INFO, 'INFO');
t.equal(bunyan.resolveLevel('warn'), bunyan.WARN, 'WARN'); t.equal(bunyan.resolveLevel('warn'), bunyan.WARN, 'WARN');
t.equal(bunyan.resolveLevel('WARN'), bunyan.WARN, 'WARN'); t.equal(bunyan.resolveLevel('WARN'), bunyan.WARN, 'WARN');
t.equal(bunyan.resolveLevel('error'), bunyan.ERROR, 'ERROR'); t.equal(bunyan.resolveLevel('error'), bunyan.ERROR, 'ERROR');
t.equal(bunyan.resolveLevel('ERROR'), bunyan.ERROR, 'ERROR'); t.equal(bunyan.resolveLevel('ERROR'), bunyan.ERROR, 'ERROR');
t.equal(bunyan.resolveLevel('fatal'), bunyan.FATAL, 'FATAL'); t.equal(bunyan.resolveLevel('fatal'), bunyan.FATAL, 'FATAL');
t.equal(bunyan.resolveLevel('FATAL'), bunyan.FATAL, 'FATAL'); t.equal(bunyan.resolveLevel('FATAL'), bunyan.FATAL, 'FATAL');
t.end(); t.end();
}); });

View file

@ -9,7 +9,7 @@ var Logger = require('../lib/bunyan');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -17,101 +17,101 @@ var test = tap4nodeunit.test;
function CapturingStream(recs) { function CapturingStream(recs) {
this.recs = recs; this.recs = recs;
} }
CapturingStream.prototype.write = function (rec) { CapturingStream.prototype.write = function (rec) {
this.recs.push(rec); this.recs.push(rec);
} }
test('raw stream', function (t) { test('raw stream', function (t) {
var recs = []; var recs = [];
var log = new Logger({ var log = new Logger({
name: 'raw-stream-test', name: 'raw-stream-test',
streams: [ streams: [
{ {
stream: new CapturingStream(recs), stream: new CapturingStream(recs),
type: 'raw' type: 'raw'
} }
] ]
}); });
log.info('first'); log.info('first');
log.info({two: 'deux'}, 'second'); log.info({two: 'deux'}, 'second');
t.equal(recs.length, 2); t.equal(recs.length, 2);
t.equal(typeof (recs[0]), 'object', 'first rec is an object'); t.equal(typeof (recs[0]), 'object', 'first rec is an object');
t.equal(recs[1].two, 'deux', '"two" field made it through'); t.equal(recs[1].two, 'deux', '"two" field made it through');
t.end(); t.end();
}); });
test('raw streams and regular streams can mix', function (t) { test('raw streams and regular streams can mix', function (t) {
var rawRecs = []; var rawRecs = [];
var nonRawRecs = []; var nonRawRecs = [];
var log = new Logger({ var log = new Logger({
name: 'raw-stream-test', name: 'raw-stream-test',
streams: [ streams: [
{ {
stream: new CapturingStream(rawRecs), stream: new CapturingStream(rawRecs),
type: 'raw' type: 'raw'
}, },
{ {
stream: new CapturingStream(nonRawRecs) stream: new CapturingStream(nonRawRecs)
} }
] ]
}); });
log.info('first'); log.info('first');
log.info({two: 'deux'}, 'second'); log.info({two: 'deux'}, 'second');
t.equal(rawRecs.length, 2); t.equal(rawRecs.length, 2);
t.equal(typeof (rawRecs[0]), 'object', 'first rawRec is an object'); t.equal(typeof (rawRecs[0]), 'object', 'first rawRec is an object');
t.equal(rawRecs[1].two, 'deux', '"two" field made it through'); t.equal(rawRecs[1].two, 'deux', '"two" field made it through');
t.equal(nonRawRecs.length, 2); t.equal(nonRawRecs.length, 2);
t.equal(typeof (nonRawRecs[0]), 'string', 'first nonRawRec is a string'); t.equal(typeof (nonRawRecs[0]), 'string', 'first nonRawRec is a string');
t.end(); t.end();
}); });
test('child adding a non-raw stream works', function (t) { test('child adding a non-raw stream works', function (t) {
var parentRawRecs = []; var parentRawRecs = [];
var rawRecs = []; var rawRecs = [];
var nonRawRecs = []; var nonRawRecs = [];
var logParent = new Logger({ var logParent = new Logger({
name: 'raw-stream-test', name: 'raw-stream-test',
streams: [ streams: [
{ {
stream: new CapturingStream(parentRawRecs), stream: new CapturingStream(parentRawRecs),
type: 'raw' type: 'raw'
} }
] ]
}); });
var logChild = logParent.child({ var logChild = logParent.child({
child: true, child: true,
streams: [ streams: [
{ {
stream: new CapturingStream(rawRecs), stream: new CapturingStream(rawRecs),
type: 'raw' type: 'raw'
}, },
{ {
stream: new CapturingStream(nonRawRecs) stream: new CapturingStream(nonRawRecs)
} }
] ]
}); });
logParent.info('first'); logParent.info('first');
logChild.info({two: 'deux'}, 'second'); logChild.info({two: 'deux'}, 'second');
t.equal(rawRecs.length, 1, t.equal(rawRecs.length, 1,
format('rawRecs length should be 1 (is %d)', rawRecs.length)); format('rawRecs length should be 1 (is %d)', rawRecs.length));
t.equal(typeof (rawRecs[0]), 'object', 'rawRec entry is an object'); t.equal(typeof (rawRecs[0]), 'object', 'rawRec entry is an object');
t.equal(rawRecs[0].two, 'deux', '"two" field made it through'); t.equal(rawRecs[0].two, 'deux', '"two" field made it through');
t.equal(nonRawRecs.length, 1); t.equal(nonRawRecs.length, 1);
t.equal(typeof (nonRawRecs[0]), 'string', 'first nonRawRec is a string'); t.equal(typeof (nonRawRecs[0]), 'string', 'first nonRawRec is a string');
t.end(); t.end();
}); });

View file

@ -7,7 +7,7 @@ var ringbuffer = new Logger.RingBuffer({ 'limit': 5 });
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -15,33 +15,33 @@ var test = tap4nodeunit.test;
var log1 = new Logger({ var log1 = new Logger({
name: 'log1', name: 'log1',
streams: [ streams: [
{ {
stream: ringbuffer, stream: ringbuffer,
type: 'raw', type: 'raw',
level: 'info' level: 'info'
} }
] ]
}); });
test('ringbuffer', function (t) { test('ringbuffer', function (t) {
log1.info('hello'); log1.info('hello');
log1.trace('there'); log1.trace('there');
log1.error('android'); log1.error('android');
t.equal(ringbuffer.records.length, 2); t.equal(ringbuffer.records.length, 2);
t.equal(ringbuffer.records[0]['msg'], 'hello'); t.equal(ringbuffer.records[0]['msg'], 'hello');
t.equal(ringbuffer.records[1]['msg'], 'android'); t.equal(ringbuffer.records[1]['msg'], 'android');
log1.error('one'); log1.error('one');
log1.error('two'); log1.error('two');
log1.error('three'); log1.error('three');
t.equal(ringbuffer.records.length, 5); t.equal(ringbuffer.records.length, 5);
log1.error('four'); log1.error('four');
t.equal(ringbuffer.records.length, 5); t.equal(ringbuffer.records.length, 5);
t.equal(ringbuffer.records[0]['msg'], 'android'); t.equal(ringbuffer.records[0]['msg'], 'android');
t.equal(ringbuffer.records[1]['msg'], 'one'); t.equal(ringbuffer.records[1]['msg'], 'one');
t.equal(ringbuffer.records[2]['msg'], 'two'); t.equal(ringbuffer.records[2]['msg'], 'two');
t.equal(ringbuffer.records[3]['msg'], 'three'); t.equal(ringbuffer.records[3]['msg'], 'three');
t.equal(ringbuffer.records[4]['msg'], 'four'); t.equal(ringbuffer.records[4]['msg'], 'four');
t.end(); t.end();
}); });

View file

@ -11,7 +11,7 @@ var verror = require('verror');
// node-tap API // node-tap API
if (require.cache[__dirname + '/tap4nodeunit.js']) if (require.cache[__dirname + '/tap4nodeunit.js'])
delete require.cache[__dirname + '/tap4nodeunit.js']; delete require.cache[__dirname + '/tap4nodeunit.js'];
var tap4nodeunit = require('./tap4nodeunit.js'); var tap4nodeunit = require('./tap4nodeunit.js');
var after = tap4nodeunit.after; var after = tap4nodeunit.after;
var before = tap4nodeunit.before; var before = tap4nodeunit.before;
@ -19,246 +19,246 @@ var test = tap4nodeunit.test;
function CapturingStream(recs) { function CapturingStream(recs) {
this.recs = recs; this.recs = recs;
} }
CapturingStream.prototype.write = function (rec) { CapturingStream.prototype.write = function (rec) {
this.recs.push(rec); this.recs.push(rec);
} }
test('req serializer', function (t) { test('req serializer', function (t) {
var records = []; var records = [];
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'serializer-test', name: 'serializer-test',
streams: [ streams: [
{ {
stream: new CapturingStream(records), stream: new CapturingStream(records),
type: 'raw' type: 'raw'
} }
], ],
serializers: { serializers: {
req: bunyan.stdSerializers.req req: bunyan.stdSerializers.req
} }
}); });
// None of these should blow up. // None of these should blow up.
var bogusReqs = [ var bogusReqs = [
undefined, undefined,
null, null,
{}, {},
1, 1,
'string', 'string',
[1, 2, 3], [1, 2, 3],
{'foo':'bar'} {'foo':'bar'}
]; ];
for (var i = 0; i < bogusReqs.length; i++) { for (var i = 0; i < bogusReqs.length; i++) {
log.info({req: bogusReqs[i]}, 'hi'); log.info({req: bogusReqs[i]}, 'hi');
t.equal(records[i].req, bogusReqs[i]); t.equal(records[i].req, bogusReqs[i]);
} }
// Get http request and response objects to play with and test. // Get http request and response objects to play with and test.
var theReq, theRes; var theReq, theRes;
var server = http.createServer(function (req, res) { var server = http.createServer(function (req, res) {
theReq = req; theReq = req;
theRes = res; theRes = res;
res.writeHead(200, {'Content-Type': 'text/plain'}); res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World\n'); res.end('Hello World\n');
}) })
server.listen(8765, function () { server.listen(8765, function () {
http.get({host: '127.0.0.1', port: 8765, path: '/'}, function (res) { http.get({host: '127.0.0.1', port: 8765, path: '/'}, function (res) {
res.resume(); res.resume();
log.info({req: theReq}, 'the request'); log.info({req: theReq}, 'the request');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.req.method, 'GET'); t.equal(lastRecord.req.method, 'GET');
t.equal(lastRecord.req.url, theReq.url); t.equal(lastRecord.req.url, theReq.url);
t.equal(lastRecord.req.remoteAddress, theReq.connection.remoteAddress); t.equal(lastRecord.req.remoteAddress, theReq.connection.remoteAddress);
t.equal(lastRecord.req.remotePort, theReq.connection.remotePort); t.equal(lastRecord.req.remotePort, theReq.connection.remotePort);
server.close(); server.close();
t.end(); t.end();
}).on('error', function (err) { }).on('error', function (err) {
t.ok(false, 'error requesting to our test server: ' + err); t.ok(false, 'error requesting to our test server: ' + err);
server.close(); server.close();
t.end(); t.end();
});
}); });
});
}); });
test('res serializer', function (t) { test('res serializer', function (t) {
var records = []; var records = [];
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'serializer-test', name: 'serializer-test',
streams: [ streams: [
{ {
stream: new CapturingStream(records), stream: new CapturingStream(records),
type: 'raw' type: 'raw'
} }
], ],
serializers: { serializers: {
res: bunyan.stdSerializers.res res: bunyan.stdSerializers.res
} }
}); });
// None of these should blow up. // None of these should blow up.
var bogusRess = [ var bogusRess = [
undefined, undefined,
null, null,
{}, {},
1, 1,
'string', 'string',
[1, 2, 3], [1, 2, 3],
{'foo':'bar'} {'foo':'bar'}
]; ];
for (var i = 0; i < bogusRess.length; i++) { for (var i = 0; i < bogusRess.length; i++) {
log.info({res: bogusRess[i]}, 'hi'); log.info({res: bogusRess[i]}, 'hi');
t.equal(records[i].res, bogusRess[i]); t.equal(records[i].res, bogusRess[i]);
} }
// Get http request and response objects to play with and test. // Get http request and response objects to play with and test.
var theReq, theRes; var theReq, theRes;
var server = http.createServer(function (req, res) { var server = http.createServer(function (req, res) {
theReq = req; theReq = req;
theRes = res; theRes = res;
res.writeHead(200, {'Content-Type': 'text/plain'}); res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World\n'); res.end('Hello World\n');
}) })
server.listen(8765, function () { server.listen(8765, function () {
http.get({host: '127.0.0.1', port: 8765, path: '/'}, function (res) { http.get({host: '127.0.0.1', port: 8765, path: '/'}, function (res) {
res.resume(); res.resume();
log.info({res: theRes}, 'the response'); log.info({res: theRes}, 'the response');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.res.statusCode, theRes.statusCode); t.equal(lastRecord.res.statusCode, theRes.statusCode);
t.equal(lastRecord.res.header, theRes._header); t.equal(lastRecord.res.header, theRes._header);
server.close(); server.close();
t.end(); t.end();
}).on('error', function (err) { }).on('error', function (err) {
t.ok(false, 'error requesting to our test server: ' + err); t.ok(false, 'error requesting to our test server: ' + err);
server.close(); server.close();
t.end(); t.end();
});
}); });
});
}); });
test('err serializer', function (t) { test('err serializer', function (t) {
var records = []; var records = [];
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'serializer-test', name: 'serializer-test',
streams: [ streams: [
{ {
stream: new CapturingStream(records), stream: new CapturingStream(records),
type: 'raw' type: 'raw'
} }
], ],
serializers: { serializers: {
err: bunyan.stdSerializers.err err: bunyan.stdSerializers.err
}
});
// None of these should blow up.
var bogusErrs = [
undefined,
null,
{},
1,
'string',
[1, 2, 3],
{'foo':'bar'}
];
for (var i = 0; i < bogusErrs.length; i++) {
log.info({err: bogusErrs[i]}, 'hi');
t.equal(records[i].err, bogusErrs[i]);
} }
});
// None of these should blow up. var theErr = new TypeError('blah');
var bogusErrs = [
undefined,
null,
{},
1,
'string',
[1, 2, 3],
{'foo':'bar'}
];
for (var i = 0; i < bogusErrs.length; i++) {
log.info({err: bogusErrs[i]}, 'hi');
t.equal(records[i].err, bogusErrs[i]);
}
var theErr = new TypeError('blah'); log.info(theErr, 'the error');
var lastRecord = records[records.length-1];
log.info(theErr, 'the error'); t.equal(lastRecord.err.message, theErr.message);
var lastRecord = records[records.length-1]; t.equal(lastRecord.err.name, theErr.name);
t.equal(lastRecord.err.message, theErr.message); t.equal(lastRecord.err.stack, theErr.stack);
t.equal(lastRecord.err.name, theErr.name); t.end();
t.equal(lastRecord.err.stack, theErr.stack);
t.end();
}); });
test('err serializer: long stack', function (t) { test('err serializer: long stack', function (t) {
var records = []; var records = [];
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'serializer-test', name: 'serializer-test',
streams: [ { streams: [ {
stream: new CapturingStream(records), stream: new CapturingStream(records),
type: 'raw' type: 'raw'
} ], } ],
serializers: { serializers: {
err: bunyan.stdSerializers.err err: bunyan.stdSerializers.err
} }
}); });
var topErr, midErr, bottomErr; var topErr, midErr, bottomErr;
// Just a VError. // Just a VError.
topErr = new verror.VError('top err'); topErr = new verror.VError('top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'Just a VError'); t.equal(lastRecord.err.message, topErr.message, 'Just a VError');
t.equal(lastRecord.err.name, topErr.name, 'Just a VError'); t.equal(lastRecord.err.name, topErr.name, 'Just a VError');
t.equal(lastRecord.err.stack, topErr.stack, 'Just a VError'); t.equal(lastRecord.err.stack, topErr.stack, 'Just a VError');
// Just a WError. // Just a WError.
topErr = new verror.WError('top err'); topErr = new verror.WError('top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'Just a WError'); t.equal(lastRecord.err.message, topErr.message, 'Just a WError');
t.equal(lastRecord.err.name, topErr.name, 'Just a WError'); t.equal(lastRecord.err.name, topErr.name, 'Just a WError');
t.equal(lastRecord.err.stack, topErr.stack, 'Just a WError'); t.equal(lastRecord.err.stack, topErr.stack, 'Just a WError');
// WError <- TypeError // WError <- TypeError
bottomErr = new TypeError('bottom err'); bottomErr = new TypeError('bottom err');
topErr = new verror.WError(bottomErr, 'top err'); topErr = new verror.WError(bottomErr, 'top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'WError <- TypeError'); t.equal(lastRecord.err.message, topErr.message, 'WError <- TypeError');
t.equal(lastRecord.err.name, topErr.name, 'WError <- TypeError'); t.equal(lastRecord.err.name, topErr.name, 'WError <- TypeError');
var expectedStack = topErr.stack + '\nCaused by: ' + bottomErr.stack; var expectedStack = topErr.stack + '\nCaused by: ' + bottomErr.stack;
t.equal(lastRecord.err.stack, expectedStack, 'WError <- TypeError'); t.equal(lastRecord.err.stack, expectedStack, 'WError <- TypeError');
// WError <- WError // WError <- WError
bottomErr = new verror.WError('bottom err'); bottomErr = new verror.WError('bottom err');
topErr = new verror.WError(bottomErr, 'top err'); topErr = new verror.WError(bottomErr, 'top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'WError <- WError'); t.equal(lastRecord.err.message, topErr.message, 'WError <- WError');
t.equal(lastRecord.err.name, topErr.name, 'WError <- WError'); t.equal(lastRecord.err.name, topErr.name, 'WError <- WError');
var expectedStack = topErr.stack + '\nCaused by: ' + bottomErr.stack; var expectedStack = topErr.stack + '\nCaused by: ' + bottomErr.stack;
t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError'); t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError');
// WError <- WError <- TypeError // WError <- WError <- TypeError
bottomErr = new TypeError('bottom err'); bottomErr = new TypeError('bottom err');
midErr = new verror.WError(bottomErr, 'mid err'); midErr = new verror.WError(bottomErr, 'mid err');
topErr = new verror.WError(midErr, 'top err'); topErr = new verror.WError(midErr, 'top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'WError <- WError <- TypeError'); t.equal(lastRecord.err.message, topErr.message, 'WError <- WError <- TypeError');
t.equal(lastRecord.err.name, topErr.name, 'WError <- WError <- TypeError'); t.equal(lastRecord.err.name, topErr.name, 'WError <- WError <- TypeError');
var expectedStack = (topErr.stack var expectedStack = (topErr.stack
+ '\nCaused by: ' + midErr.stack + '\nCaused by: ' + midErr.stack
+ '\nCaused by: ' + bottomErr.stack); + '\nCaused by: ' + bottomErr.stack);
t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError <- TypeError'); t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError <- TypeError');
// WError <- WError <- WError // WError <- WError <- WError
bottomErr = new verror.WError('bottom err'); bottomErr = new verror.WError('bottom err');
midErr = new verror.WError(bottomErr, 'mid err'); midErr = new verror.WError(bottomErr, 'mid err');
topErr = new verror.WError(midErr, 'top err'); topErr = new verror.WError(midErr, 'top err');
log.info(topErr, 'the error'); log.info(topErr, 'the error');
var lastRecord = records[records.length-1]; var lastRecord = records[records.length-1];
t.equal(lastRecord.err.message, topErr.message, 'WError <- WError <- WError'); t.equal(lastRecord.err.message, topErr.message, 'WError <- WError <- WError');
t.equal(lastRecord.err.name, topErr.name, 'WError <- WError <- WError'); t.equal(lastRecord.err.name, topErr.name, 'WError <- WError <- WError');
var expectedStack = (topErr.stack var expectedStack = (topErr.stack
+ '\nCaused by: ' + midErr.stack + '\nCaused by: ' + midErr.stack
+ '\nCaused by: ' + bottomErr.stack); + '\nCaused by: ' + bottomErr.stack);
t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError <- WError'); t.equal(lastRecord.err.stack, expectedStack, 'WError <- WError <- WError');
t.end(); t.end();
}); });
@ -266,28 +266,28 @@ test('err serializer: long stack', function (t) {
// even if the log record doesn't have the associated key. That means // even if the log record doesn't have the associated key. That means
// serializers that don't handle an `undefined` value will blow up. // serializers that don't handle an `undefined` value will blow up.
test('do not apply serializers if no record key', function (t) { test('do not apply serializers if no record key', function (t) {
var records = []; var records = [];
var log = bunyan.createLogger({ var log = bunyan.createLogger({
name: 'serializer-test', name: 'serializer-test',
streams: [ { streams: [ {
stream: new CapturingStream(records), stream: new CapturingStream(records),
type: 'raw' type: 'raw'
} ], } ],
serializers: { serializers: {
err: bunyan.stdSerializers.err, err: bunyan.stdSerializers.err,
boom: function (value) { boom: function (value) {
throw new Error('boom'); throw new Error('boom');
} }
} }
}); });
log.info({foo: 'bar'}, 'record one'); log.info({foo: 'bar'}, 'record one');
log.info({err: new Error('record two err')}, 'record two'); log.info({err: new Error('record two err')}, 'record two');
t.equal(records[0].boom, undefined); t.equal(records[0].boom, undefined);
t.equal(records[0].foo, 'bar'); t.equal(records[0].foo, 'bar');
t.equal(records[1].boom, undefined); t.equal(records[1].boom, undefined);
t.equal(records[1].err.message, 'record two err'); t.equal(records[1].err.message, 'record two err');
t.end(); t.end();
}); });

View file

@ -18,45 +18,45 @@
module.exports = { module.exports = {
after: function after(teardown) { after: function after(teardown) {
module.parent.exports.tearDown = function _teardown(callback) { module.parent.exports.tearDown = function _teardown(callback) {
try { try {
teardown.call(this, callback); teardown.call(this, callback);
} catch (e) { } catch (e) {
console.error('after:\n' + e.stack); console.error('after:\n' + e.stack);
process.exit(1); process.exit(1);
} }
}; };
}, },
before: function before(setup) { before: function before(setup) {
module.parent.exports.setUp = function _setup(callback) { module.parent.exports.setUp = function _setup(callback) {
try { try {
setup.call(this, callback); setup.call(this, callback);
} catch (e) { } catch (e) {
console.error('before:\n' + e.stack); console.error('before:\n' + e.stack);
process.exit(1); process.exit(1);
} }
}; };
}, },
test: function test(name, tester) { test: function test(name, tester) {
module.parent.exports[name] = function _(t) { module.parent.exports[name] = function _(t) {
var _done = false; var _done = false;
t.end = function end() { t.end = function end() {
if (!_done) { if (!_done) {
_done = true; _done = true;
t.done(); t.done();
} }
}; };
t.notOk = function notOk(ok, message) { t.notOk = function notOk(ok, message) {
return (t.ok(!ok, message)); return (t.ok(!ok, message));
}; };
t.error = t.ifError; t.error = t.ifError;
tester.call(this, t); tester.call(this, t);
}; };
} }
}; };

View file

@ -17,68 +17,68 @@ var ben = require('ben'); // npm install ben
var Logger = require('../lib/bunyan'); var Logger = require('../lib/bunyan');
var log = new Logger({ var log = new Logger({
name: 'svc', name: 'svc',
streams: [ streams: [
{ {
path: __dirname + '/timechild.log' path: __dirname + '/timechild.log'
}, },
{ {
stream: process.stdout stream: process.stdout
}
],
serializers: {
err: Logger.stdSerializers.err
} }
],
serializers: {
err: Logger.stdSerializers.err
}
}); });
console.log('Time `log.child`:'); console.log('Time `log.child`:');
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
var child = log.child(); var child = log.child();
}); });
console.log(' - adding no fields: %dms per iteration', ms); console.log(' - adding no fields: %dms per iteration', ms);
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
var child = log.child({a:1}); var child = log.child({a:1});
}); });
console.log(' - adding one field: %dms per iteration', ms); console.log(' - adding one field: %dms per iteration', ms);
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
var child = log.child({a:1, b:2}); var child = log.child({a:1, b:2});
}); });
console.log(' - adding two fields: %dms per iteration', ms); console.log(' - adding two fields: %dms per iteration', ms);
function fooSerializer(obj) { function fooSerializer(obj) {
return {bar: obj.bar}; return {bar: obj.bar};
} }
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
var child = log.child({ var child = log.child({
a: 1, a: 1,
serializers: {foo: fooSerializer} serializers: {foo: fooSerializer}
}); });
}); });
console.log(' - adding serializer and one field: %dms per iteration', ms); console.log(' - adding serializer and one field: %dms per iteration', ms);
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
var child = log.child({ var child = log.child({
a: 1, a: 1,
streams: [ {stream: process.stderr} ] streams: [ {stream: process.stderr} ]
}); });
}); });
console.log(' - adding a (stderr) stream and one field: %dms per iteration', console.log(' - adding a (stderr) stream and one field: %dms per iteration',
ms); ms);
var ms = ben(1e6, function () { var ms = ben(1e6, function () {
var child = log.child({}, true); var child = log.child({}, true);
}); });
console.log(' - [fast] adding no fields: %dms per iteration', ms); console.log(' - [fast] adding no fields: %dms per iteration', ms);
var ms = ben(1e6, function () { var ms = ben(1e6, function () {
var child = log.child({a:1}, true); var child = log.child({a:1}, true);
}); });
console.log(' - [fast] adding one field: %dms per iteration', ms); console.log(' - [fast] adding one field: %dms per iteration', ms);
var ms = ben(1e6, function () { var ms = ben(1e6, function () {
var child = log.child({a:1, b:2}, true); var child = log.child({a:1, b:2}, true);
}); });
console.log(' - [fast] adding two fields: %dms per iteration', ms); console.log(' - [fast] adding two fields: %dms per iteration', ms);

View file

@ -12,17 +12,17 @@ var records = [];
function Collector() { function Collector() {
} }
Collector.prototype.write = function (s) { Collector.prototype.write = function (s) {
//records.push(s); //records.push(s);
} }
var collector = new Collector(); var collector = new Collector();
var log = new Logger({ var log = new Logger({
name: 'timeguard', name: 'timeguard',
src: true, src: true,
stream: collector stream: collector
}); });
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
log.info('hi'); log.info('hi');
}); });
console.log(' - log.info: %dms per iteration', ms); console.log(' - log.info: %dms per iteration', ms);

View file

@ -12,26 +12,26 @@ var records = [];
function Collector() { function Collector() {
} }
Collector.prototype.write = function (s) { Collector.prototype.write = function (s) {
//records.push(s); //records.push(s);
} }
var collector = new Collector(); var collector = new Collector();
var logwith = new Logger({ var logwith = new Logger({
name: 'with-src', name: 'with-src',
src: true, src: true,
stream: collector stream: collector
}); });
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
logwith.info('hi'); logwith.info('hi');
}); });
console.log(' - log.info with src: %dms per iteration', ms); console.log(' - log.info with src: %dms per iteration', ms);
var logwithout = new Logger({ var logwithout = new Logger({
name: 'without-src', name: 'without-src',
stream: collector stream: collector
}); });
var ms = ben(1e5, function () { var ms = ben(1e5, function () {
logwithout.info('hi'); logwithout.info('hi');
}); });
console.log(' - log.info without src: %dms per iteration', ms); console.log(' - log.info without src: %dms per iteration', ms);