summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/debug/Frame-identity-06.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /js/src/jit-test/tests/debug/Frame-identity-06.js
parentInitial commit. (diff)
downloadfirefox-esr-upstream.tar.xz
firefox-esr-upstream.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/debug/Frame-identity-06.js')
-rw-r--r--js/src/jit-test/tests/debug/Frame-identity-06.js45
1 files changed, 45 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/debug/Frame-identity-06.js b/js/src/jit-test/tests/debug/Frame-identity-06.js
new file mode 100644
index 0000000000..04eb16b386
--- /dev/null
+++ b/js/src/jit-test/tests/debug/Frame-identity-06.js
@@ -0,0 +1,45 @@
+// Debugger.Frames for async functions are not GC'd while they're suspended.
+// The awaited promise keeps the generator alive, via its reaction lists.
+
+var g = newGlobal({newCompartment: true});
+g.eval(`
+ // Create a few promises.
+ var promises = [], resolvers = [];
+ for (let i = 0; i < 3; i++)
+ promises.push(new Promise(r => { resolvers.push(r); }));
+
+ async function f() {
+ debugger;
+ for (let p of promises) {
+ await p;
+ debugger;
+ }
+ }
+`);
+var dbg = new Debugger(g);
+var hits = 0;
+dbg.onDebuggerStatement = function (frame) {
+ if (hits === 0)
+ frame.seen = true;
+ else
+ assertEq(frame.seen, true);
+ hits++;
+};
+
+let done = false;
+g.f().then(_ => { done = true; });
+gc();
+drainJobQueue();
+gc();
+
+// Resolve the promises one by one.
+for (let [i, resolve] of g.resolvers.entries()) {
+ assertEq(hits, 1 + i);
+ assertEq(done, false);
+ resolve("x");
+ gc();
+ drainJobQueue();
+ gc();
+}
+assertEq(hits, 1 + g.resolvers.length);
+assertEq(done, true);