You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.5 KiB
76 lines
2.5 KiB
import os
|
|
import time
|
|
from flask import url_for
|
|
from .util import set_original_response, set_modified_response, live_server_setup, wait_for_all_checks
|
|
import logging
|
|
|
|
def test_check_notification_error_handling(client, live_server):
|
|
|
|
live_server_setup(live_server)
|
|
set_original_response()
|
|
|
|
# Give the endpoint time to spin up
|
|
time.sleep(1)
|
|
|
|
# Set a URL and fetch it, then set a notification URL which is going to give errors
|
|
test_url = url_for('test_endpoint', _external=True)
|
|
res = client.post(
|
|
url_for("form_quick_watch_add"),
|
|
data={"url": test_url, "tags": ''},
|
|
follow_redirects=True
|
|
)
|
|
assert b"Watch added" in res.data
|
|
|
|
wait_for_all_checks(client)
|
|
set_modified_response()
|
|
|
|
working_notification_url = url_for('test_notification_endpoint', _external=True).replace('http', 'json')
|
|
broken_notification_url = "jsons://broken-url-xxxxxxxx123/test"
|
|
|
|
res = client.post(
|
|
url_for("edit_page", uuid="first"),
|
|
# A URL with errors should not block the one that is working
|
|
data={"notification_urls": f"{broken_notification_url}\r\n{working_notification_url}",
|
|
"notification_title": "xxx",
|
|
"notification_body": "xxxxx",
|
|
"notification_format": "Text",
|
|
"url": test_url,
|
|
"tags": "",
|
|
"title": "",
|
|
"headers": "",
|
|
"time_between_check-minutes": "180",
|
|
"fetch_backend": "html_requests"},
|
|
follow_redirects=True
|
|
)
|
|
assert b"Updated watch." in res.data
|
|
|
|
found=False
|
|
for i in range(1, 10):
|
|
|
|
logging.debug("Fetching watch overview....")
|
|
res = client.get(
|
|
url_for("index"))
|
|
|
|
if bytes("Notification error detected".encode('utf-8')) in res.data:
|
|
found=True
|
|
break
|
|
|
|
time.sleep(1)
|
|
|
|
assert found
|
|
|
|
|
|
# The error should show in the notification logs
|
|
res = client.get(
|
|
url_for("notification_logs"))
|
|
found_name_resolution_error = b"Temporary failure in name resolution" in res.data or b"Name or service not known" in res.data
|
|
assert found_name_resolution_error
|
|
|
|
# And the working one, which is after the 'broken' one should still have fired
|
|
with open("test-datastore/notification.txt", "r") as f:
|
|
notification_submission = f.read()
|
|
os.unlink("test-datastore/notification.txt")
|
|
assert 'xxxxx' in notification_submission
|
|
|
|
client.get(url_for("form_delete", uuid="all"), follow_redirects=True)
|