summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/debug/Frame-eval-20.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-eval-20.js
parentInitial commit. (diff)
downloadfirefox-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 '')
-rw-r--r--js/src/jit-test/tests/debug/Frame-eval-20.js48
1 files changed, 48 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/debug/Frame-eval-20.js b/js/src/jit-test/tests/debug/Frame-eval-20.js
new file mode 100644
index 0000000000..dde786f8ef
--- /dev/null
+++ b/js/src/jit-test/tests/debug/Frame-eval-20.js
@@ -0,0 +1,48 @@
+// |jit-test| --ion-osr=off
+
+// Eval-in-frame with different type on non-youngest Ion frame.
+
+load(libdir + "jitopts.js");
+
+if (!jitTogglesMatch(Opts_Ion2NoOffthreadCompilation))
+ quit(0);
+
+withJitOptions(Opts_Ion2NoOffthreadCompilation, function () {
+ function test(shadow) {
+ var g = newGlobal({newCompartment: true});
+ var dbg = new Debugger;
+
+ // Note that we depend on CCW scripted functions being opaque to Ion
+ // optimization for this test.
+ g.h = function h(d) {
+ if (d) {
+ dbg.addDebuggee(g);
+ var f = dbg.getNewestFrame().older;
+ assertEq(f.implementation, "ion");
+ assertEq(f.environment.getVariable("foo"), 42);
+
+ // EIF of a different type too.
+ f.eval((shadow ? "var " : "") + "foo = 'string of 42'");
+ g.expected = shadow ? 42 : "string of 42";
+ }
+ }
+
+ g.eval("" + function f(d) {
+ var foo = 42;
+ g(d);
+ return foo;
+ });
+ g.eval("" + function g(d) {
+ h(d);
+ });
+
+ g.eval("(" + function () {
+ for (i = 0; i < 5; i++)
+ f(false);
+ assertEq(f(true), "string of 42");
+ } + ")();");
+ }
+
+ test(false);
+ test(true);
+});