summaryrefslogtreecommitdiff
path: root/tests/specs/run/fetch_response_finalization
diff options
context:
space:
mode:
authorMohammad Sulaiman <mohammad.sulaiman@exalt.ps>2024-11-05 08:39:05 +0200
committerGitHub <noreply@github.com>2024-11-05 06:39:05 +0000
commit89f0b796bd442ff352c3f93f69156ca6d85bfd5e (patch)
tree3ac2a58c6d85f6af57eb2c6b07b1f2d0e8687b3a /tests/specs/run/fetch_response_finalization
parentf9a05068d6de247574fb764044a446d1d7ed2e9b (diff)
chore: deprecate run itests (#26444)
Diffstat (limited to 'tests/specs/run/fetch_response_finalization')
-rw-r--r--tests/specs/run/fetch_response_finalization/__test__.jsonc5
-rw-r--r--tests/specs/run/fetch_response_finalization/fetch_response_finalization.js16
-rw-r--r--tests/specs/run/fetch_response_finalization/fetch_response_finalization.js.out2
3 files changed, 23 insertions, 0 deletions
diff --git a/tests/specs/run/fetch_response_finalization/__test__.jsonc b/tests/specs/run/fetch_response_finalization/__test__.jsonc
new file mode 100644
index 000000000..51a7e2b04
--- /dev/null
+++ b/tests/specs/run/fetch_response_finalization/__test__.jsonc
@@ -0,0 +1,5 @@
+{
+ "args": "run --v8-flags=--expose-gc --allow-net fetch_response_finalization.js",
+ "output": "fetch_response_finalization.js.out",
+ "exitCode": 0
+}
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
diff --git a/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js.out b/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js.out
new file mode 100644
index 000000000..645842a5b
--- /dev/null
+++ b/tests/specs/run/fetch_response_finalization/fetch_response_finalization.js.out
@@ -0,0 +1,2 @@
+{ "0": "stdin", "1": "stdout", "2": "stderr", "5": "fetchResponse" }
+{ "0": "stdin", "1": "stdout", "2": "stderr" }