def run_test(self): nobf_node = TestNode() bf_node = TestNode() connections = [] connections.append( NodeConn('127.0.0.1', p2p_port(0), self.nodes[0], nobf_node)) connections.append( NodeConn('127.0.0.1', p2p_port(1), self.nodes[1], bf_node)) nobf_node.add_connection(connections[0]) bf_node.add_connection(connections[1]) # Start up network handling in another thread NetworkThread().start() nobf_node.wait_for_verack() bf_node.wait_for_verack() # Verify mininodes are connected to bitcoinloved nodes peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) # Mininodes send filterclear message to bitcoinloved node. nobf_node.send_message(msg_filterclear()) bf_node.send_message(msg_filterclear()) time.sleep(3) # Verify mininodes are still connected to bitcoinloved nodes peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) # Mininodes send filteradd message to bitcoinloved node. nobf_node.send_message(msg_filteradd()) bf_node.send_message(msg_filteradd()) time.sleep(3) # Verify NoBF mininode has been dropped, and BF mininode is still connected. peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(0, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) [c.disconnect_node() for c in connections]
def run_test(self): nobf_node = TestNode() bf_node = TestNode() connections = [] connections.append(NodeConn('127.0.0.1', p2p_port(0), self.nodes[0], nobf_node)) connections.append(NodeConn('127.0.0.1', p2p_port(1), self.nodes[1], bf_node)) nobf_node.add_connection(connections[0]) bf_node.add_connection(connections[1]) # Start up network handling in another thread NetworkThread().start() nobf_node.wait_for_verack() bf_node.wait_for_verack() # Verify mininodes are connected to zcashd nodes peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) # Mininodes send filterclear message to zcashd node. nobf_node.send_message(msg_filterclear()) bf_node.send_message(msg_filterclear()) time.sleep(3) # Verify mininodes are still connected to zcashd nodes peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) # Mininodes send filteradd message to zcashd node. nobf_node.send_message(msg_filteradd()) bf_node.send_message(msg_filteradd()) time.sleep(3) # Verify NoBF mininode has been dropped, and BF mininode is still connected. peerinfo = self.nodes[0].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(0, versions.count(SPROUT_PROTO_VERSION)) peerinfo = self.nodes[1].getpeerinfo() versions = [x["version"] for x in peerinfo] assert_equal(1, versions.count(SPROUT_PROTO_VERSION)) [ c.disconnect_node() for c in connections ]