summaryrefslogtreecommitdiff
path: root/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js
diff options
context:
space:
mode:
authorhaturau <135221985+haturatu@users.noreply.github.com>2024-11-20 01:20:47 +0900
committerGitHub <noreply@github.com>2024-11-20 01:20:47 +0900
commit85719a67e59c7aa45bead26e4942d7df8b1b42d4 (patch)
treeface0aecaac53e93ce2f23b53c48859bcf1a36ec /tests/specs/run/fetch_response_finalization/fetch_response_finalization.js
parent67697bc2e4a62a9670699fd18ad0dd8efc5bd955 (diff)
parent186b52731c6bb326c4d32905c5e732d082e83465 (diff)
Merge branch 'denoland:main' into main
Diffstat (limited to 'tests/specs/run/fetch_response_finalization/fetch_response_finalization.js')
-rw-r--r--tests/specs/run/fetch_response_finalization/fetch_response_finalization.js16
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js b/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js
new file mode 100644
index 000000000..85fc6afa3
--- /dev/null
+++ b/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js
@@ -0,0 +1,16 @@
+async function doAFetch() {
+ const resp = await fetch("http://localhost:4545/README.md");
+ console.log(Deno[Deno.internal].core.resources()); // print the current resources
+ const _resp = resp;
+ // at this point resp can be GC'ed
+}
+
+await doAFetch(); // create a resource
+
+globalThis.gc(); // force GC
+
+// It is very important that there is a yield here, otherwise the finalizer for
+// the response body is not called and the resource is not closed.
+await new Promise((resolve) => setTimeout(resolve, 0));
+
+console.log(Deno[Deno.internal].core.resources()); // print the current resources