0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-31 09:14:20 -04:00
denoland-deno/cli/tests/unit/error_stack_test.ts
Bartek Iwańczuk f91fa16661
refactor(core): stack trace mapping (#8660)
This commit adds "Deno.core.createPrepareStackTrace". This function
was moved from "cli/rt/40_error_stack.js" to unify handling of stack frames in core
(before this PR there was implicit dependency on logic in "core/error.rs::JsError").
Unfortunately formatting logic must still be duplicated in "cli/error.js::PrettyJsError"
to provide coloring, but currently there's no solution to this problem.
"createPrepareStackTrace" can accept a single argument; a function that takes
a location and provides source mapped location back.
2020-12-10 14:45:41 +01:00

68 lines
1.8 KiB
TypeScript

// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { assert, assertEquals, assertMatch, unitTest } from "./test_util.ts";
unitTest(function errorStackMessageLine(): void {
const e1 = new Error();
e1.name = "Foo";
e1.message = "bar";
assertMatch(e1.stack!, /^Foo: bar\n/);
const e2 = new Error();
e2.name = "";
e2.message = "bar";
assertMatch(e2.stack!, /^bar\n/);
const e3 = new Error();
e3.name = "Foo";
e3.message = "";
assertMatch(e3.stack!, /^Foo\n/);
const e4 = new Error();
e4.name = "";
e4.message = "";
assertMatch(e4.stack!, /^\n/);
const e5 = new Error();
// deno-lint-ignore ban-ts-comment
// @ts-expect-error
e5.name = undefined;
// deno-lint-ignore ban-ts-comment
// @ts-expect-error
e5.message = undefined;
assertMatch(e5.stack!, /^Error\n/);
const e6 = new Error();
// deno-lint-ignore ban-ts-comment
// @ts-expect-error
e6.name = null;
// deno-lint-ignore ban-ts-comment
// @ts-expect-error
e6.message = null;
assertMatch(e6.stack!, /^null: null\n/);
});
unitTest(function captureStackTrace(): void {
function foo(): void {
const error = new Error();
const stack1 = error.stack!;
Error.captureStackTrace(error, foo);
const stack2 = error.stack!;
// stack2 should be stack1 without the first frame.
assertEquals(stack2, stack1.replace(/(?<=^[^\n]*\n)[^\n]*\n/, ""));
}
foo();
});
// FIXME(bartlomieju): no longer works after migrating
// to JavaScript runtime code
unitTest({ ignore: true }, function applySourceMap(): void {
const result = Deno.applySourceMap({
fileName: "CLI_SNAPSHOT.js",
lineNumber: 23,
columnNumber: 0,
});
Deno.core.print(`result: ${result}`, true);
assert(result.fileName.endsWith(".ts"));
assert(result.lineNumber != null);
assert(result.columnNumber != null);
});