openmct/platform/framework/test/LogLevelSpec.js

105 lines
4.0 KiB
JavaScript
Raw Normal View History

/*****************************************************************************
* Open MCT Web, Copyright (c) 2014-2015, United States Government
* as represented by the Administrator of the National Aeronautics and Space
* Administration. All rights reserved.
*
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* Open MCT Web includes source code licensed under additional open source
* licenses. See the Open Source Licenses file (LICENSES.md) included with
* this source code distribution or the Licensing information page available
* at runtime from the About dialog for additional information.
*****************************************************************************/
/*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);
});
});
});
}
);