From 89bdc4d8ab0fef1a59021f425483b117b101698c Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Fri, 7 Jun 2024 10:38:42 +0200 Subject: [PATCH] Refactor the wait-for-check --- changedetectionio/flask_app.py | 6 +++++- .../tests/test_filter_failure_notification.py | 12 ++++++++++-- changedetectionio/tests/util.py | 18 +++++++++--------- changedetectionio/update_worker.py | 3 ++- 4 files changed, 26 insertions(+), 13 deletions(-) diff --git a/changedetectionio/flask_app.py b/changedetectionio/flask_app.py index 3a3bb0f8..e6f401cc 100644 --- a/changedetectionio/flask_app.py +++ b/changedetectionio/flask_app.py @@ -45,7 +45,6 @@ running_update_threads = [] ticker_thread = None extra_stylesheets = [] - update_q = queue.PriorityQueue() notification_q = queue.Queue() @@ -1538,6 +1537,11 @@ def changedetection_app(config=None, datastore_o=None): # paste in etc return redirect(url_for('index')) + @app.route("/queue_size", methods=['GET']) + @login_optionally_required + def get_queue_size(): + return update_q.qsize() + @app.route("/highlight_submit_ignore_url", methods=['POST']) @login_optionally_required def highlight_submit_ignore_url(): diff --git a/changedetectionio/tests/test_filter_failure_notification.py b/changedetectionio/tests/test_filter_failure_notification.py index d364cad9..8aedca3a 100644 --- a/changedetectionio/tests/test_filter_failure_notification.py +++ b/changedetectionio/tests/test_filter_failure_notification.py @@ -22,8 +22,7 @@ def set_response_with_filter(): return None def run_filter_test(client, content_filter): - time.sleep(1) - + # cleanup for the next client.get( url_for("form_delete", uuid="all"), @@ -104,6 +103,10 @@ def run_filter_test(client, content_filter): wait_for_all_checks(client) client.get(url_for("form_watch_checknow"), follow_redirects=True) wait_for_all_checks(client) + + # Give apprise time to fire + time.sleep(3) + # Now it should exist and contain our "filter not found" alert assert os.path.isfile("test-datastore/notification.txt") @@ -123,6 +126,9 @@ def run_filter_test(client, content_filter): client.get(url_for("form_watch_checknow"), follow_redirects=True) wait_for_all_checks(client) + # Give apprise time to fire + time.sleep(3) + # It should have sent a notification, but.. assert os.path.isfile("test-datastore/notification.txt") # but it should not contain the info about a failed filter (because there was none in this case) @@ -148,11 +154,13 @@ def test_setup(live_server): live_server_setup(live_server) def test_check_include_filters_failure_notification(client, live_server): + #live_server_setup(live_server) set_original_response() wait_for_all_checks(client) run_filter_test(client, '#nope-doesnt-exist') def test_check_xpath_filter_failure_notification(client, live_server): + # live_server_setup(live_server) set_original_response() time.sleep(1) run_filter_test(client, '//*[@id="nope-doesnt-exist"]') diff --git a/changedetectionio/tests/util.py b/changedetectionio/tests/util.py index 7f8222c3..0f054ee5 100644 --- a/changedetectionio/tests/util.py +++ b/changedetectionio/tests/util.py @@ -122,16 +122,16 @@ def extract_UUID_from_client(client): def wait_for_all_checks(client): - # Loop waiting until done.. - attempt = 0 - while attempt < 60: - time.sleep(1) - # should be greater than update_worker.py: self.app.config.exit.wait(0.5) - res = client.get(url_for("index")) - if not b'Checking now' in res.data: + now = time.time() + while time.time() - now <= 30: + time.sleep(0.1) + p = client.application.view_functions['get_queue_size']() + if not p: break - logging.getLogger().info("Waiting for watch-list to not say 'Checking now'.. {}".format(attempt)) - attempt += 1 + logging.getLogger().info(f"Waiting for queue to be empty, queue size {p} - {time.time() - now}") + + # Empty queue still means that one could be processing, give time for the processing to complete + time.sleep(0.2) def live_server_setup(live_server): diff --git a/changedetectionio/update_worker.py b/changedetectionio/update_worker.py index 1c488547..9757b18a 100644 --- a/changedetectionio/update_worker.py +++ b/changedetectionio/update_worker.py @@ -160,8 +160,8 @@ class update_worker(threading.Thread): def send_filter_failure_notification(self, watch_uuid): - threshold = self.datastore.data['settings']['application'].get('filter_failure_notification_threshold_attempts') + logger.trace(f"Watch UUID: {watch_uuid} - Sending filter failure notification - threshold attempts {threshold}") watch = self.datastore.data['watching'].get(watch_uuid) if not watch: return @@ -335,6 +335,7 @@ class update_worker(threading.Thread): process_changedetection_results = False except FilterNotFoundInResponse as e: + logger.debug(f"Watch UUID: {uuid} - Got FilterNotFoundInResponse exception, Consecutive failures - {self.datastore.data['watching'][uuid].get('consecutive_filter_failures', 5)} - handling..") if not self.datastore.data['watching'].get(uuid): continue