forked from LBRYCommunity/lbry-sdk
add lbrynet.dht.protocol.data_store unit tests
This commit is contained in:
parent
664f91bfab
commit
60a24f0e6e
1 changed files with 93 additions and 0 deletions
93
tests/unit/dht/protocol/test_data_store.py
Normal file
93
tests/unit/dht/protocol/test_data_store.py
Normal file
|
@ -0,0 +1,93 @@
|
|||
import asyncio
|
||||
from torba.testcase import AsyncioTestCase
|
||||
from lbrynet.dht.protocol.data_store import DictDataStore
|
||||
from lbrynet.dht.peer import PeerManager
|
||||
|
||||
|
||||
class DataStoreTests(AsyncioTestCase):
|
||||
def setUp(self):
|
||||
self.loop = asyncio.get_event_loop()
|
||||
self.peer_manager = PeerManager(self.loop)
|
||||
self.data_store = DictDataStore(self.loop, self.peer_manager)
|
||||
|
||||
def _test_add_peer_to_blob(self, blob=b'2' * 48, node_id=b'1' * 48, address='1.2.3.4', tcp_port=3333,
|
||||
udp_port=4444):
|
||||
peer = self.peer_manager.get_kademlia_peer(node_id, address, udp_port)
|
||||
peer.update_tcp_port(tcp_port)
|
||||
before = self.data_store.get_peers_for_blob(blob)
|
||||
self.data_store.add_peer_to_blob(peer, blob, peer.compact_address_tcp(), 0, 0, peer.node_id)
|
||||
self.assertListEqual(before + [peer], self.data_store.get_peers_for_blob(blob))
|
||||
return peer
|
||||
|
||||
def test_add_peer_to_blob(self, blob=b'f' * 48, peers=None):
|
||||
peers = peers or [
|
||||
(b'a' * 48, '1.2.3.4'),
|
||||
(b'b' * 48, '1.2.3.5'),
|
||||
(b'c' * 48, '1.2.3.6'),
|
||||
]
|
||||
self.assertListEqual([], self.data_store.get_peers_for_blob(blob))
|
||||
peer_objects = []
|
||||
for (node_id, address) in peers:
|
||||
peer_objects.append(self._test_add_peer_to_blob(blob=blob, node_id=node_id, address=address))
|
||||
self.assertTrue(self.data_store.has_peers_for_blob(blob))
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob)), len(peers))
|
||||
return peer_objects
|
||||
|
||||
def test_get_storing_contacts(self, peers=None, blob1=b'd' * 48, blob2=b'e' * 48):
|
||||
peers = peers or [
|
||||
(b'a' * 48, '1.2.3.4'),
|
||||
(b'b' * 48, '1.2.3.5'),
|
||||
(b'c' * 48, '1.2.3.6'),
|
||||
]
|
||||
peer_objs1 = self.test_add_peer_to_blob(blob=blob1, peers=peers)
|
||||
self.assertEqual(len(peers), len(peer_objs1))
|
||||
self.assertEqual(len(peers), len(self.data_store.get_storing_contacts()))
|
||||
|
||||
peer_objs2 = self.test_add_peer_to_blob(blob=blob2, peers=peers)
|
||||
self.assertEqual(len(peers), len(peer_objs2))
|
||||
self.assertEqual(len(peers), len(self.data_store.get_storing_contacts()))
|
||||
|
||||
for o1, o2 in zip(peer_objs1, peer_objs2):
|
||||
self.assertIs(o1, o2)
|
||||
|
||||
def test_remove_expired_peers(self):
|
||||
peers = [
|
||||
(b'a' * 48, '1.2.3.4'),
|
||||
(b'b' * 48, '1.2.3.5'),
|
||||
(b'c' * 48, '1.2.3.6'),
|
||||
]
|
||||
blob1 = b'd' * 48
|
||||
blob2 = b'e' * 48
|
||||
|
||||
self.data_store.removed_expired_peers() # nothing should happen
|
||||
self.test_get_storing_contacts(peers, blob1, blob2)
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob1)), len(peers))
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob2)), len(peers))
|
||||
self.assertEqual(len(self.data_store.get_storing_contacts()), len(peers))
|
||||
|
||||
# expire the first peer from blob1
|
||||
first = self.data_store._data_store[blob1][0]
|
||||
self.data_store._data_store[blob1][0] = (first[0], first[1], first[2], -86401, first[4])
|
||||
self.assertEqual(len(self.data_store.get_storing_contacts()), len(peers))
|
||||
self.data_store.removed_expired_peers()
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob1)), len(peers) - 1)
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob2)), len(peers))
|
||||
self.assertEqual(len(self.data_store.get_storing_contacts()), len(peers))
|
||||
|
||||
# expire the first peer from blob2
|
||||
first = self.data_store._data_store[blob2][0]
|
||||
self.data_store._data_store[blob2][0] = (first[0], first[1], first[2], -86401, first[4])
|
||||
self.data_store.removed_expired_peers()
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob1)), len(peers) - 1)
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob2)), len(peers) - 1)
|
||||
self.assertEqual(len(self.data_store.get_storing_contacts()), len(peers) - 1)
|
||||
|
||||
# expire the second and third peers from blob1
|
||||
first = self.data_store._data_store[blob2][0]
|
||||
self.data_store._data_store[blob1][0] = (first[0], first[1], first[2], -86401, first[4])
|
||||
second = self.data_store._data_store[blob2][1]
|
||||
self.data_store._data_store[blob1][1] = (second[0], second[1], second[2], -86401, second[4])
|
||||
self.data_store.removed_expired_peers()
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob1)), 0)
|
||||
self.assertEqual(len(self.data_store.get_peers_for_blob(blob2)), len(peers) - 1)
|
||||
self.assertEqual(len(self.data_store.get_storing_contacts()), len(peers) - 1)
|
Loading…
Add table
Reference in a new issue