LCOV - code coverage report
Current view: top level - src/test/fuzz - policy_estimator.cpp (source / functions) Coverage Total Hit
Test: fuzz_coverage.info Lines: 98.5 % 68 67
Test Date: 2025-01-22 04:09:46 Functions: 100.0 % 6 6
Branches: 61.6 % 86 53

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2020-2022 The Bitcoin Core developers
       2                 :             : // Distributed under the MIT software license, see the accompanying
       3                 :             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       4                 :             : 
       5                 :             : #include <kernel/mempool_entry.h>
       6                 :             : #include <policy/fees.h>
       7                 :             : #include <policy/fees_args.h>
       8                 :             : #include <primitives/transaction.h>
       9                 :             : #include <streams.h>
      10                 :             : #include <test/fuzz/FuzzedDataProvider.h>
      11                 :             : #include <test/fuzz/fuzz.h>
      12                 :             : #include <test/fuzz/util.h>
      13                 :             : #include <test/fuzz/util/mempool.h>
      14                 :             : #include <test/util/setup_common.h>
      15                 :             : 
      16                 :             : #include <memory>
      17                 :             : #include <optional>
      18                 :             : #include <vector>
      19                 :             : 
      20                 :             : namespace {
      21                 :             : const BasicTestingSetup* g_setup;
      22                 :             : } // namespace
      23                 :             : 
      24                 :           1 : void initialize_policy_estimator()
      25                 :             : {
      26   [ +  -  +  - ]:           2 :     static const auto testing_setup = MakeNoLogFileContext<>();
      27                 :           1 :     g_setup = testing_setup.get();
      28         [ +  - ]:           2 : }
      29                 :             : 
      30         [ +  - ]:        1374 : FUZZ_TARGET(policy_estimator, .init = initialize_policy_estimator)
      31                 :             : {
      32                 :         960 :     FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
      33                 :         960 :     bool good_data{true};
      34                 :             : 
      35         [ +  - ]:         960 :     CBlockPolicyEstimator block_policy_estimator{FeeestPath(*g_setup->m_node.args), DEFAULT_ACCEPT_STALE_FEE_ESTIMATES};
      36   [ +  +  +  +  :      111882 :     LIMITED_WHILE(good_data && fuzzed_data_provider.ConsumeBool(), 10'000)
                   +  + ]
      37                 :             :     {
      38         [ +  - ]:       55099 :         CallOneOf(
      39                 :             :             fuzzed_data_provider,
      40                 :       21127 :             [&] {
      41                 :       21127 :                 const std::optional<CMutableTransaction> mtx = ConsumeDeserializable<CMutableTransaction>(fuzzed_data_provider, TX_WITH_WITNESS);
      42         [ +  + ]:       21127 :                 if (!mtx) {
      43                 :         114 :                     good_data = false;
      44         [ -  + ]:         114 :                     return;
      45                 :             :                 }
      46         [ +  - ]:       21013 :                 const CTransaction tx{*mtx};
      47                 :       21013 :                 const CTxMemPoolEntry& entry = ConsumeTxMemPoolEntry(fuzzed_data_provider, tx);
      48                 :       21013 :                 const auto tx_submitted_in_package = fuzzed_data_provider.ConsumeBool();
      49                 :       21013 :                 const auto tx_has_mempool_parents = fuzzed_data_provider.ConsumeBool();
      50         [ +  - ]:       21013 :                 const auto tx_info = NewMempoolTransactionInfo(entry.GetSharedTx(), entry.GetFee(),
      51         [ +  - ]:       21013 :                                                                entry.GetTxSize(), entry.GetHeight(),
      52                 :             :                                                                /*mempool_limit_bypassed=*/false,
      53                 :             :                                                                tx_submitted_in_package,
      54                 :             :                                                                /*chainstate_is_current=*/true,
      55   [ +  -  +  -  :       42026 :                                                                tx_has_mempool_parents);
                   +  - ]
      56         [ +  - ]:       21013 :                 block_policy_estimator.processTransaction(tx_info);
      57         [ +  + ]:       21013 :                 if (fuzzed_data_provider.ConsumeBool()) {
      58         [ +  - ]:        6454 :                     (void)block_policy_estimator.removeTx(tx.GetHash());
      59                 :             :                 }
      60         [ +  - ]:       63153 :             },
      61                 :        6982 :             [&] {
      62                 :        6982 :                 std::list<CTxMemPoolEntry> mempool_entries;
      63   [ +  +  +  - ]:       22589 :                 LIMITED_WHILE(fuzzed_data_provider.ConsumeBool(), 10000)
      64                 :             :                 {
      65                 :       15729 :                     const std::optional<CMutableTransaction> mtx = ConsumeDeserializable<CMutableTransaction>(fuzzed_data_provider, TX_WITH_WITNESS);
      66         [ +  + ]:       15729 :                     if (!mtx) {
      67                 :         122 :                         good_data = false;
      68         [ -  + ]:         122 :                         break;
      69                 :             :                     }
      70         [ +  - ]:       15607 :                     const CTransaction tx{*mtx};
      71         [ +  - ]:       15607 :                     mempool_entries.emplace_back(CTxMemPoolEntry::ExplicitCopy, ConsumeTxMemPoolEntry(fuzzed_data_provider, tx));
      72         [ +  - ]:       31336 :                 }
      73                 :        6982 :                 std::vector<RemovedMempoolTransactionInfo> txs;
      74         [ +  - ]:        6982 :                 txs.reserve(mempool_entries.size());
      75         [ +  + ]:       22589 :                 for (const CTxMemPoolEntry& mempool_entry : mempool_entries) {
      76         [ +  - ]:       15607 :                     txs.emplace_back(mempool_entry);
      77                 :             :                 }
      78         [ +  - ]:        6982 :                 block_policy_estimator.processBlock(txs, fuzzed_data_provider.ConsumeIntegral<unsigned int>());
      79                 :        6982 :             },
      80                 :        1031 :             [&] {
      81                 :        1031 :                 (void)block_policy_estimator.removeTx(ConsumeUInt256(fuzzed_data_provider));
      82                 :        1031 :             },
      83                 :       25959 :             [&] {
      84                 :       25959 :                 block_policy_estimator.FlushUnconfirmed();
      85                 :       25959 :             });
      86         [ +  - ]:       55099 :         (void)block_policy_estimator.estimateFee(fuzzed_data_provider.ConsumeIntegral<int>());
      87                 :       55099 :         EstimationResult result;
      88                 :       55099 :         auto conf_target = fuzzed_data_provider.ConsumeIntegral<int>();
      89                 :       55099 :         auto success_threshold = fuzzed_data_provider.ConsumeFloatingPoint<double>();
      90                 :       55099 :         auto horizon = fuzzed_data_provider.PickValueInArray(ALL_FEE_ESTIMATE_HORIZONS);
      91         [ +  + ]:       55099 :         auto* result_ptr = fuzzed_data_provider.ConsumeBool() ? &result : nullptr;
      92         [ +  - ]:       55099 :         (void)block_policy_estimator.estimateRawFee(conf_target, success_threshold, horizon, result_ptr);
      93                 :             : 
      94                 :       55099 :         FeeCalculation fee_calculation;
      95                 :       55099 :         conf_target = fuzzed_data_provider.ConsumeIntegral<int>();
      96         [ +  + ]:       55099 :         auto* fee_calc_ptr = fuzzed_data_provider.ConsumeBool() ? &fee_calculation : nullptr;
      97                 :       55099 :         auto conservative = fuzzed_data_provider.ConsumeBool();
      98         [ +  - ]:       55099 :         (void)block_policy_estimator.estimateSmartFee(conf_target, fee_calc_ptr, conservative);
      99                 :             : 
     100         [ +  - ]:       55099 :         (void)block_policy_estimator.HighestTargetTracked(fuzzed_data_provider.PickValueInArray(ALL_FEE_ESTIMATE_HORIZONS));
     101                 :             :     }
     102                 :         960 :     {
     103         [ +  - ]:         960 :         FuzzedFileProvider fuzzed_file_provider{fuzzed_data_provider};
     104   [ +  -  +  - ]:         960 :         AutoFile fuzzed_auto_file{fuzzed_file_provider.open()};
     105         [ +  - ]:         960 :         block_policy_estimator.Write(fuzzed_auto_file);
     106         [ +  - ]:         960 :         block_policy_estimator.Read(fuzzed_auto_file);
     107                 :           0 :     }
     108                 :         960 : }
        

Generated by: LCOV version 2.0-1