mirror of
https://github.com/nasa/openmct.git
synced 2025-02-20 17:33:23 +00:00
[Logging] Add spec for log levels
Add spec for log levels, to allow these to be passed at run-time in order to suppress logging during normal use. WTD-793.
This commit is contained in:
parent
dfba9fd510
commit
7b16428803
14
platform/framework/src/LogLevel.js
Normal file
14
platform/framework/src/LogLevel.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
/*global define*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
[],
|
||||||
|
function () {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
function LogLevel() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return LogLevel;
|
||||||
|
}
|
||||||
|
);
|
84
platform/framework/test/LogLevelSpec.js
Normal file
84
platform/framework/test/LogLevelSpec.js
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
/*global define,Promise,describe,it,expect,beforeEach,waitsFor,jasmine*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
['../src/LogLevel'],
|
||||||
|
function (LogLevel) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
var LOG_METHODS = [
|
||||||
|
'error',
|
||||||
|
'warn',
|
||||||
|
'info',
|
||||||
|
'log',
|
||||||
|
'debug'
|
||||||
|
];
|
||||||
|
|
||||||
|
describe("The logging level handler", function () {
|
||||||
|
var mockLog,
|
||||||
|
mockApp,
|
||||||
|
mockProvide,
|
||||||
|
mockDelegate,
|
||||||
|
mockMethods;
|
||||||
|
|
||||||
|
function logAll(v) {
|
||||||
|
LOG_METHODS.forEach(function (m) {
|
||||||
|
mockLog[m](v);
|
||||||
|
mockDelegate[m](v);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function expectCalls(calls, v) {
|
||||||
|
LOG_METHODS.forEach(function (m) {
|
||||||
|
if (calls.indexOf(m) > -1) {
|
||||||
|
expect(mockMethods[m]).toHaveBeenCalledWith(v);
|
||||||
|
} else {
|
||||||
|
expect(mockMethods[m]).not.toHaveBeenCalledWith(v);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
mockMethods = jasmine.createSpyObj("levels", LOG_METHODS);
|
||||||
|
mockLog = jasmine.createSpyObj('$log', LOG_METHODS);
|
||||||
|
mockApp = jasmine.createSpyObj('app', ['config']);
|
||||||
|
mockProvide = jasmine.createSpyObj('$provide', ['decorator']);
|
||||||
|
mockDelegate = jasmine.createSpyObj('$delegate', LOG_METHODS);
|
||||||
|
|
||||||
|
LOG_METHODS.forEach(function (m) {
|
||||||
|
mockLog[m].andCallFake(mockMethods[m]);
|
||||||
|
mockDelegate[m].andCallFake(mockMethods[m]);
|
||||||
|
});
|
||||||
|
|
||||||
|
mockApp.config.andCallFake(function (callback) {
|
||||||
|
callback(mockProvide);
|
||||||
|
});
|
||||||
|
|
||||||
|
mockProvide.decorator.andCallFake(function (key, callback) {
|
||||||
|
// Only $log should be configured in any case
|
||||||
|
expect(key).toEqual('$log');
|
||||||
|
callback(mockDelegate);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("defaults to 'warn' level", function () {
|
||||||
|
new LogLevel("garbage").configure(mockApp, mockLog);
|
||||||
|
logAll("test");
|
||||||
|
expectCalls(['error', 'warn'], 'test');
|
||||||
|
});
|
||||||
|
|
||||||
|
LOG_METHODS.forEach(function (m, i) {
|
||||||
|
it("supports log level '" + m + "'", function () {
|
||||||
|
// Note: This is sensitive to ordering of LOG_METHODS,
|
||||||
|
// which needs to be highest-level-first above.
|
||||||
|
var expected = LOG_METHODS.slice(0, i + 1),
|
||||||
|
message = "test " + m;
|
||||||
|
|
||||||
|
new LogLevel(m).configure(mockApp, mockLog);
|
||||||
|
logAll(message);
|
||||||
|
expectCalls(expected, message);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
@ -1,5 +1,6 @@
|
|||||||
[
|
[
|
||||||
"FrameworkInitializer",
|
"FrameworkInitializer",
|
||||||
|
"LogLevel",
|
||||||
"bootstrap/ApplicationBootstrapper",
|
"bootstrap/ApplicationBootstrapper",
|
||||||
"load/Bundle",
|
"load/Bundle",
|
||||||
"load/BundleLoader",
|
"load/BundleLoader",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user