1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-08 07:00:10 +02:00
video.js/test/unit/utils/log.test.js
Gary Katsevman 966eb56c02
feat: createLogger for easier logging in individual modules (#5418)
Create a new createLogger module for better debugging. Each logger has its own log level and its own createLogger that will nest logs underneath them. `player.log` is also included, which logs the player id as part of the log statement. The history API also got a filter method.

For example:
```js
var log = videojs.log.createLogger('foo');
log('hello');
// > VIDEOJS: foo: hello
```
2018-09-28 16:52:58 -04:00

231 lines
7.2 KiB
JavaScript

/* eslint-env qunit */
import {IE_VERSION} from '../../../src/js/utils/browser';
import log from '../../../src/js/utils/log.js';
import window from 'global/window';
import sinon from 'sinon';
QUnit.module('utils/log', {
beforeEach() {
// Back up the original console.
this.originalConsole = window.console;
// Replace the native console for testing. In IE8 `console.log` is not a
// 'function' so sinon chokes on it when trying to spy:
// https://github.com/cjohansen/Sinon.JS/issues/386
//
// Instead we'll temporarily replace them with no-op functions
window.console = {
debug: sinon.spy(),
info: sinon.spy(),
log: sinon.spy(),
warn: sinon.spy(),
error: sinon.spy()
};
},
afterEach() {
// Restore the native/original console.
window.console = this.originalConsole;
// Restore the default logging level.
log.level(log.levels.DEFAULT);
// Empty the logger's history.
log.history.clear();
}
});
const getConsoleArgs = (...arr) =>
IE_VERSION && IE_VERSION < 11 ? [arr.join(' ')] : arr;
QUnit.test('logging functions should work', function(assert) {
// Need to reset history here because there are extra messages logged
// when running via Karma.
log.history.clear();
log('log1', 'log2');
log.debug('debug1', 'debug2');
log.warn('warn1', 'warn2');
log.error('error1', 'error2');
assert.ok(window.console.log.called, 'log was called');
assert.deepEqual(
window.console.log.firstCall.args,
getConsoleArgs('VIDEOJS:', 'log1', 'log2')
);
// debug isn't enabled by default
assert.notOk(window.console.debug.called, 'debug was not called');
assert.ok(window.console.warn.called, 'warn was called');
assert.deepEqual(
window.console.warn.firstCall.args,
getConsoleArgs('VIDEOJS:', 'WARN:', 'warn1', 'warn2')
);
assert.ok(window.console.error.called, 'error was called');
assert.deepEqual(
window.console.error.firstCall.args,
getConsoleArgs('VIDEOJS:', 'ERROR:', 'error1', 'error2')
);
const history = log.history();
assert.equal(history.length, 4, 'there should be four messages in the log history');
assert.deepEqual(
history[0],
['VIDEOJS:', 'log1', 'log2'],
'history recorded the correct arguments'
);
// although not enabled by default, history should still maintain the record
assert.deepEqual(
history[1],
['VIDEOJS:', 'DEBUG:', 'debug1', 'debug2'],
'history recorded the correct arguments'
);
assert.deepEqual(
history[2],
['VIDEOJS:', 'WARN:', 'warn1', 'warn2'],
'history recorded the correct arguments'
);
assert.deepEqual(
history[3],
['VIDEOJS:', 'ERROR:', 'error1', 'error2'],
'history recorded the correct arguments'
);
});
QUnit.test('setting the log level changes what is actually logged', function(assert) {
// Need to reset history here because there are extra messages logged
// when running via Karma.
log.history.clear();
log.level('error');
log('log1', 'log2');
log.warn('warn1', 'warn2');
log.error('error1', 'error2');
assert.notOk(window.console.log.called, 'console.log was not called');
assert.notOk(window.console.warn.called, 'console.warn was not called');
assert.ok(window.console.error.called, 'console.error was called');
const history = log.history();
assert.deepEqual(history[0], ['VIDEOJS:', 'log1', 'log2'], 'history is maintained even when logging is not performed');
assert.deepEqual(history[1], ['VIDEOJS:', 'WARN:', 'warn1', 'warn2'], 'history is maintained even when logging is not performed');
assert.deepEqual(history[2], ['VIDEOJS:', 'ERROR:', 'error1', 'error2'], 'history is maintained even when logging is not performed');
log.level('off');
log('log1', 'log2');
log.warn('warn1', 'warn2');
log.error('error1', 'error2');
assert.notOk(window.console.log.called, 'console.log was not called');
assert.notOk(window.console.warn.called, 'console.warn was not called');
assert.strictEqual(window.console.error.callCount, 1, 'console.error was not called again');
assert.throws(
() => log.level('foobar'),
new Error('"foobar" in not a valid log level'),
'log.level() only accepts valid log levels when used as a setter'
);
});
QUnit.test('history can be enabled/disabled', function(assert) {
// Need to reset history here because there are extra messages logged
// when running via Karma.
log.history.clear();
log.history.disable();
log('log1');
log.warn('warn1');
log.error('error1');
let history = log.history();
assert.strictEqual(history.length, 0, 'no history was tracked');
log.history.enable();
log('log1');
log.warn('warn1');
log.error('error1');
history = log.history();
assert.strictEqual(history.length, 3, 'history was tracked');
});
QUnit.test('supports debug logging', function(assert) {
// Need to reset history here because there are extra messages logged
// when running via Karma.
log.history.clear();
log.level('debug');
log('log1', 'log2');
log.debug('debug1', 'debug2');
log.warn('warn1', 'warn2');
log.error('error1', 'error2');
assert.ok(window.console.log.called, 'console.log was called');
assert.ok(window.console.debug.called, 'console.debug was called');
assert.ok(window.console.warn.called, 'console.warn was called');
assert.ok(window.console.error.called, 'console.error called');
const history = log.history();
assert.equal(history.length, 4, 'four messages in history');
assert.deepEqual(history[0], ['VIDEOJS:', 'log1', 'log2'], 'history is maintained');
assert.deepEqual(history[1], ['VIDEOJS:', 'DEBUG:', 'debug1', 'debug2'], 'history is maintained');
assert.deepEqual(history[2], ['VIDEOJS:', 'WARN:', 'warn1', 'warn2'], 'history is maintained');
assert.deepEqual(history[3], ['VIDEOJS:', 'ERROR:', 'error1', 'error2'], 'history is maintained');
});
QUnit.test('falls back to info and log when debug is not supported', function(assert) {
// Need to reset history here because there are extra messages logged
// when running via Karma.
log.history.clear();
log.level('debug');
window.console.debug = null;
log.debug('debug1', 'debug2');
assert.ok(window.console.info.called, 'info was called');
assert.notOk(window.console.log.called, 'log was not called');
assert.notOk(window.console.warn.called, 'warn was not called');
assert.notOk(window.console.error.called, 'error was not called');
assert.deepEqual(
window.console.info.firstCall.args,
getConsoleArgs('VIDEOJS:', 'DEBUG:', 'debug1', 'debug2'),
'logged the right message'
);
window.console.info = null;
log.debug('debug3', 'debug4');
assert.ok(window.console.log.called, 'log was called');
assert.notOk(window.console.warn.called, 'warn was not called');
assert.notOk(window.console.error.called, 'error was not called');
assert.deepEqual(
window.console.log.firstCall.args,
getConsoleArgs('VIDEOJS:', 'DEBUG:', 'debug3', 'debug4'),
'logged the right message'
);
// when no comparable level logs are available, there should not be any logging
window.console.log = null;
log.debug('debug5', 'debug6');
assert.notOk(window.console.warn.called, 'warn was not called');
assert.notOk(window.console.error.called, 'error was not called');
});