You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
640 B
JavaScript
38 lines
640 B
JavaScript
'use strict';
|
|
|
|
const winston = require('winston');
|
|
const Transport = require('winston-transport');
|
|
|
|
const winstonLogged = [];
|
|
|
|
class DeferLogger extends Transport {
|
|
constructor(opts) {
|
|
super(opts);
|
|
this.logged = opts.logged;
|
|
}
|
|
|
|
log(info, callback) {
|
|
setImmediate(() => {
|
|
this.emit('logged', info);
|
|
});
|
|
|
|
this.logged.push([info.level, info.message]);
|
|
callback();
|
|
}
|
|
}
|
|
|
|
before(() => {
|
|
// defer winston logs until the end
|
|
winston.clear();
|
|
|
|
winston.add(new DeferLogger({ logged: winstonLogged }));
|
|
});
|
|
|
|
after(() => {
|
|
console.log('\n\n');
|
|
|
|
winstonLogged.forEach((args) => {
|
|
console.log(`${args[0]} ${args[1]}`);
|
|
});
|
|
});
|