Merge pull request #682 from JackDandy/feature/ChangePPlogging

Change include OSError system messages in file system failure logs du…
This commit is contained in:
JackDandy 2016-05-08 11:16:29 +01:00
commit 8432a313f0
3 changed files with 35 additions and 20 deletions

View file

@ -62,6 +62,7 @@
* Change prevent duplicate show ids from presenting items on 'Add from... Browse Shows' * Change prevent duplicate show ids from presenting items on 'Add from... Browse Shows'
* Change add 'nocache' kwarg to helpers.getURL to facilitate non-cached requests * Change add 'nocache' kwarg to helpers.getURL to facilitate non-cached requests
* Change instantly use saved value from Search Settings/Episode Search/"Check propers every" instead of after a restart * Change instantly use saved value from Search Settings/Episode Search/"Check propers every" instead of after a restart
* Change include OSError system messages in file system failure logs during post process
### 0.11.11 (2016-04-05 19:20:00 UTC) ### 0.11.11 (2016-04-05 19:20:00 UTC)

View file

@ -448,6 +448,9 @@ class PostProcessor(object):
self.in_history = True self.in_history = True
show = helpers.findCertainShow(sickbeard.showList, indexer_id) show = helpers.findCertainShow(sickbeard.showList, indexer_id)
to_return = (show, season, [], quality) to_return = (show, season, [], quality)
if not show:
self._log(u'Unknown show, check availability on ShowList page', logger.DEBUG)
break
self._log(u'Found a match in history for %s' % show.name, logger.DEBUG) self._log(u'Found a match in history for %s' % show.name, logger.DEBUG)
break break

View file

@ -225,18 +225,23 @@ class ProcessTVShow(object):
else: else:
video_batch = video_files video_batch = video_files
while 0 < len(video_batch): try:
video_pick = [''] while 0 < len(video_batch):
video_size = 0 video_pick = ['']
for cur_video_file in video_batch: video_size = 0
cur_video_size = ek.ek(os.path.getsize, ek.ek(os.path.join, path, cur_video_file)) for cur_video_file in video_batch:
if 0 == video_size or cur_video_size > video_size: cur_video_size = ek.ek(os.path.getsize, ek.ek(os.path.join, path, cur_video_file))
video_size = cur_video_size if 0 == video_size or cur_video_size > video_size:
video_pick = [cur_video_file] video_size = cur_video_size
video_pick = [cur_video_file]
video_batch = set(video_batch) - set(video_pick) video_batch = set(video_batch) - set(video_pick)
self._process_media(path, video_pick, nzb_name, process_method, force, force_replace, use_trash=cleanup) self._process_media(path, video_pick, nzb_name, process_method, force, force_replace, use_trash=cleanup)
except OSError as e:
logger.log('Batch skipped, %s%s' %
(ex(e), e.filename and (' (file %s)' % e.filename) or ''), logger.WARNING)
# Process video files in TV subdirectories # Process video files in TV subdirectories
for directory in [x for x in dirs if self._validate_dir(path, x, nzb_name_original, failed)]: for directory in [x for x in dirs if self._validate_dir(path, x, nzb_name_original, failed)]:
@ -266,18 +271,24 @@ class ProcessTVShow(object):
else: else:
video_batch = video_files video_batch = video_files
while 0 < len(video_batch): try:
video_pick = [''] while 0 < len(video_batch):
video_size = 0 video_pick = ['']
for cur_video_file in video_batch: video_size = 0
cur_video_size = ek.ek(os.path.getsize, ek.ek(os.path.join, process_path, cur_video_file)) for cur_video_file in video_batch:
if 0 == video_size or cur_video_size > video_size: cur_video_size = ek.ek(os.path.getsize, ek.ek(os.path.join, process_path, cur_video_file))
video_size = cur_video_size
video_pick = [cur_video_file]
video_batch = set(video_batch) - set(video_pick) if 0 == video_size or cur_video_size > video_size:
video_size = cur_video_size
video_pick = [cur_video_file]
self._process_media(process_path, video_pick, nzb_name, process_method, force, force_replace, use_trash=cleanup) video_batch = set(video_batch) - set(video_pick)
self._process_media(process_path, video_pick, nzb_name, process_method, force, force_replace, use_trash=cleanup)
except OSError as e:
logger.log('Batch skipped, %s%s' %
(ex(e), e.filename and (' (file %s)' % e.filename) or ''), logger.WARNING)
if process_method in ('hardlink', 'symlink') and video_in_rar: if process_method in ('hardlink', 'symlink') and video_in_rar:
self._delete_files(process_path, rar_content) self._delete_files(process_path, rar_content)