From 3b64aa4bf3a69a0933a45cf3ce448769dbb2a0f6 Mon Sep 17 00:00:00 2001 From: Alexander Kozlovsky Date: Tue, 20 Sep 2022 05:18:02 +0200 Subject: [PATCH] Fix CoreConnectTimeoutError by calculating the correct timeout for the request --- src/tribler/gui/event_request_manager.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/src/tribler/gui/event_request_manager.py b/src/tribler/gui/event_request_manager.py index e8c24a00e57..313afa6840c 100644 --- a/src/tribler/gui/event_request_manager.py +++ b/src/tribler/gui/event_request_manager.py @@ -51,7 +51,7 @@ def __init__(self, api_port, api_key, error_handler): self.network_errors = make_network_errors_dict() self.connect_timer.setSingleShot(True) - connect(self.connect_timer.timeout, self.connect) + connect(self.connect_timer.timeout, self.reconnect) self.notifier = notifier = Notifier() notifier.add_observer(notifications.events_start, self.on_events_start) @@ -166,6 +166,15 @@ def on_finished(self): self.connect_timer.start(RECONNECT_INTERVAL_MS) def connect(self, reschedule_on_err=True): + if reschedule_on_err: + self._logger.info(f"Set event request manager timeout to {CORE_CONNECTION_TIMEOUT} seconds") + self.start_time = time.time() + self._connect(reschedule_on_err) + + def reconnect(self, reschedule_on_err=True): + self._connect(reschedule_on_err) + + def _connect(self, reschedule_on_err): self._logger.info(f"Connecting to events endpoint ({'with' if reschedule_on_err else 'without'} retrying)") if self.reply is not None: self.reply.deleteLater()