mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-11-12 06:58:57 +01:00
Merge bitcoin/bitcoin#23218: p2p: Use mocktime for ping timeout
fadf1186c8p2p: Use mocktime for ping timeout (MarcoFalke) Pull request description: It is slightly confusing to use mocktime for some times, but not others. Start fixing that by making the ping timeout use mocktime. The only downside would be that tests that use mocktime disconnect peers after this patch. However, I don't think this is an issue, as the inactivity check is already disabled for all functional tests after commit6d76b57ca0. Only one unit test needed the inactivity check disabled as part of this patch. A nice side effect of this patch is that the `p2p_ping` functional test now runs 4 seconds faster. ACKs for top commit: laanwj: Code review ACKfadf1186c8Tree-SHA512: e9e7b21040a89d9d574b3038f85a67e6336de6cd6e41aa286769cd03cada6e75a94ec01700e052e56d822ef85d7813cc06bf7e67b81543eff8917a16cdccf942
This commit is contained in:
@@ -30,11 +30,16 @@ class NodeNoPong(P2PInterface):
|
||||
pass
|
||||
|
||||
|
||||
TIMEOUT_INTERVAL = 20 * 60
|
||||
|
||||
|
||||
class PingPongTest(BitcoinTestFramework):
|
||||
def set_test_params(self):
|
||||
self.setup_clean_chain = True
|
||||
self.num_nodes = 1
|
||||
self.extra_args = [['-peertimeout=3']]
|
||||
# Set the peer connection timeout low. It does not matter for this
|
||||
# test, as long as it is less than TIMEOUT_INTERVAL.
|
||||
self.extra_args = [['-peertimeout=1']]
|
||||
|
||||
def check_peer_info(self, *, pingtime, minping, pingwait):
|
||||
stats = self.nodes[0].getpeerinfo()[0]
|
||||
@@ -110,8 +115,11 @@ class PingPongTest(BitcoinTestFramework):
|
||||
self.nodes[0].ping()
|
||||
no_pong_node.wait_until(lambda: 'ping' in no_pong_node.last_message)
|
||||
with self.nodes[0].assert_debug_log(['ping timeout: 1201.000000s']):
|
||||
self.mock_forward(20 * 60 + 1)
|
||||
time.sleep(4) # peertimeout + 1
|
||||
self.mock_forward(TIMEOUT_INTERVAL // 2)
|
||||
# Check that sending a ping does not prevent the disconnect
|
||||
no_pong_node.sync_with_ping()
|
||||
self.mock_forward(TIMEOUT_INTERVAL // 2 + 1)
|
||||
no_pong_node.wait_for_disconnect()
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
||||
Reference in New Issue
Block a user