1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
const tests = [
[-0x10000000000000001n, -1n],
[-0x10000000000000000n, 0n],
[-0xffffffffffffffffn, 1n],
[-0xfffffffffffffffen, 2n],
[-0x8000000000000001n, -1n],
[-0x8000000000000000n, 0n],
[-0x7fffffffffffffffn, 1n],
[-0x7ffffffffffffffen, 2n],
[-0x100000001n, -1n],
[-0x100000000n, 0n],
[-0xffffffffn, 1n],
[-0xfffffffen, 2n],
[-0x80000001n, 0x7fffffffn],
[-0x80000000n, -0x80000000n],
[-0x7fffffffn, -0x7fffffffn],
[-0x7ffffffen, -0x7ffffffen],
[-9n, -9n],
[-8n, -8n],
[-7n, -7n],
[-6n, -6n],
[-5n, -5n],
[-4n, -4n],
[-3n, -3n],
[-2n, -2n],
[-1n, -1n],
[0n, 0n],
[1n, 1n],
[2n, 2n],
[3n, 3n],
[4n, 4n],
[5n, 5n],
[6n, 6n],
[7n, 7n],
[8n, 8n],
[9n, 9n],
[0x7ffffffen, 0x7ffffffen],
[0x7fffffffn, 0x7fffffffn],
[0x80000000n, -0x80000000n],
[0x80000001n, -0x7fffffffn],
[0xfffffffen, -2n],
[0xffffffffn, -1n],
[0x100000000n, 0n],
[0x100000001n, 1n],
[0x7ffffffffffffffen, -2n],
[0x7fffffffffffffffn, -1n],
[0x8000000000000000n, 0n],
[0x8000000000000001n, 1n],
[0xfffffffffffffffen, -2n],
[0xffffffffffffffffn, -1n],
[0x10000000000000000n, 0n],
[0x10000000000000001n, 1n],
];
function f(tests) {
for (let test of tests) {
let input = test[0], expected = test[1];
assertEq(BigInt.asIntN(32, input), expected);
}
}
for (let i = 0; i < 100; ++i) {
f(tests);
}
|