diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /js/src/jit-test/tests/optional-chain | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jit-test/tests/optional-chain')
3 files changed, 100 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/optional-chain/bug1848244.js b/js/src/jit-test/tests/optional-chain/bug1848244.js new file mode 100644 index 0000000000..cbd7bd6164 --- /dev/null +++ b/js/src/jit-test/tests/optional-chain/bug1848244.js @@ -0,0 +1,6 @@ +// Constant-folding should replace the ternary expression with one that is +// equally valid with optional chaining in the AST +function main() { + (0 ? 0 : -1n)?.g; +} +main(); diff --git a/js/src/jit-test/tests/optional-chain/call-ignore-rval.js b/js/src/jit-test/tests/optional-chain/call-ignore-rval.js new file mode 100644 index 0000000000..c5fd2fe975 --- /dev/null +++ b/js/src/jit-test/tests/optional-chain/call-ignore-rval.js @@ -0,0 +1,34 @@ +// Tests for JSOp::CallIgnoresRv in optional chains. + +// Note:: IgnoresReturnValueNative is supported for Array.prototype.splice. + +// Test for optional call. +function testOptionalCall() { + for (var i = 0; i < 100; ++i) { + var x = [1, 2, 3]; + x.splice?.(0); + } +} + +for (var i = 0; i < 5; ++i) { testOptionalCall(); } + +// Test for optional prop directly followed by call. +function testOptionalProp() { + for (var i = 0; i < 100; ++i) { + var x = [1, 2, 3]; + x?.splice(0); + } +} + +for (var i = 0; i < 5; ++i) { testOptionalProp(); } + +// Test for call in optional chain expression. +function testOptionalChain() { + for (var i = 0; i < 100; ++i) { + var x = [1, 2, 3]; + var o = {x}; + o?.x.splice(0); + } +} + +for (var i = 0; i < 5; ++i) { testOptionalChain(); } diff --git a/js/src/jit-test/tests/optional-chain/fun-call-or-apply.js b/js/src/jit-test/tests/optional-chain/fun-call-or-apply.js new file mode 100644 index 0000000000..6734c3c86b --- /dev/null +++ b/js/src/jit-test/tests/optional-chain/fun-call-or-apply.js @@ -0,0 +1,60 @@ +// Tests for JSOp::FunCall and JSOp::FunApply in optional calls. + +function f1() { + return 0; +} +function f2(a) { + return a * 2; +} + +function funCall(fn) { + // Without arguments. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.call(), 0); + } + + // Only this-arg. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.call(null), 0); + } + + // With one arg. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.call(null, 1), 0); + assertEq(f2?.call(null, 5), 10); + } + + // With multiple args. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.call(null, 1, 2, 3), 0); + assertEq(f2?.call(null, 4, 5, 6), 8); + } +} + +for (var i = 0; i < 5; ++i) { funCall(); } + +function funApply(fn) { + // Without arguments. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.apply(), 0); + } + + // Only this-arg. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.apply(null), 0); + } + + // With one arg. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.apply(null, [1]), 0); + assertEq(f2?.apply(null, [5]), 10); + } + + // With multiple args. + for (var i = 0; i < 100; ++i) { + assertEq(f1?.apply(null, [1, 2, 3]), 0); + assertEq(f2?.apply(null, [4, 5, 6]), 8); + } +} + +for (var i = 0; i < 5; ++i) { funApply(); } |