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.
67 lines
1.9 KiB
67 lines
1.9 KiB
3 years ago
|
import os
|
||
|
import time
|
||
|
import re
|
||
|
from flask import url_for
|
||
|
from . util import set_original_response, set_modified_response, live_server_setup
|
||
|
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(3)
|
||
|
|
||
|
# use a different URL so that it doesnt interfere with the actual check until we are ready
|
||
|
test_url = url_for('test_endpoint', _external=True)
|
||
|
res = client.post(
|
||
|
url_for("api_watch_add"),
|
||
|
data={"url": "https://changedetection.io/CHANGELOG.txt", "tag": ''},
|
||
|
follow_redirects=True
|
||
|
)
|
||
|
assert b"Watch added" in res.data
|
||
|
|
||
|
time.sleep(10)
|
||
|
|
||
|
# Check we capture the failure, we can just use trigger_check = y here
|
||
|
res = client.post(
|
||
|
url_for("edit_page", uuid="first"),
|
||
|
data={"notification_urls": "jsons://broken-url.changedetection.io/test",
|
||
|
"notification_title": "xxx",
|
||
|
"notification_body": "xxxxx",
|
||
|
"notification_format": "Text",
|
||
|
"url": test_url,
|
||
|
"tag": "",
|
||
|
"title": "",
|
||
|
"headers": "",
|
||
|
"minutes_between_check": "180",
|
||
|
"fetch_backend": "html_requests",
|
||
|
"trigger_check": "y"},
|
||
|
follow_redirects=True
|
||
|
)
|
||
|
assert b"Updated watch." in res.data
|
||
|
|
||
|
found=False
|
||
|
for i in range(1, 10):
|
||
|
time.sleep(1)
|
||
|
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
|
||
|
|
||
|
|
||
|
assert found
|
||
|
|
||
|
|
||
|
# The error should show in the notification logs
|
||
|
res = client.get(
|
||
|
url_for("notification_logs"))
|
||
|
assert bytes("Name or service not known".encode('utf-8')) in res.data
|
||
|
|
||
|
|
||
|
# And it should be listed on the watch overview
|