py-libp2p/tests/utils.py

32 lines
924 B
Python
Raw Normal View History

2019-03-18 07:33:10 +08:00
from contextlib import suppress
import asyncio
2019-03-18 07:33:10 +08:00
import multiaddr
2019-03-18 07:33:10 +08:00
from libp2p import new_node
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-18 07:33:10 +08: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)
async def echo_stream_handler(stream):
while True:
read_string = (await stream.read()).decode()
resp = "ack:" + read_string
await stream.write(resp.encode())