Alexander Afanasyev | a87e0a8 | 2014-10-21 14:09:19 -0400 | [diff] [blame] | 1 | #!/usr/bin/env bash |
Alexander Afanasyev | 33ce4c3 | 2014-10-24 11:19:45 -0700 | [diff] [blame] | 2 | set -e |
Davide Pesavento | 2349e28 | 2020-03-24 14:28:03 -0400 | [diff] [blame] | 3 | source .jenkins.d/util.sh |
| 4 | |
Davide Pesavento | 09d5662 | 2021-08-23 17:44:25 -0400 | [diff] [blame^] | 5 | if has Linux $NODE_LABELS; then |
| 6 | export PATH="~/.local/bin${PATH:+:}${PATH}" |
| 7 | fi |
Davide Pesavento | ab7300b | 2020-04-09 00:51:41 -0400 | [diff] [blame] | 8 | export CACHE_DIR=${CACHE_DIR:-/tmp} |
Davide Pesavento | 2349e28 | 2020-03-24 14:28:03 -0400 | [diff] [blame] | 9 | export WAF_JOBS=${WAF_JOBS:-1} |
Davide Pesavento | ab7300b | 2020-04-09 00:51:41 -0400 | [diff] [blame] | 10 | [[ $JOB_NAME == *"code-coverage" ]] && export DISABLE_ASAN=yes |
Alexander Afanasyev | a87e0a8 | 2014-10-21 14:09:19 -0400 | [diff] [blame] | 11 | |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 12 | nanos() { |
| 13 | # Cannot use date(1) because macOS does not support %N format specifier |
Davide Pesavento | d776a93 | 2020-03-20 18:42:36 -0400 | [diff] [blame] | 14 | python3 -c 'import time; print(int(time.time() * 1e9))' |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 15 | } |
Alexander Afanasyev | a87e0a8 | 2014-10-21 14:09:19 -0400 | [diff] [blame] | 16 | |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 17 | for file in .jenkins.d/*; do |
Alexander Afanasyev | e749003 | 2014-12-11 12:40:53 -0800 | [diff] [blame] | 18 | [[ -f $file && -x $file ]] || continue |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 19 | |
Davide Pesavento | 30ed628 | 2021-07-25 20:05:06 -0400 | [diff] [blame] | 20 | label=$(basename "$file" | sed -E 's/[[:digit:]]+-(.*)\..*/\1/') |
| 21 | if [[ -n $GITHUB_ACTIONS ]]; then |
| 22 | echo "::group::${label}" |
| 23 | elif [[ -n $TRAVIS ]]; then |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 24 | echo -ne "travis_fold:start:${label}\r" |
| 25 | echo -ne "travis_time:start:${label}\r" |
| 26 | start=$(nanos) |
| 27 | fi |
| 28 | |
| 29 | echo "\$ $file" |
Alexander Afanasyev | e749003 | 2014-12-11 12:40:53 -0800 | [diff] [blame] | 30 | "$file" |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 31 | |
Davide Pesavento | 30ed628 | 2021-07-25 20:05:06 -0400 | [diff] [blame] | 32 | if [[ -n $GITHUB_ACTIONS ]]; then |
| 33 | echo "::endgroup::" |
| 34 | elif [[ -n $TRAVIS ]]; then |
Davide Pesavento | e6e125e | 2019-10-08 18:08:36 -0400 | [diff] [blame] | 35 | finish=$(nanos) |
| 36 | echo -ne "travis_time:end:${label}:start=${start},finish=${finish},duration=$((finish-start)),event=${label}\r" |
| 37 | echo -ne "travis_fold:end:${label}\r" |
| 38 | fi |
Alexander Afanasyev | a87e0a8 | 2014-10-21 14:09:19 -0400 | [diff] [blame] | 39 | done |