2019-04-07 05:16:37 +08:00
|
|
|
import asyncio
|
2019-04-08 04:36:05 +08:00
|
|
|
import json
|
|
|
|
import sys
|
2019-04-07 05:16:37 +08:00
|
|
|
from sender import SenderNode
|
|
|
|
from receiver import ReceiverNode
|
|
|
|
from libp2p.peer.peerinfo import info_from_p2p_addr
|
|
|
|
from tests.utils import cleanup
|
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
ACK_PROTOCOL = "/ack/1.0.0"
|
2019-04-07 05:16:37 +08:00
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
async def create_receivers(num_receivers, topic_map):
|
2019-04-07 05:16:37 +08:00
|
|
|
receivers = []
|
2019-04-07 11:09:26 +08:00
|
|
|
|
|
|
|
# From topic_map (topic -> list of receivers), create (receiver -> topic)
|
|
|
|
receiver_to_topic_map = {}
|
|
|
|
for topic in topic_map:
|
|
|
|
for receiver in topic_map[topic]:
|
|
|
|
receiver_to_topic_map[receiver] = topic
|
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
# Create receivers
|
2019-04-07 05:16:37 +08:00
|
|
|
for i in range(num_receivers):
|
2019-04-07 11:09:26 +08:00
|
|
|
receivers.append(await ReceiverNode.create(ACK_PROTOCOL, receiver_to_topic_map[i]))
|
2019-04-07 05:16:37 +08:00
|
|
|
return receivers
|
|
|
|
|
|
|
|
async def connect(node1, node2):
|
|
|
|
# node1 connects to node2
|
|
|
|
addr = node2.get_addrs()[0]
|
|
|
|
info = info_from_p2p_addr(addr)
|
|
|
|
await node1.connect(info)
|
|
|
|
|
|
|
|
async def create_topology(adjacency_map, sender, receivers):
|
|
|
|
# Create network
|
|
|
|
|
|
|
|
# Connect senders to receivers
|
|
|
|
for target_num in adjacency_map["sender"]:
|
|
|
|
await connect(sender.libp2p_node, receivers[target_num].libp2p_node)
|
|
|
|
|
|
|
|
# Connect receivers to other receivers
|
2019-04-08 04:36:05 +08:00
|
|
|
for source_num_str in adjacency_map:
|
|
|
|
if source_num_str != "sender":
|
|
|
|
target_nums = adjacency_map[source_num_str]
|
|
|
|
source_num = int(source_num_str)
|
2019-04-07 05:16:37 +08:00
|
|
|
for target_num in target_nums:
|
|
|
|
await connect(receivers[source_num].libp2p_node, \
|
|
|
|
receivers[target_num].libp2p_node)
|
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
def get_num_receivers_in_topology(topology):
|
|
|
|
receiver_ids = []
|
2019-04-08 04:36:05 +08:00
|
|
|
for key_str in topology:
|
|
|
|
if key_str != "sender":
|
|
|
|
key_num = int(key_str)
|
|
|
|
if key_num not in receiver_ids:
|
|
|
|
receiver_ids.append(key_num)
|
|
|
|
for neighbor in topology[key_str]:
|
2019-04-07 05:48:06 +08:00
|
|
|
if neighbor not in receiver_ids:
|
|
|
|
receiver_ids.append(neighbor)
|
|
|
|
return len(receiver_ids)
|
|
|
|
|
2019-04-07 05:16:37 +08:00
|
|
|
async def main():
|
|
|
|
# Create sender
|
|
|
|
print("Sender created")
|
2019-04-07 05:48:06 +08:00
|
|
|
sender = await SenderNode.create(ACK_PROTOCOL)
|
2019-04-07 05:16:37 +08:00
|
|
|
|
|
|
|
# Create receivers
|
|
|
|
print("Receivers created")
|
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
# Define connection topology
|
2019-04-08 04:36:05 +08:00
|
|
|
topology_dict = json.loads(open(sys.argv[1]).read())
|
|
|
|
|
|
|
|
topology = topology_dict["topology"]
|
2019-04-07 05:16:37 +08:00
|
|
|
|
2019-04-07 05:48:06 +08:00
|
|
|
num_receivers = get_num_receivers_in_topology(topology)
|
|
|
|
|
|
|
|
# Define topic map
|
2019-04-08 04:36:05 +08:00
|
|
|
topic_map = topology_dict["topic_map"]
|
2019-04-07 05:48:06 +08:00
|
|
|
|
2019-04-07 11:09:26 +08:00
|
|
|
topics = topic_map.keys()
|
2019-04-07 05:48:06 +08:00
|
|
|
|
|
|
|
receivers = await create_receivers(num_receivers, topic_map)
|
|
|
|
|
2019-04-07 05:16:37 +08:00
|
|
|
# Create network topology
|
|
|
|
await create_topology(topology, sender, receivers)
|
|
|
|
print("Topology created")
|
|
|
|
|
|
|
|
# Perform throughput test
|
|
|
|
# 1) Start receivers
|
|
|
|
sender_info = info_from_p2p_addr(sender.libp2p_node.get_addrs()[0])
|
|
|
|
for receiver in receivers:
|
|
|
|
print("Starting receiving")
|
|
|
|
asyncio.ensure_future(receiver.start_receiving(sender_info))
|
2019-04-07 05:48:06 +08:00
|
|
|
|
|
|
|
# Allow time for start receiving to be completed
|
2019-04-07 05:16:37 +08:00
|
|
|
await asyncio.sleep(0.5)
|
|
|
|
|
|
|
|
# 2) Start sending messages and perform throughput test
|
2019-04-07 11:09:26 +08:00
|
|
|
# Determine number of receivers in each topic
|
|
|
|
num_receivers_in_each_topic = {}
|
|
|
|
for topic in topic_map:
|
|
|
|
num_receivers_in_each_topic[topic] = len(topic_map[topic])
|
2019-04-07 05:16:37 +08:00
|
|
|
print("Performing test")
|
2019-04-08 08:56:59 +08:00
|
|
|
await sender.perform_test(num_receivers_in_each_topic, topics, 10)
|
2019-04-08 06:40:01 +08:00
|
|
|
print("All testing completed")
|
2019-04-07 05:16:37 +08:00
|
|
|
await cleanup()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
loop = asyncio.get_event_loop()
|
|
|
|
loop.run_until_complete(main())
|
|
|
|
loop.close()
|