run.sh 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #!/usr/bin/env bash
  2. set -Eeuo pipefail
  3. cname="rabbitmq-container-$RANDOM-$RANDOM"
  4. dir="$(dirname "$(readlink -f "$BASH_SOURCE")")"
  5. serverImage="$("$dir/../image-name.sh" librarytest/rabbitmq-tls-server "$1")"
  6. "$dir/../docker-build.sh" "$dir" "$serverImage" <<EOD
  7. FROM $1
  8. RUN set -eux; \
  9. mkdir /certs; \
  10. openssl genrsa -out /certs/ca-private.key 8192; \
  11. openssl req -new -x509 \
  12. -key /certs/ca-private.key \
  13. -out /certs/ca.crt \
  14. -days $(( 365 * 30 )) \
  15. -subj '/CN=$cname-CA'; \
  16. openssl genrsa -out /certs/private.key 4096; \
  17. openssl req -new -key /certs/private.key \
  18. -out /certs/cert.csr -subj '/CN=$cname'; \
  19. openssl x509 -req -in /certs/cert.csr \
  20. -CA /certs/ca.crt -CAkey /certs/ca-private.key -CAcreateserial \
  21. -out /certs/cert.crt -days $(( 365 * 30 )); \
  22. openssl verify -CAfile /certs/ca.crt /certs/cert.crt; \
  23. cat /certs/cert.crt /certs/private.key > /certs/combined.pem; \
  24. chmod 0400 /certs/combined.pem; \
  25. chown -R rabbitmq:rabbitmq /certs
  26. COPY --chown=rabbitmq:rabbitmq dir/*.conf* /etc/rabbitmq/
  27. EOD
  28. testImage="$("$dir/../image-name.sh" librarytest/rabbitmq-tls-test "$1")"
  29. "$dir/../docker-build.sh" "$dir" "$testImage" <<'EOD'
  30. FROM alpine:3.19
  31. RUN apk add --no-cache bash coreutils drill openssl procps
  32. # https://github.com/drwetter/testssl.sh/releases
  33. ENV TESTSSL_VERSION 3.0.8
  34. RUN set -eux; \
  35. wget -O testssl.tgz "https://github.com/drwetter/testssl.sh/archive/v${TESTSSL_VERSION}.tar.gz"; \
  36. tar -xvf testssl.tgz -C /opt; \
  37. rm testssl.tgz; \
  38. ln -sv "/opt/testssl.sh-$TESTSSL_VERSION/testssl.sh" /usr/local/bin/; \
  39. testssl.sh --version
  40. EOD
  41. export ERLANG_COOKIE="rabbitmq-erlang-cookie-$RANDOM-$RANDOM"
  42. cid="$(docker run -d --name "$cname" --hostname "$cname" -e ERLANG_COOKIE "$serverImage")"
  43. trap "docker rm -vf $cid > /dev/null" EXIT
  44. testssl() {
  45. docker run -i --rm \
  46. --link "$cname" \
  47. "$testImage" \
  48. testssl.sh --quiet --color 0 "$@" "$cname:5671"
  49. }
  50. rabbitmqctl() {
  51. # not using '--entrypoint', since regular entrypoint does needed env setup
  52. docker run -i --rm \
  53. --link "$cname" \
  54. -e ERLANG_COOKIE \
  55. "$serverImage" \
  56. rabbitmqctl --node "rabbit@$cname" "$@"
  57. }
  58. rabbitmq-diagnostics() {
  59. # not using '--entrypoint', since regular entrypoint does needed env setup
  60. docker run -i --rm \
  61. --link "$cname" \
  62. -e ERLANG_COOKIE \
  63. "$serverImage" \
  64. rabbitmq-diagnostics --node "rabbit@$cname" "$@"
  65. }
  66. . "$dir/../../retry.sh" 'rabbitmq-diagnostics check_port_connectivity'
  67. rabbitmqctl status
  68. testssl --each-cipher
  69. testssl --standard
  70. #testssl --protocols # RabbitMQ still supports TLS 1.0/1.1 which are "deprecated" in testssl.sh 3.0+ (and thus fail this test)