/***************************************************************************** * Open MCT, Copyright (c) 2014-2020, United States Government * as represented by the Administrator of the National Aeronautics and Space * Administration. All rights reserved. * * Open MCT 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 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. *****************************************************************************/ define( ['../src/LogLevel'], function (LogLevel) { var LOG_METHODS = [ 'error', 'warn', 'info', 'log', 'debug' ]; describe("The logging level handler", function () { var mockLog, mockApp, 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', 'decorator']); mockDelegate = jasmine.createSpyObj('$delegate', LOG_METHODS); LOG_METHODS.forEach(function (m) { mockLog[m].and.callFake(mockMethods[m]); mockDelegate[m].and.callFake(mockMethods[m]); }); mockApp.decorator.and.callFake(function (key, decoration) { // We only expect $log to be decorated if (key === '$log' && decoration[0] === '$delegate') { decoration[1](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); }); }); }); } );