1/*
2 * Copyright (c) 2023-2024 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16function test_left_shift(): void {
17    assert new BigInt(0).operatorLeftShift(new BigInt(0)) == (0n);
18    assert new BigInt(0).operatorLeftShift(new BigInt(1)) == (0n);
19    assert new BigInt(1).operatorLeftShift(new BigInt(0)) == (1n);
20    assert new BigInt(10).operatorLeftShift(new BigInt(2)) == (40n);
21    assert new BigInt(255).operatorLeftShift(new BigInt(41)) == (560750930165760n);
22    assert new BigInt(65535).operatorLeftShift(new BigInt(60)) == (75556710804409716572160n);
23    assert new BigInt(4294967295).operatorLeftShift(new BigInt(5)) == (137438953440n);
24    assert new BigInt(18446744073709551615n).operatorLeftShift(new BigInt(6)) == (1180591620717411303360n);
25    assert new BigInt(1275418875248948586535904902545412130n).operatorLeftShift(new BigInt(123)) == (13562579802667292602585801202159372574330573695725523059072421474640855040n);
26    assert new BigInt(2).operatorLeftShift(new BigInt(218)) == (842498333348457493583344221469363458551160763204392890034487820288n);
27    assert new BigInt(-1).operatorLeftShift(new BigInt(0)) == (-1n);
28    assert new BigInt(-12).operatorLeftShift(new BigInt(4)) == (-192n);
29    assert new BigInt(-255).operatorLeftShift(new BigInt(19)) == (-133693440n);
30    assert new BigInt(-65535).operatorLeftShift(new BigInt(73)) == (-618960574909724398159134720n);
31    assert new BigInt(-4294967295).operatorLeftShift(new BigInt(24)) == (-72057594021150720n);
32    assert new BigInt(-18446744073709551615n).operatorLeftShift(new BigInt(31)) == (-39614081257132168794624491520n);
33    assert new BigInt(-4095059032950818422890113130149234924134n).operatorLeftShift(new BigInt(103)) == (-41528832328721100931613913139905162112381494314462183326283215847555072n);
34}
35
36function test_right_shift(): void {
37    assert new BigInt(-200).operatorRightShift(new BigInt(2)) == (-50n);
38    assert new BigInt(-12).operatorRightShift(new BigInt(2)) == (-3n);
39    assert new BigInt(-1).operatorRightShift(new BigInt(0)) == (-1n);
40    assert new BigInt(0).operatorRightShift(new BigInt(0)) == (0n);
41    assert new BigInt(0).operatorRightShift(new BigInt(1)) == (0n);
42    assert new BigInt(1).operatorRightShift(new BigInt(0)) == (1n);
43    assert new BigInt(55).operatorRightShift(new BigInt(2)) == (13n);
44    assert new BigInt(-50).operatorRightShift(new BigInt(2)) == (-13n);
45    assert new BigInt(255).operatorRightShift(new BigInt(4)) == (15n);
46    assert new BigInt(255).operatorRightShift(new BigInt(8)) == (0n);
47    assert new BigInt(65535).operatorRightShift(new BigInt(10)) == (63n);
48    assert new BigInt(4294967295).operatorRightShift(new BigInt(17)) == (32767n);
49    assert new BigInt(4294967295).operatorRightShift(new BigInt(48)) == (0n);
50    assert new BigInt(18446744073709551615n).operatorRightShift(new BigInt(55)) == (511n);
51    assert new BigInt(4930493049034092989191918392837727383823827n).operatorRightShift(new BigInt(129)) == (7244n);
52    assert new BigInt(34930693049034092980065918370009389341341932481328231493102392100010239n).operatorRightShift(new BigInt(41)) == (15884640128676479880626138024130973163365493965706369405371n);
53    assert new BigInt(34095405903900293499034024029409200000000000000000000094049304394284993939382949384984981018480144184891848991934893429489324901148449849382222222222222888384932890000103010381803018300103180381030084545225875678328499213403403984398439489384984287113383827387373382328328194394892948392222219791749717949183748237n).operatorRightShift(new BigInt(511)) == (5085903091997271218878067997324523590835536101241386224503069830700984460490307918626942225457432781938207872710051592009243523341752202627425621983245162030428n);
54    assert new BigInt(-255).operatorRightShift(new BigInt(2)) == (-64n);
55    assert new BigInt(-65535).operatorRightShift(new BigInt(12)) == (-16n);
56    assert new BigInt(-4294967295).operatorRightShift(new BigInt(18)) == (-16384n);
57    assert new BigInt(-18446744073709551615n).operatorRightShift(new BigInt(38)) == (-67108864n);
58    assert new BigInt(-4095059032950818422890113130149234924134n).operatorRightShift(new BigInt(99)) == (-6460863952n);
59    assert new BigInt(-3294302940940294094923040592059302590950294502940294029029409029429042942049028100104029439420990952n).operatorRightShift(new BigInt(100)) == (-2598746800062401791237527125433630339355687972972274247737341685088307n);
60}
61
62function main() : void {
63    test_left_shift()
64    test_right_shift()
65}
66
67