X-Git-Url: https://git.arvados.org/arvados-dev.git/blobdiff_plain/72c3457917a25dede1695c8abda316aa4e5afd5e..9a4afad134f563d41f2a0c84b4389698df07a8db:/jenkins/run-tests.sh diff --git a/jenkins/run-tests.sh b/jenkins/run-tests.sh index c81f3bd..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 @@ -129,7 +136,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 @@ -210,8 +217,13 @@ 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 ;; @@ -242,7 +254,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" \ @@ -270,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 @@ -357,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 @@ -370,7 +402,24 @@ fi # Needed for run_test_server.py which is used by certain (non-Python) tests. echo "pip install -q PyYAML" -pip install -q PyYAML || fatal "pip install PyYAML failed" +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 \ @@ -592,7 +671,7 @@ test_doclinkchecker() { } do_test doc doclinkchecker -stop_api +stop_services test_apiserver() { cd "$WORKSPACE/services/api" \ @@ -626,6 +705,7 @@ for p in "${pythonstuff[@]}" do do_test "$p" pip done +do_test services/dockercleaner pip "$VENV3DIR/bin/" for g in "${gostuff[@]}" do @@ -633,19 +713,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