mirror of
https://github.com/nginx-proxy/docker-letsencrypt-nginx-proxy-companion
synced 2024-11-22 20:42:04 +01:00
refactor: move to correctly namespaced labels (#1046)
This commit is contained in:
parent
ca1f5a4e69
commit
1fc38f882b
1
.github/workflows/test.yml
vendored
1
.github/workflows/test.yml
vendored
@ -83,6 +83,7 @@ jobs:
|
|||||||
test-name:
|
test-name:
|
||||||
[
|
[
|
||||||
docker_api,
|
docker_api,
|
||||||
|
docker_api_legacy,
|
||||||
location_config,
|
location_config,
|
||||||
certs_single,
|
certs_single,
|
||||||
certs_san,
|
certs_san,
|
||||||
|
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,8 +1,9 @@
|
|||||||
|
.docker
|
||||||
|
.vscode
|
||||||
certs/
|
certs/
|
||||||
conf.d/
|
conf.d/
|
||||||
data/
|
data/
|
||||||
vhost.d/
|
vhost.d/
|
||||||
.vscode
|
|
||||||
|
|
||||||
# tests
|
# tests
|
||||||
go/
|
go/
|
||||||
|
@ -157,13 +157,13 @@ if [[ "$*" == "/bin/bash /app/start.sh" ]]; then
|
|||||||
echo "Check that you are doing one of the following :" >&2
|
echo "Check that you are doing one of the following :" >&2
|
||||||
echo -e "\t- Use the --volumes-from option to mount volumes from the nginx-proxy container." >&2
|
echo -e "\t- Use the --volumes-from option to mount volumes from the nginx-proxy container." >&2
|
||||||
echo -e "\t- Set the NGINX_PROXY_CONTAINER env var on the letsencrypt-companion container to the name of the nginx-proxy container." >&2
|
echo -e "\t- Set the NGINX_PROXY_CONTAINER env var on the letsencrypt-companion container to the name of the nginx-proxy container." >&2
|
||||||
echo -e "\t- Label the nginx-proxy container to use with 'com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy'." >&2
|
echo -e "\t- Label the nginx-proxy container to use with 'com.github.nginx-proxy.nginx'." >&2
|
||||||
exit 1
|
exit 1
|
||||||
elif [[ -z "$(get_docker_gen_container)" ]] && ! is_docker_gen_container "$(get_nginx_proxy_container)"; then
|
elif [[ -z "$(get_docker_gen_container)" ]] && ! is_docker_gen_container "$(get_nginx_proxy_container)"; then
|
||||||
echo "Error: can't get docker-gen container id !" >&2
|
echo "Error: can't get docker-gen container id !" >&2
|
||||||
echo "If you are running a three containers setup, check that you are doing one of the following :" >&2
|
echo "If you are running a three containers setup, check that you are doing one of the following :" >&2
|
||||||
echo -e "\t- Set the NGINX_DOCKER_GEN_CONTAINER env var on the letsencrypt-companion container to the name of the docker-gen container." >&2
|
echo -e "\t- Set the NGINX_DOCKER_GEN_CONTAINER env var on the letsencrypt-companion container to the name of the docker-gen container." >&2
|
||||||
echo -e "\t- Label the docker-gen container to use with 'com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen'." >&2
|
echo -e "\t- Label the docker-gen container to use with 'com.github.nginx-proxy.docker-gen'." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
check_writable_directory '/etc/nginx/certs'
|
check_writable_directory '/etc/nginx/certs'
|
||||||
|
@ -278,7 +278,9 @@ function is_docker_gen_container {
|
|||||||
|
|
||||||
function get_docker_gen_container {
|
function get_docker_gen_container {
|
||||||
# First try to get the docker-gen container ID from the container label.
|
# First try to get the docker-gen container ID from the container label.
|
||||||
local docker_gen_cid; docker_gen_cid="$(labeled_cid com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen)"
|
local legacy_docker_gen_cid; legacy_docker_gen_cid="$(labeled_cid com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen)"
|
||||||
|
local new_docker_gen_cid; new_docker_gen_cid="$(labeled_cid com.github.nginx-proxy.docker-gen)"
|
||||||
|
local docker_gen_cid; docker_gen_cid="${new_docker_gen_cid:-$legacy_docker_gen_cid}"
|
||||||
|
|
||||||
# If the labeled_cid function dit not return anything and the env var is set, use it.
|
# If the labeled_cid function dit not return anything and the env var is set, use it.
|
||||||
if [[ -z "$docker_gen_cid" ]] && [[ -n "${NGINX_DOCKER_GEN_CONTAINER:-}" ]]; then
|
if [[ -z "$docker_gen_cid" ]] && [[ -n "${NGINX_DOCKER_GEN_CONTAINER:-}" ]]; then
|
||||||
@ -292,7 +294,9 @@ function get_docker_gen_container {
|
|||||||
function get_nginx_proxy_container {
|
function get_nginx_proxy_container {
|
||||||
local volumes_from
|
local volumes_from
|
||||||
# First try to get the nginx container ID from the container label.
|
# First try to get the nginx container ID from the container label.
|
||||||
local nginx_cid; nginx_cid="$(labeled_cid com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy)"
|
local legacy_nginx_cid; legacy_nginx_cid="$(labeled_cid com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy)"
|
||||||
|
local new_nginx_cid; new_nginx_cid="$(labeled_cid com.github.nginx-proxy.nginx)"
|
||||||
|
local nginx_cid; nginx_cid="${new_nginx_cid:-$legacy_nginx_cid}"
|
||||||
|
|
||||||
# If the labeled_cid function dit not return anything ...
|
# If the labeled_cid function dit not return anything ...
|
||||||
if [[ -z "${nginx_cid}" ]]; then
|
if [[ -z "${nginx_cid}" ]]; then
|
||||||
|
@ -10,7 +10,7 @@ Please read and try [basic usage](./Basic-usage.md), and **validate that you hav
|
|||||||
curl https://raw.githubusercontent.com/nginx-proxy/nginx-proxy/main/nginx.tmpl > /path/to/nginx.tmpl
|
curl https://raw.githubusercontent.com/nginx-proxy/nginx-proxy/main/nginx.tmpl > /path/to/nginx.tmpl
|
||||||
```
|
```
|
||||||
|
|
||||||
2) Use the `com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen` label on the **docker-gen** container, or explicitly set the `NGINX_DOCKER_GEN_CONTAINER` environment variable on the **acme-companion** container to the name or id of the **docker-gen** container (we'll use the later method in the example).
|
2) Use the `com.github.nginx-proxy.docker-gen` label on the **docker-gen** container, or explicitly set the `NGINX_DOCKER_GEN_CONTAINER` environment variable on the **acme-companion** container to the name or id of the **docker-gen** container (we'll use the later method in the example).
|
||||||
|
|
||||||
3) Declare `/etc/nginx/conf.d` as a volume on the nginx container so that it can be shared with the **docker-gen** container.
|
3) Declare `/etc/nginx/conf.d` as a volume on the nginx container so that it can be shared with the **docker-gen** container.
|
||||||
|
|
||||||
|
@ -82,7 +82,7 @@ services:
|
|||||||
- /path/to/nginx.tmpl:/etc/docker-gen/templates/nginx.tmpl:ro
|
- /path/to/nginx.tmpl:/etc/docker-gen/templates/nginx.tmpl:ro
|
||||||
- /var/run/docker.sock:/tmp/docker.sock:ro
|
- /var/run/docker.sock:/tmp/docker.sock:ro
|
||||||
labels:
|
labels:
|
||||||
- "com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen"
|
- "com.github.nginx-proxy.docker-gen"
|
||||||
network_mode: bridge
|
network_mode: bridge
|
||||||
|
|
||||||
acme-companion:
|
acme-companion:
|
||||||
|
@ -4,7 +4,7 @@ For **acme-companion** to work properly, it needs to know the ID of the **nginx*
|
|||||||
|
|
||||||
There are three methods to inform the **acme-companion** container of the **nginx**/**nginx-proxy** container ID:
|
There are three methods to inform the **acme-companion** container of the **nginx**/**nginx-proxy** container ID:
|
||||||
|
|
||||||
* `label` method: add the label `com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy` to the **nginx**/**nginx-proxy** container.
|
* `label` method: add the label `com.github.nginx-proxy.nginx` to the **nginx**/**nginx-proxy** container.
|
||||||
|
|
||||||
* `environment variable` method: assign a fixed name to the **nginx**/**nginx-proxy** container with `container_name:` and set the environment variable `NGINX_PROXY_CONTAINER` to this name on the **acme-companion** container.
|
* `environment variable` method: assign a fixed name to the **nginx**/**nginx-proxy** container with `container_name:` and set the environment variable `NGINX_PROXY_CONTAINER` to this name on the **acme-companion** container.
|
||||||
|
|
||||||
@ -12,7 +12,7 @@ There are three methods to inform the **acme-companion** container of the **ngin
|
|||||||
|
|
||||||
And two methods to inform the **acme-companion** container of the **docker-gen** container ID:
|
And two methods to inform the **acme-companion** container of the **docker-gen** container ID:
|
||||||
|
|
||||||
* `label` method: add the label `com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen` to the **docker-gen** container.
|
* `label` method: add the label `com.github.nginx-proxy.docker-gen` to the **docker-gen** container.
|
||||||
|
|
||||||
* `environment variable` method: assign a fixed name to the **docker-gen** container with `container_name:` and set the environment variable `NGINX_DOCKER_GEN_CONTAINER` to this name on the **acme-companion** container.
|
* `environment variable` method: assign a fixed name to the **docker-gen** container with `container_name:` and set the environment variable `NGINX_DOCKER_GEN_CONTAINER` to this name on the **acme-companion** container.
|
||||||
|
|
||||||
@ -26,12 +26,12 @@ The advantage the `label` methods have over the `environment variable` (and `vol
|
|||||||
```
|
```
|
||||||
$ docker run --detach \
|
$ docker run --detach \
|
||||||
[...]
|
[...]
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
--label com.github.nginx-proxy.nginx \
|
||||||
nginx
|
nginx
|
||||||
|
|
||||||
$ docker run --detach \
|
$ docker run --detach \
|
||||||
[...]
|
[...]
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen \
|
--label com.github.nginx-proxy.docker-gen \
|
||||||
nginxproxy/docker-gen
|
nginxproxy/docker-gen
|
||||||
|
|
||||||
$ docker run --detach \
|
$ docker run --detach \
|
||||||
@ -67,7 +67,7 @@ $ docker run --detach \
|
|||||||
|
|
||||||
$ docker run --detach \
|
$ docker run --detach \
|
||||||
[...]
|
[...]
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen \
|
--label com.github.nginx-proxy.docker-gen \
|
||||||
nginxproxy/docker-gen
|
nginxproxy/docker-gen
|
||||||
|
|
||||||
$ docker run --detach \
|
$ docker run --detach \
|
||||||
|
@ -3,6 +3,7 @@ set -e
|
|||||||
|
|
||||||
globalTests+=(
|
globalTests+=(
|
||||||
docker_api
|
docker_api
|
||||||
|
docker_api_legacy
|
||||||
location_config
|
location_config
|
||||||
default_cert
|
default_cert
|
||||||
certs_single
|
certs_single
|
||||||
|
@ -130,7 +130,7 @@ EOF
|
|||||||
get_environment
|
get_environment
|
||||||
|
|
||||||
# Stop and remove nginx-proxy and (if required) docker-gen
|
# Stop and remove nginx-proxy and (if required) docker-gen
|
||||||
for cid in $(docker ps -a --filter "label=com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite" --format "{{.ID}}"); do
|
for cid in $(docker ps -a --filter "label=com.github.nginx-proxy.acme-companion.test-suite" --format "{{.ID}}"); do
|
||||||
docker stop "$cid"
|
docker stop "$cid"
|
||||||
docker rm --volumes "$cid"
|
docker rm --volumes "$cid"
|
||||||
done
|
done
|
||||||
|
@ -28,7 +28,7 @@ case $SETUP in
|
|||||||
-v /etc/nginx/vhost.d \
|
-v /etc/nginx/vhost.d \
|
||||||
-v /usr/share/nginx/html \
|
-v /usr/share/nginx/html \
|
||||||
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite \
|
--label com.github.nginx-proxy.acme-companion.test-suite \
|
||||||
--network "$test_net" \
|
--network "$test_net" \
|
||||||
nginxproxy/nginx-proxy
|
nginxproxy/nginx-proxy
|
||||||
;;
|
;;
|
||||||
@ -42,7 +42,7 @@ case $SETUP in
|
|||||||
-v /etc/nginx/conf.d \
|
-v /etc/nginx/conf.d \
|
||||||
-v /etc/nginx/vhost.d \
|
-v /etc/nginx/vhost.d \
|
||||||
-v /usr/share/nginx/html \
|
-v /usr/share/nginx/html \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite \
|
--label com.github.nginx-proxy.acme-companion.test-suite \
|
||||||
--network "$test_net" \
|
--network "$test_net" \
|
||||||
nginx:alpine
|
nginx:alpine
|
||||||
|
|
||||||
@ -51,7 +51,7 @@ case $SETUP in
|
|||||||
--volumes-from "$NGINX_CONTAINER_NAME" \
|
--volumes-from "$NGINX_CONTAINER_NAME" \
|
||||||
-v "${GITHUB_WORKSPACE}/nginx.tmpl:/etc/docker-gen/templates/nginx.tmpl:ro" \
|
-v "${GITHUB_WORKSPACE}/nginx.tmpl:/etc/docker-gen/templates/nginx.tmpl:ro" \
|
||||||
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite \
|
--label com.github.nginx-proxy.acme-companion.test-suite \
|
||||||
--network "$test_net" \
|
--network "$test_net" \
|
||||||
nginxproxy/docker-gen \
|
nginxproxy/docker-gen \
|
||||||
-notify-sighup "$NGINX_CONTAINER_NAME" -watch /etc/docker-gen/templates/nginx.tmpl /etc/nginx/conf.d/default.conf
|
-notify-sighup "$NGINX_CONTAINER_NAME" -watch /etc/docker-gen/templates/nginx.tmpl /etc/nginx/conf.d/default.conf
|
||||||
|
@ -67,7 +67,7 @@ case $SETUP in
|
|||||||
labeled_nginx_cid="$(docker run --rm -d \
|
labeled_nginx_cid="$(docker run --rm -d \
|
||||||
--name "$nginx_lbl" \
|
--name "$nginx_lbl" \
|
||||||
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
--label com.github.nginx-proxy.nginx \
|
||||||
nginxproxy/nginx-proxy)"
|
nginxproxy/nginx-proxy)"
|
||||||
|
|
||||||
# This should target the nginx-proxy container with the label (nginx-label)
|
# This should target the nginx-proxy container with the label (nginx-label)
|
||||||
@ -156,7 +156,7 @@ EOF
|
|||||||
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
||||||
labeled_nginx1_cid="$(docker run --rm -d \
|
labeled_nginx1_cid="$(docker run --rm -d \
|
||||||
--name "$nginx_lbl" \
|
--name "$nginx_lbl" \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
--label com.github.nginx-proxy.nginx \
|
||||||
nginx:alpine)"
|
nginx:alpine)"
|
||||||
|
|
||||||
# This should target the nginx container whose id or name was obtained with
|
# This should target the nginx container whose id or name was obtained with
|
||||||
@ -176,7 +176,7 @@ EOF
|
|||||||
# Spawn a "fake docker-gen" container named docker-gen-label, with the docker_gen label.
|
# Spawn a "fake docker-gen" container named docker-gen-label, with the docker_gen label.
|
||||||
labeled_docker_gen_cid="$(docker run --rm -d \
|
labeled_docker_gen_cid="$(docker run --rm -d \
|
||||||
--name "$docker_gen_lbl" \
|
--name "$docker_gen_lbl" \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen \
|
--label com.github.nginx-proxy.docker-gen \
|
||||||
nginx:alpine)"
|
nginx:alpine)"
|
||||||
|
|
||||||
# This should target the nginx container whose id or name was obtained with
|
# This should target the nginx container whose id or name was obtained with
|
||||||
@ -205,7 +205,7 @@ EOF
|
|||||||
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
||||||
labeled_nginx2_cid="$(docker run --rm -d \
|
labeled_nginx2_cid="$(docker run --rm -d \
|
||||||
--name "$nginx_lbl" \
|
--name "$nginx_lbl" \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
--label com.github.nginx-proxy.nginx \
|
||||||
nginx:alpine)"
|
nginx:alpine)"
|
||||||
|
|
||||||
# This should target the nginx container whose id or name was obtained with
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
252
test/tests/docker_api_legacy/run.sh
Executable file
252
test/tests/docker_api_legacy/run.sh
Executable file
@ -0,0 +1,252 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
## Test for the Docker API with legacy labels.
|
||||||
|
|
||||||
|
nginx_vol='nginx-volumes-from-legacy'
|
||||||
|
nginx_env='nginx-env-var-legacy'
|
||||||
|
nginx_lbl='nginx-label-legacy'
|
||||||
|
docker_gen='docker-gen-no-label-legacy'
|
||||||
|
docker_gen_lbl='docker-gen-label-legacy'
|
||||||
|
|
||||||
|
case $SETUP in
|
||||||
|
|
||||||
|
2containers)
|
||||||
|
# Cleanup function with EXIT trap
|
||||||
|
function cleanup {
|
||||||
|
# Kill the Docker events listener
|
||||||
|
kill "$docker_events_pid" && wait "$docker_events_pid" 2>/dev/null
|
||||||
|
# Remove the remaining containers silently
|
||||||
|
docker rm --force \
|
||||||
|
"$nginx_vol" \
|
||||||
|
"$nginx_env" \
|
||||||
|
"$nginx_lbl" \
|
||||||
|
&> /dev/null
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
# Set the commands to be passed to docker exec
|
||||||
|
commands='source /app/functions.sh; reload_nginx > /dev/null; check_nginx_proxy_container_run; get_nginx_proxy_container'
|
||||||
|
|
||||||
|
# Listen to Docker exec_start events
|
||||||
|
docker events \
|
||||||
|
--filter event=exec_start \
|
||||||
|
--format 'Container {{.Actor.Attributes.name}} received {{.Action}}' &
|
||||||
|
docker_events_pid=$!
|
||||||
|
|
||||||
|
# Run a nginx-proxy container named nginx-volumes-from, without the nginx_proxy label
|
||||||
|
docker run --rm -d \
|
||||||
|
--name "$nginx_vol" \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
nginxproxy/nginx-proxy > /dev/null
|
||||||
|
|
||||||
|
# Run a nginx-proxy container named nginx-env-var, without the nginx_proxy label
|
||||||
|
docker run --rm -d \
|
||||||
|
--name "$nginx_env" \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
nginxproxy/nginx-proxy > /dev/null
|
||||||
|
|
||||||
|
# This should target the nginx-proxy container obtained with
|
||||||
|
# the --volume-from argument (nginx-volumes-from)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# This should target the nginx-proxy container obtained with
|
||||||
|
# the NGINX_PROXY_CONTAINER environment variable (nginx-env-var)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# Run a nginx-proxy container named nginx-label, with the nginx_proxy label.
|
||||||
|
# Store the container id in the labeled_nginx_cid variable.
|
||||||
|
labeled_nginx_cid="$(docker run --rm -d \
|
||||||
|
--name "$nginx_lbl" \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
||||||
|
nginxproxy/nginx-proxy)"
|
||||||
|
|
||||||
|
# This should target the nginx-proxy container with the label (nginx-label)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
cat > "${GITHUB_WORKSPACE}/test/tests/docker_api_legacy/expected-std-out.txt" <<EOF
|
||||||
|
Container $nginx_vol received exec_start: sh -c /app/docker-entrypoint.sh /usr/local/bin/docker-gen /app/nginx.tmpl /etc/nginx/conf.d/default.conf; /usr/sbin/nginx -s reload
|
||||||
|
$nginx_vol
|
||||||
|
Container $nginx_env received exec_start: sh -c /app/docker-entrypoint.sh /usr/local/bin/docker-gen /app/nginx.tmpl /etc/nginx/conf.d/default.conf; /usr/sbin/nginx -s reload
|
||||||
|
$nginx_env
|
||||||
|
Container $nginx_lbl received exec_start: sh -c /app/docker-entrypoint.sh /usr/local/bin/docker-gen /app/nginx.tmpl /etc/nginx/conf.d/default.conf; /usr/sbin/nginx -s reload
|
||||||
|
$labeled_nginx_cid
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
3containers)
|
||||||
|
# Cleanup function with EXIT trap
|
||||||
|
function cleanup {
|
||||||
|
# Kill the Docker events listener
|
||||||
|
kill $docker_events_pid && wait $docker_events_pid 2>/dev/null
|
||||||
|
# Remove the remaining containers silently
|
||||||
|
docker stop \
|
||||||
|
"$nginx_vol" \
|
||||||
|
"$nginx_env" \
|
||||||
|
"$nginx_lbl" \
|
||||||
|
"$docker_gen" \
|
||||||
|
"$docker_gen_lbl" \
|
||||||
|
&> /dev/null
|
||||||
|
}
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
# Set the commands to be passed to docker exec
|
||||||
|
commands='source /app/functions.sh; reload_nginx > /dev/null; check_nginx_proxy_container_run; get_docker_gen_container; get_nginx_proxy_container'
|
||||||
|
|
||||||
|
# Listen to Docker kill events
|
||||||
|
docker events \
|
||||||
|
--filter event=kill \
|
||||||
|
--format 'Container {{.Actor.Attributes.name}} received signal {{.Actor.Attributes.signal}}' &
|
||||||
|
docker_events_pid=$!
|
||||||
|
|
||||||
|
# Run a nginx container named nginx-volumes-from, without the nginx_proxy label.
|
||||||
|
docker run --rm -d \
|
||||||
|
--name "$nginx_vol" \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
nginx:alpine > /dev/null
|
||||||
|
|
||||||
|
# Run a nginx container named nginx-env-var, without the nginx_proxy label.
|
||||||
|
docker run --rm -d \
|
||||||
|
--name "$nginx_env" \
|
||||||
|
-v /var/run/docker.sock:/tmp/docker.sock:ro \
|
||||||
|
nginx:alpine > /dev/null
|
||||||
|
|
||||||
|
# Spawn a "fake docker-gen" container named docker-gen-nolabel, without the docker_gen label.
|
||||||
|
docker run --rm -d \
|
||||||
|
--name "$docker_gen" \
|
||||||
|
nginx:alpine > /dev/null
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the --volumes-from argument (nginx-volumes-from)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the NGINX_DOCKER_GEN_CONTAINER environment variable (docker-gen-nolabel).
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the NGINX_PROXY_CONTAINER environment variable (nginx-env-var)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the NGINX_DOCKER_GEN_CONTAINER environment variable (docker-gen-nolabel)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
||||||
|
labeled_nginx1_cid="$(docker run --rm -d \
|
||||||
|
--name "$nginx_lbl" \
|
||||||
|
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
||||||
|
nginx:alpine)"
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the nginx_proxy label (nginx-label)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the NGINX_DOCKER_GEN_CONTAINER environment variable (docker-gen-nolabel)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
docker stop "$nginx_lbl" > /dev/null
|
||||||
|
|
||||||
|
# Spawn a "fake docker-gen" container named docker-gen-label, with the docker_gen label.
|
||||||
|
labeled_docker_gen_cid="$(docker run --rm -d \
|
||||||
|
--name "$docker_gen_lbl" \
|
||||||
|
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.docker_gen \
|
||||||
|
nginx:alpine)"
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the --volumes-from argument (nginx-volumes-from)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the docker_gen label (docker-gen-label)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the NGINX_PROXY_CONTAINER environment variable (nginx-env-var)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the docker_gen label (docker-gen-label)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
# Spawn a nginx container named nginx-label, with the nginx_proxy label.
|
||||||
|
labeled_nginx2_cid="$(docker run --rm -d \
|
||||||
|
--name "$nginx_lbl" \
|
||||||
|
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy \
|
||||||
|
nginx:alpine)"
|
||||||
|
|
||||||
|
# This should target the nginx container whose id or name was obtained with
|
||||||
|
# the nginx_proxy label (nginx-label)
|
||||||
|
# and the docker-gen container whose id or name was obtained with
|
||||||
|
# the docker_gen label (docker-gen-label)
|
||||||
|
docker run --rm \
|
||||||
|
-v /var/run/docker.sock:/var/run/docker.sock:ro \
|
||||||
|
--volumes-from "$nginx_vol" \
|
||||||
|
-e "NGINX_PROXY_CONTAINER=$nginx_env" \
|
||||||
|
-e "NGINX_DOCKER_GEN_CONTAINER=$docker_gen" \
|
||||||
|
"$1" \
|
||||||
|
bash -c "$commands" 2>&1
|
||||||
|
|
||||||
|
cat > "${GITHUB_WORKSPACE}/test/tests/docker_api_legacy/expected-std-out.txt" <<EOF
|
||||||
|
Container $docker_gen received signal 1
|
||||||
|
Container $nginx_vol received signal 1
|
||||||
|
$docker_gen
|
||||||
|
$nginx_vol
|
||||||
|
Container $docker_gen received signal 1
|
||||||
|
Container $nginx_env received signal 1
|
||||||
|
$docker_gen
|
||||||
|
$nginx_env
|
||||||
|
Container $docker_gen received signal 1
|
||||||
|
Container $nginx_lbl received signal 1
|
||||||
|
$docker_gen
|
||||||
|
$labeled_nginx1_cid
|
||||||
|
Container $nginx_lbl received signal 3
|
||||||
|
Container $docker_gen_lbl received signal 1
|
||||||
|
Container $nginx_vol received signal 1
|
||||||
|
$labeled_docker_gen_cid
|
||||||
|
$nginx_vol
|
||||||
|
Container $docker_gen_lbl received signal 1
|
||||||
|
Container $nginx_env received signal 1
|
||||||
|
$labeled_docker_gen_cid
|
||||||
|
$nginx_env
|
||||||
|
Container $docker_gen_lbl received signal 1
|
||||||
|
Container $nginx_lbl received signal 1
|
||||||
|
$labeled_docker_gen_cid
|
||||||
|
$labeled_nginx2_cid
|
||||||
|
EOF
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
@ -63,7 +63,7 @@ function run_le_container {
|
|||||||
--env "DOCKER_GEN_WAIT=500ms:2s" \
|
--env "DOCKER_GEN_WAIT=500ms:2s" \
|
||||||
--env "TEST_MODE=true" \
|
--env "TEST_MODE=true" \
|
||||||
--env "DEBUG=1" \
|
--env "DEBUG=1" \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite \
|
--label com.github.nginx-proxy.acme-companion.test-suite \
|
||||||
"$image" > /dev/null; \
|
"$image" > /dev/null; \
|
||||||
then
|
then
|
||||||
[[ "${DRY_RUN:-}" == 1 ]] && echo "Started letsencrypt container for test ${name%%_2*}"
|
[[ "${DRY_RUN:-}" == 1 ]] && echo "Started letsencrypt container for test ${name%%_2*}"
|
||||||
@ -122,7 +122,7 @@ function run_nginx_container {
|
|||||||
--name "${container_name:-$virtual_host}" \
|
--name "${container_name:-$virtual_host}" \
|
||||||
-e "VIRTUAL_HOST=$virtual_host" \
|
-e "VIRTUAL_HOST=$virtual_host" \
|
||||||
-e "LETSENCRYPT_HOST=$le_host" \
|
-e "LETSENCRYPT_HOST=$le_host" \
|
||||||
--label com.github.jrcs.letsencrypt_nginx_proxy_companion.test_suite \
|
--label com.github.nginx-proxy.acme-companion.test-suite \
|
||||||
"${cli_args_arr[@]}" \
|
"${cli_args_arr[@]}" \
|
||||||
nginx:alpine > /dev/null ; \
|
nginx:alpine > /dev/null ; \
|
||||||
then
|
then
|
||||||
|
Loading…
Reference in New Issue
Block a user