From 2ba00d2e1da0c1d11352712ad9eaef20249ab317 Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Tue, 14 Jun 2022 17:01:13 +0200 Subject: [PATCH] Notifications log - log what was sent after applying all cleanups --- changedetectionio/__init__.py | 4 ++-- changedetectionio/notification.py | 4 ++++ changedetectionio/tests/test_notification.py | 4 ++++ 3 files changed, 10 insertions(+), 2 deletions(-) diff --git a/changedetectionio/__init__.py b/changedetectionio/__init__.py index 173f1097..5b6ff262 100644 --- a/changedetectionio/__init__.py +++ b/changedetectionio/__init__.py @@ -1267,7 +1267,7 @@ def notification_runner(): try: from changedetectionio import notification - notification.process_notification(n_object, datastore) + sent_obj = notification.process_notification(n_object, datastore) except Exception as e: logging.error("Watch URL: {} Error {}".format(n_object['watch_url'], str(e))) @@ -1281,7 +1281,7 @@ def notification_runner(): notification_debug_log += log_lines # Process notifications - notification_debug_log+= ["{} - SENDING {}".format(now.strftime("%Y/%m/%d %H:%M:%S,000"), json.dumps(n_object))] + notification_debug_log+= ["{} - SENDING - {}".format(now.strftime("%Y/%m/%d %H:%M:%S,000"), json.dumps(sent_obj))] # Trim the log length notification_debug_log = notification_debug_log[-100:] diff --git a/changedetectionio/notification.py b/changedetectionio/notification.py index b4c9ede2..ac510a8b 100644 --- a/changedetectionio/notification.py +++ b/changedetectionio/notification.py @@ -102,6 +102,10 @@ def process_notification(n_object, datastore): if log_value and 'WARNING' in log_value or 'ERROR' in log_value: raise Exception(log_value) + # Return what was sent for better logging + return {'title': n_title, + 'body': n_body, + 'body_format': n_format} # Notification title + body content parameters get created here. diff --git a/changedetectionio/tests/test_notification.py b/changedetectionio/tests/test_notification.py index 87cc4f57..88c5e319 100644 --- a/changedetectionio/tests/test_notification.py +++ b/changedetectionio/tests/test_notification.py @@ -154,6 +154,10 @@ def test_check_notification(client, live_server): time.sleep(1) assert os.path.exists("test-datastore/notification.txt") == False + res = client.get(url_for("notification_logs")) + # be sure we see it in the output log + assert b'New ChangeDetection.io Notification - ' + test_url.encode('utf-8') in res.data + # cleanup for the next client.get( url_for("form_delete", uuid="all"),