X-Git-Url: https://git.arvados.org/arvados-dev.git/blobdiff_plain/d7f1a63c8396715e501be04addefb0a158303e69..ffa8b415658e6d3ba3836c6e208fe35979de0bf4:/jenkins/run-tests.sh diff --git a/jenkins/run-tests.sh b/jenkins/run-tests.sh index 445509d..ef2e40d 100755 --- a/jenkins/run-tests.sh +++ b/jenkins/run-tests.sh @@ -27,6 +27,9 @@ sdk/python_test="--test-suite test.test_keep_locator" Restrict Python SDK tests to the given class apps/workbench_test="TEST=test/integration/pipeline_instances_test.rb" Restrict Workbench tests to the given file +services/arv-git-httpd_test="-check.vv" + Show all log messages, even when tests pass (also works + with services/keepstore_test etc.) ARVADOS_DEBUG=1 Print more debug messages envvar=value Set \$envvar to value. Primarily useful for WORKSPACE, @@ -56,6 +59,7 @@ services/fuse services/keepproxy services/keepstore services/nodemanager +services/arv-git-httpd sdk/cli sdk/python sdk/ruby @@ -126,6 +130,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 +179,6 @@ sanity_checks() { echo >&2 exit 1 fi - } rotate_logfile() { @@ -206,6 +219,9 @@ do leave_temp[GOPATH]=1 leave_temp[GEMHOME]=1 ;; + --retry) + retry=1 + ;; *_test=*) suite="${arg%%_test=*}" args="${arg#*=}" @@ -221,6 +237,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 +389,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,13 +410,33 @@ 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" timer_reset if [[ "$2" == "go" ]] then - go test ${testargs[$1]} "git.curoverse.com/arvados.git/$1" + if [[ -n "${testargs[$1]}" ]] + then + # "go test -check.vv giturl" doesn't work, but this + # does: + cd "$WORKSPACE/$1" && go test ${testargs[$1]} + else + # The above form gets verbose even when testargs is + # empty, so use this form in such cases: + go test "git.curoverse.com/arvados.git/$1" + fi elif [[ "$2" == "pip" ]] then cd "$WORKSPACE/$1" \ @@ -371,8 +447,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 +468,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 +576,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 +591,7 @@ do_install services/api apiserver declare -a gostuff gostuff=( + services/arv-git-httpd services/crunchstat services/keepstore services/keepproxy @@ -525,25 +606,11 @@ done install_workbench() { cd "$WORKSPACE/apps/workbench" \ + && mkdir -p tmp/cache \ && RAILS_ENV=test bundle_install_trylocal } 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 @@ -556,26 +623,33 @@ test_doclinkchecker() { } do_test doc doclinkchecker -stop_api +stop_services test_apiserver() { cd "$WORKSPACE/services/api" \ - && RAILS_ENV=test bundle exec rake test ${testargs[services/api]} + && RAILS_ENV=test bundle exec rake test TESTOPTS=-v ${testargs[services/api]} } 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() { cd "$WORKSPACE/sdk/ruby" \ - && bundle exec rake test ${testargs[sdk/ruby]} + && bundle exec rake test TESTOPTS=-v ${testargs[sdk/ruby]} } do_test sdk/ruby ruby_sdk test_cli() { cd "$WORKSPACE/sdk/cli" \ && mkdir -p /tmp/keep \ - && KEEP_LOCAL_STORE=/tmp/keep bundle exec rake test ${testargs[sdk/cli]} + && KEEP_LOCAL_STORE=/tmp/keep bundle exec rake test TESTOPTS=-v ${testargs[sdk/cli]} } do_test sdk/cli cli @@ -590,29 +664,24 @@ do done test_workbench() { - cd "$WORKSPACE/apps/workbench" \ - && RAILS_ENV=test bundle exec rake test ${testargs[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