2019-02-18 22:41:45 +01:00
|
|
|
#!/usr/bin/env bash
|
2016-11-30 06:21:53 +01:00
|
|
|
|
2019-02-18 22:41:45 +01:00
|
|
|
set -o pipefail -eux
|
2016-11-30 06:21:53 +01:00
|
|
|
|
|
|
|
declare -a args
|
2017-10-03 21:43:46 +02:00
|
|
|
IFS='/:' read -ra args <<< "$1"
|
2016-11-30 06:21:53 +01:00
|
|
|
|
|
|
|
script="${args[0]}"
|
|
|
|
|
2017-10-03 21:43:46 +02:00
|
|
|
test="$1"
|
|
|
|
|
2016-11-30 06:21:53 +01:00
|
|
|
docker images ansible/ansible
|
2018-08-30 01:05:16 +02:00
|
|
|
docker images quay.io/ansible/*
|
2016-11-30 06:21:53 +01:00
|
|
|
docker ps
|
|
|
|
|
2020-12-02 21:05:30 +01:00
|
|
|
for container in $(docker ps --format '{{.Image}} {{.ID}}' | grep -v -e '^drydock/' -e '^quay.io/ansible/shippable-build-container:' -e '^quay.io/ansible/azure-pipelines-test-container:' | sed 's/^.* //'); do
|
2019-02-21 22:59:56 +01:00
|
|
|
docker rm -f "${container}" || true # ignore errors
|
2018-07-10 06:06:13 +02:00
|
|
|
done
|
|
|
|
|
|
|
|
docker ps
|
|
|
|
|
2016-11-30 06:21:53 +01:00
|
|
|
if [ -d /home/shippable/cache/ ]; then
|
|
|
|
ls -la /home/shippable/cache/
|
|
|
|
fi
|
|
|
|
|
2018-09-21 20:38:22 +02:00
|
|
|
command -v python
|
2016-11-30 06:21:53 +01:00
|
|
|
python -V
|
|
|
|
|
2018-09-21 20:38:22 +02:00
|
|
|
command -v pip
|
2016-11-30 06:21:53 +01:00
|
|
|
pip --version
|
|
|
|
pip list --disable-pip-version-check
|
|
|
|
|
2019-08-05 23:56:38 +02:00
|
|
|
export PATH="${PWD}/bin:${PATH}"
|
2017-04-09 07:34:29 +02:00
|
|
|
export PYTHONIOENCODING='utf-8'
|
2017-05-13 19:08:42 +02:00
|
|
|
|
2017-05-17 07:49:04 +02:00
|
|
|
if [ "${JOB_TRIGGERED_BY_NAME:-}" == "nightly-trigger" ]; then
|
|
|
|
COVERAGE=yes
|
|
|
|
COMPLETE=yes
|
|
|
|
fi
|
|
|
|
|
2017-05-14 09:04:52 +02:00
|
|
|
if [ -n "${COVERAGE:-}" ]; then
|
|
|
|
# on-demand coverage reporting triggered by setting the COVERAGE environment variable to a non-empty value
|
2017-05-13 19:08:42 +02:00
|
|
|
export COVERAGE="--coverage"
|
2017-05-14 09:04:52 +02:00
|
|
|
elif [[ "${COMMIT_MESSAGE}" =~ ci_coverage ]]; then
|
|
|
|
# on-demand coverage reporting triggered by having 'ci_coverage' in the latest commit message
|
|
|
|
export COVERAGE="--coverage"
|
|
|
|
else
|
|
|
|
# on-demand coverage reporting disabled (default behavior, always-on coverage reporting remains enabled)
|
2019-03-11 23:13:09 +01:00
|
|
|
export COVERAGE="--coverage-check"
|
2017-05-14 09:04:52 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -n "${COMPLETE:-}" ]; then
|
|
|
|
# disable change detection triggered by setting the COMPLETE environment variable to a non-empty value
|
|
|
|
export CHANGED=""
|
|
|
|
elif [[ "${COMMIT_MESSAGE}" =~ ci_complete ]]; then
|
|
|
|
# disable change detection triggered by having 'ci_complete' in the latest commit message
|
|
|
|
export CHANGED=""
|
|
|
|
else
|
|
|
|
# enable change detection (default behavior)
|
|
|
|
export CHANGED="--changed"
|
2017-05-13 19:08:42 +02:00
|
|
|
fi
|
2016-11-30 06:21:53 +01:00
|
|
|
|
2018-04-13 01:15:28 +02:00
|
|
|
if [ "${IS_PULL_REQUEST:-}" == "true" ]; then
|
|
|
|
# run unstable tests which are targeted by focused changes on PRs
|
|
|
|
export UNSTABLE="--allow-unstable-changed"
|
|
|
|
else
|
|
|
|
# do not run unstable tests outside PRs
|
|
|
|
export UNSTABLE=""
|
|
|
|
fi
|
|
|
|
|
2016-12-12 21:02:25 +01:00
|
|
|
# remove empty core/extras module directories from PRs created prior to the repo-merge
|
|
|
|
find lib/ansible/modules -type d -empty -print -delete
|
|
|
|
|
2016-11-30 06:21:53 +01:00
|
|
|
function cleanup
|
|
|
|
{
|
2020-01-28 01:19:49 +01:00
|
|
|
# for complete on-demand coverage generate a report for all files with no coverage on the "sanity/5" job so we only have one copy
|
|
|
|
if [ "${COVERAGE}" == "--coverage" ] && [ "${CHANGED}" == "" ] && [ "${test}" == "sanity/5" ]; then
|
|
|
|
stub="--stub"
|
|
|
|
# trigger coverage reporting for stubs even if no other coverage data exists
|
|
|
|
mkdir -p test/results/coverage/
|
|
|
|
else
|
|
|
|
stub=""
|
|
|
|
fi
|
|
|
|
|
2019-08-28 08:40:06 +02:00
|
|
|
if [ -d test/results/coverage/ ]; then
|
|
|
|
if find test/results/coverage/ -mindepth 1 -name '.*' -prune -o -print -quit | grep -q .; then
|
2020-01-28 01:19:49 +01:00
|
|
|
process_coverage='yes' # process existing coverage files
|
|
|
|
elif [ "${stub}" ]; then
|
|
|
|
process_coverage='yes' # process coverage when stubs are enabled
|
|
|
|
else
|
|
|
|
process_coverage=''
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "${process_coverage}" ]; then
|
2019-08-28 08:40:06 +02:00
|
|
|
# use python 3.7 for coverage to avoid running out of memory during coverage xml processing
|
|
|
|
# only use it for coverage to avoid the additional overhead of setting up a virtual environment for a potential no-op job
|
|
|
|
virtualenv --python /usr/bin/python3.7 ~/ansible-venv
|
|
|
|
set +ux
|
|
|
|
. ~/ansible-venv/bin/activate
|
|
|
|
set -ux
|
|
|
|
|
|
|
|
# shellcheck disable=SC2086
|
|
|
|
ansible-test coverage xml --color -v --requirements --group-by command --group-by version ${stub:+"$stub"}
|
|
|
|
cp -a test/results/reports/coverage=*.xml shippable/codecoverage/
|
|
|
|
|
2020-02-06 07:16:15 +01:00
|
|
|
# analyze and capture code coverage aggregated by integration test target
|
|
|
|
ansible-test coverage analyze targets generate -v shippable/testresults/coverage-analyze-targets.json
|
|
|
|
|
2019-08-28 08:40:06 +02:00
|
|
|
# upload coverage report to codecov.io only when using complete on-demand coverage
|
|
|
|
if [ "${COVERAGE}" == "--coverage" ] && [ "${CHANGED}" == "" ]; then
|
|
|
|
for file in test/results/reports/coverage=*.xml; do
|
|
|
|
flags="${file##*/coverage=}"
|
|
|
|
flags="${flags%-powershell.xml}"
|
|
|
|
flags="${flags%.xml}"
|
|
|
|
# remove numbered component from stub files when converting to tags
|
|
|
|
flags="${flags//stub-[0-9]*/stub}"
|
|
|
|
flags="${flags//=/,}"
|
|
|
|
flags="${flags//[^a-zA-Z0-9_,]/_}"
|
|
|
|
|
|
|
|
bash <(curl -s https://codecov.io/bash) \
|
|
|
|
-f "${file}" \
|
|
|
|
-F "${flags}" \
|
|
|
|
-n "${test}" \
|
|
|
|
-t 83cd8957-dc76-488c-9ada-210dcea51633 \
|
|
|
|
-X coveragepy \
|
|
|
|
-X gcov \
|
|
|
|
-X fix \
|
|
|
|
-X search \
|
|
|
|
-X xcode \
|
|
|
|
|| echo "Failed to upload code coverage report to codecov.io: ${file}"
|
|
|
|
done
|
|
|
|
fi
|
2017-05-15 18:51:49 +02:00
|
|
|
fi
|
2019-08-28 08:40:06 +02:00
|
|
|
fi
|
2017-05-15 18:51:49 +02:00
|
|
|
|
2019-08-28 18:58:00 +02:00
|
|
|
if [ -d test/results/junit/ ]; then
|
|
|
|
cp -aT test/results/junit/ shippable/testresults/
|
2016-11-30 06:21:53 +01:00
|
|
|
fi
|
|
|
|
|
2019-08-28 08:40:06 +02:00
|
|
|
if [ -d test/results/data/ ]; then
|
|
|
|
cp -a test/results/data/ shippable/testresults/
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -d test/results/bot/ ]; then
|
|
|
|
cp -aT test/results/bot/ shippable/testresults/
|
|
|
|
fi
|
2016-11-30 06:21:53 +01:00
|
|
|
}
|
|
|
|
|
2020-12-02 21:05:30 +01:00
|
|
|
if [ "${SHIPPABLE_BUILD_ID:-}" ]; then trap cleanup EXIT; fi
|
2016-11-30 06:21:53 +01:00
|
|
|
|
2019-03-11 23:13:09 +01:00
|
|
|
if [[ "${COVERAGE:-}" == "--coverage" ]]; then
|
2019-03-05 20:58:13 +01:00
|
|
|
timeout=60
|
|
|
|
else
|
2019-11-01 16:59:29 +01:00
|
|
|
timeout=50
|
2019-03-05 20:58:13 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
ansible-test env --dump --show --timeout "${timeout}" --color -v
|
2018-12-21 07:08:57 +01:00
|
|
|
|
2020-12-02 21:05:30 +01:00
|
|
|
if [ "${SHIPPABLE_BUILD_ID:-}" ]; then "test/utils/shippable/check_matrix.py"; fi
|
2017-10-03 21:43:46 +02:00
|
|
|
"test/utils/shippable/${script}.sh" "${test}"
|