#!/bin/bash # Old v1 tests run_v1.sh # New tests pushd () { command pushd "$@" > /dev/null; } popd () { command popd "$@" > /dev/null; } function wait_for_server { port=$1 while ! nc -z -w 1 127.0.0.1 $port; do sleep 0.1 done sleep 1 } DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" cd "$DIR" # Create a temporary directory. tmpdir=/tmp/memgraph_drivers if [ -d $tmpdir ]; then rm -rf $tmpdir fi mkdir -p $tmpdir # Find memgraph binaries. binary_dir="$DIR/../../build" # Start memgraph. $binary_dir/memgraph \ --cartesian-product-enabled=false \ --data-directory=$tmpdir \ --query-execution-timeout-sec=5 \ --bolt-session-inactivity-timeout=10 \ --bolt-cert-file="" \ --log-file=$tmpdir/logs/memgarph.log \ --also-log-to-stderr \ --log-level ERROR & pid=$! wait_for_server 7687 # Run all available tests code_test=0 for i in *; do if [ ! -d $i ]; then continue; fi pushd $i echo "Running: $i" # run all versions for v in *; do #skip v1 (needs different server name) if [[ "$v" == "v1" || ! -d "$v" ]]; then continue; fi pushd $v echo "Running version: $v" ./run.sh code_test=$? if [ $code_test -ne 0 ]; then echo "FAILED: $i" break fi popd done; echo popd done # Stop memgraph. kill $pid wait $pid code_mg=$? # Temporary directory cleanup. if [ -d $tmpdir ]; then rm -rf $tmpdir fi # Check memgraph exit code. if [ $code_mg -ne 0 ]; then echo "The memgraph process didn't terminate properly!" exit $code_mg fi # Check test exit code. if [ $code_test -ne 0 ]; then echo "One of the tests failed!" exit $code_test fi