LCOV - code coverage report
Current view: top level - src/test/fuzz - process_messages.cpp (source / functions) Coverage Total Hit
Test: fuzz_coverage.info Lines: 97.1 % 68 66
Test Date: 2026-03-22 04:00:06 Functions: 100.0 % 6 6
Branches: 57.0 % 86 49

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2020-present 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 <banman.h>
       6                 :             : #include <consensus/consensus.h>
       7                 :             : #include <net.h>
       8                 :             : #include <net_processing.h>
       9                 :             : #include <node/warnings.h>
      10                 :             : #include <protocol.h>
      11                 :             : #include <script/script.h>
      12                 :             : #include <sync.h>
      13                 :             : #include <test/fuzz/FuzzedDataProvider.h>
      14                 :             : #include <test/fuzz/fuzz.h>
      15                 :             : #include <test/fuzz/util.h>
      16                 :             : #include <test/fuzz/util/net.h>
      17                 :             : #include <test/util/mining.h>
      18                 :             : #include <test/util/net.h>
      19                 :             : #include <test/util/setup_common.h>
      20                 :             : #include <test/util/time.h>
      21                 :             : #include <test/util/validation.h>
      22                 :             : #include <util/time.h>
      23                 :             : #include <validationinterface.h>
      24                 :             : 
      25                 :             : #include <ios>
      26                 :             : #include <string>
      27                 :             : #include <utility>
      28                 :             : #include <vector>
      29                 :             : 
      30                 :             : namespace {
      31                 :             : TestingSetup* g_setup;
      32                 :             : 
      33                 :         199 : void ResetChainman(TestingSetup& setup)
      34                 :             : {
      35                 :         199 :     SetMockTime(setup.m_node.chainman->GetParams().GenesisBlock().Time());
      36         [ +  - ]:         199 :     setup.m_node.chainman.reset();
      37                 :         199 :     setup.m_make_chainman();
      38                 :         199 :     setup.LoadVerifyActivateChainstate();
      39                 :         199 :     node::BlockAssembler::Options options;
      40                 :         199 :     options.include_dummy_extranonce = true;
      41         [ +  + ]:       39999 :     for (int i = 0; i < 2 * COINBASE_MATURITY; i++) {
      42         [ +  - ]:       39800 :         MineBlock(setup.m_node, options);
      43                 :             :     }
      44                 :         199 : }
      45                 :             : } // namespace
      46                 :             : 
      47                 :           1 : void initialize_process_messages()
      48                 :             : {
      49                 :           1 :     static const auto testing_setup{
      50                 :             :         MakeNoLogFileContext<TestingSetup>(
      51                 :             :             /*chain_type=*/ChainType::REGTEST,
      52                 :             :             {}),
      53   [ +  -  +  -  :           1 :     };
                   +  - ]
      54                 :           1 :     g_setup = testing_setup.get();
      55                 :           1 :     ResetChainman(*g_setup);
      56                 :           1 : }
      57                 :             : 
      58         [ +  - ]:        2524 : FUZZ_TARGET(process_messages, .init = initialize_process_messages)
      59                 :             : {
      60                 :        2066 :     SeedRandomStateForTest(SeedRand::ZEROS);
      61                 :        2066 :     FuzzedDataProvider fuzzed_data_provider(buffer.data(), buffer.size());
      62                 :             : 
      63                 :        2066 :     auto& node{g_setup->m_node};
      64                 :        2066 :     auto& connman{static_cast<ConnmanTestMsg&>(*node.connman)};
      65                 :        2066 :     connman.Reset();
      66                 :        2066 :     auto& chainman{static_cast<TestChainstateManager&>(*node.chainman)};
      67         [ +  - ]:        4132 :     const auto block_index_size{WITH_LOCK(chainman.GetMutex(), return chainman.BlockIndex().size())};
      68                 :        2066 :     NodeClockContext clock_ctx{1610000000s}; // any time to successfully reset ibd
      69         [ +  - ]:        2066 :     chainman.ResetIbd();
      70         [ +  - ]:        2066 :     chainman.DisableNextWrite();
      71                 :             : 
      72                 :             :     // Reset, so that dangling pointers can be detected by sanitizers.
      73         [ +  + ]:        2066 :     node.banman.reset();
      74         [ +  - ]:        2066 :     node.addrman.reset();
      75         [ +  - ]:        2066 :     node.peerman.reset();
      76         [ +  - ]:        2066 :     node.addrman = std::make_unique<AddrMan>(*node.netgroupman, /*deterministic=*/true, /*consistency_check_ratio=*/0);
      77                 :        4132 :     node.peerman = PeerManager::make(connman, *node.addrman,
      78                 :             :                                      /*banman=*/nullptr, chainman,
      79         [ +  - ]:        2066 :                                      *node.mempool, *node.warnings,
      80                 :             :                                      PeerManager::Options{
      81                 :             :                                          .reconcile_txs = true,
      82                 :             :                                          .deterministic_rng = true,
      83                 :        2066 :                                      });
      84         [ +  - ]:        2066 :     connman.SetMsgProc(node.peerman.get());
      85         [ +  - ]:        2066 :     connman.SetAddrman(*node.addrman);
      86                 :             : 
      87         [ +  - ]:        2066 :     node.validation_signals->RegisterValidationInterface(node.peerman.get());
      88                 :             : 
      89         [ +  - ]:        2066 :     LOCK(NetEventsInterface::g_msgproc_mutex);
      90                 :             : 
      91                 :        2066 :     std::vector<CNode*> peers;
      92                 :        2066 :     const auto num_peers_to_add = fuzzed_data_provider.ConsumeIntegralInRange(1, 3);
      93         [ +  + ]:        5627 :     for (int i = 0; i < num_peers_to_add; ++i) {
      94         [ +  - ]:        3561 :         peers.push_back(ConsumeNodeAsUniquePtr(fuzzed_data_provider, i).release());
      95                 :        3561 :         CNode& p2p_node = *peers.back();
      96                 :             : 
      97                 :        3561 :         FillNode(fuzzed_data_provider, connman, p2p_node);
      98                 :             : 
      99         [ +  - ]:        3561 :         connman.AddTestNode(p2p_node);
     100                 :             :     }
     101                 :             : 
     102   [ +  +  +  + ]:       28064 :     LIMITED_WHILE(fuzzed_data_provider.ConsumeBool(), 30)
     103                 :             :     {
     104   [ +  -  +  - ]:       25998 :         const std::string random_message_type{fuzzed_data_provider.ConsumeBytesAsString(CMessageHeader::MESSAGE_TYPE_SIZE).c_str()};
     105                 :             : 
     106         [ +  - ]:       25998 :         clock_ctx.set(ConsumeTime(fuzzed_data_provider));
     107                 :             : 
     108         [ +  - ]:       25998 :         CSerializedNetMsg net_msg;
     109         [ +  - ]:       25998 :         net_msg.m_type = random_message_type;
     110                 :       25998 :         net_msg.data = ConsumeRandomLengthByteVector(fuzzed_data_provider, MAX_PROTOCOL_MESSAGE_LENGTH);
     111                 :             : 
     112                 :       25998 :         CNode& random_node = *PickValue(fuzzed_data_provider, peers);
     113                 :             : 
     114         [ +  - ]:       25998 :         connman.FlushSendBuffer(random_node);
     115         [ +  - ]:       25998 :         (void)connman.ReceiveMsgFrom(random_node, std::move(net_msg));
     116                 :             : 
     117                 :             :         bool more_work{true};
     118         [ +  + ]:      179701 :         while (more_work) { // Ensure that every message is eventually processed in some way or another
     119         [ +  - ]:      153703 :             random_node.fPauseSend = false;
     120                 :             : 
     121                 :      153703 :             try {
     122         [ +  - ]:      153703 :                 more_work = connman.ProcessMessagesOnce(random_node);
     123         [ -  - ]:           0 :             } catch (const std::ios_base::failure&) {
     124                 :           0 :             }
     125         [ +  - ]:      153703 :             node.peerman->SendMessages(random_node);
     126                 :             :         }
     127                 :       25998 :     }
     128         [ +  - ]:        2066 :     node.validation_signals->SyncWithValidationInterfaceQueue();
     129         [ +  - ]:        2066 :     node.validation_signals->UnregisterValidationInterface(node.peerman.get());
     130         [ +  - ]:        2066 :     node.connman->StopNodes();
     131   [ +  -  +  + ]:        4132 :     if (block_index_size != WITH_LOCK(chainman.GetMutex(), return chainman.BlockIndex().size())) {
     132                 :             :         // Reuse the global chainman, but reset it when it is dirty
     133         [ +  - ]:         198 :         ResetChainman(*g_setup);
     134                 :             :     }
     135         [ +  - ]:        4132 : }
        

Generated by: LCOV version 2.0-1