From ed0b1fe1151b1f4ec446dacd67c43ebd7e2ab62a Mon Sep 17 00:00:00 2001 From: jonaswinkler Date: Thu, 11 Feb 2021 22:16:41 +0100 Subject: [PATCH] better exception logging --- src/documents/classifier.py | 4 ++-- src/documents/index.py | 4 ++-- src/documents/management/commands/document_archiver.py | 2 +- src/documents/management/commands/document_consumer.py | 6 ++---- src/paperless_mail/tasks.py | 7 ++----- 5 files changed, 9 insertions(+), 14 deletions(-) diff --git a/src/documents/classifier.py b/src/documents/classifier.py index 81f860314..c880e50d6 100755 --- a/src/documents/classifier.py +++ b/src/documents/classifier.py @@ -43,9 +43,9 @@ def load_classifier(): version=version, timeout=86400) except (EOFError, IncompatibleClassifierVersionError) as e: # there's something wrong with the model file. - logger.error( + logger.exception( f"Unrecoverable error while loading document " - f"classification model: {str(e)}, deleting model file." + f"classification model, deleting model file." ) os.unlink(settings.MODEL_FILE) classifier = None diff --git a/src/documents/index.py b/src/documents/index.py index bc17daeb1..ea788f4b3 100644 --- a/src/documents/index.py +++ b/src/documents/index.py @@ -78,8 +78,8 @@ def open_index(recreate=False): try: if exists_in(settings.INDEX_DIR) and not recreate: return open_dir(settings.INDEX_DIR, schema=get_schema()) - except Exception as e: - logger.error(f"Error while opening the index: {e}, recreating.") + except Exception: + logger.exception(f"Error while opening the index, recreating.") if not os.path.isdir(settings.INDEX_DIR): os.makedirs(settings.INDEX_DIR, exist_ok=True) diff --git a/src/documents/management/commands/document_archiver.py b/src/documents/management/commands/document_archiver.py index fe8c8b530..297c95121 100644 --- a/src/documents/management/commands/document_archiver.py +++ b/src/documents/management/commands/document_archiver.py @@ -60,7 +60,7 @@ def handle_document(document_id): index.update_document(writer, document) except Exception as e: - logger.error(f"Error while parsing document {document}: {str(e)}") + logger.exception(f"Error while parsing document {document}") finally: parser.cleanup() diff --git a/src/documents/management/commands/document_consumer.py b/src/documents/management/commands/document_consumer.py index c01743628..aaa644891 100644 --- a/src/documents/management/commands/document_consumer.py +++ b/src/documents/management/commands/document_consumer.py @@ -54,8 +54,7 @@ def _consume(filepath): if settings.CONSUMER_SUBDIRS_AS_TAGS: tag_ids = _tags_from_path(filepath) except Exception as e: - logger.error( - "Error creating tags from path: {}".format(e)) + logger.exception("Error creating tags from path") try: async_task("documents.tasks.consume_file", @@ -66,8 +65,7 @@ def _consume(filepath): # Catch all so that the consumer won't crash. # This is also what the test case is listening for to check for # errors. - logger.error( - "Error while consuming document: {}".format(e)) + logger.exception("Error while consuming document") def _consume_wait_unmodified(file, num_tries=20, wait_time=1): diff --git a/src/paperless_mail/tasks.py b/src/paperless_mail/tasks.py index 086edef7b..c591f04b9 100644 --- a/src/paperless_mail/tasks.py +++ b/src/paperless_mail/tasks.py @@ -13,11 +13,8 @@ def process_mail_accounts(): try: total_new_documents += MailAccountHandler().handle_mail_account( account) - except MailError as e: - logger.error( - f"Error while processing mail account {account}: {e}", - exc_info=True - ) + except MailError: + logger.exception(f"Error while processing mail account {account}") if total_new_documents > 0: return f"Added {total_new_documents} document(s)."