1
0
mirror of https://github.com/eternnoir/pyTelegramBotAPI.git synced 2023-08-10 21:12:57 +03:00

Merge pull request #1072 from Badiboy/master

Infinity polling fall down fixed
This commit is contained in:
Badiboy 2021-01-14 03:57:00 +03:00 committed by GitHub
commit a0d86977b0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 10 additions and 6 deletions

View File

@ -6,6 +6,7 @@ import re
import sys import sys
import threading import threading
import time import time
import traceback
logger = logging.getLogger('TeleBot') logger = logging.getLogger('TeleBot')
formatter = logging.Formatter( formatter = logging.Formatter(
@ -459,7 +460,8 @@ class TeleBot:
try: try:
self.polling(none_stop=True, timeout=timeout, long_polling_timeout=long_polling_timeout, *args, **kwargs) self.polling(none_stop=True, timeout=timeout, long_polling_timeout=long_polling_timeout, *args, **kwargs)
except Exception as e: except Exception as e:
logger.error("Infinity polling exception: {}".format(e)) logger.error("Infinity polling exception: %s", str(e))
logger.debug("Exception traceback:\n%s", traceback.format_exc())
time.sleep(3) time.sleep(3)
continue continue
logger.info("Infinity polling: polling exited") logger.info("Infinity polling: polling exited")

View File

@ -254,7 +254,7 @@ def get_updates(token, offset=None, limit=None, timeout=None, allowed_updates=No
if limit: if limit:
payload['limit'] = limit payload['limit'] = limit
if timeout: if timeout:
payload['timeout'] = timeout payload['connect-timeout'] = timeout
if long_polling_timeout: if long_polling_timeout:
payload['long_polling_timeout'] = long_polling_timeout payload['long_polling_timeout'] = long_polling_timeout
if allowed_updates is not None: # Empty lists should pass if allowed_updates is not None: # Empty lists should pass

View File

@ -235,8 +235,10 @@ def or_clear(self):
def orify(e, changed_callback): def orify(e, changed_callback):
e._set = e.set if not hasattr(e, "_set"):
e._clear = e.clear e._set = e.set
if not hasattr(e, "_clear"):
e._clear = e.clear
e.changed = changed_callback e.changed = changed_callback
e.set = lambda: or_set(e) e.set = lambda: or_set(e)
e.clear = lambda: or_clear(e) e.clear = lambda: or_clear(e)
@ -244,7 +246,7 @@ def orify(e, changed_callback):
def OrEvent(*events): def OrEvent(*events):
or_event = threading.Event() or_event = threading.Event()
def changed(): def changed():
bools = [e.is_set() for e in events] bools = [ev.is_set() for ev in events]
if any(bools): if any(bools):
or_event.set() or_event.set()
else: else:

View File

@ -1,3 +1,3 @@
# Versions should comply with PEP440. # Versions should comply with PEP440.
# This line is parsed in setup.py: # This line is parsed in setup.py:
__version__ = '3.7.5' __version__ = '3.7.5.u1'