Fix infinite loop loading network_timezones.

Change add optional "stack_size" setting as integer to config.ini under "General" stanza.
Change prevent too many retries when loading network timezones, conversions, and zoneinfo in a short time.
Update to UnRar 5.50 beta 6.
This commit is contained in:
Prinz23 2017-07-25 22:47:12 +01:00 committed by JackDandy
parent 9c3a158a5d
commit 1bd9cf863e
5 changed files with 65 additions and 4 deletions

View file

@ -1,4 +1,12 @@
### 0.12.21 (2017-06-19 23:35:00 UTC) ### 0.12.26 (2017-08-20 13:05:00 UTC)
* Fix infinite loop loading network_timezones
* Change add optional "stack_size" setting as integer to config.ini under "General" stanza
* Change prevent too many retries when loading network timezones, conversions, and zoneinfo in a short time
* Update to UnRar 5.50 beta 6
### 0.12.25 (2017-06-19 23:35:00 UTC)
* Remove provider SceneAccess * Remove provider SceneAccess

View file

@ -302,6 +302,17 @@ class SickGear(object):
print(u'Unable to find "%s", all settings will be default!' % sickbeard.CONFIG_FILE) print(u'Unable to find "%s", all settings will be default!' % sickbeard.CONFIG_FILE)
sickbeard.CFG = ConfigObj(sickbeard.CONFIG_FILE) sickbeard.CFG = ConfigObj(sickbeard.CONFIG_FILE)
stack_size = None
try:
stack_size = int(sickbeard.CFG['General']['stack_size'])
except:
stack_size = None
if stack_size:
try:
threading.stack_size(stack_size)
except (StandardError, Exception) as e:
print('Stack Size %s not set: %s' % (stack_size, e.message))
# check all db versions # check all db versions
for d, min_v, max_v, mo in [ for d, min_v, max_v, mo in [

Binary file not shown.

View file

@ -1427,6 +1427,9 @@ def save_config():
# For passwords you must include the word `password` in the item_name and # For passwords you must include the word `password` in the item_name and
# add `helpers.encrypt(ITEM_NAME, ENCRYPTION_VERSION)` in save_config() # add `helpers.encrypt(ITEM_NAME, ENCRYPTION_VERSION)` in save_config()
new_config['General'] = {} new_config['General'] = {}
s_z = check_setting_int(CFG, 'General', 'stack_size', 0)
if s_z:
new_config['General']['stack_size'] = s_z
new_config['General']['config_version'] = CONFIG_VERSION new_config['General']['config_version'] = CONFIG_VERSION
new_config['General']['branch'] = BRANCH new_config['General']['branch'] = BRANCH
new_config['General']['git_remote'] = GIT_REMOTE new_config['General']['git_remote'] = GIT_REMOTE

View file

@ -38,6 +38,9 @@ pm_regex = re.compile(r'(P[. ]? ?M)', flags=re.I)
network_dict = None network_dict = None
network_dupes = None network_dupes = None
last_failure = {'datetime': datetime.datetime.fromordinal(1), 'count': 0}
max_retry_time = 900
max_retry_count = 3
country_timezones = { country_timezones = {
'AU': 'Australia/Sydney', 'AR': 'America/Buenos_Aires', 'AUSTRALIA': 'Australia/Sydney', 'BR': 'America/Sao_Paulo', 'AU': 'Australia/Sydney', 'AR': 'America/Buenos_Aires', 'AUSTRALIA': 'Australia/Sydney', 'BR': 'America/Sao_Paulo',
@ -49,6 +52,24 @@ country_timezones = {
'TW': 'Asia/Taipei', 'UK': 'Europe/London', 'US': 'US/Eastern', 'ZA': 'Africa/Johannesburg'} 'TW': 'Asia/Taipei', 'UK': 'Europe/London', 'US': 'US/Eastern', 'ZA': 'Africa/Johannesburg'}
def reset_last_retry():
global last_failure
last_failure = {'datetime': datetime.datetime.fromordinal(1), 'count': 0}
def update_last_retry():
global last_failure
last_failure = {'datetime': datetime.datetime.now(), 'count': last_failure.get('count', 0) + 1}
def should_try_loading():
global last_failure
if last_failure.get('count', 0) >= max_retry_count and \
(datetime.datetime.now() - last_failure.get('datetime', datetime.datetime.fromordinal(1))).seconds < max_retry_time:
return False
return True
def tz_fallback(t): def tz_fallback(t):
return t if isinstance(t, datetime.tzinfo) else tz.tzlocal() return t if isinstance(t, datetime.tzinfo) else tz.tzlocal()
@ -99,6 +120,9 @@ def _remove_old_zoneinfo():
# update the dateutil zoneinfo # update the dateutil zoneinfo
def _update_zoneinfo(): def _update_zoneinfo():
if not should_try_loading():
return
global sb_timezone global sb_timezone
sb_timezone = get_tz() sb_timezone = get_tz()
@ -107,10 +131,13 @@ def _update_zoneinfo():
url_data = helpers.getURL(url_zv) url_data = helpers.getURL(url_zv)
if url_data is None: if url_data is None:
update_last_retry()
# When urlData is None, trouble connecting to github # When urlData is None, trouble connecting to github
logger.log(u'Loading zoneinfo.txt failed, this can happen from time to time. Unable to get URL: %s' % url_zv, logger.log(u'Loading zoneinfo.txt failed, this can happen from time to time. Unable to get URL: %s' % url_zv,
logger.WARNING) logger.WARNING)
return return
else:
reset_last_retry()
zonefilename = zoneinfo.ZONEFILENAME zonefilename = zoneinfo.ZONEFILENAME
cur_zoneinfo = zonefilename cur_zoneinfo = zonefilename
@ -175,6 +202,9 @@ def _update_zoneinfo():
# update the network timezone table # update the network timezone table
def update_network_dict(): def update_network_dict():
if not should_try_loading():
return
_remove_old_zoneinfo() _remove_old_zoneinfo()
_update_zoneinfo() _update_zoneinfo()
load_network_conversions() load_network_conversions()
@ -186,10 +216,13 @@ def update_network_dict():
url_data = helpers.getURL(url) url_data = helpers.getURL(url)
if url_data is None: if url_data is None:
update_last_retry()
# When urlData is None, trouble connecting to github # When urlData is None, trouble connecting to github
logger.log(u'Updating network timezones failed, this can happen from time to time. URL: %s' % url, logger.WARNING) logger.log(u'Updating network timezones failed, this can happen from time to time. URL: %s' % url, logger.WARNING)
load_network_dict() load_network_dict(load=False)
return return
else:
reset_last_retry()
try: try:
for line in url_data.splitlines(): for line in url_data.splitlines():
@ -231,7 +264,7 @@ def update_network_dict():
# load network timezones from db into dict # load network timezones from db into dict
def load_network_dict(): def load_network_dict(load=True):
global network_dict, network_dupes global network_dict, network_dupes
my_db = db.DBConnection('cache.db') my_db = db.DBConnection('cache.db')
@ -240,7 +273,7 @@ def load_network_dict():
sql = 'SELECT %s AS network_name, timezone FROM [network_timezones] ' % sql_name + \ sql = 'SELECT %s AS network_name, timezone FROM [network_timezones] ' % sql_name + \
'GROUP BY %s HAVING COUNT(*) = 1 ORDER BY %s;' % (sql_name, sql_name) 'GROUP BY %s HAVING COUNT(*) = 1 ORDER BY %s;' % (sql_name, sql_name)
cur_network_list = my_db.select(sql) cur_network_list = my_db.select(sql)
if cur_network_list is None or len(cur_network_list) < 1: if load and (cur_network_list is None or len(cur_network_list) < 1):
update_network_dict() update_network_dict()
cur_network_list = my_db.select(sql) cur_network_list = my_db.select(sql)
network_dict = dict(cur_network_list) network_dict = dict(cur_network_list)
@ -360,6 +393,9 @@ def standardize_network(network, country):
def load_network_conversions(): def load_network_conversions():
if not should_try_loading():
return
conversions = [] conversions = []
# network conversions are stored on github pages # network conversions are stored on github pages
@ -367,9 +403,12 @@ def load_network_conversions():
url_data = helpers.getURL(url) url_data = helpers.getURL(url)
if url_data is None: if url_data is None:
update_last_retry()
# When urlData is None, trouble connecting to github # When urlData is None, trouble connecting to github
logger.log(u'Updating network conversions failed, this can happen from time to time. URL: %s' % url, logger.WARNING) logger.log(u'Updating network conversions failed, this can happen from time to time. URL: %s' % url, logger.WARNING)
return return
else:
reset_last_retry()
try: try:
for line in url_data.splitlines(): for line in url_data.splitlines():