X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f3685f741ad7eca0fcaa2b11dc550f0ef5acd3ac..c56d04266de4e97b1b861c068309476ca562d72f:/sdk/cwl/test_with_arvbox.sh diff --git a/sdk/cwl/test_with_arvbox.sh b/sdk/cwl/test_with_arvbox.sh index 29109a4e6a..39c834ed60 100755 --- a/sdk/cwl/test_with_arvbox.sh +++ b/sdk/cwl/test_with_arvbox.sh @@ -1,4 +1,7 @@ #!/bin/sh +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: Apache-2.0 set -x @@ -9,8 +12,10 @@ fi reset_container=1 leave_running=0 config=dev -docker_pull=1 -tag="" +tag="latest" +pythoncmd=python +suite=conformance +runapi=containers while test -n "$1" ; do arg="$1" @@ -27,16 +32,28 @@ while test -n "$1" ; do config=$2 shift ; shift ;; - --no-docker-pull) - docker_pull=0 - shift - ;; --tag) tag=$2 shift ; shift ;; + --build) + build=1 + shift + ;; + --pythoncmd) + pythoncmd=$2 + shift ; shift + ;; + --suite) + suite=$2 + shift ; shift + ;; + --api) + runapi=$2 + shift ; shift + ;; -h|--help) - echo "$0 [--no-reset-container] [--leave-running] [--no-docker-pull] [--config dev|localdemo] [--tag docker_tag]" + echo "$0 [--no-reset-container] [--leave-running] [--config dev|localdemo] [--tag docker_tag] [--build] [--pythoncmd python(2|3)] [--suite (integration|conformance-v1.0|conformance-v1.1)]" exit ;; *) @@ -49,7 +66,13 @@ if test -z "$ARVBOX_CONTAINER" ; then export ARVBOX_CONTAINER=cwltest fi +if test "$suite" = "conformance" ; then + suite=conformance-v1.0 +fi + if test $reset_container = 1 ; then + arvbox stop + docker rm $ARVBOX_CONTAINER arvbox reset -f fi @@ -60,23 +83,54 @@ set -eu -o pipefail . /usr/local/lib/arvbox/common.sh -cd /usr/src/arvados/sdk/cwl -python setup.py sdist -pip_install \$(ls -r dist/arvados-cwl-runner-*.tar.gz | head -n1) +export PYCMD=$pythoncmd + +if test $config = dev ; then + cd /usr/src/arvados/sdk/cwl + \$PYCMD setup.py sdist + pip_install \$(ls -r dist/arvados-cwl-runner-*.tar.gz | head -n1) +fi + +set -x + +if [ \$PYCMD = "python3" ]; then + pip3 install cwltest +else + pip install cwltest +fi mkdir -p /tmp/cwltest cd /tmp/cwltest -if ! test -d common-workflow-language ; then - git clone https://github.com/common-workflow-language/common-workflow-language.git + +if [[ "$suite" = "conformance-v1.0" ]] ; then + if ! test -d common-workflow-language ; then + git clone https://github.com/common-workflow-language/common-workflow-language.git + fi + cd common-workflow-language +elif [[ "$suite" = "conformance-v1.1" ]] ; then + if ! test -d cwl-v1.1 ; then + git clone https://github.com/common-workflow-language/cwl-v1.1.git + fi + cd cwl-v1.1 +fi + +if [[ "$suite" != "integration" ]] ; then + git pull fi -cd common-workflow-language -git pull + export ARVADOS_API_HOST=localhost:8000 export ARVADOS_API_HOST_INSECURE=1 export ARVADOS_API_TOKEN=\$(cat /var/lib/arvados/superuser_token) -if test $docker_pull = 1 ; then +if test -n "$build" ; then + /usr/src/arvados/build/build-dev-docker-jobs-image.sh +elif test "$tag" = "latest" ; then arv-keepdocker --pull arvados/jobs $tag +else + jobsimg=\$(curl https://versions.arvados.org/v1/commit/$tag | python -c "import json; import sys; sys.stdout.write(json.load(sys.stdin)['Versions']['Docker']['arvados/jobs'])") + arv-keepdocker --pull arvados/jobs \$jobsimg + docker tag arvados/jobs:\$jobsimg arvados/jobs:latest + arv-keepdocker arvados/jobs latest fi cat >/tmp/cwltest/arv-cwl-jobs <