47#include <boost/test/unit_test.hpp>
49using namespace std::literals;
75 explicit NoCopyOrMove(
int i) : i{i} { }
77 NoCopyOrMove() =
delete;
78 NoCopyOrMove(
const NoCopyOrMove&) =
delete;
79 NoCopyOrMove(NoCopyOrMove&&) =
delete;
80 NoCopyOrMove& operator=(
const NoCopyOrMove&) =
delete;
81 NoCopyOrMove& operator=(NoCopyOrMove&&) =
delete;
83 operator bool()
const {
return i != 0; }
85 int get_ip1() {
return i + 1; }
89 [&]() {
Assume(get_ip1()); }();
90 return Assume(get_ip1() != 5);
98 const std::unique_ptr<int> p_two =
Assert(std::make_unique<int>(2));
100 const int two = *
Assert(p_two);
104 const bool result{
Assume(two == 2)};
117 const int nine{*
Assert(std::optional<int>{9})};
129 BOOST_ERROR(
"break was swallowed!");
139 BOOST_ERROR(
"break was swallowed!");
143constexpr char HEX_PARSE_INPUT[] =
"04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f";
145 0x04, 0x67, 0x8a, 0xfd, 0xb0, 0xfe, 0x55, 0x48, 0x27, 0x19, 0x67, 0xf1, 0xa6, 0x71, 0x30, 0xb7,
146 0x10, 0x5c, 0xd6, 0xa8, 0x28, 0xe0, 0x39, 0x09, 0xa6, 0x79, 0x62, 0xe0, 0xea, 0x1f, 0x61, 0xde,
147 0xb6, 0x49, 0xf6, 0xbc, 0x3f, 0x4c, 0xef, 0x38, 0xc4, 0xf3, 0x55, 0x04, 0xe5, 0x1e, 0xc1, 0x12,
148 0xde, 0x5c, 0x38, 0x4d, 0xf7, 0xba, 0x0b, 0x8d, 0x57, 0x8a, 0x4c, 0x70, 0x2b, 0x6b, 0xf1, 0x1d,
154 std::vector<unsigned char> result;
158 constexpr std::array<std::byte, 65> hex_literal_array{
operator""_hex<util::detail::Hex(HEX_PARSE_INPUT)>()};
160 BOOST_CHECK_EQUAL_COLLECTIONS(hex_literal_span.begin(), hex_literal_span.end(), expected.begin(), expected.end());
162 const std::vector<std::byte> hex_literal_vector{
operator""_hex_v<util::detail::Hex(HEX_PARSE_INPUT)>()};
164 BOOST_CHECK_EQUAL_COLLECTIONS(hex_literal_span.begin(), hex_literal_span.end(), expected.begin(), expected.end());
166 constexpr std::array<uint8_t, 65> hex_literal_array_uint8{
operator""_hex_u8<util::detail::Hex(HEX_PARSE_INPUT)>()};
167 BOOST_CHECK_EQUAL_COLLECTIONS(hex_literal_array_uint8.begin(), hex_literal_array_uint8.end(), expected.begin(), expected.end());
169 result =
operator""_hex_v_u8<util::detail::Hex(HEX_PARSE_INPUT)>();
170 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
173 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
176 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
179 expected = {0x12, 0x34, 0x56, 0x78};
181 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
182 result = TryParseHex<uint8_t>(
"12 34 56 78").value();
183 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
186 expected = {0x89, 0x34, 0x56, 0x78};
188 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
189 result = TryParseHex<uint8_t>(
" 89 34 56 78").value();
190 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
193 expected = {0xff, 0xaa};
195 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
196 result = TryParseHex<uint8_t>(
" Ff aA ").value();
197 BOOST_CHECK_EQUAL_COLLECTIONS(result.begin(), result.end(), expected.begin(), expected.end());
200 static_assert(
""_hex.empty());
201 static_assert(
""_hex_u8.empty());
212 const std::string with_embedded_null{
" 11 "s
243 constexpr std::string_view out_exp{
"04678afdb0"};
254 auto input = std::string();
255 for (
size_t i=0; i<256; ++i) {
256 input.push_back(
static_cast<char>(i));
260 BOOST_TEST_REQUIRE(hex.size() == 512);
261 static constexpr auto hexmap = std::string_view(
"0123456789abcdef");
262 for (
size_t i = 0; i < 256; ++i) {
263 auto upper = hexmap.find(hex[i * 2]);
264 auto lower = hexmap.find(hex[i * 2 + 1]);
265 BOOST_TEST_REQUIRE(upper != std::string_view::npos);
266 BOOST_TEST_REQUIRE(lower != std::string_view::npos);
267 BOOST_TEST_REQUIRE(i == upper*16 + lower);
274 std::array mut_arr{uint8_t{0xaa}, uint8_t{0xbb}};
276 mut_bytes[1] = std::byte{0x11};
289 const auto op_upper = [](
const std::string&
s) {
return ToUpper(
s); };
297 const std::string original(
"A test \"%s\" string '%s'.");
298 auto test_replaceall = [&original](
const std::string& search,
const std::string& substitute,
const std::string& expected) {
299 auto test = original;
304 test_replaceall(
"",
"foo", original);
305 test_replaceall(original,
"foo",
"foo");
306 test_replaceall(
"%s",
"foo",
"A test \"foo\" string 'foo'.");
307 test_replaceall(
"\"",
"foo",
"A test foo%sfoo string '%s'.");
308 test_replaceall(
"'",
"foo",
"A test \"%s\" string foo%sfoo.");
323 BOOST_CHECK_EQUAL(
TrimString(std::string(
"\x05\x04\x03\x02\x01\x00", 6), std::string(
"\x05\x04\x03\x02\x01", 5)), std::string(
"\0", 1));
356 const std::string valid{
"2000-01-01T00:00:01Z"};
358 for (
auto mut{0U}; mut < valid.size(); ++mut) {
359 std::string invalid{valid};
510 for (
int mod=2;mod<11;mod++)
514 int err = 30*10000./mod*sqrt((1./mod*(1-1./mod))/10000.);
516 while(mask<mod-1)mask=(mask<<1)+1;
520 for (
int i = 0; i < 10000; i++) {
523 rval=m_rng.rand32()&mask;
524 }
while(rval>=(uint32_t)mod);
545#define B "check_prefix"
546#define E "check_postfix"
549 int64_t s64t = -9223372036854775807LL;
550 uint64_t u64t = 18446744073709551615ULL;
555 size_t st = 12345678;
556 ssize_t sst = -12345678;
561 ptrdiff_t pt = 87654321;
562 ptrdiff_t spt = -87654321;
574 for (
const auto& num_sleep : {0ms, 1ms}) {
588 const auto steady_ms_0 = Now<SteadyMilliseconds>();
589 const auto steady_0 = std::chrono::steady_clock::now();
590 const auto ms_0 = GetTime<std::chrono::milliseconds>();
591 const auto us_0 = GetTime<std::chrono::microseconds>();
593 BOOST_CHECK(steady_ms_0 < Now<SteadyMilliseconds>());
594 BOOST_CHECK(steady_0 + 1ms <= std::chrono::steady_clock::now());
595 BOOST_CHECK(ms_0 < GetTime<std::chrono::milliseconds>());
596 BOOST_CHECK(us_0 < GetTime<std::chrono::microseconds>());
618 constexpr T MAXI{std::numeric_limits<T>::max()};
638 TestAddMatrixOverflow<T>();
639 constexpr T MINI{std::numeric_limits<T>::min()};
640 constexpr T MAXI{std::numeric_limits<T>::max()};
658 TestAddMatrixOverflow<unsigned>();
659 TestAddMatrix<signed>();
721 BOOST_CHECK(!ToIntegral<T>(
"-32482348723847471234"));
722 BOOST_CHECK(!ToIntegral<T>(
"32482348723847471234"));
737 RunToIntegralTests<uint64_t>();
738 RunToIntegralTests<int64_t>();
739 RunToIntegralTests<uint32_t>();
740 RunToIntegralTests<int32_t>();
741 RunToIntegralTests<uint16_t>();
742 RunToIntegralTests<int16_t>();
743 RunToIntegralTests<uint8_t>();
744 RunToIntegralTests<int8_t>();
746 BOOST_CHECK(!ToIntegral<int64_t>(
"-9223372036854775809"));
747 BOOST_CHECK_EQUAL(ToIntegral<int64_t>(
"-9223372036854775808").value(), -9'223'372'036'854'775'807LL - 1LL);
748 BOOST_CHECK_EQUAL(ToIntegral<int64_t>(
"9223372036854775807").value(), 9'223'372'036'854'775'807);
749 BOOST_CHECK(!ToIntegral<int64_t>(
"9223372036854775808"));
753 BOOST_CHECK_EQUAL(ToIntegral<uint64_t>(
"18446744073709551615").value(), 18'446'744'073'709'551'615ULL);
754 BOOST_CHECK(!ToIntegral<uint64_t>(
"18446744073709551616"));
789 return strtoll(str.c_str(),
nullptr, 10);
819 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int32_t>(
"-32482348723847471234"), -2'147'483'647 - 1);
820 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int32_t>(
"32482348723847471234"), 2'147'483'647);
822 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int64_t>(
"-9223372036854775809"), -9'223'372'036'854'775'807LL - 1LL);
823 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int64_t>(
"-9223372036854775808"), -9'223'372'036'854'775'807LL - 1LL);
824 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int64_t>(
"9223372036854775807"), 9'223'372'036'854'775'807);
825 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int64_t>(
"9223372036854775808"), 9'223'372'036'854'775'807);
827 std::map<std::string, int64_t> atoi64_test_pairs = {
828 {
"-9223372036854775809", std::numeric_limits<int64_t>::min()},
829 {
"-9223372036854775808", -9'223'372'036'854'775'807LL - 1LL},
830 {
"9223372036854775807", 9'223'372'036'854'775'807},
831 {
"9223372036854775808", std::numeric_limits<int64_t>::max()},
838 for (
const auto& pair : atoi64_test_pairs) {
843 for (
const auto& pair : atoi64_test_pairs) {
849 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<uint64_t>(
"18446744073709551615"), 18'446'744'073'709'551'615ULL);
850 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<uint64_t>(
"18446744073709551616"), 18'446'744'073'709'551'615ULL);
852 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int32_t>(
"-2147483649"), -2'147'483'648LL);
853 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<int32_t>(
"-2147483648"), -2'147'483'648LL);
859 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<uint32_t>(
"4294967295"), 4'294'967'295U);
860 BOOST_CHECK_EQUAL(LocaleIndependentAtoi<uint32_t>(
"4294967296"), 4'294'967'295U);
1061 BOOST_CHECK_EQUAL(
FormatParagraph(
"This_is_a_very_long_test_string_without_any_spaces_so_it_should_just_get_returned_as_is_despite_the_length until it gets here", 79),
"This_is_a_very_long_test_string_without_any_spaces_so_it_should_just_get_returned_as_is_despite_the_length\nuntil it gets here");
1064 BOOST_CHECK_EQUAL(
FormatParagraph(
"a b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de f g h i j k l m n o p", 79),
"a b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de\nf g h i j k l m n o p");
1065 BOOST_CHECK_EQUAL(
FormatParagraph(
"x\na b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de f g h i j k l m n o p", 79),
"x\na b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de\nf g h i j k l m n o p");
1067 BOOST_CHECK_EQUAL(
FormatParagraph(
"x\na b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9 a b c d e fg h i j k", 79, 4),
"x\na b c d e f g h i j k l m n o p q r s t u v w x y z 1 2 3 4 5 6 7 8 9 a b c de\n f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9 a b c d e fg\n h i j k");
1069 BOOST_CHECK_EQUAL(
FormatParagraph(
"This is a very long test string. This is a second sentence in the very long test string.", 79),
"This is a very long test string. This is a second sentence in the very long\ntest string.");
1070 BOOST_CHECK_EQUAL(
FormatParagraph(
"This is a very long test string.\nThis is a second sentence in the very long test string. This is a third sentence in the very long test string.", 79),
"This is a very long test string.\nThis is a second sentence in the very long test string. This is a third\nsentence in the very long test string.");
1071 BOOST_CHECK_EQUAL(
FormatParagraph(
"This is a very long test string.\n\nThis is a second sentence in the very long test string. This is a third sentence in the very long test string.", 79),
"This is a very long test string.\n\nThis is a second sentence in the very long test string. This is a third\nsentence in the very long test string.");
1072 BOOST_CHECK_EQUAL(
FormatParagraph(
"Testing that normal newlines do not get indented.\nLike here.", 79),
"Testing that normal newlines do not get indented.\nLike here.");
1077 std::vector<std::string> comments;
1078 comments.emplace_back(
"comment1");
1079 std::vector<std::string> comments2;
1080 comments2.emplace_back(
"comment1");
1176 int rv = read(fd, &ch, 1);
1188 rv = write(fd, &ch, 1);
1194 rv = write(fd, &ch, 1);
1209 fs::path dirname = m_args.GetDataDirBase() /
"lock_dir";
1215 void (*old_handler)(int) = signal(SIGCHLD, SIG_DFL);
1295 signal(SIGCHLD, old_handler);
1300 fs::remove_all(dirname);
1340 return std::string(span.
begin(), span.
end());
1351 input =
"MilkToastHoney";
1353 success =
Const(
"", sp);
1357 success =
Const(
"Milk", sp);
1361 success =
Const(
"Bread", sp);
1364 success =
Const(
"Toast", sp);
1368 success =
Const(
"Honeybadger", sp);
1371 success =
Const(
"Honey", sp);
1376 input =
"Foo(Bar(xy,z()))";
1379 success =
Func(
"FooBar", sp);
1382 success =
Func(
"Foo(", sp);
1385 success =
Func(
"Foo", sp);
1389 success =
Func(
"Bar", sp);
1393 success =
Func(
"xy", sp);
1399 input =
"(n*(n-1))/2";
1411 input =
"(aaaaa,bbbbb()),c";
1423 input =
"((a),(b),(c)),xxx";
1430 std::vector<Span<const char>> results;
1433 results =
Split(input,
'x');
1440 input =
"one#two#three";
1441 results =
Split(input,
'-');
1445 input =
"one#two#three";
1446 results =
Split(input,
'#');
1452 input =
"*foo*bar*";
1453 results =
Split(input,
'*');
1465 std::vector<std::string> result =
SplitString(
"",
'-');
1472 std::vector<std::string> result =
SplitString(
"-",
'-');
1480 std::vector<std::string> result =
SplitString(
"--",
'-');
1489 std::vector<std::string> result =
SplitString(
"abc",
'-');
1496 std::vector<std::string> result =
SplitString(
"a-b",
'-');
1504 std::vector<std::string> result =
SplitString(
"AAA",
'a');
1511 using V = std::vector<std::string>;
1512 BOOST_TEST(
SplitString(
"a,b.c:d;e",
",;") == V({
"a",
"b.c:d",
"e"}));
1513 BOOST_TEST(
SplitString(
"a,b.c:d;e",
",;:.") == V({
"a",
"b",
"c",
"d",
"e"}));
1514 BOOST_TEST(
SplitString(
"a,b.c:d;e",
"") == V({
"a,b.c:d;e"}));
1515 BOOST_TEST(
SplitString(
"aaa",
"bcdefg") == V({
"aaa"}));
1516 BOOST_TEST(
SplitString(
"x\0a,b"s,
"\0"s) == V({
"x",
"a,b"}));
1517 BOOST_TEST(
SplitString(
"x\0a,b"s,
'\0') == V({
"x",
"a,b"}));
1518 BOOST_TEST(
SplitString(
"x\0a,b"s,
"\0,"s) == V({
"x",
"a",
"b"}));
1519 BOOST_TEST(
SplitString(
"abcdefg",
"bcd") == V({
"a",
"",
"",
"efg"}));
1532 const std::string NUL(
"O\x00O", 3);
1541 const Tracker* origin;
1545 Tracker() noexcept : origin(this) {}
1546 Tracker(
const Tracker&
t) noexcept : origin(
t.origin), copies(
t.copies + 1) {}
1547 Tracker(Tracker&&
t) noexcept : origin(
t.origin), copies(
t.copies) {}
1548 Tracker& operator=(
const Tracker&
t)
noexcept
1552 copies =
t.copies + 1;
1575 auto v2 =
Vector(std::move(t2));
1580 auto v3 =
Vector(t1, std::move(t2));
1587 auto v4 =
Vector(std::move(v3[0]), v3[1], std::move(t3));
1596 auto v5 =
Cat(v1, v4);
1607 auto v6 =
Cat(std::move(v1), v3);
1616 auto v7 =
Cat(v2, std::move(v4));
1627 auto v8 =
Cat(std::move(v2), std::move(v3));
1639 const std::array<unsigned char, 32> privkey_bytes = {
1642 0xD9, 0x7F, 0x51, 0x08, 0xF1, 0x1C, 0xDA, 0x6E,
1643 0xEE, 0xBA, 0xAA, 0x42, 0x0F, 0xEF, 0x07, 0x26,
1644 0xB1, 0xF8, 0x98, 0x06, 0x0B, 0x98, 0x48, 0x9F,
1645 0xA3, 0x09, 0x84, 0x63, 0xC0, 0x03, 0x28, 0x66
1648 const std::string message =
"Trust no one";
1650 const std::string expected_signature =
1651 "IPojfrX2dfPnH26UegfbGQQLrdK844DlHq5157/P6h57WyuS/Qsl+h/WSVGDF4MUi4rWSswW38oimDYfNNUBUOk=";
1654 std::string generated_signature;
1656 BOOST_REQUIRE_MESSAGE(!privkey.
IsValid(),
1657 "Confirm the private key is invalid");
1659 BOOST_CHECK_MESSAGE(!
MessageSign(privkey, message, generated_signature),
1660 "Sign with an invalid private key");
1662 privkey.
Set(privkey_bytes.begin(), privkey_bytes.end(),
true);
1664 BOOST_REQUIRE_MESSAGE(privkey.
IsValid(),
1665 "Confirm the private key is valid");
1667 BOOST_CHECK_MESSAGE(
MessageSign(privkey, message, generated_signature),
1668 "Sign with a valid private key");
1678 "signature should be irrelevant",
1684 "3B5fQsEXEaV8v6U3ejYc8XaKXAkyQj2MjV",
1685 "signature should be irrelevant",
1691 "1KqbBpLy5FARmTPD4VZnDDpYjkUvkr82Pm",
1692 "invalid signature, not in base64 encoding",
1693 "message should be irrelevant"),
1698 "1KqbBpLy5FARmTPD4VZnDDpYjkUvkr82Pm",
1699 "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=",
1700 "message should be irrelevant"),
1705 "15CRxFdyRpGZLW9w8HnHvVduizdL5jKNbs",
1706 "IPojfrX2dfPnH26UegfbGQQLrdK844DlHq5157/P6h57WyuS/Qsl+h/WSVGDF4MUi4rWSswW38oimDYfNNUBUOk=",
1707 "I never signed this"),
1712 "15CRxFdyRpGZLW9w8HnHvVduizdL5jKNbs",
1713 "IPojfrX2dfPnH26UegfbGQQLrdK844DlHq5157/P6h57WyuS/Qsl+h/WSVGDF4MUi4rWSswW38oimDYfNNUBUOk=",
1719 "11canuhp9X2NocwCq7xNrQYTmUgZAnLK3",
1720 "IIcaIENoYW5jZWxsb3Igb24gYnJpbmsgb2Ygc2Vjb25kIGJhaWxvdXQgZm9yIGJhbmtzIAaHRtbCeDZINyavx14=",
1727 const std::string unsigned_tx =
"...";
1728 const std::string prefixed_message =
1731 std::string(1, (
char)unsigned_tx.length()) +
1735 const uint256 message_hash1 =
Hash(prefixed_message);
1739 BOOST_CHECK_NE(message_hash1, signature_hash);
1805 fs::path tmpfolder = m_args.GetDataDirBase();
1806 fs::path tmpfile = tmpfolder /
"read_binary.dat";
1807 std::string expected_text;
1808 for (
int i = 0; i < 30; i++) {
1809 expected_text +=
"0123456789";
1812 std::ofstream file{tmpfile};
1813 file << expected_text;
1823 auto [valid, text] =
ReadBinaryFile(tmpfile, expected_text.size() / 2);
1829 fs::path invalid_file = tmpfolder /
"invalid_binary.dat";
1838 fs::path tmpfolder = m_args.GetDataDirBase();
1839 fs::path tmpfile = tmpfolder /
"write_binary.dat";
1840 std::string expected_text =
"bitcoin";
1842 std::string actual_text;
1843 std::ifstream file{tmpfile};
1844 file >> actual_text;
1852 std::vector<uint8_t> v = {1, 2, 3};
1859 std::vector<bool> v = {
false,
true,
false,
false,
true,
true};
1866 std::deque<int> v = {1, 3, 3, 7};
1873template <
typename T>
1876 constexpr auto MAX{std::numeric_limits<T>::max()};
1886 BOOST_CHECK_EQUAL(CheckedLeftShift<T>(1, std::numeric_limits<T>::digits - 1), MAX / 2 + 1);
1889 BOOST_CHECK(!CheckedLeftShift<T>((MAX >> 1) + 1, 1));
1891 BOOST_CHECK(!CheckedLeftShift<T>(1, std::numeric_limits<T>::digits));
1892 BOOST_CHECK(!CheckedLeftShift<T>(1, std::numeric_limits<T>::digits + 1));
1894 if constexpr (std::is_signed_v<T>) {
1895 constexpr auto MIN{std::numeric_limits<T>::min()};
1902 BOOST_CHECK(!CheckedLeftShift<T>((MIN >> 1) - 1, 1));
1908template <
typename T>
1911 constexpr auto MAX{std::numeric_limits<T>::max()};
1921 BOOST_CHECK_EQUAL(SaturatingLeftShift<T>(1, std::numeric_limits<T>::digits - 1), MAX / 2 + 1);
1926 BOOST_CHECK_EQUAL(SaturatingLeftShift<T>(1, std::numeric_limits<T>::digits), MAX);
1927 BOOST_CHECK_EQUAL(SaturatingLeftShift<T>(1, std::numeric_limits<T>::digits + 1), MAX);
1929 if constexpr (std::is_signed_v<T>) {
1930 constexpr auto MIN{std::numeric_limits<T>::min()};
1945 TestCheckedLeftShift<uint8_t>();
1946 TestCheckedLeftShift<int8_t>();
1947 TestCheckedLeftShift<size_t>();
1948 TestCheckedLeftShift<uint64_t>();
1949 TestCheckedLeftShift<int64_t>();
1954 TestSaturatingLeftShift<uint8_t>();
1955 TestSaturatingLeftShift<int8_t>();
1956 TestSaturatingLeftShift<size_t>();
1957 TestSaturatingLeftShift<uint64_t>();
1958 TestSaturatingLeftShift<int64_t>();
1965 const auto max_mib{std::numeric_limits<size_t>::max() >> 20};
1966 BOOST_CHECK_EXCEPTION(
operator""_MiB(
static_cast<unsigned long long>(max_mib) + 1), std::overflow_error,
HasReason(
"MiB value too large for size_t byte conversion"));
int64_t CAmount
Amount in satoshis (Can be negative)
static constexpr CAmount COIN
The amount of satoshis in one BTC.
#define Assert(val)
Identity function.
#define Assume(val)
Assume is the identity function.
An encapsulated private key.
bool IsValid() const
Check whether this private key is valid.
void Set(const T pbegin, const T pend, bool fCompressedIn)
Initialize using begin and end iterators to byte data.
BOOST_CHECK_EXCEPTION predicates to check the specific validation error.
A Span is an object that can refer to a contiguous sequence of objects.
constexpr C * begin() const noexcept
constexpr C * end() const noexcept
Path class wrapper to block calls to the fs::path(std::string) implicit constructor and the fs::path:...
std::string FormatSubVersion(const std::string &name, int nClientVersion, const std::vector< std::string > &comments)
Format the subversion field according to BIP 14 spec (https://github.com/bitcoin/bips/blob/master/bip...
uint256 MessageHash(const std::string &message)
Hashes a message for signing and verification in a manner that prevents inadvertently signing a trans...
bool MessageSign(const CKey &privkey, const std::string &message, std::string &signature)
Sign a message.
const std::string MESSAGE_MAGIC
Text used to signify that a signed message follows and to prevent inadvertently signing a transaction...
MessageVerificationResult MessageVerify(const std::string &address, const std::string &signature, const std::string &message)
Verify a signed message.
BOOST_FIXTURE_TEST_SUITE(cuckoocache_tests, BasicTestingSetup)
Test Suite for CuckooCache.
BOOST_AUTO_TEST_SUITE_END()
void ReleaseDirectoryLocks()
Release all directory locks.
uint256 Hash(const T &in1)
Compute the 256-bit hash of an object.
#define T(expected, seed, data)
std::string HexStr(const Span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
std::optional< CAmount > ParseMoney(const std::string &money_string)
Parse an amount denoted in full coins.
std::string FormatMoney(const CAmount n)
Money parsing/formatting utilities.
std::string LogEscapeMessage(std::string_view str)
Belts and suspenders: make sure outgoing log messages don't contain potentially suspicious characters...
static bool create_directories(const std::filesystem::path &p)
Create directory (and if necessary its parents), unless the leaf directory already exists or is a sym...
bool Const(const std::string &str, Span< const char > &sp)
Parse a constant.
Span< const char > Expr(Span< const char > &sp)
Extract the expression that sp begins with.
bool Func(const std::string &str, Span< const char > &sp)
Parse a function call.
""_hex is a compile-time user-defined literal returning a std::array<std::byte>, equivalent to ParseH...
std::vector< std::string > SplitString(std::string_view str, char sep)
consteval uint8_t ConstevalHexDigit(const char c)
consteval version of HexDigit() without the lookup table.
std::string_view TrimStringView(std::string_view str, std::string_view pattern=" \f\n\r\t\v")
std::string_view RemovePrefixView(std::string_view str, std::string_view prefix)
std::string TrimString(std::string_view str, std::string_view pattern=" \f\n\r\t\v")
std::string RemovePrefix(std::string_view str, std::string_view prefix)
auto Join(const C &container, const S &separator, UnaryOp unary_op)
Join all container items.
std::vector< T > Split(const Span< const char > &sp, std::string_view separators)
Split a string on any char found in separators, returning a vector.
void ReplaceAll(std::string &in_out, const std::string &search, const std::string &substitute)
LockResult LockDirectory(const fs::path &directory, const fs::path &lockfile_name, bool probe_only)
#define BOOST_CHECK_EQUAL(v1, v2)
#define BOOST_CHECK(expr)
std::optional< T > CheckedAdd(const T i, const T j) noexcept
T SaturatingAdd(const T i, const T j) noexcept
bool WriteBinaryFile(const fs::path &filename, const std::string &data)
Write contents of std::string to a file.
std::pair< bool, std::string > ReadBinaryFile(const fs::path &filename, size_t maxsize)
Read full contents of a file and return them in a std::string.
@ ERR_MALFORMED_SIGNATURE
The provided signature couldn't be parsed (maybe invalid base64).
@ ERR_INVALID_ADDRESS
The provided address is invalid.
@ ERR_ADDRESS_NO_KEY
The provided address is valid but does not refer to a public key.
@ ERR_NOT_SIGNED
The message was not signed with the private key of the provided address.
@ OK
The message verification was successful.
@ ERR_PUBKEY_NOT_RECOVERED
A public key could not be recovered from the provided signature and message.
Span< const std::byte > MakeByteSpan(V &&v) noexcept
constexpr auto MakeUCharSpan(V &&v) -> decltype(UCharSpanCast(Span{std::forward< V >(v)}))
Like the Span constructor, but for (const) unsigned char member types only.
Span< std::byte > MakeWritableByteSpan(V &&v) noexcept
constexpr bool IsDigit(char c)
Tests if the given character is a decimal digit.
bool TimingResistantEqual(const T &a, const T &b)
Timing-attack-resistant comparison.
std::vector< Byte > ParseHex(std::string_view hex_str)
Like TryParseHex, but returns an empty vector on invalid input.
@ SAFE_CHARS_UA_COMMENT
BIP-0014 subset.
static time_point now() noexcept
Return current system time or mocked time, if set.
#define TRY_LOCK(cs, name)
@ ZEROS
Seed with a compile time constant of zeros.
void UninterruptibleSleep(const std::chrono::microseconds &n)
int64_t GetTime()
DEPRECATED Use either ClockType::now() or Now<TimePointType>() if a cast is needed.
std::string FormatISO8601Date(int64_t nTime)
void SetMockTime(int64_t nMockTimeIn)
DEPRECATED Use SetMockTime with chrono type.
std::optional< int64_t > ParseISO8601DateTime(std::string_view str)
std::string FormatISO8601DateTime(int64_t nTime)
ISO 8601 formatting is preferred.
std::string Capitalize(std::string str)
Capitalizes the first character of the given string.
bool ParseInt32(std::string_view str, int32_t *out)
Convert string to signed 32-bit integer with strict parse error feedback.
bool ParseUInt16(std::string_view str, uint16_t *out)
Convert decimal string to unsigned 16-bit integer with strict parse error feedback.
std::string ToUpper(std::string_view str)
Returns the uppercase equivalent of the given string.
bool ParseFixedPoint(std::string_view val, int decimals, int64_t *amount_out)
Parse number as fixed point according to JSON number syntax.
bool ParseInt64(std::string_view str, int64_t *out)
Convert string to signed 64-bit integer with strict parse error feedback.
bool ParseUInt8(std::string_view str, uint8_t *out)
Convert decimal string to unsigned 8-bit integer with strict parse error feedback.
bool ParseUInt64(std::string_view str, uint64_t *out)
Convert decimal string to unsigned 64-bit integer with strict parse error feedback.
bool IsHex(std::string_view str)
std::string FormatParagraph(std::string_view in, size_t width, size_t indent)
Format a paragraph of text to a fixed width, adding spaces for indentation to any added line.
bool ParseUInt32(std::string_view str, uint32_t *out)
Convert decimal string to unsigned 32-bit integer with strict parse error feedback.
std::optional< std::vector< Byte > > TryParseHex(std::string_view str)
Parse the hex string into bytes (uint8_t or std::byte).
std::optional< uint64_t > ParseByteUnits(std::string_view str, ByteUnit default_multiplier)
Parse a string with suffix unit [k|K|m|M|g|G|t|T].
std::string ToLower(std::string_view str)
Returns the lowercase equivalent of the given string.
std::string SanitizeString(std::string_view str, int rule)
Remove unsafe chars.
int64_t atoi64_legacy(const std::string &str)
constexpr uint8_t HEX_PARSE_OUTPUT[]
constexpr char HEX_PARSE_INPUT[]
static void TestOtherProcess(fs::path dirname, fs::path lockname, int fd)
static constexpr char ExitCommand
static constexpr char UnlockCommand
static void TestAddMatrixOverflow()
static void TestAddMatrix()
BOOST_AUTO_TEST_CASE(util_check)
static void RunToIntegralTests()
static const std::string STRING_WITH_EMBEDDED_NULL_CHAR
static constexpr char LockCommand
static std::string SpanToStr(const Span< const char > &span)
void TestCheckedLeftShift()
void TestSaturatingLeftShift()
V Cat(V v1, V &&v2)
Concatenate two vectors, moving elements.
std::vector< typename std::common_type< Args... >::type > Vector(Args &&... args)
Construct a vector with the specified elements.
void ClearShrink(V &v) noexcept
Clear a vector (or std::deque) and release its allocated memory.