X-Git-Url: https://git.arvados.org/arvados-dev.git/blobdiff_plain/4af2bd565b75a9dcbb553975599d5e0b8856e940..9a4afad134f563d41f2a0c84b4389698df07a8db:/jenkins/run-tests.sh diff --git a/jenkins/run-tests.sh b/jenkins/run-tests.sh index c5e5656..8e58d67 100755 --- a/jenkins/run-tests.sh +++ b/jenkins/run-tests.sh @@ -18,6 +18,7 @@ Options: --skip-install Do not run any install steps. Just run tests. You should provide GOPATH, GEMHOME, and VENVDIR options from a previous invocation if you use this option. +--only-install Run specific install step WORKSPACE=path Arvados source tree to test. CONFIGSRC=path Dir with api server config files to copy into source tree. (If none given, leave config files alone in source tree.) @@ -27,6 +28,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, @@ -52,10 +56,12 @@ apps/workbench_profile doc services/api services/crunchstat +services/dockercleaner services/fuse services/keepproxy services/keepstore services/nodemanager +services/arv-git-httpd sdk/cli sdk/python sdk/ruby @@ -74,6 +80,7 @@ unset $(env | cut -d= -f1 | grep \^ARVADOS_) GITDIR= GOPATH= VENVDIR= +VENV3DIR= PYTHONPATH= GEMHOME= @@ -85,7 +92,7 @@ skip_install= declare -A leave_temp clear_temp() { leaving="" - for var in VENVDIR GOPATH GITDIR GEMHOME + for var in VENVDIR VENV3DIR GOPATH GITDIR GEMHOME do if [[ -z "${leave_temp[$var]}" ]] then @@ -126,6 +133,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 +182,6 @@ sanity_checks() { echo >&2 exit 1 fi - } rotate_logfile() { @@ -201,11 +217,19 @@ do --skip-install) skip_install=1 ;; + --only-install) + skip_install=1 + only_install="$1"; shift + ;; --leave-temp) leave_temp[VENVDIR]=1 + leave_temp[VENV3DIR]=1 leave_temp[GOPATH]=1 leave_temp[GEMHOME]=1 ;; + --retry) + retry=1 + ;; *_test=*) suite="${arg%%_test=*}" args="${arg#*=}" @@ -221,6 +245,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" @@ -235,7 +298,7 @@ cd "$WORKSPACE" find -name '*.pyc' -delete # Set up temporary install dirs (unless existing dirs were supplied) -for tmpdir in VENVDIR GOPATH GEMHOME +for tmpdir in VENVDIR VENV3DIR GOPATH GEMHOME do if [[ -n "${!tmpdir}" ]]; then leave_temp[$tmpdir]=1 @@ -322,6 +385,10 @@ ln -sfn "$WORKSPACE" "$GOPATH/src/git.curoverse.com/arvados.git" \ virtualenv --setuptools "$VENVDIR" || fatal "virtualenv $VENVDIR failed" . "$VENVDIR/bin/activate" +# When re-using $VENVDIR, upgrade any packages (except arvados) that are +# already installed +pip install --quiet --upgrade `pip freeze | grep -v arvados | cut -f1 -d=` + # Note: this must be the last time we change PATH, otherwise rvm will # whine a lot. setup_ruby_environment @@ -334,18 +401,32 @@ 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 --quiet PyYAML || fatal "pip install PyYAML failed" + +# If Python 3 is available, set up its virtualenv in $VENV3DIR. +# Otherwise, skip dependent tests. +PYTHON3=$(which python3) +if [ "0" = "$?" ]; then + virtualenv --python "$PYTHON3" --setuptools "$VENV3DIR" \ + || fatal "python3 virtualenv $VENV3DIR failed" +else + PYTHON3= + skip[services/dockercleaner]=1 + cat >&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 \ @@ -503,6 +639,7 @@ do_install services/api apiserver declare -a gostuff gostuff=( + services/arv-git-httpd services/crunchstat services/keepstore services/keepproxy @@ -517,46 +654,58 @@ done install_workbench() { cd "$WORKSPACE/apps/workbench" \ - && RAILS_ENV=test bundle install --no-deployment + && mkdir -p tmp/cache \ + && RAILS_ENV=test bundle_install_trylocal } do_install apps/workbench workbench test_doclinkchecker() { - cd "$WORKSPACE/doc" - # Make sure python-epydoc is installed or the next line won't do much good! - ARVADOS_API_HOST=qr1hi.arvadosapi.com - PYTHONPATH=$WORKSPACE/sdk/python/ bundle exec rake linkchecker baseurl=file://$WORKSPACE/doc/.site/ arvados_workbench_host=workbench.$ARVADOS_API_HOST arvados_api_host=$ARVADOS_API_HOST - unset ARVADOS_API_HOST + ( + set -e + cd "$WORKSPACE/doc" + ARVADOS_API_HOST=qr1hi.arvadosapi.com + # Make sure python-epydoc is installed or the next line won't + # do much good! + PYTHONPATH=$WORKSPACE/sdk/python/ bundle exec rake linkchecker baseurl=file://$WORKSPACE/doc/.site/ arvados_workbench_host=workbench.$ARVADOS_API_HOST arvados_api_host=$ARVADOS_API_HOST + ) } do_test doc doclinkchecker +stop_services + +test_apiserver() { + cd "$WORKSPACE/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 install --no-deployment \ - && 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" \ - && bundle install --no-deployment \ && 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 -test_apiserver() { - cd "$WORKSPACE/services/api" - RAILS_ENV=test bundle exec rake test ${testargs[services/api]} -} -do_test services/api apiserver - -rotate_logfile "$WORKSPACE/services/api/log/" "test.log" - for p in "${pythonstuff[@]}" do do_test "$p" pip done +do_test services/dockercleaner pip "$VENV3DIR/bin/" for g in "${gostuff[@]}" do @@ -564,26 +713,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" - -report_outcomes -clear_temp - -exit ${#failures} +exit_cleanly