1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-11 16:42:21 -05:00

fix(ext/fetch): Connect async error stack with user code (#13899)

This commit is contained in:
Nayeem Rahman 2022-03-22 17:08:33 +00:00 committed by GitHub
parent f81334d5bd
commit d2c099ce34
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 28 additions and 2 deletions

View file

@ -2517,3 +2517,10 @@ itest!(wasm_streaming_panic_test {
output: "wasm_streaming_panic_test.js.out",
exit_code: 1,
});
// Regression test for https://github.com/denoland/deno/issues/13897.
itest!(fetch_async_error_stack {
args: "run --quiet -A fetch_async_error_stack.ts",
output: "fetch_async_error_stack.ts.out",
exit_code: 1,
});

View file

@ -0,0 +1 @@
await fetch("https://nonexistent.deno.land/");

View file

@ -0,0 +1,5 @@
error: Uncaught (in promise) TypeError: error sending request for url[WILDCARD]
await fetch("https://nonexistent.deno.land/");
^[WILDCARD]
at async fetch (deno:[WILDCARD])
at async file:///[WILDCARD]/fetch_async_error_stack.ts:1:1

View file

@ -409,8 +409,13 @@
* @param {RequestInit} init
*/
function fetch(input, init = {}) {
// There is an async dispatch later that causes a stack trace disconnect.
// We reconnect it by assigning the result of that dispatch to `opPromise`,
// awaiting `opPromise` in an inner function also named `fetch()` and
// returning the result from that.
let opPromise = undefined;
// 1.
return new Promise((resolve, reject) => {
const result = new Promise((resolve, reject) => {
const prefix = "Failed to call 'fetch'";
webidl.requiredArguments(arguments.length, 1, { prefix });
// 2.
@ -441,7 +446,7 @@
}
// 12.
PromisePrototypeCatch(
opPromise = PromisePrototypeCatch(
PromisePrototypeThen(
mainFetch(request, false, requestObject.signal),
(response) => {
@ -479,6 +484,14 @@
},
);
});
if (opPromise) {
PromisePrototypeCatch(result, () => {});
return (async function fetch() {
await opPromise;
return result;
})();
}
return result;
}
function abortFetch(request, responseObject, error) {