X-Git-Url: https://git.arvados.org/arvados-dev.git/blobdiff_plain/6c6ca86bfa400d880d051fd87c7c1fb9b8905114..a3465f97627494bde0f148e27559046308cbedda:/jenkins/run-tests.sh diff --git a/jenkins/run-tests.sh b/jenkins/run-tests.sh index 713ffda..6f5dd38 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 @@ -129,7 +130,7 @@ report_outcomes() { exit_cleanly() { trap - INT rotate_logfile "$WORKSPACE/apps/workbench/log/" "test.log" - stop_api + stop_services rotate_logfile "$WORKSPACE/services/api/log/" "test.log" report_outcomes clear_temp @@ -215,6 +216,9 @@ do leave_temp[GOPATH]=1 leave_temp[GEMHOME]=1 ;; + --retry) + retry=1 + ;; *_test=*) suite="${arg%%_test=*}" args="${arg#*=}" @@ -239,7 +243,23 @@ start_api() { && (env | egrep ^ARVADOS) } -stop_api() { +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" \ @@ -370,11 +390,11 @@ 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 } @@ -387,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" @@ -404,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 @@ -430,7 +463,7 @@ do_install() { else "install_$1" fi - checkexit "$1 install" + checkexit $? "$1 install" title "End of $1 install (`timer`)" else title "Skipping $1 install" @@ -531,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 \ @@ -544,6 +579,7 @@ do_install services/api apiserver declare -a gostuff gostuff=( + services/arv-git-httpd services/crunchstat services/keepstore services/keepproxy @@ -575,7 +611,7 @@ test_doclinkchecker() { } do_test doc doclinkchecker -stop_api +stop_services test_apiserver() { cd "$WORKSPACE/services/api" \ @@ -616,19 +652,22 @@ 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