mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-08 10:31:50 -05:00
[net processing] Add Orphanage empty consistency check
When removing the final peer, assert that m_tx_orphanage is empty.
This commit is contained in:
parent
201c5e4aec
commit
9190b01d8d
2 changed files with 8 additions and 0 deletions
|
@ -1194,6 +1194,7 @@ void PeerManagerImpl::FinalizeNode(const CNode& node)
|
|||
assert(m_outbound_peers_with_protect_from_disconnect == 0);
|
||||
assert(m_wtxid_relay_peers == 0);
|
||||
assert(m_txrequest.Size() == 0);
|
||||
assert(m_orphanage.Size() == 0);
|
||||
}
|
||||
} // cs_main
|
||||
if (node.fSuccessfullyConnected && misbehavior == 0 &&
|
||||
|
|
|
@ -47,6 +47,13 @@ public:
|
|||
* (ie orphans that may have found their final missing parent, and so should be reconsidered for the mempool) */
|
||||
void AddChildrenToWorkSet(const CTransaction& tx, std::set<uint256>& orphan_work_set) const EXCLUSIVE_LOCKS_REQUIRED(g_cs_orphans);
|
||||
|
||||
/** Return how many entries exist in the orphange */
|
||||
size_t Size() LOCKS_EXCLUDED(::g_cs_orphans)
|
||||
{
|
||||
LOCK(::g_cs_orphans);
|
||||
return m_orphans.size();
|
||||
}
|
||||
|
||||
protected:
|
||||
struct OrphanTx {
|
||||
CTransactionRef tx;
|
||||
|
|
Loading…
Add table
Reference in a new issue