run.sh 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. #!/bin/bash
  2. set -eo pipefail
  3. dir="$(dirname "$(readlink -f "$BASH_SOURCE")")"
  4. image="$1"
  5. serverImage="$("$dir/../image-name.sh" librarytest/postgres-initdb "$image")"
  6. "$dir/../docker-build.sh" "$dir" -t "$serverImage" <<EOD
  7. FROM $image
  8. COPY dir/initdb.sql /docker-entrypoint-initdb.d/
  9. EOD
  10. export POSTGRES_USER='my cool postgres user'
  11. export POSTGRES_PASSWORD='my cool postgres password'
  12. export POSTGRES_DB='my cool postgres database'
  13. cname="postgres-container-$RANDOM-$RANDOM"
  14. cid="$(
  15. docker run -d \
  16. -e POSTGRES_USER \
  17. -e POSTGRES_PASSWORD \
  18. -e POSTGRES_DB \
  19. --name "$cname" \
  20. "$serverImage"
  21. )"
  22. trap "docker rm -vf $cid > /dev/null" EXIT
  23. psql() {
  24. docker run --rm -i \
  25. --link "$cname":postgres \
  26. --entrypoint psql \
  27. -e PGPASSWORD="$POSTGRES_PASSWORD" \
  28. "$image" \
  29. --host postgres \
  30. --username "$POSTGRES_USER" \
  31. --dbname "$POSTGRES_DB" \
  32. --quiet --no-align --tuples-only \
  33. "$@"
  34. }
  35. . "$dir/../../retry.sh" --tries "$POSTGRES_TEST_TRIES" --sleep "$POSTGRES_TEST_SLEEP" "echo 'SELECT 1' | psql"
  36. [ "$(echo 'SELECT COUNT(*) FROM test' | psql)" = 1 ]
  37. [ "$(echo 'SELECT c FROM test' | psql)" = 'goodbye!' ]