2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2020-10-08 10:05:19 +01:00
|
|
|
import { assert, assertEquals, assertMatch, unitTest } from "./test_util.ts";
|
2019-07-29 19:11:08 +10:00
|
|
|
|
2020-05-27 00:02:16 +10:00
|
|
|
// @ts-expect-error TypeScript (as of 3.7) does not support indexing namespaces by symbol
|
2020-04-28 00:06:03 +01:00
|
|
|
const { setPrepareStackTrace } = Deno[Deno.internal];
|
2019-07-29 19:11:08 +10:00
|
|
|
|
|
|
|
interface CallSite {
|
|
|
|
getThis(): unknown;
|
2020-04-13 15:54:16 +01:00
|
|
|
getTypeName(): string | null;
|
2020-11-03 16:19:29 +01:00
|
|
|
// deno-lint-ignore ban-types
|
2020-04-13 15:54:16 +01:00
|
|
|
getFunction(): Function | null;
|
|
|
|
getFunctionName(): string | null;
|
|
|
|
getMethodName(): string | null;
|
|
|
|
getFileName(): string | null;
|
2019-07-29 19:11:08 +10:00
|
|
|
getLineNumber(): number | null;
|
|
|
|
getColumnNumber(): number | null;
|
|
|
|
getEvalOrigin(): string | null;
|
2020-04-13 15:54:16 +01:00
|
|
|
isToplevel(): boolean | null;
|
2019-07-29 19:11:08 +10:00
|
|
|
isEval(): boolean;
|
|
|
|
isNative(): boolean;
|
|
|
|
isConstructor(): boolean;
|
|
|
|
isAsync(): boolean;
|
|
|
|
isPromiseAll(): boolean;
|
|
|
|
getPromiseIndex(): number | null;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getMockCallSite(
|
2020-04-13 15:54:16 +01:00
|
|
|
fileName: string,
|
|
|
|
lineNumber: number | null,
|
2020-07-14 15:24:17 -04:00
|
|
|
columnNumber: number | null,
|
2019-07-29 19:11:08 +10:00
|
|
|
): CallSite {
|
|
|
|
return {
|
|
|
|
getThis(): unknown {
|
|
|
|
return undefined;
|
|
|
|
},
|
|
|
|
getTypeName(): string {
|
|
|
|
return "";
|
|
|
|
},
|
2020-11-03 16:19:29 +01:00
|
|
|
// deno-lint-ignore ban-types
|
2019-07-29 19:11:08 +10:00
|
|
|
getFunction(): Function {
|
|
|
|
return (): void => {};
|
|
|
|
},
|
|
|
|
getFunctionName(): string {
|
|
|
|
return "";
|
|
|
|
},
|
|
|
|
getMethodName(): string {
|
|
|
|
return "";
|
|
|
|
},
|
|
|
|
getFileName(): string {
|
2020-04-13 15:54:16 +01:00
|
|
|
return fileName;
|
2019-07-29 19:11:08 +10:00
|
|
|
},
|
|
|
|
getLineNumber(): number | null {
|
2020-04-13 15:54:16 +01:00
|
|
|
return lineNumber;
|
2019-07-29 19:11:08 +10:00
|
|
|
},
|
|
|
|
getColumnNumber(): number | null {
|
2020-04-13 15:54:16 +01:00
|
|
|
return columnNumber;
|
2019-07-29 19:11:08 +10:00
|
|
|
},
|
|
|
|
getEvalOrigin(): null {
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
isToplevel(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
isEval(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
isNative(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
isConstructor(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
isAsync(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
isPromiseAll(): false {
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
getPromiseIndex(): null {
|
|
|
|
return null;
|
2020-03-29 04:03:49 +11:00
|
|
|
},
|
2019-07-29 19:11:08 +10:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-10-08 10:05:19 +01:00
|
|
|
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/);
|
|
|
|
});
|
|
|
|
|
2020-07-19 19:49:44 +02:00
|
|
|
// FIXME(bartlomieju): no longer works after migrating
|
|
|
|
// to JavaScript runtime code
|
|
|
|
unitTest({ ignore: true }, function prepareStackTrace(): void {
|
2020-11-03 16:19:29 +01:00
|
|
|
// deno-lint-ignore no-explicit-any
|
2019-07-29 19:11:08 +10:00
|
|
|
const MockError = {} as any;
|
|
|
|
setPrepareStackTrace(MockError);
|
|
|
|
assert(typeof MockError.prepareStackTrace === "function");
|
|
|
|
const prepareStackTrace: (
|
|
|
|
error: Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
structuredStackTrace: CallSite[],
|
2019-07-29 19:11:08 +10:00
|
|
|
) => string = MockError.prepareStackTrace;
|
|
|
|
const result = prepareStackTrace(new Error("foo"), [
|
2020-03-29 04:03:49 +11:00
|
|
|
getMockCallSite("CLI_SNAPSHOT.js", 23, 0),
|
2019-07-29 19:11:08 +10:00
|
|
|
]);
|
|
|
|
assert(result.startsWith("Error: foo\n"));
|
2020-06-05 11:37:40 -04:00
|
|
|
assert(result.includes(".ts:"), "should remap to something in 'js/'");
|
2019-07-29 19:11:08 +10:00
|
|
|
});
|
|
|
|
|
2020-05-29 13:02:36 +01:00
|
|
|
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();
|
|
|
|
});
|
|
|
|
|
2020-07-19 19:49:44 +02:00
|
|
|
// FIXME(bartlomieju): no longer works after migrating
|
|
|
|
// to JavaScript runtime code
|
|
|
|
unitTest({ ignore: true }, function applySourceMap(): void {
|
2019-07-29 19:11:08 +10:00
|
|
|
const result = Deno.applySourceMap({
|
2020-04-13 15:54:16 +01:00
|
|
|
fileName: "CLI_SNAPSHOT.js",
|
|
|
|
lineNumber: 23,
|
|
|
|
columnNumber: 0,
|
2019-07-29 19:11:08 +10:00
|
|
|
});
|
2020-07-19 19:49:44 +02:00
|
|
|
Deno.core.print(`result: ${result}`, true);
|
2020-04-13 15:54:16 +01:00
|
|
|
assert(result.fileName.endsWith(".ts"));
|
|
|
|
assert(result.lineNumber != null);
|
|
|
|
assert(result.columnNumber != null);
|
2019-07-29 19:11:08 +10:00
|
|
|
});
|