diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /js/src/jit-test/tests/basic/bug791465.js | |
parent | Initial commit. (diff) | |
download | firefox-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 'js/src/jit-test/tests/basic/bug791465.js')
-rw-r--r-- | js/src/jit-test/tests/basic/bug791465.js | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/basic/bug791465.js b/js/src/jit-test/tests/basic/bug791465.js new file mode 100644 index 0000000000..13460a11f0 --- /dev/null +++ b/js/src/jit-test/tests/basic/bug791465.js @@ -0,0 +1,75 @@ +load(libdir + "asserts.js"); + +var valid_strict_funs = [ + // directive ends on next line + function () { + "use strict" + ; + }, + function () { + "use strict" + }, + // directive ends on same line + function () { "use strict"; }, + function () { "use strict" }, +]; + +for (var f of valid_strict_funs) { + assertThrowsInstanceOf(function() { f.caller }, TypeError); +} + + +var binary_ops = [ + "||", "&&", + "|", "^", "&", + "==", "!=", "===", "!==", + "<", "<=", ">", ">=", "in", "instanceof", + "<<", ">>", ">>>", + "+", "-", + "*", "/", "%", +]; + +var invalid_strict_funs = [ + function () { + "use strict" + , "not"; + }, + function () { + "use strict" + ? 1 : 0; + }, + function () { + "use strict" + .length; + }, + function () { + "use strict" + [0]; + }, + function () { + "use strict" + (); + }, + ...([]), + ...(binary_ops.map(op => Function("'use strict'\n " + op + " 'not'"))), +]; + +for (var f of invalid_strict_funs) { + f.caller; +} + + +var assignment_ops = [ + "=", "+=", "-=", + "|=", "^=", "&=", + "<<=", ">>=", ">>>=", + "*=", "/=", "%=", +]; + +var invalid_strict_funs_syntax_error = assignment_ops.map(op => ("'use strict'\n " + op + " 'not'")); + +// assignment with string literal as LHS is an early error, therefore we +// can only test for SyntaxError +for (var f of invalid_strict_funs_syntax_error) { + assertThrowsInstanceOf(function() { Function(f) }, SyntaxError); +} |