From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- js/src/jit-test/tests/debug/Frame-onStack-07.js | 56 +++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 js/src/jit-test/tests/debug/Frame-onStack-07.js (limited to 'js/src/jit-test/tests/debug/Frame-onStack-07.js') diff --git a/js/src/jit-test/tests/debug/Frame-onStack-07.js b/js/src/jit-test/tests/debug/Frame-onStack-07.js new file mode 100644 index 0000000000..055a7d41b2 --- /dev/null +++ b/js/src/jit-test/tests/debug/Frame-onStack-07.js @@ -0,0 +1,56 @@ +// frame.onStack is false for generator frames popped due to exception or termination. + +load(libdir + "/asserts.js"); + +function test(when, what) { + let g = newGlobal({newCompartment: true}); + g.eval("function* f(x) { yield x; }"); + + let dbg = new Debugger; + let gw = dbg.addDebuggee(g); + let fw = gw.getOwnPropertyDescriptor("f").value; + + let t = 0; + let poppedFrame; + + function tick(frame) { + if (frame.callee == fw) { + if (t == when) { + poppedFrame = frame; + dbg.onEnterFrame = undefined; + frame.onPop = undefined; + return what; + } + t++; + } + return undefined; + } + + dbg.onDebuggerStatement = frame => { + dbg.onEnterFrame = frame => { + frame.onPop = function() { + return tick(this); + }; + return tick(frame); + }; + let result = frame.eval("for (let _ of f(0)) {}"); + if (result && "stack" in result) { + result.stack = true; + } + assertDeepEq(result, what); + }; + g.eval("debugger;"); + + assertEq(t, when); + assertEq(poppedFrame.onStack, false); + assertErrorMessage(() => poppedFrame.older, + Error, + "Debugger.Frame is not on stack or suspended"); +} + +for (let when = 0; when < 6; when++) { + for (let what of [null, {throw: "fit", stack: true}]) { + test(when, what); + } +} + -- cgit v1.2.3