X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2d03ecf4a147db64708991bd3bf2f1d9fc9b358e..a3465f97627494bde0f148e27559046308cbedda:/jenkins/run-tests.sh diff --git a/jenkins/run-tests.sh b/jenkins/run-tests.sh index 689405b2ef..6f5dd38731 100755 --- a/jenkins/run-tests.sh +++ b/jenkins/run-tests.sh @@ -56,6 +56,7 @@ services/fuse services/keepproxy services/keepstore services/nodemanager +services/arv-git-httpd sdk/cli sdk/python sdk/ruby @@ -126,6 +127,16 @@ report_outcomes() { fi } +exit_cleanly() { + trap - INT + rotate_logfile "$WORKSPACE/apps/workbench/log/" "test.log" + stop_services + rotate_logfile "$WORKSPACE/services/api/log/" "test.log" + report_outcomes + clear_temp + exit ${#failures} +} + sanity_checks() { # Make sure WORKSPACE is set if ! [[ -n "$WORKSPACE" ]]; then @@ -165,7 +176,6 @@ sanity_checks() { echo >&2 exit 1 fi - } rotate_logfile() { @@ -206,6 +216,9 @@ do leave_temp[GOPATH]=1 leave_temp[GEMHOME]=1 ;; + --retry) + retry=1 + ;; *_test=*) suite="${arg%%_test=*}" args="${arg#*=}" @@ -221,6 +234,45 @@ do esac done +start_api() { + echo 'Starting API server...' + cd "$WORKSPACE" \ + && eval $(python sdk/python/tests/run_test_server.py start --auth admin) \ + && export ARVADOS_TEST_API_HOST="$ARVADOS_API_HOST" \ + && export ARVADOS_TEST_API_INSTALLED="$$" \ + && (env | egrep ^ARVADOS) +} + +start_nginx_proxy_services() { + echo 'Starting keepproxy, arv-git-httpd, and nginx ssl proxy...' + cd "$WORKSPACE" \ + && python sdk/python/tests/run_test_server.py start_keep_proxy \ + && python sdk/python/tests/run_test_server.py start_arv-git-httpd \ + && python sdk/python/tests/run_test_server.py start_nginx \ + && export ARVADOS_TEST_PROXY_SERVICES=1 +} + +stop_services() { + if [[ -n "$ARVADOS_TEST_PROXY_SERVICES" ]]; then + unset ARVADOS_TEST_PROXY_SERVICES + cd "$WORKSPACE" \ + && python sdk/python/tests/run_test_server.py stop_nginx \ + && python sdk/python/tests/run_test_server.py stop_arv-git-httpd \ + && python sdk/python/tests/run_test_server.py stop_keep_proxy + fi + if [[ -n "$ARVADOS_TEST_API_HOST" ]]; then + unset ARVADOS_TEST_API_HOST + cd "$WORKSPACE" \ + && python sdk/python/tests/run_test_server.py stop + fi +} + +interrupt() { + failures+=("($(basename $0) interrupted)") + exit_cleanly +} +trap interrupt INT + sanity_checks echo "WORKSPACE=$WORKSPACE" @@ -334,14 +386,15 @@ then fi # Needed for run_test_server.py which is used by certain (non-Python) tests. -pip install PyYAML || fatal "pip install PyYAML failed" +echo "pip install -q PyYAML" +pip install -q PyYAML || fatal "pip install PyYAML failed" checkexit() { - if [[ "$?" != "0" ]]; then - title "!!!!!! $1 FAILED !!!!!!" - failures+=("$1 (`timer`)") + if [[ "$1" != "0" ]]; then + title "!!!!!! $2 FAILED !!!!!!" + failures+=("$2 (`timer`)") else - successes+=("$1 (`timer`)") + successes+=("$2 (`timer`)") fi } @@ -354,6 +407,17 @@ timer() { } do_test() { + while ! do_test_once ${@} && [[ "$retry" == 1 ]] + do + read -p 'Try again? [Y/n] ' x + if [[ "$x" != "y" ]] && [[ "$x" != "" ]] + then + break + fi + done +} + +do_test_once() { if [[ -z "${skip[$1]}" ]] && ( [[ -z "$only" ]] || [[ "$only" == "$1" ]] ) then title "Running $1 tests" @@ -371,8 +435,10 @@ do_test() { else "test_$1" fi - checkexit "$1 tests" + result="$?" + checkexit $result "$1 tests" title "End of $1 tests (`timer`)" + return $result else title "Skipping $1 tests" fi @@ -390,14 +456,14 @@ do_install() { then cd "$WORKSPACE/$1" \ && python setup.py sdist rotate --keep=1 --match .tar.gz \ - && pip install --upgrade dist/*.tar.gz + && pip install -q --upgrade dist/*.tar.gz elif [[ "$2" != "" ]] then "install_$2" else "install_$1" fi - checkexit "$1 install" + checkexit $? "$1 install" title "End of $1 install (`timer`)" else title "Skipping $1 install" @@ -498,9 +564,11 @@ install_apiserver() { && git add tmp \ && git commit -m 'initial commit' - # Clear out any lingering postgresql connections to arvados_test, so that we can drop it - # This assumes the current user is a postgresql superuser - psql arvados_test -c "SELECT pg_terminate_backend (pg_stat_activity.procpid::int) FROM pg_stat_activity WHERE pg_stat_activity.datname = 'arvados_test';" 2>/dev/null + # Clear out any lingering postgresql connections to the test + # database, so that we can drop it. This assumes the current user + # is a postgresql superuser. + test_database=$(python -c "import yaml; print yaml.load(file('config/database.yml'))['test']['database']") + psql "$test_database" -c "SELECT pg_terminate_backend (pg_stat_activity.procpid::int) FROM pg_stat_activity WHERE pg_stat_activity.datname = '$test_database';" 2>/dev/null cd "$WORKSPACE/services/api" \ && RAILS_ENV=test bundle exec rake db:drop \ @@ -511,6 +579,7 @@ do_install services/api apiserver declare -a gostuff gostuff=( + services/arv-git-httpd services/crunchstat services/keepstore services/keepproxy @@ -530,21 +599,6 @@ install_workbench() { } do_install apps/workbench workbench -start_api() { - echo 'Starting API server...' - cd "$WORKSPACE" \ - && eval $(python sdk/python/tests/run_test_server.py start --auth admin) \ - && export ARVADOS_TEST_API_HOST="$ARVADOS_API_HOST" \ - && export ARVADOS_TEST_API_INSTALLED="$$" \ - && (env | egrep ^ARVADOS) -} - -stop_api() { - unset ARVADOS_TEST_API_HOST - cd "$WORKSPACE" \ - && python sdk/python/tests/run_test_server.py stop -} - test_doclinkchecker() { ( set -e @@ -557,7 +611,7 @@ test_doclinkchecker() { } do_test doc doclinkchecker -stop_api +stop_services test_apiserver() { cd "$WORKSPACE/services/api" \ @@ -565,6 +619,13 @@ test_apiserver() { } do_test services/api apiserver +# Shortcut for when we're only running apiserver tests. This saves a bit of time, +# because we don't need to start up the api server for subsequent tests. +if [ ! -z "$only" ] && [ "$only" == "services/api" ]; then + rotate_logfile "$WORKSPACE/services/api/log/" "test.log" + exit_cleanly +fi + start_api test_ruby_sdk() { @@ -591,29 +652,24 @@ do done test_workbench() { - cd "$WORKSPACE/apps/workbench" \ + start_nginx_proxy_services \ + && cd "$WORKSPACE/apps/workbench" \ && RAILS_ENV=test bundle exec rake test TESTOPTS=-v ${testargs[apps/workbench]} } do_test apps/workbench workbench test_workbench_benchmark() { - cd "$WORKSPACE/apps/workbench" \ + start_nginx_proxy_services \ + && cd "$WORKSPACE/apps/workbench" \ && RAILS_ENV=test bundle exec rake test:benchmark ${testargs[apps/workbench_benchmark]} } do_test apps/workbench_benchmark workbench_benchmark test_workbench_profile() { - cd "$WORKSPACE/apps/workbench" \ + start_nginx_proxy_services \ + && cd "$WORKSPACE/apps/workbench" \ && RAILS_ENV=test bundle exec rake test:profile ${testargs[apps/workbench_profile]} } do_test apps/workbench_profile workbench_profile -rotate_logfile "$WORKSPACE/apps/workbench/log/" "test.log" - -stop_api -rotate_logfile "$WORKSPACE/services/api/log/" "test.log" - -report_outcomes -clear_temp - -exit ${#failures} +exit_cleanly