#!/bin/bash set -e DB_NAME='postgres' DB_USER='postgres' DB_PASS='postgres' DB_PORT=5432 # Start postgres container CID=$(docker run --detach \ --env "POSTGRES_DB=${DB_NAME}" \ --env "POSTGRES_USER=${DB_USER}" \ --env "POSTGRES_PASSWORD=${DB_PASS}" \ --env "POSTGRES_HOST_AUTH_METHOD=trust" \ --env "PGHOST=0.0.0.0" \ --env "PGPORT=${DB_PORT}" \ 'postgres:latest') # On exit kill the container trap "docker kill ${CID}" exit sleep 5 #docker exec "$CID" psql --user "$DB_USER" --password "$DB_PASS" -c "CREATE DATABASE \"${DB_NAME}\" WITH LOCALE \"C.UTF-8\" TEMPLATE \"template0\";" docker exec "$CID" psql --user "$DB_USER" --password "$DB_PASS" -c "GRANT ALL PRIVILEGES ON DATABASE \"${DB_NAME}\" TO \"${DB_USER}\";" # Get running container IP IP=$(docker container inspect "${CID}" \ --format '{{ .NetworkSettings.IPAddress }}') GTS_DB_TYPE=postgres \ GTS_DB_ADDRESS=${IP} \ GTS_DB_PORT=${DB_PORT} \ GTS_DB_USER=${DB_USER} \ GTS_DB_PASSWORD=${DB_PASS} \ GTS_DB_DATABASE=${DB_NAME} \ go test ./... -p 1 ${@}