X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/62a2ccba46cb5b83e510e727afa44eee2e893676..refs/heads/13220-run-tests:/build/run-build-packages-one-target.sh diff --git a/build/run-build-packages-one-target.sh b/build/run-build-packages-one-target.sh index ff82e46e04..31a546fd35 100755 --- a/build/run-build-packages-one-target.sh +++ b/build/run-build-packages-one-target.sh @@ -21,6 +21,8 @@ Syntax: Build only a specific package --only-test Test only a specific package +--force-test + Test even if there is no new untested package --build-version Version to build (default: \$ARVADOS_BUILDING_VERSION-\$ARVADOS_BUILDING_ITERATION or @@ -49,7 +51,7 @@ if ! [[ -d "$WORKSPACE" ]]; then fi PARSEDOPTS=$(getopt --name "$0" --longoptions \ - help,debug,test-packages,target:,command:,only-test:,only-build:,build-version: \ + help,debug,test-packages,target:,command:,only-test:,force-test,only-build:,build-version: \ -- "" "$@") if [ $? -ne 0 ]; then exit 1 @@ -74,6 +76,9 @@ while [ $# -gt 0 ]; do test_packages=1 packages="$2"; shift ;; + --force-test) + FORCE_TEST=true + ;; --only-build) ONLY_BUILD="$2"; shift ;; @@ -161,6 +166,8 @@ popd if test -z "$packages" ; then packages="arvados-api-server + arvados-client + arvados-docker-cleaner arvados-git-httpd arvados-node-manager arvados-src @@ -179,10 +186,6 @@ if test -z "$packages" ; then python-arvados-fuse python-arvados-python-client python-arvados-cwl-runner" - - if [[ $TARGET != centos7 ]]; then - packages="$packages arvados-docker-cleaner" - fi fi FINAL_EXITCODE=0 @@ -206,6 +209,14 @@ if [[ -n "$test_packages" ]]; then if [[ -n "$ONLY_BUILD" ]] && [[ "$p" != "$ONLY_BUILD" ]]; then continue fi + if [[ -e "${WORKSPACE}/packages/.last_test_${TARGET}" ]] && [[ -z "$FORCE_TEST" ]]; then + MATCH=`find ${WORKSPACE}/packages/ -newer ${WORKSPACE}/packages/.last_test_${TARGET} -regex .*${TARGET}/$p.*` + if [[ "$MATCH" == "" ]]; then + # No new package has been built that needs testing + echo "Skipping $p test because no new package was built since the last test." + continue + fi + fi echo echo "START: $p test on $IMAGE" >&2 if docker run --rm \ @@ -222,6 +233,8 @@ if [[ -n "$test_packages" ]]; then echo "ERROR: $p test on $IMAGE failed with exit status $FINAL_EXITCODE" >&2 fi done + + touch ${WORKSPACE}/packages/.last_test_${TARGET} else echo echo "START: build packages on $IMAGE" >&2