2018-12-24 14:12:59 +01:00
|
|
|
#!/bin/bash
|
2019-01-24 11:11:08 +01:00
|
|
|
# run-shellcheck
|
2018-12-24 14:12:59 +01:00
|
|
|
# usage : $0 [--nodel|--nowait] [1.1_script-to-test.sh...]
|
|
|
|
# --nodel will keep logs
|
|
|
|
# --nowait will not wait for you to see logs
|
|
|
|
# if all test docker passed return 0, otherwise 1 meaning some tests failed
|
|
|
|
|
|
|
|
tmpdir=$(mktemp -d -t debcistest.XXXXXX)
|
|
|
|
failedtarget=""
|
|
|
|
|
|
|
|
cleanup() {
|
|
|
|
if [ "$nodel" -eq 0 ]; then
|
|
|
|
rm -rf "$tmpdir"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# `exit 255` for runtime error
|
|
|
|
trap "cleanup; exit 255" EXIT HUP INT
|
|
|
|
|
|
|
|
if [ ! -t 0 ]; then
|
|
|
|
echo -e "\e[34mNo stdin \e[0m"
|
|
|
|
nodel=1
|
|
|
|
nowait=1
|
|
|
|
fi
|
|
|
|
|
|
|
|
nodel=0
|
|
|
|
nowait=0
|
|
|
|
OPTIONS=$(getopt --long nodel,nowait -- "$0" "$@")
|
|
|
|
eval set -- "$OPTIONS"
|
|
|
|
# Treating options
|
|
|
|
while true; do
|
|
|
|
case "$1" in
|
2020-12-04 14:08:01 +01:00
|
|
|
--nodel)
|
|
|
|
nodel=1
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--nowait)
|
|
|
|
nowait=1
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--)
|
|
|
|
shift
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
*) break ;;
|
2018-12-24 14:12:59 +01:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
# Execution summary
|
|
|
|
if [ "$nodel" -eq 1 ]; then
|
2020-12-04 14:08:01 +01:00
|
|
|
echo -e "\e[34mLog directory: $tmpdir \e[0m"
|
2018-12-24 14:12:59 +01:00
|
|
|
fi
|
|
|
|
if [ "$nowait" -eq 1 ]; then
|
2020-12-04 14:08:01 +01:00
|
|
|
echo -e "\e[34mRunning in non-interactive mode\e[0m"
|
2018-12-24 14:12:59 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Actual execution
|
|
|
|
# Loops over found targets and runs docker_build_and_run_tests
|
|
|
|
for target in $("$(dirname "$0")"/docker_build_and_run_tests.sh 2>&1 | grep "Supported" | cut -d ':' -f 2); do
|
|
|
|
echo "Running $target $*"
|
2020-12-04 14:08:01 +01:00
|
|
|
"$(dirname "$0")"/docker_build_and_run_tests.sh "$target" "$@" 2>&1 |
|
|
|
|
tee "${tmpdir}"/"${target}" |
|
2018-12-24 14:12:59 +01:00
|
|
|
grep -q "All tests succeeded"
|
|
|
|
ret=$?
|
|
|
|
if [[ 0 -eq $ret ]]; then
|
|
|
|
echo -e "\e[92mOK\e[0m $target"
|
|
|
|
else
|
|
|
|
echo -e "\e[91mKO\e[0m $target"
|
|
|
|
failedtarget="$failedtarget ${tmpdir}/${target}"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2020-12-04 15:14:18 +01:00
|
|
|
if [[ -n "$failedtarget" && "$nowait" -eq 0 ]]; then
|
2018-12-24 14:12:59 +01:00
|
|
|
echo -e "\nPress \e[1mENTER\e[0m to display failed test logs"
|
|
|
|
echo -e "Use \e[1m:n\e[0m (next) and \e[1m:p\e[0m (previous) to navigate between log files"
|
|
|
|
echo -e "and \e[1mq\e[0m to quit"
|
|
|
|
# shellcheck disable=2015,2162,2034
|
|
|
|
test -t 0 && read _wait || true
|
|
|
|
# disable shellcheck to allow expansion of logfiles list
|
|
|
|
# shellcheck disable=2086
|
|
|
|
less -R $failedtarget
|
|
|
|
fi
|
|
|
|
|
|
|
|
trap - EXIT HUP INT
|
|
|
|
cleanup
|
|
|
|
|
|
|
|
exit ${failedtarget:+1}
|