From fadd568931a2d21e0f80e1efaf2281f5164fa20e Mon Sep 17 00:00:00 2001 From: MarcoFalke <*~=`'#}+{/-|&$^_@721217.xyz> Date: Wed, 18 Dec 2024 09:13:35 +0100 Subject: [PATCH] fuzz: Fix misplaced SeedRand::ZEROS After commit fae63bf13033adec80c7e6d73144a21ea3cfbc6d this must be placed even before test_setup. --- src/test/fuzz/util/check_globals.cpp | 6 +++--- src/test/fuzz/utxo_total_supply.cpp | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/test/fuzz/util/check_globals.cpp b/src/test/fuzz/util/check_globals.cpp index 4b74ddedd63f0..fbc5a55598bef 100644 --- a/src/test/fuzz/util/check_globals.cpp +++ b/src/test/fuzz/util/check_globals.cpp @@ -24,12 +24,12 @@ struct CheckGlobalsImpl { "The current fuzz target used the global random state.\n\n" "This is acceptable, but requires the fuzz target to call \n" - "SeedRandomStateForTest(SeedRand::ZEROS) at the beginning \n" - "of processing the fuzz input.\n\n" + "SeedRandomStateForTest(SeedRand::ZEROS) in the first line \n" + "of the FUZZ_TARGET function.\n\n" "An alternative solution would be to avoid any use of globals.\n\n" - "Without a solution, fuzz stability and determinism can lead \n" + "Without a solution, fuzz instability and non-determinism can lead \n" "to non-reproducible bugs or inefficient fuzzing.\n\n" << std::endl; std::abort(); // Abort, because AFL may try to recover from a std::exit diff --git a/src/test/fuzz/utxo_total_supply.cpp b/src/test/fuzz/utxo_total_supply.cpp index 8dfc6c8e57511..84d82f71e2898 100644 --- a/src/test/fuzz/utxo_total_supply.cpp +++ b/src/test/fuzz/utxo_total_supply.cpp @@ -21,6 +21,7 @@ using node::BlockAssembler; FUZZ_TARGET(utxo_total_supply) { + SeedRandomStateForTest(SeedRand::ZEROS); /** The testing setup that creates a chainman only (no chainstate) */ ChainTestingSetup test_setup{ ChainType::REGTEST, @@ -28,7 +29,6 @@ FUZZ_TARGET(utxo_total_supply) .extra_args = {"-testactivationheight=bip34@2"}, }, }; - SeedRandomStateForTest(SeedRand::ZEROS); // Can not be done before test_setup // Create chainstate test_setup.LoadVerifyActivateChainstate(); auto& node{test_setup.m_node};