From 983177fbf15299ab8f7652c44f63ccbeee7481b3 Mon Sep 17 00:00:00 2001 From: Ewald de Wit Date: Sun, 25 Oct 2020 14:31:10 +0100 Subject: [PATCH] Issue #303: Bypass regression in TWS 480.4l+ that no longer sends accountDownloadEnd for multi-accounts. --- ib_insync/ib.py | 49 ++++++++++++++++++++++++------------------------- 1 file changed, 24 insertions(+), 25 deletions(-) diff --git a/ib_insync/ib.py b/ib_insync/ib.py index 12fec7e9a..434b065f1 100644 --- a/ib_insync/ib.py +++ b/ib_insync/ib.py @@ -1621,7 +1621,7 @@ async def connectAsync( account: str = ''): if self.isConnected(): - self._logger.warn('Already connected') + self._logger.warning('Already connected') return self self.wrapper.clientId = clientId @@ -1634,32 +1634,31 @@ async def connectAsync( if clientId == 0: self.reqAutoOpenOrders(True) - # request completed orders - if not readonly and self.client.serverVersion() >= 150: - try: - await asyncio.wait_for( - self.reqCompletedOrdersAsync(False), timeout or None) - except asyncio.TimeoutError: - self._logger.error('reqCompletedOrders timed out') - - # request updates for the main account accounts = self.client.getAccounts() - await asyncio.wait_for( - asyncio.gather( - self.reqAccountUpdatesAsync(account or accounts[0]), - self.reqPositionsAsync(), - self.reqExecutionsAsync()), - timeout or None) - - # request updates for sub-accounts, if there are not too many + if not account and len(accounts) == 1: + account = accounts[0] + + # prepare initializing requests + reqs = {} # name -> request + reqs['positions'] = self.reqPositionsAsync() + reqs['executions'] = self.reqExecutionsAsync() + if not readonly and self.client.serverVersion() >= 150: + reqs['completed orders'] = self.reqCompletedOrdersAsync(False) + if account: + reqs['account updates'] =self.reqAccountUpdatesAsync(account) if len(accounts) <= self.MaxSyncedSubAccounts: - await asyncio.wait_for( - asyncio.gather( - *(self.reqAccountUpdatesMultiAsync(a) - for a in accounts)), - timeout or None) - else: - self._logger.warning('Not requesting sub-account updates') + for acc in accounts: + reqs[f'account updates for {acc}'] = \ + self.reqAccountUpdatesMultiAsync(acc) + + # run initializing requests concurrently and log if any times out + tasks = [ + asyncio.wait_for(req, timeout or None) + for req in reqs.values()] + resps = await asyncio.gather(*tasks, return_exceptions=True) + for name, resp in zip(reqs, resps): + if isinstance(resp, asyncio.TimeoutError): + self._logger.error(f'{name} request timed out') self._logger.info('Synchronization complete') self.connectedEvent.emit()