mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-10-10 19:43:13 +02:00
Merge bitcoin/bitcoin#28805: test: Make existing functional tests compatible with --v2transport
35fb9930ad
test: enable v2 transport for p2p_timeouts.py (Martin Zumsande)2c1669c37a
test: enable v2 transport for rpc_net.py (Sebastian Falbesoner)cc961c2695
test: enable v2 transport for p2p_node_network_limited.py (Sebastian Falbesoner)3598a1b5c9
test: enable --v2transport in combination with --usecli (Martin Zumsande)68a9001751
test: persist -v2transport over restarts and respect -v2transport=0 (Martin Zumsande) Pull request description: This makes the functional test suite compatible with BIP324, so that `python3 test_runner.py --v2transport` should succeed (currently, 12 tests fail for me on master). Includes two commits by TheStack I found in an old discussion https://github.com/bitcoin/bitcoin/pull/28331#discussion_r1326714164 Note that even though all tests should pass, the python `p2p.py` module will do v2 connections only after the merge of #24748, so that for now only connections between two full nodes will actually run v2. Some of the fixed tests were added with `--v2transport` to the test runner. Though after #24748 we might also want to consider running the entire suite with `--v2transport` in some CI. ACKs for top commit: sipa: utACK35fb9930ad
. Thanks for taking care of this. achow101: ACK35fb9930ad
theStack: ACK35fb9930ad
stratospher: ACK35fb993
. Tree-SHA512: 80dc0bf211fa525ff1d092043aea9f222f14c02e5832a548fb8b83b9ede1fcee03c5e8ade0d05c331bdaa492af9c1cf3d0f0b15b846673c6eacea82dd4cefbc3
This commit is contained in:
@@ -150,7 +150,7 @@ class NetTest(BitcoinTestFramework):
|
||||
"synced_blocks": -1,
|
||||
"synced_headers": -1,
|
||||
"timeoffset": 0,
|
||||
"transport_protocol_type": "v1",
|
||||
"transport_protocol_type": "v1" if not self.options.v2transport else "detecting",
|
||||
"version": 0,
|
||||
},
|
||||
)
|
||||
@@ -160,19 +160,23 @@ class NetTest(BitcoinTestFramework):
|
||||
def test_getnettotals(self):
|
||||
self.log.info("Test getnettotals")
|
||||
# Test getnettotals and getpeerinfo by doing a ping. The bytes
|
||||
# sent/received should increase by at least the size of one ping (32
|
||||
# bytes) and one pong (32 bytes).
|
||||
# sent/received should increase by at least the size of one ping
|
||||
# and one pong. Both have a payload size of 8 bytes, but the total
|
||||
# size depends on the used p2p version:
|
||||
# - p2p v1: 24 bytes (header) + 8 bytes (payload) = 32 bytes
|
||||
# - p2p v2: 21 bytes (header/tag with short-id) + 8 bytes (payload) = 29 bytes
|
||||
ping_size = 32 if not self.options.v2transport else 29
|
||||
net_totals_before = self.nodes[0].getnettotals()
|
||||
peer_info_before = self.nodes[0].getpeerinfo()
|
||||
|
||||
self.nodes[0].ping()
|
||||
self.wait_until(lambda: (self.nodes[0].getnettotals()['totalbytessent'] >= net_totals_before['totalbytessent'] + 32 * 2), timeout=1)
|
||||
self.wait_until(lambda: (self.nodes[0].getnettotals()['totalbytesrecv'] >= net_totals_before['totalbytesrecv'] + 32 * 2), timeout=1)
|
||||
self.wait_until(lambda: (self.nodes[0].getnettotals()['totalbytessent'] >= net_totals_before['totalbytessent'] + ping_size * 2), timeout=1)
|
||||
self.wait_until(lambda: (self.nodes[0].getnettotals()['totalbytesrecv'] >= net_totals_before['totalbytesrecv'] + ping_size * 2), timeout=1)
|
||||
|
||||
for peer_before in peer_info_before:
|
||||
peer_after = lambda: next(p for p in self.nodes[0].getpeerinfo() if p['id'] == peer_before['id'])
|
||||
self.wait_until(lambda: peer_after()['bytesrecv_per_msg'].get('pong', 0) >= peer_before['bytesrecv_per_msg'].get('pong', 0) + 32, timeout=1)
|
||||
self.wait_until(lambda: peer_after()['bytessent_per_msg'].get('ping', 0) >= peer_before['bytessent_per_msg'].get('ping', 0) + 32, timeout=1)
|
||||
self.wait_until(lambda: peer_after()['bytesrecv_per_msg'].get('pong', 0) >= peer_before['bytesrecv_per_msg'].get('pong', 0) + ping_size, timeout=1)
|
||||
self.wait_until(lambda: peer_after()['bytessent_per_msg'].get('ping', 0) >= peer_before['bytessent_per_msg'].get('ping', 0) + ping_size, timeout=1)
|
||||
|
||||
def test_getnetworkinfo(self):
|
||||
self.log.info("Test getnetworkinfo")
|
||||
@@ -345,7 +349,10 @@ class NetTest(BitcoinTestFramework):
|
||||
node = self.nodes[0]
|
||||
|
||||
self.restart_node(0)
|
||||
self.connect_nodes(0, 1)
|
||||
# we want to use a p2p v1 connection here in order to ensure
|
||||
# a peer id of zero (a downgrade from v2 to v1 would lead
|
||||
# to an increase of the peer id)
|
||||
self.connect_nodes(0, 1, peer_advertises_v2=False)
|
||||
|
||||
self.log.info("Test sendmsgtopeer")
|
||||
self.log.debug("Send a valid message")
|
||||
|
Reference in New Issue
Block a user