Skip to content

Commit 91482e5

Browse files
committed
Merge #14460: tests: Improve 'CAmount' tests
29ed2d6 Improve CAmount tests (Hennadii Stepanov) Pull request description: This provides: - more `MoneyRange` tests; - new `CFeeRate` constructor tests with zero byte size; - explicit using of the `CAmount` type. Tree-SHA512: ca0ad6ccb37909a2a5c11034dc07b316a84c32fb40c6f8b6cfc28ebec72a1de157f31d22e767ae80d70ed06d7296f23870cc5ed0689f34a754ae763d50e23d43
2 parents e754c6e + 29ed2d6 commit 91482e5

File tree

1 file changed

+31
-26
lines changed

1 file changed

+31
-26
lines changed

src/test/amount_tests.cpp

Lines changed: 31 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -13,8 +13,10 @@ BOOST_FIXTURE_TEST_SUITE(amount_tests, BasicTestingSetup)
1313
BOOST_AUTO_TEST_CASE(MoneyRangeTest)
1414
{
1515
BOOST_CHECK_EQUAL(MoneyRange(CAmount(-1)), false);
16-
BOOST_CHECK_EQUAL(MoneyRange(MAX_MONEY + CAmount(1)), false);
16+
BOOST_CHECK_EQUAL(MoneyRange(CAmount(0)), true);
1717
BOOST_CHECK_EQUAL(MoneyRange(CAmount(1)), true);
18+
BOOST_CHECK_EQUAL(MoneyRange(MAX_MONEY), true);
19+
BOOST_CHECK_EQUAL(MoneyRange(MAX_MONEY + CAmount(1)), false);
1820
}
1921

2022
BOOST_AUTO_TEST_CASE(GetFeeTest)
@@ -23,50 +25,53 @@ BOOST_AUTO_TEST_CASE(GetFeeTest)
2325

2426
feeRate = CFeeRate(0);
2527
// Must always return 0
26-
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
27-
BOOST_CHECK_EQUAL(feeRate.GetFee(1e5), 0);
28+
BOOST_CHECK_EQUAL(feeRate.GetFee(0), CAmount(0));
29+
BOOST_CHECK_EQUAL(feeRate.GetFee(1e5), CAmount(0));
2830

2931
feeRate = CFeeRate(1000);
3032
// Must always just return the arg
31-
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
32-
BOOST_CHECK_EQUAL(feeRate.GetFee(1), 1);
33-
BOOST_CHECK_EQUAL(feeRate.GetFee(121), 121);
34-
BOOST_CHECK_EQUAL(feeRate.GetFee(999), 999);
35-
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 1e3);
36-
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 9e3);
33+
BOOST_CHECK_EQUAL(feeRate.GetFee(0), CAmount(0));
34+
BOOST_CHECK_EQUAL(feeRate.GetFee(1), CAmount(1));
35+
BOOST_CHECK_EQUAL(feeRate.GetFee(121), CAmount(121));
36+
BOOST_CHECK_EQUAL(feeRate.GetFee(999), CAmount(999));
37+
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), CAmount(1e3));
38+
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), CAmount(9e3));
3739

3840
feeRate = CFeeRate(-1000);
3941
// Must always just return -1 * arg
40-
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
41-
BOOST_CHECK_EQUAL(feeRate.GetFee(1), -1);
42-
BOOST_CHECK_EQUAL(feeRate.GetFee(121), -121);
43-
BOOST_CHECK_EQUAL(feeRate.GetFee(999), -999);
44-
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), -1e3);
45-
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), -9e3);
42+
BOOST_CHECK_EQUAL(feeRate.GetFee(0), CAmount(0));
43+
BOOST_CHECK_EQUAL(feeRate.GetFee(1), CAmount(-1));
44+
BOOST_CHECK_EQUAL(feeRate.GetFee(121), CAmount(-121));
45+
BOOST_CHECK_EQUAL(feeRate.GetFee(999), CAmount(-999));
46+
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), CAmount(-1e3));
47+
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), CAmount(-9e3));
4648

4749
feeRate = CFeeRate(123);
4850
// Truncates the result, if not integer
49-
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
50-
BOOST_CHECK_EQUAL(feeRate.GetFee(8), 1); // Special case: returns 1 instead of 0
51-
BOOST_CHECK_EQUAL(feeRate.GetFee(9), 1);
52-
BOOST_CHECK_EQUAL(feeRate.GetFee(121), 14);
53-
BOOST_CHECK_EQUAL(feeRate.GetFee(122), 15);
54-
BOOST_CHECK_EQUAL(feeRate.GetFee(999), 122);
55-
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 123);
56-
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 1107);
51+
BOOST_CHECK_EQUAL(feeRate.GetFee(0), CAmount(0));
52+
BOOST_CHECK_EQUAL(feeRate.GetFee(8), CAmount(1)); // Special case: returns 1 instead of 0
53+
BOOST_CHECK_EQUAL(feeRate.GetFee(9), CAmount(1));
54+
BOOST_CHECK_EQUAL(feeRate.GetFee(121), CAmount(14));
55+
BOOST_CHECK_EQUAL(feeRate.GetFee(122), CAmount(15));
56+
BOOST_CHECK_EQUAL(feeRate.GetFee(999), CAmount(122));
57+
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), CAmount(123));
58+
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), CAmount(1107));
5759

5860
feeRate = CFeeRate(-123);
5961
// Truncates the result, if not integer
60-
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
61-
BOOST_CHECK_EQUAL(feeRate.GetFee(8), -1); // Special case: returns -1 instead of 0
62-
BOOST_CHECK_EQUAL(feeRate.GetFee(9), -1);
62+
BOOST_CHECK_EQUAL(feeRate.GetFee(0), CAmount(0));
63+
BOOST_CHECK_EQUAL(feeRate.GetFee(8), CAmount(-1)); // Special case: returns -1 instead of 0
64+
BOOST_CHECK_EQUAL(feeRate.GetFee(9), CAmount(-1));
6365

6466
// check alternate constructor
6567
feeRate = CFeeRate(1000);
6668
altFeeRate = CFeeRate(feeRate);
6769
BOOST_CHECK_EQUAL(feeRate.GetFee(100), altFeeRate.GetFee(100));
6870

6971
// Check full constructor
72+
BOOST_CHECK(CFeeRate(CAmount(-1), 0) == CFeeRate(0));
73+
BOOST_CHECK(CFeeRate(CAmount(0), 0) == CFeeRate(0));
74+
BOOST_CHECK(CFeeRate(CAmount(1), 0) == CFeeRate(0));
7075
// default value
7176
BOOST_CHECK(CFeeRate(CAmount(-1), 1000) == CFeeRate(-1));
7277
BOOST_CHECK(CFeeRate(CAmount(0), 1000) == CFeeRate(0));

0 commit comments

Comments
 (0)