py-libp2p/tests/routing/test_kad_peer_router.py

76 lines
2.1 KiB
Python
Raw Normal View History

2019-04-28 09:59:25 +08:00
import pytest
from libp2p.kademlia.network import KademliaServer
2019-08-03 13:36:19 +08:00
from libp2p.peer.id import ID
2019-10-16 02:32:25 +08:00
from libp2p.routing.kademlia.kademlia_peer_router import (
KadmeliaPeerRouter,
peer_info_to_str,
)
2019-04-28 09:59:25 +08:00
2019-08-01 06:00:12 +08:00
2019-04-28 09:59:25 +08:00
@pytest.mark.asyncio
2019-04-29 01:49:10 +08:00
async def test_simple_two_nodes():
2019-04-28 09:59:25 +08:00
node_a = KademliaServer()
await node_a.listen(5678)
node_b = KademliaServer()
await node_b.listen(5679)
2019-04-29 01:49:10 +08:00
node_a_value = await node_b.bootstrap([("127.0.0.1", 5678)])
node_a_kad_peerinfo = node_a_value[0]
2019-10-16 02:32:25 +08:00
await node_a.set(node_a_kad_peerinfo.xor_id, peer_info_to_str(node_a_kad_peerinfo))
2019-04-29 01:49:10 +08:00
router = KadmeliaPeerRouter(node_b)
returned_info = await router.find_peer(ID(node_a_kad_peerinfo.peer_id_bytes))
assert returned_info == node_a_kad_peerinfo
2019-04-29 01:49:10 +08:00
2019-08-01 06:00:12 +08:00
2019-04-29 01:49:10 +08:00
@pytest.mark.asyncio
async def test_simple_three_nodes():
node_a = KademliaServer()
await node_a.listen(5701)
node_b = KademliaServer()
await node_b.listen(5702)
node_c = KademliaServer()
await node_c.listen(5703)
node_a_value = await node_b.bootstrap([("127.0.0.1", 5701)])
node_a_kad_peerinfo = node_a_value[0]
await node_c.bootstrap([("127.0.0.1", 5702)])
2019-10-16 02:32:25 +08:00
await node_a.set(node_a_kad_peerinfo.xor_id, peer_info_to_str(node_a_kad_peerinfo))
2019-04-29 01:49:10 +08:00
router = KadmeliaPeerRouter(node_c)
returned_info = await router.find_peer(ID(node_a_kad_peerinfo.peer_id_bytes))
assert returned_info == node_a_kad_peerinfo
2019-08-01 06:00:12 +08:00
@pytest.mark.asyncio
async def test_simple_four_nodes():
node_a = KademliaServer()
await node_a.listen(5801)
node_b = KademliaServer()
await node_b.listen(5802)
node_c = KademliaServer()
await node_c.listen(5803)
node_d = KademliaServer()
await node_d.listen(5804)
node_a_value = await node_b.bootstrap([("127.0.0.1", 5801)])
node_a_kad_peerinfo = node_a_value[0]
await node_c.bootstrap([("127.0.0.1", 5802)])
await node_d.bootstrap([("127.0.0.1", 5803)])
2019-10-16 02:32:25 +08:00
await node_b.set(node_a_kad_peerinfo.xor_id, peer_info_to_str(node_a_kad_peerinfo))
router = KadmeliaPeerRouter(node_d)
returned_info = await router.find_peer(ID(node_a_kad_peerinfo.peer_id_bytes))
assert returned_info == node_a_kad_peerinfo