From 2f16aee0dd631a6b4f6163ce1bbe01ae5dd60a0d Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Mon, 13 Nov 2023 14:37:48 +0100 Subject: [PATCH] Attempt to test --- .github/workflows/test-only.yml | 9 ++ .../run_custom_browser_url_tests.sh | 10 ++ .../tests/custom_browser_url/__init__.py | 1 + .../test_custom_browser_url.py | 91 +++++++++++++++++++ 4 files changed, 111 insertions(+) create mode 100755 changedetectionio/run_custom_browser_url_tests.sh create mode 100644 changedetectionio/tests/custom_browser_url/__init__.py create mode 100644 changedetectionio/tests/custom_browser_url/test_custom_browser_url.py diff --git a/.github/workflows/test-only.yml b/.github/workflows/test-only.yml index 08a3f944..65588b63 100644 --- a/.github/workflows/test-only.yml +++ b/.github/workflows/test-only.yml @@ -31,6 +31,9 @@ jobs: # Selenium+browserless docker run --network changedet-network -d --hostname selenium -p 4444:4444 --rm --shm-size="2g" selenium/standalone-chrome:4 docker run --network changedet-network -d --hostname browserless -e "FUNCTION_BUILT_INS=[\"fs\",\"crypto\"]" -e "DEFAULT_LAUNCH_ARGS=[\"--window-size=1920,1080\"]" --rm -p 3000:3000 --shm-size="2g" browserless/chrome:1.60-chrome-stable + + # For accessing custom browser tests + docker run --network changedet-network -d --name browserless-custom-url --hostname browserless-custom-url -e "FUNCTION_BUILT_INS=[\"fs\",\"crypto\"]" -e "DEFAULT_LAUNCH_ARGS=[\"--window-size=1920,1080\"]" --rm -p 3000:3000 --shm-size="2g" browserless/chrome:1.60-chrome-stable - name: Build changedetection.io container for testing run: | @@ -86,6 +89,12 @@ jobs: # And again with PLAYWRIGHT_DRIVER_URL=.. cd .. + - name: Test custom browser URL + run: | + cd changedetectionio + ./run_custom_browser_url_tests.sh + cd .. + - name: Test changedetection.io container starts+runs basically without error run: | docker run -p 5556:5000 -d test-changedetectionio diff --git a/changedetectionio/run_custom_browser_url_tests.sh b/changedetectionio/run_custom_browser_url_tests.sh new file mode 100755 index 00000000..ced47351 --- /dev/null +++ b/changedetectionio/run_custom_browser_url_tests.sh @@ -0,0 +1,10 @@ +#!/bin/bash + +# exit when any command fails +set -e +# enable debug +set -x + +docker run --rm -e "PLAYWRIGHT_DRIVER_URL=ws://browserless:3000" --network changedet-network test-changedetectionio bash -c 'cd changedetectionio;pytest custom_browser_url/test_custom_browser_url.py::test_request_via_custom_browser_url' +docker logs browserless-custom-url + diff --git a/changedetectionio/tests/custom_browser_url/__init__.py b/changedetectionio/tests/custom_browser_url/__init__.py new file mode 100644 index 00000000..f4572339 --- /dev/null +++ b/changedetectionio/tests/custom_browser_url/__init__.py @@ -0,0 +1 @@ +# placeholder \ No newline at end of file diff --git a/changedetectionio/tests/custom_browser_url/test_custom_browser_url.py b/changedetectionio/tests/custom_browser_url/test_custom_browser_url.py new file mode 100644 index 00000000..3335dd99 --- /dev/null +++ b/changedetectionio/tests/custom_browser_url/test_custom_browser_url.py @@ -0,0 +1,91 @@ +# !/usr/bin/python3 +import os + +from flask import url_for +from ..util import live_server_setup, wait_for_all_checks + +def do_test(client, live_server, make_test_use_extra_browser=False): + + is_extra_browser = 'use-extra-browser' if make_test_use_extra_browser else 'not-extra-browser' + # Grep for this string in the logs? + test_url = f"https://changedetection.io/ci-test.html?is_custom={is_extra_browser}" + custom_browser_name = 'custom browser URL' + + # needs to be set and something like 'ws://127.0.0.1:3000?stealth=1&--disable-web-security=true' + assert os.getenv('PLAYWRIGHT_DRIVER_URL'), "Needs PLAYWRIGHT_DRIVER_URL set for this test" + + ##################### + res = client.post( + url_for("settings_page"), + data={"application-empty_pages_are_a_change": "", + "requests-time_between_check-minutes": 180, + 'application-fetch_backend': "html_webdriver", + # browserless-custom-url is setup in .github/workflows/test-only.yml + 'requests-extra_browsers-0-browser_connection_url': 'ws://browserless-custom-url:3000?stealth=1&--disable-web-security=true', + 'requests-extra_browsers-0-browser_name': custom_browser_name + }, + follow_redirects=True + ) + + assert b"Settings updated." in res.data + + # Add our URL to the import page + res = client.post( + url_for("import_page"), + data={"urls": test_url}, + follow_redirects=True + ) + + assert b"1 Imported" in res.data + wait_for_all_checks(client) + + if make_test_use_extra_browser: + + # So the name should appear in the edit page under "Request" > "Fetch Method" + res = client.get( + url_for("edit_page", uuid="first"), + follow_redirects=True + ) + assert b'custom browser URL' in res.data + + res = client.post( + url_for("edit_page", uuid="first"), + data={ + "url": test_url, + "tags": "", + "headers": "", + 'fetch_backend': f"extra_browser_{custom_browser_name}", + 'webdriver_js_execute_code': '' + }, + follow_redirects=True + ) + with open('/tmp/fuck.html' , 'wb') as f: + f.write(res.data) + + assert b"Updated watch." in res.data + wait_for_all_checks(client) + + # Force recheck + res = client.get(url_for("form_watch_checknow"), follow_redirects=True) + assert b'1 watches queued for rechecking.' in res.data + + wait_for_all_checks(client) + + res = client.get( + url_for("preview_page", uuid="first"), + follow_redirects=True + ) + assert b'cool it works' in res.data + + +# Requires playwright to be installed +def test_request_via_custom_browser_url(client, live_server): + live_server_setup(live_server) + # We do this so we can grep the logs of the custom container and see if the request actually went through that container + do_test(client, live_server, make_test_use_extra_browser=True) + + +def test_request_not_via_custom_browser_url(client, live_server): + live_server_setup(live_server) + # We do this so we can grep the logs of the custom container and see if the request actually went through that container + do_test(client, live_server, make_test_use_extra_browser=False)