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-this-16.js | 38 ++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 js/src/jit-test/tests/debug/Frame-this-16.js (limited to 'js/src/jit-test/tests/debug/Frame-this-16.js') diff --git a/js/src/jit-test/tests/debug/Frame-this-16.js b/js/src/jit-test/tests/debug/Frame-this-16.js new file mode 100644 index 0000000000..43aec1f2c5 --- /dev/null +++ b/js/src/jit-test/tests/debug/Frame-this-16.js @@ -0,0 +1,38 @@ +// Test that Debugger.Frame.prototype.this works on a suspended async +// generator function. + +load(libdir + "asserts.js"); + +const g = newGlobal({ newCompartment: true }); +const dbg = new Debugger(); +const gDO = dbg.addDebuggee(g); + +g.eval(` +var context = {}; +var f = async function*() { + await Promise.resolve(); + return this; +}.bind(context); +`); + +let frame; +dbg.onEnterFrame = f => { + frame = f; + assertEq(frame.this, gDO.makeDebuggeeValue(g.context)); + dbg.onEnterFrame = undefined; +}; + +(async () => { + const it = g.f(); + + assertEq(!!frame, true); + assertEq(frame.this, gDO.makeDebuggeeValue(g.context)); + + const promise = it.next(); + + assertEq(frame.this, gDO.makeDebuggeeValue(g.context)); + + await promise; + + assertThrowsInstanceOf(() => frame.this, Error); +})(); -- cgit v1.2.3