X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/caeb94881de75f2f8ee0156951c7f54006499e15..7cb351cc32727ca7d9fb1af4543ab2718d31a9f4:/sdk/cwl/test_with_arvbox.sh diff --git a/sdk/cwl/test_with_arvbox.sh b/sdk/cwl/test_with_arvbox.sh index aa98252c0c..0021bc8d90 100755 --- a/sdk/cwl/test_with_arvbox.sh +++ b/sdk/cwl/test_with_arvbox.sh @@ -12,8 +12,11 @@ fi reset_container=1 leave_running=0 config=dev +devcwl=0 tag="latest" -pythoncmd=python +pythoncmd=python3 +suite=conformance +runapi=containers while test -n "$1" ; do arg="$1" @@ -38,12 +41,24 @@ while test -n "$1" ; do build=1 shift ;; + --devcwl) + devcwl=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] [--config dev|localdemo] [--tag docker_tag] [--build] [--pythoncmd python[23]]" + echo "$0 [--no-reset-container] [--leave-running] [--config dev|localdemo] [--tag docker_tag] [--build] [--pythoncmd python(2|3)] [--suite (integration|conformance-v1.0|conformance-*)]" exit ;; *) @@ -56,6 +71,10 @@ 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 @@ -77,32 +96,61 @@ if test $config = dev ; then pip_install \$(ls -r dist/arvados-cwl-runner-*.tar.gz | head -n1) fi -if [ \$PYCMD = "python3" ]; then +set -x + +if [ "\$PYCMD" = "python3" ]; then pip3 install cwltest else - pip3 install cwltest + 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-(.*) ]] ; then + version=\${BASH_REMATCH[1]} + if ! test -d cwl-\${version} ; then + git clone https://github.com/common-workflow-language/cwl-\${version}.git + fi + cd cwl-\${version} +elif [[ "$suite" != "integration" ]] ; then + echo "ERROR: unknown suite '$suite'" + exit 1 fi -cd common-workflow-language -git pull + +if [[ "$suite" != "integration" ]] ; then + git pull +fi + export ARVADOS_API_HOST=localhost:8000 export ARVADOS_API_HOST_INSECURE=1 -export ARVADOS_API_TOKEN=\$(cat /var/lib/arvados/superuser_token) - +export ARVADOS_API_TOKEN=\$(cat /var/lib/arvados-arvbox/superuser_token) if test -n "$build" ; then - /usr/src/arvados/build/build-dev-docker-jobs-image.sh + /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 + set +u + export WORKSPACE=/usr/src/arvados + . /usr/src/arvados/build/run-library.sh + TMPHERE=\$(pwd) + cd /usr/src/arvados + + # This defines python_sdk_version and cwl_runner_version with python-style + # package suffixes (.dev/rc) + calculate_python_sdk_cwl_package_versions + + cd \$TMPHERE + set -u + + arv-keepdocker --pull arvados/jobs \$cwl_runner_version + docker tag arvados/jobs:\$cwl_runner_version arvados/jobs:latest arv-keepdocker arvados/jobs latest fi @@ -118,8 +166,19 @@ exec arvados-cwl-runner --api=containers \\\$@ EOF2 chmod +x /tmp/cwltest/arv-cwl-containers +EXTRA=--compute-checksum + +if [[ $devcwl -eq 1 ]] ; then + EXTRA="\$EXTRA --enable-dev" +fi + env -exec ./run_test.sh RUNNER=/tmp/cwltest/arv-cwl-containers EXTRA=--compute-checksum $@ +if [[ "$suite" = "integration" ]] ; then + cd /usr/src/arvados/sdk/cwl/tests + exec ./arvados-tests.sh $@ +else + exec ./run_test.sh RUNNER=/tmp/cwltest/arv-cwl-${runapi} EXTRA="\$EXTRA" $@ +fi EOF CODE=$?