[amount] test negative fee rates and full constructor
This commit is contained in:
parent
30c2dd8d05
commit
11114a69c8
1 changed files with 29 additions and 0 deletions
|
@ -27,6 +27,15 @@ BOOST_AUTO_TEST_CASE(GetFeeTest)
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 1e3);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 1e3);
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 9e3);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 9e3);
|
||||||
|
|
||||||
|
feeRate = CFeeRate(-1000);
|
||||||
|
// Must always just return -1 * arg
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(1), -1);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(121), -121);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(999), -999);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), -1e3);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), -9e3);
|
||||||
|
|
||||||
feeRate = CFeeRate(123);
|
feeRate = CFeeRate(123);
|
||||||
// Truncates the result, if not integer
|
// Truncates the result, if not integer
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
|
||||||
|
@ -37,6 +46,26 @@ BOOST_AUTO_TEST_CASE(GetFeeTest)
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(999), 122);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(999), 122);
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 123);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(1e3), 123);
|
||||||
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 1107);
|
BOOST_CHECK_EQUAL(feeRate.GetFee(9e3), 1107);
|
||||||
|
|
||||||
|
feeRate = CFeeRate(-123);
|
||||||
|
// Truncates the result, if not integer
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(0), 0);
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(8), -1); // Special case: returns -1 instead of 0
|
||||||
|
BOOST_CHECK_EQUAL(feeRate.GetFee(9), -1);
|
||||||
|
|
||||||
|
// Check full constructor
|
||||||
|
// default value
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(-1), 1000) == CFeeRate(-1));
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(0), 1000) == CFeeRate(0));
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(1), 1000) == CFeeRate(1));
|
||||||
|
// lost precision (can only resolve satoshis per kB)
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(1), 1001) == CFeeRate(0));
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(2), 1001) == CFeeRate(1));
|
||||||
|
// some more integer checks
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(26), 789) == CFeeRate(32));
|
||||||
|
BOOST_CHECK(CFeeRate(CAmount(27), 789) == CFeeRate(34));
|
||||||
|
// Maximum size in bytes, should not crash
|
||||||
|
CFeeRate(MAX_MONEY, (std::numeric_limits<size_t>::max() >> 1) - 1).GetFeePerK();
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
Loading…
Reference in a new issue