From adf67eb21baf39a222b65480e45ae76f093e8f66 Mon Sep 17 00:00:00 2001 From: brunoerg Date: Fri, 15 Aug 2025 10:13:47 -0300 Subject: [PATCH] fuzz: create FeeEstimatorTestingSetup to set fee_estimator --- src/wallet/test/fuzz/fees.cpp | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/src/wallet/test/fuzz/fees.cpp b/src/wallet/test/fuzz/fees.cpp index 515c3b19078..9cf7e89deb3 100644 --- a/src/wallet/test/fuzz/fees.cpp +++ b/src/wallet/test/fuzz/fees.cpp @@ -14,7 +14,23 @@ namespace wallet { namespace { -TestingSetup* g_setup; + +struct FeeEstimatorTestingSetup : public TestingSetup { + FeeEstimatorTestingSetup(const ChainType chain_type, TestOpts opts) : TestingSetup{chain_type, opts} + { + } + + ~FeeEstimatorTestingSetup() { + m_node.fee_estimator.reset(); + } + + void SetFeeEstimator(std::unique_ptr fee_estimator) + { + m_node.fee_estimator = std::move(fee_estimator); + } +}; + +FeeEstimatorTestingSetup* g_setup; class FuzzedBlockPolicyEstimator : public CBlockPolicyEstimator { @@ -37,7 +53,7 @@ public: void initialize_setup() { - static const auto testing_setup = MakeNoLogFileContext(); + static const auto testing_setup = MakeNoLogFileContext(); g_setup = testing_setup.get(); } @@ -57,7 +73,7 @@ FUZZ_TARGET(wallet_fees, .init = initialize_setup) }; node.mempool = std::make_unique(mempool_opts, error); std::unique_ptr fee_estimator = std::make_unique(fuzzed_data_provider); - node.fee_estimator = std::move(fee_estimator); + g_setup->SetFeeEstimator(std::move(fee_estimator)); std::unique_ptr wallet_ptr{std::make_unique(node.chain.get(), "", CreateMockableWalletDatabase())}; CWallet& wallet{*wallet_ptr}; {