mirror of
https://github.com/nginx-proxy/docker-letsencrypt-nginx-proxy-companion
synced 2024-11-23 13:22:55 +01:00
Add test unit for permissions
This commit is contained in:
parent
cd5729ce02
commit
6d2f4ddb12
@ -48,6 +48,7 @@ after_failure:
|
||||
- docker logs certs_single
|
||||
- docker logs certs_san
|
||||
- docker logs force_renew
|
||||
- docker logs permissions
|
||||
- docker logs symlinks
|
||||
- docker logs boulder
|
||||
- if [[ $SETUP = "3containers" ]]; then docker logs $DOCKER_GEN_CONTAINER_NAME; fi
|
||||
|
@ -12,6 +12,7 @@ imageTests+=(
|
||||
certs_single
|
||||
certs_san
|
||||
force_renew
|
||||
permissions
|
||||
symlinks
|
||||
'
|
||||
)
|
||||
|
4
test/tests/permissions/expected-std-out.txt
Normal file
4
test/tests/permissions/expected-std-out.txt
Normal file
@ -0,0 +1,4 @@
|
||||
Started letsencrypt container for test permissions
|
||||
Started test web server for le1.wtf
|
||||
Symlink to le1.wtf certificate has been generated.
|
||||
The link is pointing to the file ./le1.wtf/fullchain.pem
|
61
test/tests/permissions/run.sh
Executable file
61
test/tests/permissions/run.sh
Executable file
@ -0,0 +1,61 @@
|
||||
#!/bin/bash
|
||||
|
||||
## Test for sensitive files and folders permissions
|
||||
|
||||
if [[ -z $TRAVIS_CI ]]; then
|
||||
le_container_name="$(basename ${0%/*})_$(date "+%Y-%m-%d_%H.%M.%S")"
|
||||
else
|
||||
le_container_name="$(basename ${0%/*})"
|
||||
fi
|
||||
run_le_container ${1:?} "$le_container_name"
|
||||
|
||||
# Create the $domains array from comma separated domains in TEST_DOMAINS.
|
||||
IFS=',' read -r -a domains <<< "$TEST_DOMAINS"
|
||||
|
||||
# Cleanup function with EXIT trap
|
||||
function cleanup {
|
||||
# Remove the ${domains[0]} Nginx container silently.
|
||||
docker rm --force "${domains[0]}" > /dev/null 2>&1
|
||||
# Cleanup the files created by this run of the test to avoid foiling following test(s).
|
||||
docker exec "$le_container_name" bash -c 'rm -rf /etc/nginx/certs/le?.wtf*'
|
||||
# Stop the LE container
|
||||
docker stop "$le_container_name" > /dev/null
|
||||
}
|
||||
trap cleanup EXIT
|
||||
|
||||
# Run an nginx container for ${domains[0]}.
|
||||
docker run --rm -d \
|
||||
--name "${domains[0]}" \
|
||||
-e "VIRTUAL_HOST=${domains[0]}" \
|
||||
-e "LETSENCRYPT_HOST=${domains[0]}" \
|
||||
nginx:alpine > /dev/null && echo "Started test web server for ${domains[0]}"
|
||||
|
||||
# Wait for the cert symlink.
|
||||
wait_for_symlink "${domains[0]}" "$le_container_name"
|
||||
|
||||
# Array of folder paths to test
|
||||
folders=( \
|
||||
[0]="/etc/nginx/certs/accounts" \
|
||||
[1]="/etc/nginx/certs/accounts/boulder:4000" \
|
||||
[2]="/etc/nginx/certs/accounts/boulder:4000/directory" \
|
||||
[3]="/etc/nginx/certs/${domains[0]}" \
|
||||
)
|
||||
|
||||
# Test folder paths
|
||||
for folder in "${folders[@]}"; do
|
||||
ownership_and_permissions="$(docker exec "$le_container_name" stat -c %U:%G:%a "$folder")"
|
||||
[[ "$ownership_and_permissions" == root:root:700 ]] || echo "Expected root:root:700 on ${folder}, found ${ownership_and_permissions}."
|
||||
done
|
||||
|
||||
# Array of file paths to test
|
||||
files=( \
|
||||
[0]="/etc/nginx/certs/default.key" \
|
||||
[1]="/etc/nginx/certs/accounts/boulder:4000/directory/default.json" \
|
||||
[2]="/etc/nginx/certs/${domains[0]}/key.pem" \
|
||||
)
|
||||
|
||||
# Test file paths
|
||||
for file in "${files[@]}"; do
|
||||
ownership_and_permissions="$(docker exec "$le_container_name" stat -c %U:%G:%a "$file")"
|
||||
[[ "$ownership_and_permissions" == root:root:600 ]] || echo "Expected root:root:600 on ${file}, found ${ownership_and_permissions}."
|
||||
done
|
Loading…
Reference in New Issue
Block a user