mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
- remove all '#JERRY_ESNEXT' macro - remove 5.1 build profile, update test runner accordingly (Note: all builtins are turn on by default) - move tests from tests/jerry/esnext into tests/jerry, concatenate files with same names - add skiplist to some snapshot tests that were supported only in 5.1 - fix doxygen issues that were hidden before (bc. of es.next macro) Co-authored-by: Martin Negyokru negyokru@inf.u-szeged.hu JerryScript-DCO-1.0-Signed-off-by: Adam Szilagyi aszilagy@inf.u-szeged.hu
57 lines
1.9 KiB
JavaScript
57 lines
1.9 KiB
JavaScript
/* Copyright JS Foundation and other contributors, http://js.foundation
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
function check_result(bigint, expected)
|
|
{
|
|
assert(bigint.toString() === expected)
|
|
}
|
|
|
|
function check_error (code, error_type)
|
|
{
|
|
try {
|
|
eval(code)
|
|
assert(false)
|
|
} catch (e) {
|
|
assert(e instanceof error_type)
|
|
}
|
|
}
|
|
|
|
check_error("BigInt(undefined)", TypeError)
|
|
check_error("BigInt(null)", TypeError)
|
|
check_error("BigInt(Symbol())", TypeError)
|
|
|
|
check_error("BigInt(0.25)", RangeError)
|
|
check_error("BigInt(-0.25)", RangeError)
|
|
check_error("BigInt(-10000000.25)", RangeError)
|
|
check_error("BigInt(4503599627370495.5)", RangeError)
|
|
check_error("BigInt(NaN)", RangeError)
|
|
check_error("BigInt(Infinity)", RangeError)
|
|
|
|
check_result(BigInt(true), "1")
|
|
check_result(BigInt(false), "0")
|
|
check_result(BigInt({ valueOf() { return "0x100" } }), "256")
|
|
|
|
check_result(BigInt(0), "0")
|
|
check_result(BigInt(-0), "0")
|
|
check_result(BigInt(8192), "8192")
|
|
check_result(BigInt(-0xffffffffff), "-1099511627775")
|
|
check_result(BigInt(0x1fffffffffffff), "9007199254740991")
|
|
check_result(BigInt(-4503599627370496), "-4503599627370496")
|
|
check_result(BigInt(4503599627370496.5), "4503599627370496")
|
|
check_result(BigInt(9007199254740991.5), "9007199254740992")
|
|
check_result(BigInt(0x1fffffffffffff * (2 ** 70)), "10633823966279325802638835764831453184")
|
|
check_result(BigInt(-0x1fffffffffffff * (2 ** 128)), "-3064991081731777376434327133362154903862870812598992896")
|
|
|