2019-01-18 17:20:41 +03:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -euo pipefail
|
|
|
|
|
|
|
|
CIRCLECI_FOLDER="${BASH_SOURCE[0]%/*}"
|
|
|
|
cd $CIRCLECI_FOLDER
|
|
|
|
CIRCLECI_FOLDER="$PWD"
|
|
|
|
|
|
|
|
SERVER_ROOT="$CIRCLECI_FOLDER/../server"
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
i=1
|
|
|
|
echoInfo() {
|
|
|
|
echo -e "\033[36m$i. $*\033[0m"
|
|
|
|
i=$[i+1]
|
|
|
|
}
|
|
|
|
|
|
|
|
fail_if_port_busy() {
|
|
|
|
local PORT=$1
|
|
|
|
if nc -z localhost $PORT ; then
|
|
|
|
echo "Port $PORT is busy. Exiting"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
wait_for_port() {
|
|
|
|
local PORT=$1
|
|
|
|
echo "waiting for $PORT"
|
2019-12-13 00:46:33 +03:00
|
|
|
for _ in $(seq 1 60);
|
2019-02-14 12:37:47 +03:00
|
|
|
do
|
|
|
|
nc -z localhost $PORT && echo "port $PORT is ready" && return
|
|
|
|
echo -n .
|
|
|
|
sleep 0.2
|
|
|
|
done
|
|
|
|
echo "Failed waiting for $PORT" && exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
test_export_metadata_with_admin_secret() {
|
|
|
|
curl -f -d'{"type" : "export_metadata", "args" : {} }' localhost:8080/v1/query -H "X-Hasura-Admin-Secret: $1" > /dev/null
|
|
|
|
}
|
|
|
|
|
2019-01-18 17:20:41 +03:00
|
|
|
cd $SERVER_ROOT
|
|
|
|
|
|
|
|
if [ -z "${HASURA_GRAPHQL_DATABASE_URL:-}" ] ; then
|
|
|
|
echo "Env var HASURA_GRAPHQL_DATABASE_URL is not set"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ! stack --allow-different-user exec -- which graphql-engine > /dev/null && [ -z "${GRAPHQL_ENGINE:-}" ] ; then
|
|
|
|
echo "Do 'stack build' before tests, or export the location of executable in the GRAPHQL_ENGINE envirnoment variable"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
GRAPHQL_ENGINE=${GRAPHQL_ENGINE:-"$(stack --allow-different-user exec -- which graphql-engine)"}
|
|
|
|
if ! [ -x "$GRAPHQL_ENGINE" ] ; then
|
|
|
|
echo "$GRAPHQL_ENGINE is not present or is not an executable"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
HGE_PID=""
|
|
|
|
|
|
|
|
run_hge_with_flags() {
|
|
|
|
fail_if_port_busy 8080
|
|
|
|
set -x
|
|
|
|
stdbuf -o0 "$GRAPHQL_ENGINE" serve $* > "$OUTPUT_FOLDER/graphql-engine.log" & HGE_PID=$!
|
|
|
|
set +x
|
|
|
|
wait_for_port 8080
|
|
|
|
}
|
|
|
|
|
|
|
|
kill_hge() {
|
2019-08-26 08:31:27 +03:00
|
|
|
kill -s INT $HGE_PID || true
|
2019-02-14 12:37:47 +03:00
|
|
|
wait $HGE_PID || true
|
|
|
|
}
|
|
|
|
|
|
|
|
trap kill_hge ERR
|
|
|
|
trap kill_hge INT
|
|
|
|
|
2019-01-18 17:20:41 +03:00
|
|
|
OUTPUT_FOLDER=${OUTPUT_FOLDER:-"$CIRCLECI_FOLDER/test-server-flags-output"}
|
|
|
|
mkdir -p "$OUTPUT_FOLDER"
|
|
|
|
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
########## Test --use-prepared-statements=false and flag --admin-secret
|
|
|
|
|
|
|
|
key="HGE$RANDOM$RANDOM"
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
run_hge_with_flags --use-prepared-statements=false --admin-secret="$key"
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
echoInfo "Test flag --admin-secret=XXXX"
|
|
|
|
grep -F '"admin_secret_set":true' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null
|
|
|
|
test_export_metadata_with_admin_secret "$key"
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
echoInfo "Test flag --use-prepared-statements=false"
|
|
|
|
grep -F '"use_prepared_statements":false' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
kill_hge
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
###### Test --use-prepared-statements=true
|
|
|
|
key="HGE$RANDOM$RANDOM"
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
run_hge_with_flags --use-prepared-statements=true
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
echoInfo "Test --use-prepared-statements=true"
|
|
|
|
grep -F '"use_prepared_statements":true' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null || (cat "$OUTPUT_FOLDER/graphql-engine.log" && false)
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
kill_hge
|
|
|
|
|
|
|
|
######### Test HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=abcd
|
2019-01-18 17:20:41 +03:00
|
|
|
|
|
|
|
|
|
|
|
export HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=abcd
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
fail_if_port_busy 8080
|
|
|
|
timeout 3 stdbuf -o0 "$GRAPHQL_ENGINE" serve > "$OUTPUT_FOLDER/graphql-engine.log" 2>&1 & PID=$!
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
wait $PID || true
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
echoInfo "Test HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=abcd"
|
|
|
|
grep -F 'Not a valid boolean text' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null || (cat "$OUTPUT_FOLDER/graphql-engine.log" && false)
|
2019-01-18 17:20:41 +03:00
|
|
|
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
######### Test HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=false and HASURA_GRAPHQL_ADMIN_SECRET=XXXX
|
|
|
|
key="HGE$RANDOM$RANDOM"
|
2019-01-18 17:20:41 +03:00
|
|
|
|
|
|
|
export HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=false
|
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
export HASURA_GRAPHQL_ADMIN_SECRET="$key"
|
|
|
|
|
|
|
|
run_hge_with_flags
|
|
|
|
|
|
|
|
echoInfo "Test flag HASURA_GRAPHQL_ADMIN_SECRET=XXXX"
|
|
|
|
grep -F '"admin_secret_set":true' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null || (cat "$OUTPUT_FOLDER/graphql-engine.log" && false)
|
|
|
|
test_export_metadata_with_admin_secret "$key"
|
|
|
|
|
|
|
|
|
|
|
|
echoInfo "Test HASURA_GRAPHQL_USE_PREPARED_STATEMENTS=false"
|
|
|
|
grep -F '"use_prepared_statements":false' "$OUTPUT_FOLDER/graphql-engine.log" >/dev/null || (cat "$OUTPUT_FOLDER/graphql-engine.log" && false)
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
kill_hge
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
unset HASURA_GRAPHQL_ADMIN_SECRET
|
2019-01-18 17:20:41 +03:00
|
|
|
|
2019-02-14 12:37:47 +03:00
|
|
|
unset HASURA_GRAPHQL_USE_PREPARED_STATEMENTS
|