#!/usr/bin/env bash set -e if [ x"$DEBUG" = xtrue ]; then set -x fi trap _catch_err ERR trap _cleanup EXIT LOCAL_DIR="$(cd "$(dirname "$0")" ; pwd -P)" . "$LOCAL_DIR"/../conf.env TMP_DIR=$(mktemp -d) _catch_err() { echo "Test FAILED" } _cleanup() { echo "Cleaning up..." docker rm -f "${NGINX_VERSION}"_test > /dev/null 2>&1 rm -rf "$TMP_DIR" } _setup_crypto_stuff() { openssl dhparam -out "$TMP_DIR"/dhparams.pem 512 openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 \ -subj "/C=ES/ST=Madrid/L=Madrid/O=dcarrillo/CN=localhost" \ -keyout "$TMP_DIR"/cert.key -out "$TMP_DIR"/cert.pem } _check_status_code() { if [ "$1" != 200 ]; then printf "Test failed, status code %s is not 200\n" "$STATUS_CODE" exit 1 else echo "Test succeeded" fi } _check_if_is_ip() { if echo "$1" | grep -E "^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$" > /dev/null; then echo "Test succeeded" else printf "Test failed, response %s is not an IP" "$RESPONSE" exit 1 fi } _setup_crypto_stuff docker run --name "${NGINX_VERSION}"_test --rm -p 65521:80 -p 65523:443 \ -v "$LOCAL_DIR"/nginx.conf:/usr/local/nginx/conf/nginx.conf:ro \ -v "$LOCAL_DIR"/GeoLite2-Country.mmdb:/tmp/GeoLite2-Country.mmdb:ro \ -v "$TMP_DIR"/cert.pem:/tmp/cert.pem:ro \ -v "$TMP_DIR"/cert.key:/tmp/cert.key:ro \ -v "$TMP_DIR"/dhparams.pem:/tmp/dhparams.pem:ro \ -d "${DOCKER_IMAGE}":"${NGINX_VERSION}" > /dev/null for request in http://localhost:65521/nginx_status https://localhost:65523/nginx_status; do printf "\nRequesting %s\n" $request STATUS_CODE=$(curl -s -k -m 5 -o /dev/null -w "%{http_code}" $request) _check_status_code "$STATUS_CODE" done printf "\nRequesting http://localhost:65521/ip\n" RESPONSE=$(curl -s -m 5 http://localhost:65521/ip) _check_if_is_ip "$RESPONSE" echo "All tests succeeded !"