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/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js | |
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/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js')
-rw-r--r-- | js/src/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js b/js/src/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js new file mode 100644 index 0000000000..b0e580fbad --- /dev/null +++ b/js/src/tests/test262/built-ins/BigInt/constructor-from-string-syntax-errors.js @@ -0,0 +1,79 @@ +// Copyright (C) 2017 Caio Lima. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +description: Invalid String into BigInt constructor should throw SyntaxError +esid: sec-string-to-bigint +info: | + ToBigInt ( argument ) + + String: + + Let n be StringToBigInt(prim). + If n is NaN, throw a SyntaxError exception. + Return n. + + StringToBigInt ( argument ) + + Replace the StrUnsignedDecimalLiteral production with DecimalDigits to not allow Infinity, decimal points, or exponents. + +features: [BigInt] +---*/ + +assert.throws(SyntaxError, function() { + BigInt("10n"); +}); + +assert.throws(SyntaxError, function() { + BigInt("10x"); +}); + +assert.throws(SyntaxError, function() { + BigInt("10b"); +}); + +assert.throws(SyntaxError, function() { + BigInt("10.5"); +}); + +assert.throws(SyntaxError, function() { + BigInt("0b"); +}); + +assert.throws(SyntaxError, function() { + BigInt("-0x1"); +}); + +assert.throws(SyntaxError, function() { + BigInt("-0XFFab"); +}); + +assert.throws(SyntaxError, function() { + BigInt("0oa"); +}); + +assert.throws(SyntaxError, function() { + BigInt("000 12"); +}); + +assert.throws(SyntaxError, function() { + BigInt("0o"); +}); + +assert.throws(SyntaxError, function() { + BigInt("0x"); +}); + +assert.throws(SyntaxError, function() { + BigInt("00o"); +}); + +assert.throws(SyntaxError, function() { + BigInt("00b"); +}); + +assert.throws(SyntaxError, function() { + BigInt("00x"); +}); + +reportCompare(0, 0); |