|
@@ -0,0 +1,63 @@
|
|
|
+"""
|
|
|
+Test that nginx-proxy-tester can build successfully
|
|
|
+"""
|
|
|
+import pytest
|
|
|
+import docker
|
|
|
+import re
|
|
|
+
|
|
|
+client = docker.from_env()
|
|
|
+
|
|
|
+@pytest.fixture(scope="session")
|
|
|
+def docker_build(request):
|
|
|
+
|
|
|
+ dockerfile_path = "requirements/"
|
|
|
+ dockerfile_name="Dockerfile-nginx-proxy-tester"
|
|
|
+
|
|
|
+
|
|
|
+ image, logs = client.images.build(
|
|
|
+ path=dockerfile_path,
|
|
|
+ dockerfile=dockerfile_name,
|
|
|
+ rm=True,
|
|
|
+ tag="nginx-proxy-tester-ci",
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+ for log in logs:
|
|
|
+ if "stream" in log:
|
|
|
+ print(log["stream"].strip())
|
|
|
+ if "error" in log:
|
|
|
+ raise Exception(log["error"])
|
|
|
+
|
|
|
+ def teardown():
|
|
|
+
|
|
|
+ client.images.remove(image.id, force=True)
|
|
|
+
|
|
|
+ request.addfinalizer(teardown)
|
|
|
+
|
|
|
+
|
|
|
+ return "nginx-proxy-tester-ci"
|
|
|
+
|
|
|
+def test_build_nginx_proxy_tester(docker_build):
|
|
|
+ assert docker_build == "nginx-proxy-tester-ci"
|
|
|
+
|
|
|
+def test_run_nginx_proxy_tester(docker_build):
|
|
|
+
|
|
|
+ container = client.containers.run("nginx-proxy-tester-ci",
|
|
|
+ command="pytest -V",
|
|
|
+ detach=True,
|
|
|
+
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+ result = container.wait()
|
|
|
+ exit_code = result.get("StatusCode", 1)
|
|
|
+
|
|
|
+
|
|
|
+ output = container.logs().decode("utf-8").strip()
|
|
|
+
|
|
|
+
|
|
|
+ container.remove()
|
|
|
+
|
|
|
+
|
|
|
+ assert exit_code == 0, "Container exited with a non-zero exit code"
|
|
|
+ assert re.search(r"pytest\s\d+\.\d+\.\d+", output)
|