Browse Source

synchronizer: fix race

The synchronizer would sometimes not send 'wallet_updated' triggers
if it was fast enough to do all the work between two 0.1 sec ticks.
(is_up_to_date() would return True both before and after)
3.3.3.1
SomberNight 6 years ago
parent
commit
cbd91ba5b1
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 6
      electrum/synchronizer.py

6
electrum/synchronizer.py

@ -55,6 +55,7 @@ class Synchronizer(PrintError):
self.requested_histories = {} self.requested_histories = {}
self.requested_addrs = set() self.requested_addrs = set()
self.scripthash_to_address = {} self.scripthash_to_address = {}
self._processed_some_notifications = False # so that we don't miss them
# Queues # Queues
self.add_queue = asyncio.Queue() self.add_queue = asyncio.Queue()
self.status_queue = asyncio.Queue() self.status_queue = asyncio.Queue()
@ -152,6 +153,7 @@ class Synchronizer(PrintError):
h, status = await self.status_queue.get() h, status = await self.status_queue.get()
addr = self.scripthash_to_address[h] addr = self.scripthash_to_address[h]
await group.spawn(self.on_address_status, addr, status) await group.spawn(self.on_address_status, addr, status)
self._processed_some_notifications = True
@property @property
def session(self): def session(self):
@ -176,6 +178,8 @@ class Synchronizer(PrintError):
await asyncio.sleep(0.1) await asyncio.sleep(0.1)
self.wallet.synchronize() self.wallet.synchronize()
up_to_date = self.is_up_to_date() up_to_date = self.is_up_to_date()
if up_to_date != self.wallet.is_up_to_date(): if (up_to_date != self.wallet.is_up_to_date()
or up_to_date and self._processed_some_notifications):
self._processed_some_notifications = False
self.wallet.set_up_to_date(up_to_date) self.wallet.set_up_to_date(up_to_date)
self.wallet.network.trigger_callback('wallet_updated', self.wallet) self.wallet.network.trigger_callback('wallet_updated', self.wallet)

Loading…
Cancel
Save