summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/debug/wasm-jseval.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /js/src/jit-test/tests/debug/wasm-jseval.js
parentInitial commit. (diff)
downloadfirefox-upstream.tar.xz
firefox-upstream.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/debug/wasm-jseval.js')
-rw-r--r--js/src/jit-test/tests/debug/wasm-jseval.js45
1 files changed, 45 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/debug/wasm-jseval.js b/js/src/jit-test/tests/debug/wasm-jseval.js
new file mode 100644
index 0000000000..ef35c3c0b7
--- /dev/null
+++ b/js/src/jit-test/tests/debug/wasm-jseval.js
@@ -0,0 +1,45 @@
+// |jit-test| skip-if: !wasmDebuggingEnabled()
+// Tests that JS can be evaluated on wasm module scripts frames.
+
+load(libdir + "wasm.js");
+
+wasmRunWithDebugger(
+ '(module (memory 1 1)\
+ (global (mut f64) (f64.const 0.5))\
+ (global f32 (f32.const 3.5))\
+ (func (param i32) (local f64) (f64.const 1.0) (tee_local 1) (set_global 0) (nop))\
+ (export "test" (func 0))\
+ (data (i32.const 0) "Abc\\x2A"))',
+ undefined,
+ function ({dbg}) {
+ dbg.onEnterFrame = function (frame) {
+ if (frame.type != 'wasmcall') return;
+
+ var memoryContent = frame.eval('new DataView(memory0.buffer).getUint8(3)').return;
+ assertEq(memoryContent, 42, 'valid memory content is expected (0x2A)');
+
+ var global1AndParamSum = frame.eval('global1 + var0').return;
+ assertEq(global1AndParamSum, 3.5);
+
+ var stepNumber = 0;
+ frame.onStep = function () {
+ switch (stepNumber) {
+ case 1: // after i64.const 1.0
+ assertEq(frame.eval('global0').return, 0.5);
+ assertEq(frame.eval('var1').return, 0.0);
+ break;
+ case 2: // after tee_local $var1
+ assertEq(frame.eval('var1').return, 1.0);
+ break;
+ case 3: // after set_global $global0
+ assertEq(frame.eval('global0').return, 1.0);
+ break;
+ }
+ stepNumber++;
+ };
+ };
+ },
+ function ({error}) {
+ assertEq(error, undefined);
+ }
+);