I wish I could get stack traces to work in TypeScript. I only seem to see the bottommost function name. I'm using Node.js v12.4.0 on Windows 10 (1803).
This is the code:
async function thrower() {
throw new Error("test");
}
async function level1() {
return await thrower();
}
async function level2() {
return await level1();
}
async function level3() {
return await level2();
}
async function main() {
try {
await level3();
} catch(err) {
console.warn("main error", err);
}
}
console.log("node version", process.version);
main().then(() => {
console.log("all done " + __filename);
}).catch((err) => {
console.error("Something went wrong in here :(", __filename, err);
})
The resulting stack trace that does not mention level1
or level2
or level3
:
ts-node test-stack.ts
node version v12.4.0
main error Error: test
at D:\dev\server\test-stack.ts:2:9
at step (D:\dev\server\test-stack.ts:31:23)
at Object.next (D:\dev\server\test-stack.ts:12:53)
at D:\dev\server\test-stack.ts:6:71
at new Promise (<anonymous>)
at __awaiter (D:\dev\server\test-stack.ts:2:12)
at thrower (D:\dev\server\test-stack.ts:37:12)
at D:\dev\server\test-stack.ts:6:16
at step (D:\dev\server\test-stack.ts:31:23)
at Object.next (D:\dev\server\test-stack.ts:12:53)
all done D:\dev\server\test-stack.ts