Skip to content

Commit

Permalink
test: add assert_getpeerinfo method and coverage in p2p_addrfetch.py
Browse files Browse the repository at this point in the history
  • Loading branch information
jonatack committed Jul 28, 2021
1 parent 5e21382 commit 9321086
Showing 1 changed file with 12 additions and 6 deletions.
18 changes: 12 additions & 6 deletions test/functional/p2p_addrfetch.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,18 +21,24 @@


class P2PAddrFetch(BitcoinTestFramework):

def set_test_params(self):
self.setup_clean_chain = True
self.num_nodes = 1

def assert_getpeerinfo(self, *, peer_ids):
num_peers = len(peer_ids)
info = self.nodes[0].getpeerinfo()
assert_equal(len(info), num_peers)
for n in range(0, num_peers):
assert_equal(info[n]['id'], peer_ids[n])
assert_equal(info[n]['connection_type'], 'addr-fetch')

def run_test(self):
node = self.nodes[0]
self.log.info("Connect to an addr-fetch peer")
peer = node.add_outbound_p2p_connection(P2PInterface(), p2p_idx=0, connection_type="addr-fetch")
info = node.getpeerinfo()
assert_equal(len(info), 1)
assert_equal(info[0]['connection_type'], 'addr-fetch')
peer_id = 0
peer = node.add_outbound_p2p_connection(P2PInterface(), p2p_idx=peer_id, connection_type="addr-fetch")
self.assert_getpeerinfo(peer_ids=[peer_id])

self.log.info("Check that we send getaddr but don't try to sync headers with the addr-fetch peer")
peer.sync_send_with_ping()
Expand All @@ -45,7 +51,7 @@ def run_test(self):
msg = msg_addr()
msg.addrs = [ADDR]
peer.send_and_ping(msg)
assert_equal(len(node.getpeerinfo()), 1)
self.assert_getpeerinfo(peer_ids=[peer_id])

self.log.info("Check that answering with larger addr messages leads to disconnect")
msg.addrs = [ADDR] * 2
Expand Down

0 comments on commit 9321086

Please sign in to comment.