85 lines
3.0 KiB
85 lines
3.0 KiB
#!/bin/bash
|
|
|
|
# exit when any command fails
|
|
set -e
|
|
# enable debug
|
|
set -x
|
|
|
|
# Test proxy list handling, starting two squids on different ports
|
|
# Each squid adds a different header to the response, which is the main thing we test for.
|
|
docker run --network changedet-network -d --name squid-one --hostname squid-one --rm -v `pwd`/tests/proxy_list/squid.conf:/etc/squid/conf.d/debian.conf ubuntu/squid:4.13-21.10_edge
|
|
docker run --network changedet-network -d --name squid-two --hostname squid-two --rm -v `pwd`/tests/proxy_list/squid.conf:/etc/squid/conf.d/debian.conf ubuntu/squid:4.13-21.10_edge
|
|
|
|
# Used for configuring a custom proxy URL via the UI - with username+password auth
|
|
docker run --network changedet-network -d \
|
|
--name squid-custom \
|
|
--hostname squid-custom \
|
|
--rm \
|
|
-v `pwd`/tests/proxy_list/squid-auth.conf:/etc/squid/conf.d/debian.conf \
|
|
-v `pwd`/tests/proxy_list/squid-passwords.txt:/etc/squid3/passwords \
|
|
ubuntu/squid:4.13-21.10_edge
|
|
|
|
|
|
## 2nd test actually choose the preferred proxy from proxies.json
|
|
docker run --network changedet-network \
|
|
-v `pwd`/tests/proxy_list/proxies.json-example:/app/changedetectionio/test-datastore/proxies.json \
|
|
test-changedetectionio \
|
|
bash -c 'cd changedetectionio && pytest tests/proxy_list/test_multiple_proxy.py'
|
|
|
|
set +e
|
|
echo "- Looking for chosen.changedetection.io request in squid-one - it should NOT be here"
|
|
docker logs squid-one 2>/dev/null|grep chosen.changedetection.io
|
|
if [ $? -ne 1 ]
|
|
then
|
|
echo "Saw a request to chosen.changedetection.io in the squid logs (while checking preferred proxy - squid one) WHEN I SHOULD NOT"
|
|
exit 1
|
|
fi
|
|
|
|
set -e
|
|
echo "- Looking for chosen.changedetection.io request in squid-two"
|
|
# And one in the 'second' squid (user selects this as preferred)
|
|
docker logs squid-two 2>/dev/null|grep chosen.changedetection.io
|
|
if [ $? -ne 0 ]
|
|
then
|
|
echo "Did not see a request to chosen.changedetection.io in the squid logs (while checking preferred proxy - squid two)"
|
|
exit 1
|
|
fi
|
|
|
|
# Test the UI configurable proxies
|
|
docker run --network changedet-network \
|
|
test-changedetectionio \
|
|
bash -c 'cd changedetectionio && pytest tests/proxy_list/test_select_custom_proxy.py'
|
|
|
|
|
|
# Should see a request for one.changedetection.io in there
|
|
echo "- Looking for .changedetection.io request in squid-custom"
|
|
docker logs squid-custom 2>/dev/null|grep "TCP_TUNNEL.200.*changedetection.io"
|
|
if [ $? -ne 0 ]
|
|
then
|
|
echo "Did not see a valid request to changedetection.io in the squid logs (while checking preferred proxy - squid two)"
|
|
exit 1
|
|
fi
|
|
|
|
# Test "no-proxy" option
|
|
docker run --network changedet-network \
|
|
test-changedetectionio \
|
|
bash -c 'cd changedetectionio && pytest tests/proxy_list/test_noproxy.py'
|
|
|
|
# We need to handle grep returning 1
|
|
set +e
|
|
# Check request was never seen in any container
|
|
for c in $(echo "squid-one squid-two squid-custom"); do
|
|
echo ....Checking $c
|
|
docker logs $c &> $c.txt
|
|
grep noproxy $c.txt
|
|
if [ $? -ne 1 ]
|
|
then
|
|
echo "Saw request for noproxy in $c container"
|
|
cat $c.txt
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
|
|
docker kill squid-one squid-two squid-custom
|