Compare commits

...
Sign in to create a new pull request.

2 commits

Author SHA1 Message Date
Victor Shyba
27afc759ff fix peer search using inexistent variable, fix test to cover it 2019-05-10 14:23:40 -03:00
Victor Shyba
7abb28cb3e raise ban cap to 30 minutes 2019-05-10 14:23:40 -03:00
3 changed files with 3 additions and 3 deletions

View file

@ -15,6 +15,7 @@ log = logging.getLogger(__name__)
class BlobDownloader: class BlobDownloader:
BAN_FACTOR = 2.0 # fixme: when connection manager gets implemented, move it out from here BAN_FACTOR = 2.0 # fixme: when connection manager gets implemented, move it out from here
BAN_CAP = 30.0*60.0 # maximum time a node remains banned before being retried
def __init__(self, loop: asyncio.BaseEventLoop, config: 'Config', blob_manager: 'BlobManager', def __init__(self, loop: asyncio.BaseEventLoop, config: 'Config', blob_manager: 'BlobManager',
peer_queue: asyncio.Queue): peer_queue: asyncio.Queue):
@ -71,7 +72,7 @@ class BlobDownloader:
now = self.loop.time() now = self.loop.time()
self.ignored = dict(( self.ignored = dict((
(peer, when) for (peer, when) in self.ignored.items() (peer, when) for (peer, when) in self.ignored.items()
if (now - when) < min(30.0, (self.failures.get(peer, 0) ** self.BAN_FACTOR)) if (now - when) < min(self.BAN_CAP, (self.failures.get(peer, 0) ** self.BAN_FACTOR))
)) ))
@cache_concurrent @cache_concurrent

View file

@ -201,7 +201,6 @@ class Node:
try: try:
async with peer_generator as junction: async with peer_generator as junction:
yield junction yield junction
await peer_generator.finished.wait()
finally: finally:
if add_hashes_task and not (add_hashes_task.done() or add_hashes_task.cancelled()): if add_hashes_task and not (add_hashes_task.done() or add_hashes_task.cancelled()):
add_hashes_task.cancel() add_hashes_task.cancel()

View file

@ -105,7 +105,7 @@ class TestBlobAnnouncer(AsyncioTestCase):
_, task = last.accumulate_peers(search_q, peer_q) _, task = last.accumulate_peers(search_q, peer_q)
found_peers = await peer_q.get() found_peers = await peer_q.get()
task.cancel() await task
self.assertEqual(1, len(found_peers)) self.assertEqual(1, len(found_peers))
self.assertEqual(self.node.protocol.node_id, found_peers[0].node_id) self.assertEqual(self.node.protocol.node_id, found_peers[0].node_id)