From 186ec5d177aff6e5e0ba5ace9aba8e1cecdb24c7 Mon Sep 17 00:00:00 2001 From: Josh Wolfe Date: Thu, 18 Jan 2018 11:21:31 -0700 Subject: [PATCH] BigInt and Number type mismatch tests for infix operators --- .../expressions/addition/bigint-and-number.js | 33 +++++++++++++++++++ .../bitwise-and/bigint-and-number.js | 32 ++++++++++++++++++ .../bitwise-or/bigint-and-number.js | 32 ++++++++++++++++++ .../bitwise-xor/bigint-and-number.js | 32 ++++++++++++++++++ .../expressions/division/bigint-and-number.js | 32 ++++++++++++++++++ .../exponentiation/bigint-and-number.js | 32 ++++++++++++++++++ .../left-shift/bigint-and-number.js | 32 ++++++++++++++++++ .../expressions/modulus/bigint-and-number.js | 32 ++++++++++++++++++ .../multiplication/bigint-and-number.js | 32 ++++++++++++++++++ .../right-shift/bigint-and-number.js | 32 ++++++++++++++++++ .../subtraction/bigint-and-number.js | 32 ++++++++++++++++++ .../unsigned-right-shift/bigint-and-number.js | 32 ++++++++++++++++++ 12 files changed, 385 insertions(+) create mode 100644 test/language/expressions/addition/bigint-and-number.js create mode 100644 test/language/expressions/bitwise-and/bigint-and-number.js create mode 100644 test/language/expressions/bitwise-or/bigint-and-number.js create mode 100644 test/language/expressions/bitwise-xor/bigint-and-number.js create mode 100644 test/language/expressions/division/bigint-and-number.js create mode 100644 test/language/expressions/exponentiation/bigint-and-number.js create mode 100644 test/language/expressions/left-shift/bigint-and-number.js create mode 100644 test/language/expressions/modulus/bigint-and-number.js create mode 100644 test/language/expressions/multiplication/bigint-and-number.js create mode 100644 test/language/expressions/right-shift/bigint-and-number.js create mode 100644 test/language/expressions/subtraction/bigint-and-number.js create mode 100644 test/language/expressions/unsigned-right-shift/bigint-and-number.js diff --git a/test/language/expressions/addition/bigint-and-number.js b/test/language/expressions/addition/bigint-and-number.js new file mode 100644 index 0000000000..1d41b3985c --- /dev/null +++ b/test/language/expressions/addition/bigint-and-number.js @@ -0,0 +1,33 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-addition-operator-plus-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for addition operator +features: [BigInt] +info: | + Let lprim be ? ToPrimitive(lval). + Let rprim be ? ToPrimitive(rval). + ... + Let lnum be ? ToNumeric(lprim) + Let rnum be ? ToNumeric(rprim) + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n + 1; }, "1n + 1 throws TypeError"); +assert.throws(TypeError, function() { 1 + 1n; }, "1 + 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) + 1; }, "Object(1n) + 1 throws TypeError"); +assert.throws(TypeError, function() { 1 + Object(1n); }, "1 + Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n + Object(1); }, "1n + Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) + 1n; }, "Object(1) + 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) + Object(1); }, "Object(1n) + Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) + Object(1n); }, "Object(1) + Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n + NaN; }, "1n + NaN throws TypeError"); +assert.throws(TypeError, function() { NaN + 1n; }, "NaN + 1n throws TypeError"); +assert.throws(TypeError, function() { 1n + Infinity; }, "1n + Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity + 1n; }, "Infinity + 1n throws TypeError"); +assert.throws(TypeError, function() { 1n + true; }, "1n + true throws TypeError"); +assert.throws(TypeError, function() { true + 1n; }, "true + 1n throws TypeError"); +assert.throws(TypeError, function() { 1n + null; }, "1n + null throws TypeError"); +assert.throws(TypeError, function() { null + 1n; }, "null + 1n throws TypeError"); +assert.throws(TypeError, function() { 1n + undefined; }, "1n + undefined throws TypeError"); +assert.throws(TypeError, function() { undefined + 1n; }, "undefined + 1n throws TypeError"); diff --git a/test/language/expressions/bitwise-and/bigint-and-number.js b/test/language/expressions/bitwise-and/bigint-and-number.js new file mode 100644 index 0000000000..db1b23e8e1 --- /dev/null +++ b/test/language/expressions/bitwise-and/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-binary-bitwise-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for bitwise-and operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n & 1; }, "1n & 1 throws TypeError"); +assert.throws(TypeError, function() { 1 & 1n; }, "1 & 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) & 1; }, "Object(1n) & 1 throws TypeError"); +assert.throws(TypeError, function() { 1 & Object(1n); }, "1 & Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n & Object(1); }, "1n & Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) & 1n; }, "Object(1) & 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) & Object(1); }, "Object(1n) & Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) & Object(1n); }, "Object(1) & Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n & NaN; }, "1n & NaN throws TypeError"); +assert.throws(TypeError, function() { NaN & 1n; }, "NaN & 1n throws TypeError"); +assert.throws(TypeError, function() { 1n & Infinity; }, "1n & Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity & 1n; }, "Infinity & 1n throws TypeError"); +assert.throws(TypeError, function() { 1n & true; }, "1n & true throws TypeError"); +assert.throws(TypeError, function() { true & 1n; }, "true & 1n throws TypeError"); +assert.throws(TypeError, function() { 1n & "1"; }, '1n & "1" throws TypeError'); +assert.throws(TypeError, function() { "1" & 1n; }, '"1" & 1n throws TypeError'); +assert.throws(TypeError, function() { 1n & null; }, "1n & null throws TypeError"); +assert.throws(TypeError, function() { null & 1n; }, "null & 1n throws TypeError"); +assert.throws(TypeError, function() { 1n & undefined; }, "1n & undefined throws TypeError"); +assert.throws(TypeError, function() { undefined & 1n; }, "undefined & 1n throws TypeError"); diff --git a/test/language/expressions/bitwise-or/bigint-and-number.js b/test/language/expressions/bitwise-or/bigint-and-number.js new file mode 100644 index 0000000000..dd9b809702 --- /dev/null +++ b/test/language/expressions/bitwise-or/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-binary-bitwise-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for bitwise-or operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n | 1; }, "1n | 1 throws TypeError"); +assert.throws(TypeError, function() { 1 | 1n; }, "1 | 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) | 1; }, "Object(1n) | 1 throws TypeError"); +assert.throws(TypeError, function() { 1 | Object(1n); }, "1 | Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n | Object(1); }, "1n | Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) | 1n; }, "Object(1) | 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) | Object(1); }, "Object(1n) | Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) | Object(1n); }, "Object(1) | Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n | NaN; }, "1n | NaN throws TypeError"); +assert.throws(TypeError, function() { NaN | 1n; }, "NaN | 1n throws TypeError"); +assert.throws(TypeError, function() { 1n | Infinity; }, "1n | Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity | 1n; }, "Infinity | 1n throws TypeError"); +assert.throws(TypeError, function() { 1n | true; }, "1n | true throws TypeError"); +assert.throws(TypeError, function() { true | 1n; }, "true | 1n throws TypeError"); +assert.throws(TypeError, function() { 1n | "1"; }, '1n | "1" throws TypeError'); +assert.throws(TypeError, function() { "1" | 1n; }, '"1" | 1n throws TypeError'); +assert.throws(TypeError, function() { 1n | null; }, "1n | null throws TypeError"); +assert.throws(TypeError, function() { null | 1n; }, "null | 1n throws TypeError"); +assert.throws(TypeError, function() { 1n | undefined; }, "1n | undefined throws TypeError"); +assert.throws(TypeError, function() { undefined | 1n; }, "undefined | 1n throws TypeError"); diff --git a/test/language/expressions/bitwise-xor/bigint-and-number.js b/test/language/expressions/bitwise-xor/bigint-and-number.js new file mode 100644 index 0000000000..4b5f2f696e --- /dev/null +++ b/test/language/expressions/bitwise-xor/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-binary-bitwise-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for bitwise-xor operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n ^ 1; }, "1n ^ 1 throws TypeError"); +assert.throws(TypeError, function() { 1 ^ 1n; }, "1 ^ 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) ^ 1; }, "Object(1n) ^ 1 throws TypeError"); +assert.throws(TypeError, function() { 1 ^ Object(1n); }, "1 ^ Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n ^ Object(1); }, "1n ^ Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) ^ 1n; }, "Object(1) ^ 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) ^ Object(1); }, "Object(1n) ^ Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) ^ Object(1n); }, "Object(1) ^ Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n ^ NaN; }, "1n ^ NaN throws TypeError"); +assert.throws(TypeError, function() { NaN ^ 1n; }, "NaN ^ 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ^ Infinity; }, "1n ^ Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity ^ 1n; }, "Infinity ^ 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ^ true; }, "1n ^ true throws TypeError"); +assert.throws(TypeError, function() { true ^ 1n; }, "true ^ 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ^ "1"; }, '1n ^ "1" throws TypeError'); +assert.throws(TypeError, function() { "1" ^ 1n; }, '"1" ^ 1n throws TypeError'); +assert.throws(TypeError, function() { 1n ^ null; }, "1n ^ null throws TypeError"); +assert.throws(TypeError, function() { null ^ 1n; }, "null ^ 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ^ undefined; }, "1n ^ undefined throws TypeError"); +assert.throws(TypeError, function() { undefined ^ 1n; }, "undefined ^ 1n throws TypeError"); diff --git a/test/language/expressions/division/bigint-and-number.js b/test/language/expressions/division/bigint-and-number.js new file mode 100644 index 0000000000..fd7a6d0613 --- /dev/null +++ b/test/language/expressions/division/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-multiplicative-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for division operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n / 1; }, "1n / 1 throws TypeError"); +assert.throws(TypeError, function() { 1 / 1n; }, "1 / 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) / 1; }, "Object(1n) / 1 throws TypeError"); +assert.throws(TypeError, function() { 1 / Object(1n); }, "1 / Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n / Object(1); }, "1n / Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) / 1n; }, "Object(1) / 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) / Object(1); }, "Object(1n) / Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) / Object(1n); }, "Object(1) / Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n / NaN; }, "1n / NaN throws TypeError"); +assert.throws(TypeError, function() { NaN / 1n; }, "NaN / 1n throws TypeError"); +assert.throws(TypeError, function() { 1n / Infinity; }, "1n / Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity / 1n; }, "Infinity / 1n throws TypeError"); +assert.throws(TypeError, function() { 1n / true; }, "1n / true throws TypeError"); +assert.throws(TypeError, function() { true / 1n; }, "true / 1n throws TypeError"); +assert.throws(TypeError, function() { 1n / "1"; }, '1n / "1" throws TypeError'); +assert.throws(TypeError, function() { "1" / 1n; }, '"1" / 1n throws TypeError'); +assert.throws(TypeError, function() { 1n / null; }, "1n / null throws TypeError"); +assert.throws(TypeError, function() { null / 1n; }, "null / 1n throws TypeError"); +assert.throws(TypeError, function() { 1n / undefined; }, "1n / undefined throws TypeError"); +assert.throws(TypeError, function() { undefined / 1n; }, "undefined / 1n throws TypeError"); diff --git a/test/language/expressions/exponentiation/bigint-and-number.js b/test/language/expressions/exponentiation/bigint-and-number.js new file mode 100644 index 0000000000..f8b96cac6a --- /dev/null +++ b/test/language/expressions/exponentiation/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-exp-operator-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for exponentiation operator +features: [BigInt] +info: | + Let base be ? ToNumeric(leftValue). + Let exponent be ? ToNumeric(rightValue). + If Type(base) does not equal Type(exponent), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n ** 1; }, "1n ** 1 throws TypeError"); +assert.throws(TypeError, function() { 1 ** 1n; }, "1 ** 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) ** 1; }, "Object(1n) ** 1 throws TypeError"); +assert.throws(TypeError, function() { 1 ** Object(1n); }, "1 ** Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n ** Object(1); }, "1n ** Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) ** 1n; }, "Object(1) ** 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) ** Object(1); }, "Object(1n) ** Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) ** Object(1n); }, "Object(1) ** Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n ** NaN; }, "1n ** NaN throws TypeError"); +assert.throws(TypeError, function() { NaN ** 1n; }, "NaN ** 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ** Infinity; }, "1n ** Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity ** 1n; }, "Infinity ** 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ** true; }, "1n ** true throws TypeError"); +assert.throws(TypeError, function() { true ** 1n; }, "true ** 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ** "1"; }, '1n ** "1" throws TypeError'); +assert.throws(TypeError, function() { "1" ** 1n; }, '"1" ** 1n throws TypeError'); +assert.throws(TypeError, function() { 1n ** null; }, "1n ** null throws TypeError"); +assert.throws(TypeError, function() { null ** 1n; }, "null ** 1n throws TypeError"); +assert.throws(TypeError, function() { 1n ** undefined; }, "1n ** undefined throws TypeError"); +assert.throws(TypeError, function() { undefined ** 1n; }, "undefined ** 1n throws TypeError"); diff --git a/test/language/expressions/left-shift/bigint-and-number.js b/test/language/expressions/left-shift/bigint-and-number.js new file mode 100644 index 0000000000..585fc56418 --- /dev/null +++ b/test/language/expressions/left-shift/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-left-shift-operator-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for left-shift operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n << 1; }, "1n << 1 throws TypeError"); +assert.throws(TypeError, function() { 1 << 1n; }, "1 << 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) << 1; }, "Object(1n) << 1 throws TypeError"); +assert.throws(TypeError, function() { 1 << Object(1n); }, "1 << Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n << Object(1); }, "1n << Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) << 1n; }, "Object(1) << 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) << Object(1); }, "Object(1n) << Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) << Object(1n); }, "Object(1) << Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n << NaN; }, "1n << NaN throws TypeError"); +assert.throws(TypeError, function() { NaN << 1n; }, "NaN << 1n throws TypeError"); +assert.throws(TypeError, function() { 1n << Infinity; }, "1n << Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity << 1n; }, "Infinity << 1n throws TypeError"); +assert.throws(TypeError, function() { 1n << true; }, "1n << true throws TypeError"); +assert.throws(TypeError, function() { true << 1n; }, "true << 1n throws TypeError"); +assert.throws(TypeError, function() { 1n << "1"; }, '1n << "1" throws TypeError'); +assert.throws(TypeError, function() { "1" << 1n; }, '"1" << 1n throws TypeError'); +assert.throws(TypeError, function() { 1n << null; }, "1n << null throws TypeError"); +assert.throws(TypeError, function() { null << 1n; }, "null << 1n throws TypeError"); +assert.throws(TypeError, function() { 1n << undefined; }, "1n << undefined throws TypeError"); +assert.throws(TypeError, function() { undefined << 1n; }, "undefined << 1n throws TypeError"); diff --git a/test/language/expressions/modulus/bigint-and-number.js b/test/language/expressions/modulus/bigint-and-number.js new file mode 100644 index 0000000000..afdb0aa870 --- /dev/null +++ b/test/language/expressions/modulus/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-multiplicative-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for modulus operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n % 1; }, "1n % 1 throws TypeError"); +assert.throws(TypeError, function() { 1 % 1n; }, "1 % 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) % 1; }, "Object(1n) % 1 throws TypeError"); +assert.throws(TypeError, function() { 1 % Object(1n); }, "1 % Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n % Object(1); }, "1n % Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) % 1n; }, "Object(1) % 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) % Object(1); }, "Object(1n) % Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) % Object(1n); }, "Object(1) % Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n % NaN; }, "1n % NaN throws TypeError"); +assert.throws(TypeError, function() { NaN % 1n; }, "NaN % 1n throws TypeError"); +assert.throws(TypeError, function() { 1n % Infinity; }, "1n % Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity % 1n; }, "Infinity % 1n throws TypeError"); +assert.throws(TypeError, function() { 1n % true; }, "1n % true throws TypeError"); +assert.throws(TypeError, function() { true % 1n; }, "true % 1n throws TypeError"); +assert.throws(TypeError, function() { 1n % "1"; }, '1n % "1" throws TypeError'); +assert.throws(TypeError, function() { "1" % 1n; }, '"1" % 1n throws TypeError'); +assert.throws(TypeError, function() { 1n % null; }, "1n % null throws TypeError"); +assert.throws(TypeError, function() { null % 1n; }, "null % 1n throws TypeError"); +assert.throws(TypeError, function() { 1n % undefined; }, "1n % undefined throws TypeError"); +assert.throws(TypeError, function() { undefined % 1n; }, "undefined % 1n throws TypeError"); diff --git a/test/language/expressions/multiplication/bigint-and-number.js b/test/language/expressions/multiplication/bigint-and-number.js new file mode 100644 index 0000000000..a62f585671 --- /dev/null +++ b/test/language/expressions/multiplication/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-multiplicative-operators-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for multiplication operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n * 1; }, "1n * 1 throws TypeError"); +assert.throws(TypeError, function() { 1 * 1n; }, "1 * 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) * 1; }, "Object(1n) * 1 throws TypeError"); +assert.throws(TypeError, function() { 1 * Object(1n); }, "1 * Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n * Object(1); }, "1n * Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) * 1n; }, "Object(1) * 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) * Object(1); }, "Object(1n) * Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) * Object(1n); }, "Object(1) * Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n * NaN; }, "1n * NaN throws TypeError"); +assert.throws(TypeError, function() { NaN * 1n; }, "NaN * 1n throws TypeError"); +assert.throws(TypeError, function() { 1n * Infinity; }, "1n * Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity * 1n; }, "Infinity * 1n throws TypeError"); +assert.throws(TypeError, function() { 1n * true; }, "1n * true throws TypeError"); +assert.throws(TypeError, function() { true * 1n; }, "true * 1n throws TypeError"); +assert.throws(TypeError, function() { 1n * "1"; }, '1n * "1" throws TypeError'); +assert.throws(TypeError, function() { "1" * 1n; }, '"1" * 1n throws TypeError'); +assert.throws(TypeError, function() { 1n * null; }, "1n * null throws TypeError"); +assert.throws(TypeError, function() { null * 1n; }, "null * 1n throws TypeError"); +assert.throws(TypeError, function() { 1n * undefined; }, "1n * undefined throws TypeError"); +assert.throws(TypeError, function() { undefined * 1n; }, "undefined * 1n throws TypeError"); diff --git a/test/language/expressions/right-shift/bigint-and-number.js b/test/language/expressions/right-shift/bigint-and-number.js new file mode 100644 index 0000000000..e8dde0473b --- /dev/null +++ b/test/language/expressions/right-shift/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-signed-right-shift-operator-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for right-shift operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n >> 1; }, "1n >> 1 throws TypeError"); +assert.throws(TypeError, function() { 1 >> 1n; }, "1 >> 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) >> 1; }, "Object(1n) >> 1 throws TypeError"); +assert.throws(TypeError, function() { 1 >> Object(1n); }, "1 >> Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n >> Object(1); }, "1n >> Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) >> 1n; }, "Object(1) >> 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) >> Object(1); }, "Object(1n) >> Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) >> Object(1n); }, "Object(1) >> Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n >> NaN; }, "1n >> NaN throws TypeError"); +assert.throws(TypeError, function() { NaN >> 1n; }, "NaN >> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >> Infinity; }, "1n >> Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity >> 1n; }, "Infinity >> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >> true; }, "1n >> true throws TypeError"); +assert.throws(TypeError, function() { true >> 1n; }, "true >> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >> "1"; }, '1n >> "1" throws TypeError'); +assert.throws(TypeError, function() { "1" >> 1n; }, '"1" >> 1n throws TypeError'); +assert.throws(TypeError, function() { 1n >> null; }, "1n >> null throws TypeError"); +assert.throws(TypeError, function() { null >> 1n; }, "null >> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >> undefined; }, "1n >> undefined throws TypeError"); +assert.throws(TypeError, function() { undefined >> 1n; }, "undefined >> 1n throws TypeError"); diff --git a/test/language/expressions/subtraction/bigint-and-number.js b/test/language/expressions/subtraction/bigint-and-number.js new file mode 100644 index 0000000000..c75fd73a0f --- /dev/null +++ b/test/language/expressions/subtraction/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-subtraction-operator-minus-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for subtraction operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n - 1; }, "1n - 1 throws TypeError"); +assert.throws(TypeError, function() { 1 - 1n; }, "1 - 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) - 1; }, "Object(1n) - 1 throws TypeError"); +assert.throws(TypeError, function() { 1 - Object(1n); }, "1 - Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n - Object(1); }, "1n - Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) - 1n; }, "Object(1) - 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) - Object(1); }, "Object(1n) - Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) - Object(1n); }, "Object(1) - Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n - NaN; }, "1n - NaN throws TypeError"); +assert.throws(TypeError, function() { NaN - 1n; }, "NaN - 1n throws TypeError"); +assert.throws(TypeError, function() { 1n - Infinity; }, "1n - Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity - 1n; }, "Infinity - 1n throws TypeError"); +assert.throws(TypeError, function() { 1n - true; }, "1n - true throws TypeError"); +assert.throws(TypeError, function() { true - 1n; }, "true - 1n throws TypeError"); +assert.throws(TypeError, function() { 1n - "1"; }, '1n - "1" throws TypeError'); +assert.throws(TypeError, function() { "1" - 1n; }, '"1" - 1n throws TypeError'); +assert.throws(TypeError, function() { 1n - null; }, "1n - null throws TypeError"); +assert.throws(TypeError, function() { null - 1n; }, "null - 1n throws TypeError"); +assert.throws(TypeError, function() { 1n - undefined; }, "1n - undefined throws TypeError"); +assert.throws(TypeError, function() { undefined - 1n; }, "undefined - 1n throws TypeError"); diff --git a/test/language/expressions/unsigned-right-shift/bigint-and-number.js b/test/language/expressions/unsigned-right-shift/bigint-and-number.js new file mode 100644 index 0000000000..d60cdcff74 --- /dev/null +++ b/test/language/expressions/unsigned-right-shift/bigint-and-number.js @@ -0,0 +1,32 @@ +// Copyright (C) 2018 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-unsigned-right-shift-operator-runtime-semantics-evaluation +description: Mixing BigInt and Number produces a TypeError for unsigned-right-shift operator +features: [BigInt] +info: | + Let lnum be ? ToNumeric(leftValue). + Let rnum be ? ToNumeric(rightValue). + If Type(lnum) does not equal Type(rnum), throw a TypeError exception. +---*/ + +assert.throws(TypeError, function() { 1n >>> 1; }, "1n >>> 1 throws TypeError"); +assert.throws(TypeError, function() { 1 >>> 1n; }, "1 >>> 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) >>> 1; }, "Object(1n) >>> 1 throws TypeError"); +assert.throws(TypeError, function() { 1 >>> Object(1n); }, "1 >>> Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n >>> Object(1); }, "1n >>> Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) >>> 1n; }, "Object(1) >>> 1n throws TypeError"); +assert.throws(TypeError, function() { Object(1n) >>> Object(1); }, "Object(1n) >>> Object(1) throws TypeError"); +assert.throws(TypeError, function() { Object(1) >>> Object(1n); }, "Object(1) >>> Object(1n) throws TypeError"); +assert.throws(TypeError, function() { 1n >>> NaN; }, "1n >>> NaN throws TypeError"); +assert.throws(TypeError, function() { NaN >>> 1n; }, "NaN >>> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >>> Infinity; }, "1n >>> Infinity throws TypeError"); +assert.throws(TypeError, function() { Infinity >>> 1n; }, "Infinity >>> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >>> true; }, "1n >>> true throws TypeError"); +assert.throws(TypeError, function() { true >>> 1n; }, "true >>> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >>> "1"; }, '1n >>> "1" throws TypeError'); +assert.throws(TypeError, function() { "1" >>> 1n; }, '"1" >>> 1n throws TypeError'); +assert.throws(TypeError, function() { 1n >>> null; }, "1n >>> null throws TypeError"); +assert.throws(TypeError, function() { null >>> 1n; }, "null >>> 1n throws TypeError"); +assert.throws(TypeError, function() { 1n >>> undefined; }, "1n >>> undefined throws TypeError"); +assert.throws(TypeError, function() { undefined >>> 1n; }, "undefined >>> 1n throws TypeError");