UNPKG

3.4 kBJavaScriptView Raw
1"use strict";
2
3function consoleLogIsCalledBy(log, methodName) {
4 it(methodName + " calls console.log", function() {
5 log.setLevel(log.levels.TRACE);
6 log[methodName]("Log message for call to " + methodName);
7 expect(console.log.calls.count()).toEqual(1);
8 });
9}
10
11function mockConsole() {
12 return {"log" : jasmine.createSpy("console.log")};
13}
14
15define(['../lib/loglevel', 'test/test-helpers'], function(log, testHelpers) {
16 var originalConsole = window.console;
17
18 describe("Fallback functionality:", function() {
19 describe("with no console present", function() {
20 beforeEach(function() {
21 window.console = undefined;
22 });
23
24 afterEach(function() {
25 window.console = originalConsole;
26 });
27
28 it("silent method calls are allowed", function() {
29 var result = log.setLevel(log.levels.SILENT);
30 log.trace("hello");
31
32 expect(result).toBeUndefined();
33 });
34
35 it("setting an active level gently returns an error string", function() {
36 var result = log.setLevel(log.levels.TRACE);
37 expect(result).toEqual("No console available for logging");
38 });
39
40 it("active method calls are allowed, once the active setLevel fails", function() {
41 log.setLevel(log.levels.TRACE);
42 log.trace("hello");
43 expect().nothing();
44 });
45
46 describe("if a console later appears", function () {
47 it("logging is re-enabled and works correctly when next used", function () {
48 log.setLevel(log.levels.WARN);
49
50 window.console = mockConsole();
51 log.error("error");
52
53 expect(window.console.log).toHaveBeenCalled();
54 });
55
56 it("logging is re-enabled but does nothing when used at a blocked level", function () {
57 log.setLevel(log.levels.WARN);
58
59 window.console = mockConsole();
60 log.trace("trace");
61
62 expect(window.console.log).not.toHaveBeenCalled();
63 });
64
65 it("changing level works correctly from that point", function () {
66 window.console = mockConsole();
67 var result = log.setLevel(log.levels.WARN);
68
69 expect(result).toBeUndefined();
70 });
71 });
72 });
73
74 describe("with a console that only supports console.log", function() {
75 beforeEach(function() {
76 window.console = mockConsole();
77 });
78
79 afterEach(function() {
80 window.console = originalConsole;
81 });
82
83 it("log can be set to silent", function() {
84 log.setLevel(log.levels.SILENT);
85 expect().nothing();
86 });
87
88 it("log can be set to an active level", function() {
89 log.setLevel(log.levels.ERROR);
90 expect().nothing();
91 });
92
93 consoleLogIsCalledBy(log, "trace");
94 consoleLogIsCalledBy(log, "debug");
95 consoleLogIsCalledBy(log, "info");
96 consoleLogIsCalledBy(log, "warn");
97 consoleLogIsCalledBy(log, "trace");
98 });
99 });
100});
101