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, 0xffffffffn],
[-0x10000000000000000n, 0n],
[-0xffffffffffffffffn, 1n],
[-0xfffffffffffffffen, 2n],
[-0x8000000000000001n, 0xffffffffn],
[-0x8000000000000000n, 0n],
[-0x7fffffffffffffffn, 1n],
[-0x7ffffffffffffffen, 2n],
[-0x100000001n, 0xffffffffn],
[-0x100000000n, 0n],
[-0xffffffffn, 1n],
[-0xfffffffen, 2n],
[-0x80000001n, 0x7fffffffn],
[-0x80000000n, 0x80000000n],
[-0x7fffffffn, 0x80000001n],
[-0x7ffffffen, 0x80000002n],
[-9n, 0xfffffff7n],
[-8n, 0xfffffff8n],
[-7n, 0xfffffff9n],
[-6n, 0xfffffffan],
[-5n, 0xfffffffbn],
[-4n, 0xfffffffcn],
[-3n, 0xfffffffdn],
[-2n, 0xfffffffen],
[-1n, 0xffffffffn],
[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, 0x80000001n],
[0xfffffffen, 0xfffffffen],
[0xffffffffn, 0xffffffffn],
[0x100000000n, 0n],
[0x100000001n, 1n],
[0x7ffffffffffffffen, 0xfffffffen],
[0x7fffffffffffffffn, 0xffffffffn],
[0x8000000000000000n, 0n],
[0x8000000000000001n, 1n],
[0xfffffffffffffffen, 0xfffffffen],
[0xffffffffffffffffn, 0xffffffffn],
[0x10000000000000000n, 0n],
[0x10000000000000001n, 1n],
];
function f(tests) {
for (let test of tests) {
let input = test[0], expected = test[1];
assertEq(BigInt.asUintN(32, input), expected);
}
}
for (let i = 0; i < 100; ++i) {
f(tests);
}
|