Skip to content

Commit

Permalink
test: parallelize tasks in TEST-24-UNIT-TESTS
Browse files Browse the repository at this point in the history
  • Loading branch information
mrc0mmand committed Mar 6, 2019
1 parent 965bfcd commit 2f2a045
Show file tree
Hide file tree
Showing 2 changed files with 77 additions and 22 deletions.
2 changes: 2 additions & 0 deletions test/TEST-24-UNIT-TESTS/test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,8 @@ test_setup() {
setup_basic_environment
install_keymaps yes
install_zoneinfo
# Install nproc to determine # of CPUs for correct parallelization
inst_binary nproc

# setup the testsuite service
cat >$initdir/etc/systemd/system/testsuite.service <<EOF
Expand Down
97 changes: 75 additions & 22 deletions test/TEST-24-UNIT-TESTS/testsuite.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,31 +4,84 @@
#set -ex
#set -o pipefail

for i in /usr/lib/systemd/tests/test-*; do
if [[ ! -x $i ]]; then continue; fi
NAME=${i##*/}
echo "Running $NAME"
$i > /$NAME.log 2>&1
ret=$?
if (( $ret && $ret != 77 )); then
echo "$NAME failed with $ret"
echo $NAME >> /failed-tests
echo "--- $NAME begin ---" >> /failed
cat /$NAME.log >> /failed
echo "--- $NAME end ---" >> /failed
elif (( $ret == 77 )); then
echo "$NAME skipped"
echo $NAME >> /skipped-tests
echo "--- $NAME begin ---" >> /skipped
cat /$NAME.log >> /skipped
echo "--- $NAME end ---" >> /skipped
NPROC=$(nproc)
MAX_QUEUE_SIZE=${NPROC:-2}
IFS=$'\n' TEST_LIST=($(ls /usr/lib/systemd/tests/test-*))

# Check & report test results
# Arguments:
# $1: test path
# $2: test exit code
function report_result() {
if [[ $# -ne 2 ]]; then
echo >&2 "check_result: missing arguments"
exit 1
fi

local name="${1##*/}"
local ret=$2

if [[ $ret -ne 0 && $ret != 77 ]]; then
echo "$name failed with $ret"
echo "$name" >> /failed-tests
{
echo "--- $name begin ---"
cat "/$name.log"
echo "--- $name end ---"
} >> /failed
elif [[ $ret == 77 ]]; then
echo "$name skipped"
echo "$name" >> /skipped-tests
{
echo "--- $name begin ---"
cat "/$name.log"
echo "--- $name end ---"
} >> /skipped
else
echo "$NAME OK"
echo $NAME >> /testok
echo "$name OK"
echo "$name" >> /testok
fi

systemd-cat echo "--- $name ---"
systemd-cat cat "/$name.log"
}

# Associative array for running tasks, where running[test-path]=PID
declare -A running=()
for task in "${TEST_LIST[@]}"; do
# If there's MAX_QUEUE_SIZE running tasks, keep checking the running queue
# until one of the tasks finishes, so we can replace it.
while [[ ${#running[@]} -ge $MAX_QUEUE_SIZE ]]; do
for key in "${!running[@]}"; do
if ! kill -0 ${running[$key]} &>/dev/null; then
# Task has finished, report its result and drop it from the queue
wait ${running[$key]}
ec=$?
report_result "$key" $ec
unset running["$key"]
# Break from inner for loop and outer while loop to skip
# the sleep below when we find a free slot in the queue
break 2
fi
done

# Precisely* calculated constant to keep the spinlock from burning the CPU(s)
sleep 0.01
done

if [[ -x $task ]]; then
log_file="/${task##*/}.log"
$task &> "$log_file" &
running[$task]=$!
fi
done

systemd-cat echo "--- $NAME ---"
systemd-cat cat /$NAME.log
# Wait for remaining running tasks
for key in "${!running[@]}"; do
wait ${running[$key]}
ec=$?
report_result "$key" $ec
unset running["$key"]
done

exit 0

0 comments on commit 2f2a045

Please sign in to comment.