bunkerized-nginx/tests/AutoconfTest.py

129 lines
6.1 KiB
Python
Raw Normal View History

2022-07-13 22:57:36 +02:00
from Test import Test
2023-03-02 18:04:02 +01:00
from os.path import isdir, join, isfile
from os import chown, walk, getenv, listdir
2022-07-14 15:16:33 +02:00
from shutil import copytree, rmtree
2022-07-13 22:57:36 +02:00
from traceback import format_exc
from subprocess import run
from time import sleep
2023-03-02 18:04:02 +01:00
from logger import log
2022-07-13 22:57:36 +02:00
2023-03-02 18:04:02 +01:00
class AutoconfTest(Test) :
2022-07-13 22:57:36 +02:00
2023-03-02 18:04:02 +01:00
def __init__(self, name, timeout, tests, no_copy_container=False, delay=0) :
super().__init__(name, "autoconf", timeout, tests, no_copy_container=no_copy_container, delay=delay)
2022-07-13 22:57:36 +02:00
self._domains = {
r"www\.example\.com": getenv("TEST_DOMAIN1"),
r"auth\.example\.com": getenv("TEST_DOMAIN1"),
r"app1\.example\.com": getenv("TEST_DOMAIN1_1"),
r"app2\.example\.com": getenv("TEST_DOMAIN1_2"),
2023-03-02 18:04:02 +01:00
r"app3\.example\.com": getenv("TEST_DOMAIN1_3")
2022-07-13 22:57:36 +02:00
}
2023-03-02 18:04:02 +01:00
self._check_domains()
2022-07-13 22:57:36 +02:00
2023-03-02 18:04:02 +01:00
def init() :
try :
if not Test.init() :
2022-07-13 22:57:36 +02:00
return False
proc = run("sudo chown -R root:root /tmp/bw-data", shell=True)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
raise(Exception("chown failed (autoconf stack)"))
if isdir("/tmp/autoconf") :
2022-07-13 22:57:36 +02:00
rmtree("/tmp/autoconf")
2023-03-02 18:04:02 +01:00
copytree("./misc/integrations", "/tmp/integrations")
compose = "/tmp/integrations/autoconf.yml"
Test.replace_in_file(compose, r"bunkerity/bunkerweb:.*$", "local/bunkerweb-tests:latest")
Test.replace_in_file(compose, r"bunkerity/bunkerweb-autoconf:.*$", "local/autoconf-tests:latest")
Test.replace_in_file(compose, r"bunkerity/bunkerweb-scheduler:.*$", "local/scheduler-tests:latest")
Test.replace_in_file(compose, r"\./bw\-data:/", "/tmp/bw-data:/")
2023-03-02 18:04:02 +01:00
proc = run("docker-compose pull --ignore-pull-failures", cwd="/tmp/autoconf", shell=True)
if proc.returncode != 0 :
raise(Exception("docker-compose pull failed (autoconf stack)"))
2022-07-13 22:57:36 +02:00
proc = run("docker-compose up -d", cwd="/tmp/autoconf", shell=True)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
raise(Exception("docker-compose up failed (autoconf stack)"))
2022-07-13 22:57:36 +02:00
i = 0
healthy = False
2023-03-02 18:04:02 +01:00
while i < 30 :
proc = run('docker inspect --format "{{json .State.Health }}" autoconf-mybunker-1', cwd="/tmp/autoconf", shell=True, capture_output=True)
if proc.returncode != 0 :
raise(Exception("docker inspect failed (autoconf stack)"))
if "healthy" in proc.stdout.decode() :
2022-07-13 22:57:36 +02:00
healthy = True
break
sleep(1)
i += 1
2023-03-02 18:04:02 +01:00
if not healthy :
raise(Exception("autoconf stack is not healthy"))
except :
log("AUTOCONF", "", "exception while running AutoconfTest.init()\n" + format_exc())
2022-07-13 22:57:36 +02:00
return False
return True
2023-03-02 18:04:02 +01:00
def end() :
2022-07-13 22:57:36 +02:00
ret = True
2023-03-02 18:04:02 +01:00
try :
if not Test.end() :
2022-07-13 22:57:36 +02:00
return False
proc = run("docker-compose down -v", cwd="/tmp/autoconf", shell=True)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
2022-07-13 22:57:36 +02:00
ret = False
rmtree("/tmp/autoconf")
2023-03-02 18:04:02 +01:00
except :
log("AUTOCONF", "", "exception while running AutoconfTest.end()\n" + format_exc())
2022-07-13 22:57:36 +02:00
return False
return ret
2023-03-02 18:04:02 +01:00
def _setup_test(self) :
try :
2022-07-13 22:57:36 +02:00
super()._setup_test()
2023-03-02 18:04:02 +01:00
test = "/tmp/tests/" + self._name
compose = "/tmp/tests/" + self._name + "/autoconf.yml"
example_data = "/tmp/tests/" + self._name + "/bw-data"
Test.replace_in_file(compose, r"bunkerity/bunkerweb:.*$", "local/bunkerweb-tests:latest")
Test.replace_in_file(compose, r"bunkerity/bunkerweb-scheduler:.*$", "local/scheduler-tests:latest")
Test.replace_in_file(compose, r"bunkerity/bunkerweb-autoconf:.*$", "local/autoconf-tests:latest")
Test.replace_in_file(compose, r"\./bw\-data:/", "/tmp/bw-data:/")
Test.replace_in_file(compose, r"\- bw_data:/", "- /tmp/bw-data:/")
2023-03-02 18:04:02 +01:00
for ex_domain, test_domain in self._domains.items() :
Test.replace_in_files(test, ex_domain, test_domain)
Test.rename(test, ex_domain, test_domain)
2022-07-15 09:46:50 +02:00
Test.replace_in_files(test, "example.com", getenv("ROOT_DOMAIN"))
2023-03-02 18:04:02 +01:00
setup = test + "/setup-autoconf.sh"
if isfile(setup) :
2022-07-13 22:57:36 +02:00
proc = run("sudo ./setup-autoconf.sh", cwd=test, shell=True)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
raise(Exception("setup-autoconf failed"))
if isdir(example_data) and not self._no_copy_container :
proc = run("sudo bash -c 'cp -rp " + example_data + "/* /tmp/bw-data'", shell=True)
if proc.returncode != 0 :
raise(Exception("cp bw-data failed"))
proc = run("docker-compose -f autoconf.yml pull --ignore-pull-failures", shell=True, cwd=test)
if proc.returncode != 0 :
raise(Exception("docker-compose pull failed"))
proc = run("docker-compose -f autoconf.yml up -d", shell=True, cwd=test)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
raise(Exception("docker-compose up failed"))
except :
log("AUTOCONF", "", "exception while running AutoconfTest._setup_test()\n" + format_exc())
2022-07-13 22:57:36 +02:00
self._cleanup_test()
return False
return True
2023-03-02 18:04:02 +01:00
def _cleanup_test(self) :
try :
test = "/tmp/tests/" + self._name
proc = run("docker-compose -f autoconf.yml down -v", shell=True, cwd=test)
2023-03-02 18:04:02 +01:00
if proc.returncode != 0 :
raise(Exception("docker-compose down failed"))
2022-07-13 22:57:36 +02:00
super()._cleanup_test()
2023-03-02 18:04:02 +01:00
except :
log("AUTOCONF", "", "exception while running AutoconfTest._cleanup_test()\n" + format_exc())
2022-07-13 22:57:36 +02:00
return False
return True
2022-07-14 14:27:18 +02:00
2023-03-02 18:04:02 +01:00
def _debug_fail(self) :
2022-07-14 14:27:18 +02:00
autoconf = "/tmp/autoconf"
proc = run("docker-compose logs", shell=True, cwd=autoconf)
2023-03-02 18:04:02 +01:00
test = "/tmp/tests/" + self._name
proc = run("docker-compose -f autoconf.yml logs", shell=True, cwd=test)