zephyr/tests/bsim/run_parallel.sh
Alberto Escolar Piedras f8d747f85c bsim tests: run_parallel: Allow providing tests explicitly
Add the options to provide a file with a list of tests
to run with a possible TESTS_FILE variable,
or to provide the actual list of tests directly
in TESTS_LIST.

If a file is provided, comments (#) and empty lines will be
skipped.

Signed-off-by: Alberto Escolar Piedras <alberto.escolar.piedras@nordicsemi.no>
2023-04-05 16:46:11 +02:00

108 lines
2.9 KiB
Bash
Executable file

#!/usr/bin/env bash
# Copyright 2018 Oticon A/S
# SPDX-License-Identifier: Apache-2.0
# Syntax run_parallel.sh [-h] [options]
start=$SECONDS
function display_help(){
echo "run_parallel.sh [-help] [options]"
echo " Execute all cases which do not start with an _ (underscore)"
echo " [options] will be passed directly to the scripts"
echo " The results will be saved to \${RESULTS_FILE}, by default"
echo " ../RunResults.xml"
echo " Testcases are searched for in \${SEARCH_PATH}, by default this folder"
echo " You can instead also provide a space separated test list with \${TESTS_LIST}, "
echo " or an input file including a list of tests \${TESTS_FILE} (w one line"
echo " per test, you can comment lines with #)"
}
# Parse command line
if [ $# -ge 1 ]; then
if grep -Eiq "(\?|-\?|-h|help|-help|--help)" <<< $1 ; then
display_help
exit 0
fi
fi
err=0
i=0
if [ -n "${TESTS_FILE}" ]; then
#remove comments and empty lines from file
all_cases=$(sed 's/#.*$//;/^$/d' "${TESTS_FILE}")
elif [ -n "${TESTS_LIST}" ]; then
all_cases=${TESTS_LIST}
else
SEARCH_PATH="${SEARCH_PATH:-.}"
all_cases=`find ${SEARCH_PATH} -name "*.sh" | \
grep -Ev "(/_|run_parallel|compile.sh)"`
#we dont run ourselves
fi
set -u
RESULTS_FILE="${RESULTS_FILE:-`pwd`/../RunResults.xml}"
tmp_res_file=tmp.xml
all_cases_a=( $all_cases )
n_cases=$((${#all_cases_a[@]}))
touch ${RESULTS_FILE}
echo "Attempting to run ${n_cases} cases (logging to \
`realpath ${RESULTS_FILE}`)"
chmod +x $all_cases
export CLEAN_XML="sed -E -e 's/&/\&amp;/g' -e 's/</\&lt;/g' -e 's/>/\&gt;/g' \
-e 's/\"/&quot;/g'"
echo -n "" > $tmp_res_file
if [ `command -v parallel` ]; then
parallel '
echo "<testcase name=\"{}\" time=\"0\">"
{} $@ &> {#}.log
if [ $? -ne 0 ]; then
(>&2 echo -e "\e[91m{} FAILED\e[39m")
(>&2 cat {#}.log)
echo "<failure message=\"failed\" type=\"failure\">"
cat {#}.log | eval $CLEAN_XML
echo "</failure>"
rm {#}.log
echo "</testcase>"
exit 1
else
(>&2 echo -e "{} PASSED")
rm {#}.log
echo "</testcase>"
fi
' ::: $all_cases >> $tmp_res_file ; err=$?
else #fallback in case parallel is not installed
for case in $all_cases; do
echo "<testcase name=\"$case\" time=\"0\">" >> $tmp_res_file
$case $@ &> $i.log
if [ $? -ne 0 ]; then
echo -e "\e[91m$case FAILED\e[39m"
cat $i.log
echo "<failure message=\"failed\" type=\"failure\">" >> $tmp_res_file
cat $i.log | eval $CLEAN_XML >> $tmp_res_file
echo "</failure>" >> $tmp_res_file
let "err++"
else
echo -e "$case PASSED"
fi
echo "</testcase>" >> $tmp_res_file
rm $i.log
let i=i+1
done
fi
echo -e "</testsuite>\n</testsuites>\n" >> $tmp_res_file
dur=$(($SECONDS - $start))
echo -e "<testsuites>\n<testsuite errors=\"0\" failures=\"$err\"\
name=\"bsim tests\" skip=\"0\" tests=\"$n_cases\" time=\"$dur\">" \
| cat - $tmp_res_file > $RESULTS_FILE
rm $tmp_res_file
exit $err