From fd25fe8a5fe75bf3467c3656dc4bb8317d3fd8ac Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Wed, 25 Sep 2024 14:32:25 +0200 Subject: [PATCH] Use local data instead of reaching out to changedetection when testing --- changedetectionio/run_socks_proxy_tests.sh | 3 +++ .../tests/proxy_socks5/test_socks5_proxy.py | 24 ++++++++++++++++--- .../proxy_socks5/test_socks5_proxy_sources.py | 22 ++++++++++++++--- 3 files changed, 43 insertions(+), 6 deletions(-) diff --git a/changedetectionio/run_socks_proxy_tests.sh b/changedetectionio/run_socks_proxy_tests.sh index 2040d552..7c72c92f 100755 --- a/changedetectionio/run_socks_proxy_tests.sh +++ b/changedetectionio/run_socks_proxy_tests.sh @@ -16,6 +16,7 @@ echo "---------------------------------- SOCKS5 -------------------" docker run --network changedet-network \ -v `pwd`/tests/proxy_socks5/proxies.json-example:/app/changedetectionio/test-datastore/proxies.json \ --rm \ + --hostname cdio \ -e "SOCKSTEST=proxiesjson" \ test-changedetectionio \ bash -c 'cd changedetectionio && pytest tests/proxy_socks5/test_socks5_proxy_sources.py' @@ -23,6 +24,7 @@ docker run --network changedet-network \ # SOCKS5 related - by manually entering in UI docker run --network changedet-network \ --rm \ + --hostname cdio \ -e "SOCKSTEST=manual" \ test-changedetectionio \ bash -c 'cd changedetectionio && pytest tests/proxy_socks5/test_socks5_proxy.py' @@ -30,6 +32,7 @@ docker run --network changedet-network \ # SOCKS5 related - test from proxies.json via playwright - NOTE- PLAYWRIGHT DOESNT SUPPORT AUTHENTICATING PROXY docker run --network changedet-network \ -e "SOCKSTEST=manual-playwright" \ + --hostname cdio \ -v `pwd`/tests/proxy_socks5/proxies.json-example-noauth:/app/changedetectionio/test-datastore/proxies.json \ -e "PLAYWRIGHT_DRIVER_URL=ws://sockpuppetbrowser:3000" \ --rm \ diff --git a/changedetectionio/tests/proxy_socks5/test_socks5_proxy.py b/changedetectionio/tests/proxy_socks5/test_socks5_proxy.py index f9ce166d..01152050 100644 --- a/changedetectionio/tests/proxy_socks5/test_socks5_proxy.py +++ b/changedetectionio/tests/proxy_socks5/test_socks5_proxy.py @@ -1,12 +1,27 @@ #!/usr/bin/env python3 import os -import time from flask import url_for from changedetectionio.tests.util import live_server_setup, wait_for_all_checks +def set_response(): + import time + data = f""" + +

Awesome, you made it

+ yeah the socks request worked + + + """ + + with open("test-datastore/endpoint-content.txt", "w") as f: + f.write(data) + time.sleep(1) + + def test_socks5(client, live_server, measure_memory_usage): live_server_setup(live_server) + set_response() # Setup a proxy res = client.post( @@ -24,7 +39,10 @@ def test_socks5(client, live_server, measure_memory_usage): assert b"Settings updated." in res.data - test_url = "https://changedetection.io/CHANGELOG.txt?socks-test-tag=" + os.getenv('SOCKSTEST', '') + # Because the socks server should connect back to us + test_url = url_for('test_endpoint', _external=True) + f"?socks-test-tag={os.getenv('SOCKSTEST', '')}" + test_url = test_url.replace('localhost.localdomain', 'cdio') + test_url = test_url.replace('localhost', 'cdio') res = client.post( url_for("form_quick_watch_add"), @@ -60,4 +78,4 @@ def test_socks5(client, live_server, measure_memory_usage): ) # Should see the proper string - assert "+0200:".encode('utf-8') in res.data + assert "Awesome, you made it".encode('utf-8') in res.data diff --git a/changedetectionio/tests/proxy_socks5/test_socks5_proxy_sources.py b/changedetectionio/tests/proxy_socks5/test_socks5_proxy_sources.py index 0da50acc..5c473303 100644 --- a/changedetectionio/tests/proxy_socks5/test_socks5_proxy_sources.py +++ b/changedetectionio/tests/proxy_socks5/test_socks5_proxy_sources.py @@ -1,16 +1,32 @@ #!/usr/bin/env python3 import os -import time from flask import url_for from changedetectionio.tests.util import live_server_setup, wait_for_all_checks +def set_response(): + import time + data = f""" + +

Awesome, you made it

+ yeah the socks request worked + + + """ + + with open("test-datastore/endpoint-content.txt", "w") as f: + f.write(data) + time.sleep(1) + # should be proxies.json mounted from run_proxy_tests.sh already # -v `pwd`/tests/proxy_socks5/proxies.json-example:/app/changedetectionio/test-datastore/proxies.json def test_socks5_from_proxiesjson_file(client, live_server, measure_memory_usage): live_server_setup(live_server) - - test_url = "https://changedetection.io/CHANGELOG.txt?socks-test-tag=" + os.getenv('SOCKSTEST', '') + set_response() + # Because the socks server should connect back to us + test_url = url_for('test_endpoint', _external=True) + f"?socks-test-tag={os.getenv('SOCKSTEST', '')}" + test_url = test_url.replace('localhost.localdomain', 'cdio') + test_url = test_url.replace('localhost', 'cdio') res = client.get(url_for("settings_page")) assert b'name="requests-proxy" type="radio" value="socks5proxy"' in res.data