2023-07-24 12:14:13 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2023-08-08 11:26:34 +00:00
|
|
|
# Ensure test args are set.
|
|
|
|
ARGS=${@}; [ -z "$ARGS" ] && \
|
|
|
|
ARGS='./...'
|
|
|
|
|
|
|
|
# Database config.
|
2023-07-24 12:14:13 +00:00
|
|
|
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} \
|
2023-08-08 11:26:34 +00:00
|
|
|
go test ./... -p 1 ${ARGS}
|