X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=shell%2Ftox-run.sh;h=6b45116621ae1bea84eb84ff01702b3aa06ab3f0;hb=68bfb0c6bd7ba0c23e665ba4045acbba0e26af02;hp=dd6769996a0299621d122bc95d740af76c9252ba;hpb=7030e31159d6ee4fbab8ae015611a39cbcd62e2c;p=releng%2Fglobal-jjb.git diff --git a/shell/tox-run.sh b/shell/tox-run.sh index dd676999..6b451166 100644 --- a/shell/tox-run.sh +++ b/shell/tox-run.sh @@ -27,16 +27,35 @@ if [ -d "/opt/pyenv" ]; then export PATH="$PYENV_ROOT/bin:$PATH" fi -if [ ! -z "$TOX_ENVS" ]; then - detox -e "$TOX_ENVS" | tee -a "$ARCHIVE_TOX_DIR/detox.log" +set +e # Allow detox to fail so that we can collect the logs in the next step + +PARALLEL="${PARALLEL:-true}" +if [ "${PARALLEL}" = true ]; then + if [ ! -z "$TOX_ENVS" ]; then + detox -e "$TOX_ENVS" | tee -a "$ARCHIVE_TOX_DIR/detox.log" + tox_status="${PIPESTATUS[0]}" + else + detox | tee -a "$ARCHIVE_TOX_DIR/detox.log" + tox_status="${PIPESTATUS[0]}" + fi else - detox | tee -a "$ARCHIVE_TOX_DIR/detox.log" + if [ ! -z "$TOX_ENVS" ]; then + tox -e "$TOX_ENVS" | tee -a "$ARCHIVE_TOX_DIR/tox.log" + tox_status="${PIPESTATUS[0]}" + else + tox | tee -a "$ARCHIVE_TOX_DIR/tox.log" + tox_status="${PIPESTATUS[0]}" + fi fi # Disable SC2116 as we want to echo a space separated list of TOX_ENVS # shellcheck disable=SC2116 -for i in $(echo "${TOX_ENVS//,/ }"); do - cp -r ".tox/$i/log" "$ARCHIVE_TOX_DIR/$i" +for i in .tox/*/log; do + tox_env=$(echo $i | awk -F'/' '{print $2}') + cp -r "$i" "$ARCHIVE_TOX_DIR/$tox_env" done +set -e # Logs collected so re-enable echo "Completed tox runs." + +test "$tox_status" -eq 0 || exit "$tox_status"