mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-03-02 01:36:13 +00:00
Merge bitcoin/bitcoin#34511: test: fully reset the state of CConnman in tests
2cb7e99deee1017a6edd94d82de556895138361d test: also reset CConnman::m_private_broadcast in tests (Vasil Dimov) 91b7c874e2b1479ed29f067cd1bef7724aabd951 test: add ConnmanTestMsg convenience method Reset() (Vasil Dimov) Pull request description: Member variables of `CConnman::m_private_broadcast` (introduced in https://github.com/bitcoin/bitcoin/pull/29415) could influence the tests which creates non-determinism if the same instance of `CConnman` is used for repeated test iterations. So, reset the state of `CConnman::m_private_broadcast` from `ConnmanTestMsg::Reset()`. Currently this affects the fuzz tests `process_message` and `process_messages`. Reported in https://github.com/bitcoin/bitcoin/issues/34476#issuecomment-3849088794 ACKs for top commit: maflcko: review ACK 2cb7e99deee1017a6edd94d82de556895138361d 🚙 Crypt-iQ: tACK 2cb7e99deee1017a6edd94d82de556895138361d frankomosh: Code Review ACK 2cb7e99deee1017a6edd94d82de556895138361d brunoerg: code review ACK 2cb7e99deee1017a6edd94d82de556895138361d Tree-SHA512: 0f4b114542da8dc611689457ce67034c15cbfe409b006b2db72bc74078ee9513f5ce3d0e6e67d37c127cfa0a5170fe72fe3ea45ce2a61d45a358dd11bd1881f8
This commit is contained in:
commit
84e826ddc1
@ -1241,7 +1241,7 @@ public:
|
||||
/// Wait for the number of needed connections to become greater than 0.
|
||||
void NumToOpenWait() const;
|
||||
|
||||
private:
|
||||
protected:
|
||||
/**
|
||||
* Check if private broadcast can be done to IPv4 or IPv6 peers and if so via which proxy.
|
||||
* If private broadcast connections should not be opened to IPv4 or IPv6, then this will
|
||||
@ -1251,6 +1251,8 @@ public:
|
||||
|
||||
/// Number of `ConnectionType::PRIVATE_BROADCAST` connections to open.
|
||||
std::atomic_size_t m_num_to_open{0};
|
||||
|
||||
friend struct ConnmanTestMsg;
|
||||
} m_private_broadcast;
|
||||
|
||||
bool CheckIncomingNonce(uint64_t nonce);
|
||||
|
||||
@ -72,8 +72,7 @@ FUZZ_TARGET(process_message, .init = initialize_process_message)
|
||||
|
||||
auto& node{g_setup->m_node};
|
||||
auto& connman{static_cast<ConnmanTestMsg&>(*node.connman)};
|
||||
connman.ResetAddrCache();
|
||||
connman.ResetMaxOutboundCycle();
|
||||
connman.Reset();
|
||||
auto& chainman{static_cast<TestChainstateManager&>(*node.chainman)};
|
||||
const auto block_index_size{WITH_LOCK(chainman.GetMutex(), return chainman.BlockIndex().size())};
|
||||
SetMockTime(1610000000); // any time to successfully reset ibd
|
||||
|
||||
@ -62,8 +62,7 @@ FUZZ_TARGET(process_messages, .init = initialize_process_messages)
|
||||
|
||||
auto& node{g_setup->m_node};
|
||||
auto& connman{static_cast<ConnmanTestMsg&>(*node.connman)};
|
||||
connman.ResetAddrCache();
|
||||
connman.ResetMaxOutboundCycle();
|
||||
connman.Reset();
|
||||
auto& chainman{static_cast<TestChainstateManager&>(*node.chainman)};
|
||||
const auto block_index_size{WITH_LOCK(chainman.GetMutex(), return chainman.BlockIndex().size())};
|
||||
SetMockTime(1610000000); // any time to successfully reset ibd
|
||||
|
||||
@ -80,6 +80,14 @@ void ConnmanTestMsg::ResetMaxOutboundCycle()
|
||||
nMaxOutboundTotalBytesSentInCycle = 0;
|
||||
}
|
||||
|
||||
void ConnmanTestMsg::Reset()
|
||||
{
|
||||
ResetAddrCache();
|
||||
ResetMaxOutboundCycle();
|
||||
m_private_broadcast.m_outbound_tor_ok_at_least_once.store(false);
|
||||
m_private_broadcast.m_num_to_open.store(0);
|
||||
}
|
||||
|
||||
void ConnmanTestMsg::NodeReceiveMsgBytes(CNode& node, std::span<const uint8_t> msg_bytes, bool& complete) const
|
||||
{
|
||||
assert(node.ReceiveMsgBytes(msg_bytes, complete));
|
||||
|
||||
@ -49,6 +49,8 @@ struct ConnmanTestMsg : public CConnman {
|
||||
|
||||
void ResetAddrCache();
|
||||
void ResetMaxOutboundCycle();
|
||||
/// Reset the internal state.
|
||||
void Reset();
|
||||
|
||||
std::vector<CNode*> TestNodes()
|
||||
{
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user