logger component tests

master
Meir Rotstein 2017-11-19 11:23:56 +02:00
parent 91374acba3
commit b0e28ee344
2 changed files with 104 additions and 0 deletions

View File

@ -8,3 +8,4 @@ globals:
it: false
before: false
beforeEach: false
afterEach: false

103
spec/logger.spec.js Normal file
View File

@ -0,0 +1,103 @@
'use strict';
var logger = require('../lib/compile/logger')
, should = require('./chai').should();
describe('logger object tests', function() {
var origConsoleWarn = console.warn;
var origConsoleLog = console.log;
var origConsoleError = console.error;
var consoleWarnCalled = false;
var consoleLogCalled = false;
var consoleErrorCalled = false;
beforeEach(function() {
console.warn = function() {
consoleWarnCalled = true;
origConsoleWarn.apply(console, arguments);
};
console.log = function() {
consoleLogCalled = true;
origConsoleLog.apply(console, arguments);
};
console.error = function() {
consoleErrorCalled = true;
origConsoleError.apply(console, arguments);
return 'boo';
};
});
afterEach(function() {
console.warn = origConsoleWarn;
console.log = origConsoleLog;
console.error = origConsoleError;
logger.reset();
consoleErrorCalled = consoleLogCalled = consoleWarnCalled = false;
});
it('logger should log into global console by default', function() {
logger.log('42');
logger.warn('42');
logger.error('42');
should.equal(consoleWarnCalled, true);
should.equal(consoleLogCalled, true);
should.equal(consoleErrorCalled, true);
});
it('logger should log only into a custom logger if given console by default', function() {
var customWarnCalled = false;
var customLogCalled = false;
var customErrorCalled = false;
var customLogger = {
warn: function() {
customWarnCalled = true;
},
log: function() {
customLogCalled = true;
},
error: function() {
customErrorCalled = true;
}
};
logger.set(customLogger);
logger.log('42');
logger.warn('42');
logger.error('42');
should.equal(consoleWarnCalled, false);
should.equal(consoleLogCalled, false);
should.equal(consoleErrorCalled, false);
should.equal(customWarnCalled, true);
should.equal(customLogCalled, true);
should.equal(customErrorCalled, true);
});
it('if a custom logger is given without basic logging functions implementations it should not leads to an exception', function() {
logger.set({});
logger.log('42');
logger.warn('42');
logger.error('42');
should.equal(consoleWarnCalled, false);
should.equal(consoleLogCalled, false);
should.equal(consoleErrorCalled, false);
});
it('if a custom logger is set to null logging should be disabled', function() {
logger.set(null);
logger.log('42');
logger.warn('42');
logger.error('42');
should.equal(consoleWarnCalled, false);
should.equal(consoleLogCalled, false);
should.equal(consoleErrorCalled, false);
});
});