run.sh 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #!/bin/bash
  2. set -eo pipefail
  3. dir="$(dirname "$(readlink -f "$BASH_SOURCE")")"
  4. image="$1"
  5. export POSTGRES_USER='my cool postgres user'
  6. export POSTGRES_PASSWORD='my cool postgres password'
  7. export POSTGRES_DB='my cool postgres database'
  8. cname="postgres-container-$RANDOM-$RANDOM"
  9. cid="$(docker run -d -e POSTGRES_USER -e POSTGRES_PASSWORD -e POSTGRES_DB --name "$cname" "$image")"
  10. trap "docker rm -vf $cid > /dev/null" EXIT
  11. psql() {
  12. docker run --rm -i \
  13. --link "$cname":postgres \
  14. --entrypoint psql \
  15. -e PGPASSWORD="$POSTGRES_PASSWORD" \
  16. "$image" \
  17. --host postgres \
  18. --username "$POSTGRES_USER" \
  19. --dbname "$POSTGRES_DB" \
  20. --quiet --no-align --tuples-only \
  21. "$@"
  22. }
  23. . "$dir/../../retry.sh" --tries "$POSTGRES_TEST_TRIES" --sleep "$POSTGRES_TEST_SLEEP" "echo 'SELECT 1' | psql"
  24. echo 'CREATE TABLE test (a INT, b INT, c VARCHAR(255))' | psql
  25. [ "$(echo 'SELECT COUNT(*) FROM test' | psql)" = 0 ]
  26. psql <<'EOSQL'
  27. INSERT INTO test VALUES (1, 2, 'hello')
  28. EOSQL
  29. [ "$(echo 'SELECT COUNT(*) FROM test' | psql)" = 1 ]
  30. psql <<'EOSQL'
  31. INSERT INTO test VALUES (2, 3, 'goodbye!')
  32. EOSQL
  33. [ "$(echo 'SELECT COUNT(*) FROM test' | psql)" = 2 ]
  34. echo 'DELETE FROM test WHERE a = 1' | psql
  35. [ "$(echo 'SELECT COUNT(*) FROM test' | psql)" = 1 ]
  36. [ "$(echo 'SELECT c FROM test' | psql)" = 'goodbye!' ]
  37. echo 'DROP TABLE test' | psql
  38. # test jit support to ensure llvm lib is correct
  39. # SET jit = on; is required for postgres 11; on 12+ it is on by default
  40. [ "$(echo 'SET jit = on; SELECT pg_jit_available();' | psql)" = 't' ]