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