mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-05 14:27:59 +03:00
f8e133070b
* run basic tests after upgrade * terminate before specifying file in pytest cmd * Move fixture definitions out of test classes Previously we had abstract classes with the fixtures defined in them. The test classes then inherits these super classes. This is creating inheritence problems, especially when you want to just inherit the tests in class, but not the fixtures. We have now moved all those fixture definitions outside of the class (in conftest.py). These fixtures are now used by the test classes when and where they are required. * Run pytests on server upgrade Server upgrade tests are run by 1) Run pytest with schema/metadata setup but do not do schema/metadata teardown 2) Upgrade the server 3) Run pytest using the above schema and teardown at the end of the tests 4) Cleanup hasura metadata and start again with next set of tests We have added options --skip-schema-setup and --skip-schema-teardown to help running server upgrade tests. While running the tests, we noticed that error codes and messages for some of the tests have changed. So we have added another option to pytest `--avoid-error-message-checks`. If this flag is set, and if comparing expected and response message fails, and if the expected response has an error message, Pytest will throw warnings instead of an error. * Use marks to specify server-upgrade tests Not all tests can be run as serve upgrade tests, particularly those which themselves change the schema. We introduce two pytest markers. Marker allow_server_upgrade_test will add the test into the list of server upgrade tests that can be run. skip_server_upgrade_test removes it from the list. With this we have added tests for queries, mutations, and selected event trigger and remote schema tests to the list of server upgrade tests. * Remove components not needed anymore * Install curl * Fix error in query validation * Fix error in test_v1_queries.py * install procps for server upgrade tests * Use postgres image which has postgis installed * set pager off with psql * quote the bash variable WORKTREE_DIR Co-authored-by: nizar-m <19857260+nizar-m@users.noreply.github.com> Co-authored-by: Vamshi Surabhi <0x777@users.noreply.github.com>
79 lines
1.9 KiB
Bash
Executable File
79 lines
1.9 KiB
Bash
Executable File
#! /usr/bin/env bash
|
|
# This is the non-circleci version of run.sh
|
|
#
|
|
# This script will start postgres in a docker container,
|
|
# sets a python virtual environment,
|
|
# and sets some of the required variables that run.sh needs,
|
|
# before executing run.sh
|
|
set -euo pipefail
|
|
ROOT="${BASH_SOURCE[0]%/*}"
|
|
|
|
SERVER_DIR="$ROOT/../../server"
|
|
|
|
cd $SERVER_DIR
|
|
set -x
|
|
cabal new-build --project-file=cabal.project.dev-sh exe:graphql-engine
|
|
export SERVER_BINARY=$(cabal new-exec which graphql-engine)
|
|
cd -
|
|
set +x
|
|
|
|
export SERVER_OUTPUT_DIR="server-output"
|
|
export LATEST_SERVER_BINARY="./graphql-engine-latest"
|
|
|
|
# Create Python virtualenv
|
|
if ! [ -f ".venv/bin/activate" ] ; then
|
|
virtualenv .venv
|
|
fi
|
|
|
|
. .venv/bin/activate
|
|
|
|
PG_PORT=25432
|
|
PG_CONTAINER_NAME="hasura-dev-postgres-$PG_PORT"
|
|
export PGPASSWORD=postgres
|
|
CONF=$(cat <<-EOF
|
|
log_statement=all
|
|
log_connections=on
|
|
log_disconnections=on
|
|
log_hostname=off
|
|
log_duration=on
|
|
port=$PG_PORT
|
|
EOF
|
|
)
|
|
export HASURA_GRAPHQL_DATABASE_URL="postgres://postgres:$PGPASSWORD@127.0.0.1:$PG_PORT/postgres"
|
|
|
|
DOCKER_PSQL="docker exec -u postgres -it $PG_CONTAINER_NAME psql -p $PG_PORT"
|
|
|
|
function wait_docker_postgres {
|
|
echo -n "Waiting for postgres to come up"
|
|
until $DOCKER_PSQL postgres -c '\l' &>/dev/null; do
|
|
echo -n '.' && sleep 0.2
|
|
done
|
|
echo " Ok"
|
|
}
|
|
|
|
function launch_postgres_container(){
|
|
CONF_FLAGS=$(echo "$CONF" | sed -e 's/^/-c /' | tr '\n' ' ')
|
|
echo "Launching postgres container: $PG_CONTAINER_NAME"
|
|
set -x
|
|
docker run --name "$PG_CONTAINER_NAME" -p 127.0.0.1:"$PG_PORT":$PG_PORT --expose="$PG_PORT" \
|
|
-e POSTGRES_PASSWORD="$PGPASSWORD" -d circleci/postgres:11.5-alpine-postgis $CONF_FLAGS
|
|
set +x
|
|
}
|
|
|
|
function stop_postgres_container(){
|
|
docker stop "$PG_CONTAINER_NAME"
|
|
docker rm -v "$PG_CONTAINER_NAME"
|
|
}
|
|
|
|
launch_postgres_container
|
|
|
|
wait_docker_postgres
|
|
|
|
trap stop_postgres_container ERR
|
|
|
|
set -x
|
|
"$ROOT"/run.sh "$@"
|
|
set +x
|
|
|
|
stop_postgres_container
|