Make sure that jjb-cleanup.sh allows unbound vars
[releng/global-jjb.git] / shell / tox-run.sh
1 #!/bin/bash -l
2 # SPDX-License-Identifier: EPL-1.0
3 ##############################################################################
4 # Copyright (c) 2017 The Linux Foundation and others.
5 #
6 # All rights reserved. This program and the accompanying materials
7 # are made available under the terms of the Eclipse Public License v1.0
8 # which accompanies this distribution, and is available at
9 # http://www.eclipse.org/legal/epl-v10.html
10 ##############################################################################
11 echo "---> tox-run.sh"
12
13 # Ensure we fail the job if any steps fail.
14 # DO NOT set -u as virtualenv's activate script has unbound variables
15 set -e -o pipefail
16
17 ARCHIVE_TOX_DIR="$WORKSPACE/archives/tox"
18 mkdir -p "$ARCHIVE_TOX_DIR"
19 cd "$WORKSPACE/$TOX_DIR"
20
21 if [ -d "/opt/pyenv" ]; then
22     echo "---> Setting up pyenv"
23     export PYENV_ROOT="/opt/pyenv"
24     export PATH="$PYENV_ROOT/bin:$PATH"
25 fi
26
27 set +e  # Allow detox to fail so that we can collect the logs in the next step
28
29 PARALLEL="${PARALLEL:-true}"
30 if [ "${PARALLEL}" = true ]; then
31     if [ ! -z "$TOX_ENVS" ]; then
32         detox -e "$TOX_ENVS"  | tee -a "$ARCHIVE_TOX_DIR/detox.log"
33         tox_status="${PIPESTATUS[0]}"
34     else
35         detox | tee -a "$ARCHIVE_TOX_DIR/detox.log"
36         tox_status="${PIPESTATUS[0]}"
37     fi
38 else
39     if [ ! -z "$TOX_ENVS" ]; then
40         tox -e "$TOX_ENVS"  | tee -a "$ARCHIVE_TOX_DIR/tox.log"
41         tox_status="${PIPESTATUS[0]}"
42     else
43         tox | tee -a "$ARCHIVE_TOX_DIR/tox.log"
44         tox_status="${PIPESTATUS[0]}"
45     fi
46 fi
47
48 # Disable SC2116 as we want to echo a space separated list of TOX_ENVS
49 # shellcheck disable=SC2116
50 for i in .tox/*/log; do
51     tox_env=$(echo $i | awk -F'/' '{print $2}')
52     cp -r "$i" "$ARCHIVE_TOX_DIR/$tox_env"
53 done
54 set -e  # Logs collected so re-enable
55
56 echo "Completed tox runs."
57
58 test "$tox_status" -eq 0 || exit "$tox_status"