bitwise-not tests for BigInt (#1277)

This commit is contained in:
Josh Wolfe 2017-10-16 11:17:13 -07:00 committed by Leo Balter
parent d36a1777b4
commit 5b721a23b5
2 changed files with 70 additions and 0 deletions

View File

@ -0,0 +1,33 @@
// Copyright (C) 2017 Josh Wolfe. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
description: Bitwise NOT for BigInt object wrappers
esid: sec-bitwise-not-operator-runtime-semantics-evaluation
info: |
Runtime Semantics: Evaluation
UnaryExpression : ~ UnaryExpression
1. Let expr be the result of evaluating UnaryExpression.
2. Let oldValue be ? ToNumeric(? GetValue(expr)).
3. Let T be Type(oldValue).
4. Return ? T::bitwiseNOT(oldValue).
features: [BigInt, Symbol.toPrimitive]
---*/
assert.sameValue(~Object(1n), -2n, "~Object(1n) === -2n");
function err() {
throw new Test262Error();
}
assert.sameValue(
~{[Symbol.toPrimitive]: function() { return 1n; }, valueOf: err, toString: err}, -2n,
"primitive from @@toPrimitive");
assert.sameValue(
~{valueOf: function() { return 1n; }, toString: err}, -2n,
"primitive from {}.valueOf");
assert.sameValue(
~{toString: function() { return 1n; }}, -2n,
"primitive from {}.toString");

View File

@ -0,0 +1,37 @@
// Copyright (C) 2017 Josh Wolfe. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
description: Bitwise NOT for BigInt values
esid: sec-numeric-types-bigint-bitwiseNOT
info: |
BigInt::bitwiseNOT (x)
The abstract operation BigInt::bitwiseNOT with an argument x of BigInt type returns the one's complement of x; that is, -x - 1.
features: [BigInt]
---*/
assert.sameValue(~0n, -1n, "~0n === -1n");
assert.sameValue(~(0n), -1n, "~(0n) === -1n");
assert.sameValue(~1n, -2n, "~1n === -2n");
assert.sameValue(~-1n, 0n, "~-1n === 0n");
assert.sameValue(~(-1n), 0n, "~(-1n) === 0n");
assert.sameValue(~~1n, 1n, "~~1n === 1n");
assert.sameValue(~0x5an, -0x5bn, "~0x5an === -0x5bn");
assert.sameValue(~-0x5an, 0x59n, "~-0x5an === 0x59n");
assert.sameValue(~0xffn, -0x100n, "~0xffn === -0x100n");
assert.sameValue(~-0xffn, 0xfen, "~-0xffn === 0xfen");
assert.sameValue(~0xffffn, -0x10000n, "~0xffffn === -0x10000n");
assert.sameValue(~-0xffffn, 0xfffen, "~-0xffffn === 0xfffen");
assert.sameValue(~0xffffffffn, -0x100000000n, "~0xffffffffn === -0x100000000n");
assert.sameValue(~-0xffffffffn, 0xfffffffen, "~-0xffffffffn === 0xfffffffen");
assert.sameValue(
~0xffffffffffffffffn, -0x10000000000000000n,
"~0xffffffffffffffffn === -0x10000000000000000n");
assert.sameValue(
~-0xffffffffffffffffn, 0xfffffffffffffffen,
"~-0xffffffffffffffffn === 0xfffffffffffffffen");
assert.sameValue(
~0x123456789abcdef0fedcba9876543210n, -0x123456789abcdef0fedcba9876543211n,
"~0x123456789abcdef0fedcba9876543210n === -0x123456789abcdef0fedcba9876543211n");