py-libp2p/tests/utils.py

55 lines
1.6 KiB
Python
Raw Normal View History

2019-03-17 19:33:10 -04:00
from contextlib import suppress
import asyncio
2019-03-17 19:33:10 -04:00
import multiaddr
2019-03-17 19:33:10 -04:00
from libp2p import new_node
2019-07-25 23:11:27 +08:00
from libp2p.peer.peerinfo import info_from_p2p_addr
async def connect(node1, node2):
"""
Connect node1 to node2
"""
addr = node2.get_addrs()[0]
info = info_from_p2p_addr(addr)
await node1.connect(info)
async def cleanup():
pending = asyncio.all_tasks()
for task in pending:
task.cancel()
# Now we should await task to execute it's cancellation.
# Cancelled task raises asyncio.CancelledError that we can suppress:
with suppress(asyncio.CancelledError):
await task
2019-03-17 19:33:10 -04:00
2019-03-17 19:33:10 -04:00
async def set_up_nodes_by_transport_opt(transport_opt_list):
nodes_list = []
for transport_opt in transport_opt_list:
node = await new_node(transport_opt=transport_opt)
await node.get_network().listen(multiaddr.Multiaddr(transport_opt[0]))
nodes_list.append(node)
return tuple(nodes_list)
2019-07-31 15:00:12 -07:00
2019-03-17 19:33:10 -04:00
async def echo_stream_handler(stream):
while True:
read_string = (await stream.read()).decode()
resp = "ack:" + read_string
await stream.write(resp.encode())
2019-03-17 21:15:14 -04:00
2019-07-31 15:00:12 -07:00
2019-03-17 21:15:14 -04:00
async def perform_two_host_set_up_custom_handler(handler):
transport_opt_list = [["/ip4/127.0.0.1/tcp/0"], ["/ip4/127.0.0.1/tcp/0"]]
2019-03-17 21:30:56 -04:00
(node_a, node_b) = await set_up_nodes_by_transport_opt(transport_opt_list)
2019-03-17 21:15:14 -04:00
node_b.set_stream_handler("/echo/1.0.0", handler)
# Associate the peer with local ip address (see default parameters of Libp2p())
node_a.get_peerstore().add_addrs(node_b.get_id(), node_b.get_addrs(), 10)
2019-03-17 21:30:56 -04:00
return node_a, node_b