fuzz: add mempool_utils.cpp #26250
pull fanquake wants to merge 2 commits into bitcoin:master from fanquake:fuzz_add_mempool_utils_h changing 10 files +43 −25-
fanquake commented at 2:49 pm on October 4, 2022: memberMoving the heavy (Boost) mempool code out of fuzz/util.h. Means that (for ex) a crypto_common fuzz unit doesn’t need to care about seeing endless Boost headers. This results in a ~10% speedup (for me) when compiling the fuzz tests. Your results may vary.
-
fanquake added the label Tests on Oct 4, 2022
-
in src/Makefile.test_fuzz.include:20 in 53366df01e outdated
16@@ -17,5 +17,6 @@ libtest_fuzz_a_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) $(BOOST_CPPFLAGS) 17 libtest_fuzz_a_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS) 18 libtest_fuzz_a_SOURCES = \ 19 test/fuzz/fuzz.cpp \ 20+ test/fuzz/mempool_utils.cpp \
maflcko commented at 3:06 pm on October 4, 2022:I wonder if we can nest more folders. Maybesrc/test/fuzz/util/mempool.cpp
to differentiate utils from tests?
fanquake commented at 4:53 pm on October 4, 2022:Added some nesting.in src/test/fuzz/mempool_utils.cpp:20 in 53366df01e outdated
15+{ 16+ // Avoid: 17+ // policy/feerate.cpp:28:34: runtime error: signed integer overflow: 34873208148477500 * 1000 cannot be represented in type 'long' 18+ // 19+ // Reproduce using CFeeRate(348732081484775, 10).GetFeePerK() 20+ const CAmount fee = std::min<CAmount>(ConsumeMoney(fuzzed_data_provider), std::numeric_limits<CAmount>::max() / static_cast<CAmount>(100000));
maflcko commented at 3:08 pm on October 4, 2022:unrelated:
0 const CAmount fee{ConsumeMoney(fuzzed_data_provider, /*max=*/std::numeric_limits<CAmount>::max() / CAmount{100'000})};
It should be possible to just pass the max. (Can do in a separate commit, if you want)
fanquake commented at 4:53 pm on October 4, 2022:Added another commit for this.maflcko commented at 3:08 pm on October 4, 2022: memberlgtmfanquake force-pushed on Oct 4, 2022fuzz: add util/mempool/h.cpp
Moving the mempool code (Boost) out of util.h, results in a ~10% speedup (for me) when compiling the fuzz tests.
fuzz: pass max fee into ConsumeTxMemPoolEntry 8a6b6dfcd8fanquake force-pushed on Oct 4, 2022DrahtBot commented at 8:23 pm on October 4, 2022: contributorThe following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
Reviewers, this pull request conflicts with the following ones:
- #17786 (refactor: Nuke policy/fees->mempool circular dependencies by hebasto)
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.
in src/test/fuzz/util/mempool.h:9 in eb15569280 outdated
6-#define BITCOIN_TEST_FUZZ_MEMPOOL_UTILS_H 7+#ifndef BITCOIN_TEST_FUZZ_UTIL_MEMPOOL_H 8+#define BITCOIN_TEST_FUZZ_UTIL_MEMPOOL_H 9 10+#include <primitives/transaction.h> 11+#include <test/fuzz/FuzzedDataProvider.h>
maflcko commented at 8:27 am on October 5, 2022:those two includes could be fwd-decls, but it doesn’t matter because everywhere where this header is included, the full includes already existmaflcko approvedmaflcko commented at 8:28 am on October 5, 2022: memberreview ACK 8a6b6dfcd8d26b62c3a13beba72440635fcc5e19 🍮
Signature:
0-----BEGIN PGP SIGNED MESSAGE----- 1Hash: SHA512 2 3review ACK 8a6b6dfcd8d26b62c3a13beba72440635fcc5e19 🍮 4-----BEGIN PGP SIGNATURE----- 5 6iQGzBAEBCgAdFiEE+rVPoUahrI9sLGYTzit1aX5ppUgFAlwqrYAACgkQzit1aX5p 7pUgJuAv+MyuzOk4R07Q6iwAbpfd78pnXvv/5J2YAj5mpWWifj9ZAJL72sYk/K1I8 85K4ukFrthMelgGVV7Hkz7KcSEQu/rRpjHRRILFuYsnxGwhVYi4RCH0w+s4jrotBc 9onA2qBJaft8ULZtZg1wDS+Lkl8VLQ9bwkYmUkZgJf9vaUQwMYFlO70QkqidubjcR 10+lslpo9UkFD4uH8q9YLClPvGWWxpjB/6x8/CKDEVt7Yfu1cQypX6kmgrG4T2Kmgi 116FrJDAM0ECts/di/V1TLhRsGdQrSMhDxx0UawygzgaLTBc38ezG7sE17ram+ems+ 12cpE+mDhWu56QWG6hCrpIyRH2pkDcjymAwIjfEug9EromErGocKKpY1nK5BVaqNbl 13KKhrNnZ4x+DBhvgBxCiGzfGFP2oGgDAKPY4Ke22LjdpdC1szqBcLMdWVyPCKrJBc 14VzypwHcwe8rGkqZaVmGzIGB7PSEfJCEhvscA31Z7vFBsuHqTiz/OROgV+J4+/qPr 15fQ8WY0tK 16=GxLp 17-----END PGP SIGNATURE-----
maflcko merged this on Oct 5, 2022maflcko closed this on Oct 5, 2022
glozow commented at 8:41 am on October 5, 2022: memberpost-merge concept ACKsidhujag referenced this in commit 05b8fd05f9 on Oct 5, 2022fanquake deleted the branch on Oct 10, 2022bitcoin locked this on Oct 10, 2023
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 00:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me