add optional delay argument to enqueue_maybe_ping, fix default value

This commit is contained in:
Jack Robison 2018-05-29 11:00:59 -04:00
parent 73e813f9ec
commit fb3aac15fa
No known key found for this signature in database
GPG key ID: DF25C68FE0239BB2

View file

@ -28,12 +28,12 @@ class PingQueue(object):
self._semaphore = defer.DeferredSemaphore(1) self._semaphore = defer.DeferredSemaphore(1)
self._ping_semaphore = defer.DeferredSemaphore(constants.alpha) self._ping_semaphore = defer.DeferredSemaphore(constants.alpha)
self._process_lc = node.get_looping_call(self._semaphore.run, self._process) self._process_lc = node.get_looping_call(self._semaphore.run, self._process)
self._delay = 300
def _add_contact(self, contact): def _add_contact(self, contact, delay=None):
if contact in self._enqueued_contacts: if contact in self._enqueued_contacts:
return defer.succeed(None) return defer.succeed(None)
self._enqueued_contacts[contact] = self._get_time() + self._delay delay = delay or constants.checkRefreshInterval
self._enqueued_contacts[contact] = self._get_time() + delay
self._queue.append(contact) self._queue.append(contact)
return defer.succeed(None) return defer.succeed(None)
@ -49,11 +49,6 @@ class PingQueue(object):
self._queue.appendleft(contact) self._queue.appendleft(contact)
defer.returnValue(None) defer.returnValue(None)
def _ping(contact):
d = contact.ping()
d.addErrback(lambda err: err.trap(TimeoutError))
return d
pinged = [] pinged = []
checked = [] checked = []
while now > self._enqueued_contacts[contact]: while now > self._enqueued_contacts[contact]:
@ -65,9 +60,17 @@ class PingQueue(object):
contact = self._queue.popleft() contact = self._queue.popleft()
if not now > self._enqueued_contacts[contact]: if not now > self._enqueued_contacts[contact]:
checked.append(contact) checked.append(contact)
# log.info("ping %i/%i peers", len(pinged), len(checked))
yield defer.DeferredList([self._ping_semaphore.run(_ping, contact) for contact in pinged]) @defer.inlineCallbacks
def _ping(contact):
try:
yield contact.ping()
except TimeoutError:
pass
except Exception as err:
log.warning("unexpected error: %s", err)
yield defer.DeferredList([_ping(contact) for contact in pinged])
for contact in checked: for contact in checked:
if contact in self._enqueued_contacts: if contact in self._enqueued_contacts:
@ -81,8 +84,8 @@ class PingQueue(object):
def stop(self): def stop(self):
return self._node.safe_stop_looping_call(self._process_lc) return self._node.safe_stop_looping_call(self._process_lc)
def enqueue_maybe_ping(self, contact): def enqueue_maybe_ping(self, contact, delay=None):
return self._semaphore.run(self._add_contact, contact) return self._semaphore.run(self._add_contact, contact, delay)
class KademliaProtocol(protocol.DatagramProtocol): class KademliaProtocol(protocol.DatagramProtocol):