run.sh 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #!/usr/bin/env bash
  2. set -Eeuo pipefail
  3. dir="$(dirname "$(readlink -f "$BASH_SOURCE")")"
  4. serverImage="$("$dir/../image-name.sh" librarytest/rabbitmq-tls-server "$1")"
  5. "$dir/../docker-build.sh" "$dir" "$serverImage" <<EOD
  6. FROM $1
  7. RUN set -eux; \
  8. mkdir /certs; \
  9. openssl genrsa -out /certs/ca-private.key 8192; \
  10. openssl req -new -x509 \
  11. -key /certs/ca-private.key \
  12. -out /certs/ca.crt \
  13. -days $(( 365 * 30 )) \
  14. -subj '/CN=lolca'; \
  15. openssl genrsa -out /certs/private.key 4096; \
  16. openssl req -new -key /certs/private.key \
  17. -out /certs/cert.csr -subj '/CN=lolcert'; \
  18. openssl x509 -req -in /certs/cert.csr \
  19. -CA /certs/ca.crt -CAkey /certs/ca-private.key -CAcreateserial \
  20. -out /certs/cert.crt -days $(( 365 * 30 )); \
  21. openssl verify -CAfile /certs/ca.crt /certs/cert.crt; \
  22. chown -R rabbitmq:rabbitmq /certs
  23. ENV RABBITMQ_SSL_CACERTFILE=/certs/ca.crt RABBITMQ_SSL_CERTFILE=/certs/cert.crt RABBITMQ_SSL_KEYFILE=/certs/private.key
  24. EOD
  25. testImage="$("$dir/../image-name.sh" librarytest/rabbitmq-tls-test "$1")"
  26. "$dir/../docker-build.sh" "$dir" "$testImage" <<'EOD'
  27. FROM alpine:3.10
  28. RUN apk add --no-cache bash coreutils drill openssl procps
  29. # https://github.com/drwetter/testssl.sh/releases
  30. ENV TESTSSL_VERSION 2.9.5-8
  31. RUN set -eux; \
  32. wget -O testssl.tgz "https://github.com/drwetter/testssl.sh/archive/v${TESTSSL_VERSION}.tar.gz"; \
  33. tar -xvf testssl.tgz -C /opt; \
  34. rm testssl.tgz; \
  35. ln -sv "/opt/testssl.sh-$TESTSSL_VERSION/testssl.sh" /usr/local/bin/; \
  36. testssl.sh --version
  37. EOD
  38. export RABBITMQ_ERLANG_COOKIE="rabbitmq-erlang-cookie-$RANDOM-$RANDOM"
  39. cname="rabbitmq-container-$RANDOM-$RANDOM"
  40. cid="$(docker run -d --name "$cname" --hostname "$cname" -e RABBITMQ_ERLANG_COOKIE "$serverImage")"
  41. trap "docker rm -vf $cid > /dev/null" EXIT
  42. testssl() {
  43. docker run -i --rm --link "$cname" "$testImage" \
  44. testssl.sh --quiet --color 0 "$@" "$cname:5671"
  45. }
  46. rabbitmqctl() {
  47. docker run -i --rm --link "$cname" -e RABBITMQ_ERLANG_COOKIE "$serverImage" \
  48. rabbitmqctl --node "rabbit@$cname" "$@"
  49. }
  50. rabbitmq-diagnostics() {
  51. docker run -i --rm --link "$cname" -e RABBITMQ_ERLANG_COOKIE "$serverImage" \
  52. rabbitmq-diagnostics --node "rabbit@$cname" "$@"
  53. }
  54. . "$dir/../../retry.sh" 'rabbitmq-diagnostics check_port_connectivity'
  55. rabbitmqctl status
  56. testssl --protocols --standard --each-cipher