2018-08-27 14:59:38 -04:00
|
|
|
// Copyright 2018 the Deno authors. All rights reserved. MIT license.
|
2018-10-01 12:41:37 -04:00
|
|
|
import { test, assert, assertEqual } from "./test_util.ts";
|
2018-08-27 14:59:38 -04:00
|
|
|
import { stringifyArgs } from "./console.ts";
|
|
|
|
|
|
|
|
// tslint:disable-next-line:no-any
|
|
|
|
function stringify(...args: any[]): string {
|
|
|
|
return stringifyArgs(args);
|
|
|
|
}
|
|
|
|
|
|
|
|
test(function consoleTestAssert() {
|
|
|
|
console.assert(true);
|
|
|
|
|
|
|
|
let hasThrown = false;
|
|
|
|
try {
|
|
|
|
console.assert(false);
|
|
|
|
} catch {
|
|
|
|
hasThrown = true;
|
|
|
|
}
|
|
|
|
assertEqual(hasThrown, true);
|
|
|
|
});
|
|
|
|
|
|
|
|
test(function consoleTestStringifyComplexObjects() {
|
|
|
|
assertEqual(stringify("foo"), "foo");
|
|
|
|
assertEqual(stringify(["foo", "bar"]), `[ "foo", "bar" ]`);
|
|
|
|
assertEqual(stringify({ foo: "bar" }), `{ foo: "bar" }`);
|
|
|
|
});
|
|
|
|
|
|
|
|
test(function consoleTestStringifyCircular() {
|
|
|
|
class Base {
|
|
|
|
a = 1;
|
|
|
|
m1() {}
|
|
|
|
}
|
|
|
|
|
|
|
|
class Extended extends Base {
|
|
|
|
b = 2;
|
|
|
|
m2() {}
|
|
|
|
}
|
|
|
|
|
|
|
|
// tslint:disable-next-line:no-any
|
|
|
|
const nestedObj: any = {
|
|
|
|
num: 1,
|
|
|
|
bool: true,
|
|
|
|
str: "a",
|
|
|
|
method() {},
|
2018-09-24 10:06:48 -04:00
|
|
|
async asyncMethod() {},
|
|
|
|
*generatorMethod() {},
|
2018-08-27 14:59:38 -04:00
|
|
|
un: undefined,
|
|
|
|
nu: null,
|
|
|
|
arrowFunc: () => {},
|
|
|
|
extendedClass: new Extended(),
|
|
|
|
nFunc: new Function(),
|
|
|
|
extendedCstr: Extended
|
|
|
|
};
|
|
|
|
|
|
|
|
const circularObj = {
|
|
|
|
num: 2,
|
|
|
|
bool: false,
|
|
|
|
str: "b",
|
|
|
|
method() {},
|
|
|
|
un: undefined,
|
|
|
|
nu: null,
|
|
|
|
nested: nestedObj,
|
|
|
|
emptyObj: {},
|
|
|
|
arr: [1, "s", false, null, nestedObj],
|
|
|
|
baseClass: new Base()
|
|
|
|
};
|
|
|
|
|
|
|
|
nestedObj.o = circularObj;
|
2018-10-05 10:20:10 -04:00
|
|
|
// tslint:disable-next-line:max-line-length
|
2018-09-30 18:10:20 -04:00
|
|
|
const nestedObjExpected = `{ num: 1, bool: true, str: "a", method: [Function: method], asyncMethod: [AsyncFunction: asyncMethod], generatorMethod: [GeneratorFunction: generatorMethod], un: undefined, nu: null, arrowFunc: [Function: arrowFunc], extendedClass: Extended { a: 1, b: 2 }, nFunc: [Function], extendedCstr: [Function: Extended], o: { num: 2, bool: false, str: "b", method: [Function: method], un: undefined, nu: null, nested: [Circular], emptyObj: [object], arr: [object], baseClass: [object] } }`;
|
2018-08-27 14:59:38 -04:00
|
|
|
|
|
|
|
assertEqual(stringify(1), "1");
|
2018-11-30 19:59:41 -05:00
|
|
|
assertEqual(stringify(1n), "1n");
|
2018-08-27 14:59:38 -04:00
|
|
|
assertEqual(stringify("s"), "s");
|
|
|
|
assertEqual(stringify(false), "false");
|
|
|
|
assertEqual(stringify(Symbol(1)), "Symbol(1)");
|
|
|
|
assertEqual(stringify(null), "null");
|
|
|
|
assertEqual(stringify(undefined), "undefined");
|
|
|
|
assertEqual(stringify(new Extended()), "Extended { a: 1, b: 2 }");
|
|
|
|
assertEqual(stringify(function f() {}), "[Function: f]");
|
2018-09-24 10:06:48 -04:00
|
|
|
assertEqual(stringify(async function af() {}), "[AsyncFunction: af]");
|
|
|
|
assertEqual(stringify(function* gf() {}), "[GeneratorFunction: gf]");
|
|
|
|
assertEqual(
|
|
|
|
stringify(async function* agf() {}),
|
|
|
|
"[AsyncGeneratorFunction: agf]"
|
|
|
|
);
|
2018-08-27 14:59:38 -04:00
|
|
|
assertEqual(stringify(nestedObj), nestedObjExpected);
|
|
|
|
assertEqual(stringify(JSON), "{}");
|
2018-08-27 20:00:54 -04:00
|
|
|
assertEqual(
|
|
|
|
stringify(console),
|
2018-10-05 07:29:55 -04:00
|
|
|
// tslint:disable-next-line:max-line-length
|
2018-10-01 12:41:37 -04:00
|
|
|
"Console { printFunc: [Function], log: [Function], debug: [Function], info: [Function], dir: [Function], warn: [Function], error: [Function], assert: [Function] }"
|
2018-08-27 20:00:54 -04:00
|
|
|
);
|
2018-08-27 14:59:38 -04:00
|
|
|
});
|
2018-09-26 12:44:59 -04:00
|
|
|
|
2018-09-30 18:10:20 -04:00
|
|
|
test(function consoleTestStringifyWithDepth() {
|
2018-10-05 10:20:10 -04:00
|
|
|
// tslint:disable-next-line:no-any
|
2018-09-30 18:10:20 -04:00
|
|
|
const nestedObj: any = { a: { b: { c: { d: { e: { f: 42 } } } } } };
|
|
|
|
assertEqual(
|
|
|
|
stringifyArgs([nestedObj], { depth: 3 }),
|
|
|
|
"{ a: { b: { c: [object] } } }"
|
|
|
|
);
|
|
|
|
assertEqual(
|
|
|
|
stringifyArgs([nestedObj], { depth: 4 }),
|
|
|
|
"{ a: { b: { c: { d: [object] } } } }"
|
|
|
|
);
|
|
|
|
assertEqual(stringifyArgs([nestedObj], { depth: 0 }), "[object]");
|
|
|
|
assertEqual(
|
|
|
|
stringifyArgs([nestedObj], { depth: null }),
|
|
|
|
"{ a: { b: [object] } }"
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2018-09-26 12:44:59 -04:00
|
|
|
test(function consoleTestError() {
|
|
|
|
class MyError extends Error {
|
2018-10-03 21:18:23 -04:00
|
|
|
constructor(errStr: string) {
|
|
|
|
super(errStr);
|
2018-09-26 12:44:59 -04:00
|
|
|
this.name = "MyError";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
throw new MyError("This is an error");
|
|
|
|
} catch (e) {
|
|
|
|
assertEqual(stringify(e).split("\n")[0], "MyError: This is an error");
|
|
|
|
}
|
|
|
|
});
|
2018-10-01 12:41:37 -04:00
|
|
|
|
|
|
|
// Test bound this issue
|
|
|
|
test(function consoleDetachedLog() {
|
|
|
|
const log = console.log;
|
|
|
|
const dir = console.dir;
|
|
|
|
const debug = console.debug;
|
|
|
|
const info = console.info;
|
|
|
|
const warn = console.warn;
|
|
|
|
const error = console.error;
|
|
|
|
const consoleAssert = console.assert;
|
|
|
|
log("Hello world");
|
|
|
|
dir("Hello world");
|
|
|
|
debug("Hello world");
|
|
|
|
info("Hello world");
|
|
|
|
warn("Hello world");
|
|
|
|
error("Hello world");
|
|
|
|
consoleAssert(true);
|
|
|
|
});
|