mirror of
https://github.com/thib8956/nginx-proxy
synced 2024-11-22 11:56:31 +00:00
Added BATS tests for dhparam generation
This commit is contained in:
parent
7c0f7b9449
commit
f73a52afaf
@ -61,7 +61,7 @@ function setup {
|
|||||||
prepare_web_container bats-ssl-hosts-4 "80 443" \
|
prepare_web_container bats-ssl-hosts-4 "80 443" \
|
||||||
-e VIRTUAL_HOST=*.nginx-proxy.bats \
|
-e VIRTUAL_HOST=*.nginx-proxy.bats \
|
||||||
-e CERT_NAME=nginx-proxy.bats
|
-e CERT_NAME=nginx-proxy.bats
|
||||||
dockergen_wait_for_event $SUT_CONTAINER start bats-ssl-hosts-1
|
dockergen_wait_for_event $SUT_CONTAINER start bats-ssl-hosts-4
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
||||||
# THEN
|
# THEN
|
||||||
@ -76,7 +76,7 @@ function setup {
|
|||||||
-e VIRTUAL_HOST=*.nginx-proxy.bats \
|
-e VIRTUAL_HOST=*.nginx-proxy.bats \
|
||||||
-e CERT_NAME=nginx-proxy.bats \
|
-e CERT_NAME=nginx-proxy.bats \
|
||||||
-e HTTPS_METHOD=noredirect
|
-e HTTPS_METHOD=noredirect
|
||||||
dockergen_wait_for_event $SUT_CONTAINER start bats-ssl-hosts-3
|
dockergen_wait_for_event $SUT_CONTAINER start bats-ssl-hosts-5
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
||||||
# THEN
|
# THEN
|
||||||
@ -85,7 +85,6 @@ function setup {
|
|||||||
refute_output -p "Strict-Transport-Security: max-age=31536000"
|
refute_output -p "Strict-Transport-Security: max-age=31536000"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@test "[$TEST_FILE] stop all bats containers" {
|
@test "[$TEST_FILE] stop all bats containers" {
|
||||||
stop_bats_containers
|
stop_bats_containers
|
||||||
}
|
}
|
||||||
|
85
test/ssl_dhparam.bats
Normal file
85
test/ssl_dhparam.bats
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
#!/usr/bin/env bats
|
||||||
|
load test_helpers
|
||||||
|
|
||||||
|
function setup {
|
||||||
|
# make sure to stop any web container before each test so we don't
|
||||||
|
# have any unexpected contaiener running with VIRTUAL_HOST or VIRUTAL_PORT set
|
||||||
|
stop_bats_containers web
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] test dhparam.pem is generated if missing (WARNING: this test is slow!):" {
|
||||||
|
SUT_CONTAINER=bats-nginx-proxy-${TEST_FILE}-1
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
run docker_clean $SUT_CONTAINER \
|
||||||
|
&& docker run -d \
|
||||||
|
--label bats-type="nginx-proxy" \
|
||||||
|
--name $SUT_CONTAINER \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
$SUT_IMAGE \
|
||||||
|
&& wait_for_nginxproxy_container_to_start $SUT_CONTAINER \
|
||||||
|
&& docker logs $SUT_CONTAINER
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
docker_wait_for_log $SUT_CONTAINER 9 "Watching docker events"
|
||||||
|
|
||||||
|
# THEN
|
||||||
|
run docker exec $SUT_CONTAINER ps aux
|
||||||
|
assert_output -p "openssl"
|
||||||
|
|
||||||
|
DEFAULT_HASH=$(docker exec $SUT_CONTAINER md5sum /etc/nginx/dhparam/dhparam.pem | cut -d" " -f1)
|
||||||
|
docker_wait_for_log $SUT_CONTAINER 240 "dhparam generation complete, reloading nginx"
|
||||||
|
|
||||||
|
run docker exec $SUT_CONTAINER md5sum /etc/nginx/dhparam/dhparam.pem
|
||||||
|
refute_output -p $DEFAULT_HASH
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] test dhparam.pem is generated if default one is present" {
|
||||||
|
SUT_CONTAINER=bats-nginx-proxy-${TEST_FILE}-2
|
||||||
|
|
||||||
|
# Copy the default dhparams to a volume and mount it in to ensure it's regenerated
|
||||||
|
TMP_DIR=/tmp/nginx-proxy-bats
|
||||||
|
if [ ! -d $TMP_DIR ]; then
|
||||||
|
mkdir $TMP_DIR
|
||||||
|
fi
|
||||||
|
cp $DIR/../dhparam.pem.default $TMP_DIR/dhparam.pem
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
run docker_clean $SUT_CONTAINER \
|
||||||
|
&& docker run -d \
|
||||||
|
--label bats-type="nginx-proxy" \
|
||||||
|
--name $SUT_CONTAINER \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
-v $TMP_DIR:/etc/nginx/dhparam \
|
||||||
|
$SUT_IMAGE \
|
||||||
|
&& wait_for_nginxproxy_container_to_start $SUT_CONTAINER \
|
||||||
|
&& docker logs $SUT_CONTAINER
|
||||||
|
|
||||||
|
docker logs $SUT_CONTAINER
|
||||||
|
|
||||||
|
assert_success
|
||||||
|
docker_wait_for_log $SUT_CONTAINER 9 "Watching docker events"
|
||||||
|
|
||||||
|
# THEN
|
||||||
|
run docker exec $SUT_CONTAINER ps aux
|
||||||
|
assert_output -p "openssl"
|
||||||
|
|
||||||
|
docker exec $SUT_CONTAINER rm -rf /etc/nginx/dhparam/*
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] test dhparam.pem is not generated if custom one is present" {
|
||||||
|
SUT_CONTAINER=bats-nginx-proxy-${TEST_FILE}-3
|
||||||
|
|
||||||
|
# WHEN
|
||||||
|
run nginxproxy $SUT_CONTAINER -v /var/run/docker.sock:/tmp/docker.sock:ro
|
||||||
|
assert_success
|
||||||
|
docker_wait_for_log $SUT_CONTAINER 9 "Watching docker events"
|
||||||
|
|
||||||
|
# THEN
|
||||||
|
run docker exec $SUT_CONTAINER ps aux
|
||||||
|
refute_output -p "openssl"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] stop all bats containers" {
|
||||||
|
stop_bats_containers
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user