13af6ab5fSopenharmony_ci/*
23af6ab5fSopenharmony_ci * Copyright (c) 2023-2024 Huawei Device Co., Ltd.
33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License.
53af6ab5fSopenharmony_ci * You may obtain a copy of the License at
63af6ab5fSopenharmony_ci *
73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
83af6ab5fSopenharmony_ci *
93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and
133af6ab5fSopenharmony_ci * limitations under the License.
143af6ab5fSopenharmony_ci */
153af6ab5fSopenharmony_ci
163af6ab5fSopenharmony_cifunction test_divide(): void {
173af6ab5fSopenharmony_ci    assert new BigInt(10).operatorDivide(new BigInt(3)) == (3n);
183af6ab5fSopenharmony_ci    assert new BigInt(-10).operatorDivide(new BigInt(3)) == (-3n);
193af6ab5fSopenharmony_ci    assert new BigInt(10).operatorDivide(new BigInt(-3)) == (-3n);
203af6ab5fSopenharmony_ci    assert new BigInt(-10).operatorDivide(new BigInt(-3)) == (3n);
213af6ab5fSopenharmony_ci    assert new BigInt(100).operatorDivide(new BigInt(50)) == (2n);
223af6ab5fSopenharmony_ci    assert new BigInt(100).operatorDivide(new BigInt(-50)) == (-2n);
233af6ab5fSopenharmony_ci    assert new BigInt(-100).operatorDivide(new BigInt(50)) == (-2n);
243af6ab5fSopenharmony_ci    assert new BigInt(-100).operatorDivide(new BigInt(-50)) == (2n);
253af6ab5fSopenharmony_ci    assert new BigInt(3124378143267041203423n).operatorDivide(new BigInt(43621978)) == (71623944775430n);
263af6ab5fSopenharmony_ci    assert new BigInt(-3124378143267041203423n).operatorDivide(new BigInt(43621978)) == (-71623944775430n);
273af6ab5fSopenharmony_ci    assert new BigInt(3124378143267041203423n).operatorDivide(new BigInt(-43621978)) == (-71623944775430n);
283af6ab5fSopenharmony_ci    assert new BigInt(-3124378143267041203423n).operatorDivide(new BigInt(-43621978)) == (71623944775430n);
293af6ab5fSopenharmony_ci    assert new BigInt(100).operatorDivide(new BigInt(250)) == (0n);
303af6ab5fSopenharmony_ci    assert new BigInt(100).operatorDivide(new BigInt(-250)) == (0n);
313af6ab5fSopenharmony_ci    assert new BigInt(-100).operatorDivide(new BigInt(250)) == (0n);
323af6ab5fSopenharmony_ci    assert new BigInt(-100).operatorDivide(new BigInt(-250)) == (0n);
333af6ab5fSopenharmony_ci    assert new BigInt(65000).operatorDivide(new BigInt(100)) == (650n);
343af6ab5fSopenharmony_ci    assert new BigInt(65000).operatorDivide(new BigInt(-100)) == (-650n);
353af6ab5fSopenharmony_ci    assert new BigInt(-65000).operatorDivide(new BigInt(100)) == (-650n);
363af6ab5fSopenharmony_ci    assert new BigInt(-65000).operatorDivide(new BigInt(-100)) == (650n);
373af6ab5fSopenharmony_ci}
383af6ab5fSopenharmony_ci
393af6ab5fSopenharmony_cifunction main() : void {
403af6ab5fSopenharmony_ci    test_divide()
413af6ab5fSopenharmony_ci}
42