diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js')
-rw-r--r-- | js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js b/js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js new file mode 100644 index 0000000000..4d4d408d9e --- /dev/null +++ b/js/src/jit-test/tests/debug/Environment-module-tla-env-after-pop.js @@ -0,0 +1,54 @@ +// Accessing the variables in the snapshot after popping the module +// should work until the module's top-level script's evaluation finishes. + +var g = newGlobal({newCompartment: true}); +g.eval(` +var accessVarInSnapshot = null; +`); +g.eval(` +var resolve; +var p = new Promise(r => resolve = r); +`); +var dbg = new Debugger; +var gw = dbg.addDebuggee(g); +dbg.onDebuggerStatement = function (frame) { + assertEq(frame.environment.getVariable("x"), 10); + frame.eval("accessVarInSnapshot = function() { return ++x }"); + assertEq(gw.executeInGlobal("accessVarInSnapshot()").return, 11); +}; +const m = g.parseModule(` + let x = 10; + await 20; + debugger; + await p; +`); +moduleLink(m); + +// Run until `await p`. +moduleEvaluate(m); + +drainJobQueue(); + +assertEq(g.accessVarInSnapshot !== null, true); + +// At this point, the module's top-level script's evaluation isn't yet finished, +// and the module's ScriptSlot is still alive. +// Accessing the snapshot should work. +assertEq(g.accessVarInSnapshot(), 12); + +// Continue the module's top-level script's evaluation. +g.eval(` +resolve(); +`); + +drainJobQueue(); + +// At this point, the module's ScriptSlot is cleared and accessing the +// snapshot doesn't work. +try { + g.accessVarInSnapshot(); + // the above should throw. + assertEq(true, false); +} catch (e) { + assertEq(e+"", "ReferenceError: x is not defined"); +} |