1 Star 0 Fork 0

animalcoder/Vue

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
console-fallback-test.js 3.18 KB
一键复制 编辑 原始数据 按行查看 历史
animalcoder 提交于 2020-03-17 14:52 +08:00 . Vueinit
"use strict";
function consoleLogIsCalledBy(log, methodName) {
it(methodName + " calls console.log", function() {
log.setLevel(log.levels.TRACE);
log[methodName]("Log message for call to " + methodName);
expect(console.log.calls.length).toEqual(1);
});
}
function mockConsole() {
return {"log" : jasmine.createSpy("console.log")};
}
define(['../lib/loglevel'], function(log) {
var originalConsole = window.console;
describe("Fallback functionality:", function() {
describe("with no console present", function() {
beforeEach(function() {
window.console = undefined;
});
afterEach(function() {
window.console = originalConsole;
});
it("silent method calls are allowed", function() {
var result = log.setLevel(log.levels.SILENT);
log.trace("hello");
expect(result).toBeUndefined();
});
it("setting an active level gently returns an error string", function() {
var result = log.setLevel(log.levels.TRACE);
expect(result).toEqual("No console available for logging");
});
it("active method calls are allowed, once the active setLevel fails", function() {
log.setLevel(log.levels.TRACE);
log.trace("hello");
});
describe("if a console later appears", function () {
it("logging is re-enabled and works correctly when next used", function () {
log.setLevel(log.levels.WARN);
window.console = mockConsole();
log.error("error");
expect(window.console.log).toHaveBeenCalled();
});
it("logging is re-enabled but does nothing when used at a blocked level", function () {
log.setLevel(log.levels.WARN);
window.console = mockConsole();
log.trace("trace");
expect(window.console.log).not.toHaveBeenCalled();
});
it("changing level works correctly from that point", function () {
window.console = mockConsole();
var result = log.setLevel(log.levels.WARN);
expect(result).toBeUndefined();
});
});
});
describe("with a console that only supports console.log", function() {
beforeEach(function() {
window.console = mockConsole();
});
afterEach(function() {
window.console = originalConsole;
});
it("log can be set to silent", function() {
log.setLevel(log.levels.SILENT);
});
it("log can be set to an active level", function() {
log.setLevel(log.levels.ERROR);
});
consoleLogIsCalledBy(log, "trace");
consoleLogIsCalledBy(log, "debug");
consoleLogIsCalledBy(log, "info");
consoleLogIsCalledBy(log, "warn");
consoleLogIsCalledBy(log, "trace");
});
});
});
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/animalcoder/Vue.git
git@gitee.com:animalcoder/Vue.git
animalcoder
Vue
Vue
master

搜索帮助