1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-21 22:04:01 +03:00
systemd/test/units/TEST-02-UNITTESTS.sh
Yu Watanabe aa7507ea4a TEST-02-UNITTESTS: reuse $TEST_MATCH_SUBTEST to specify unit tests to be run
Then, we can easily test specific unit tests in qemu or container.
2024-10-22 20:14:33 +09:00

119 lines
3.1 KiB
Bash
Executable File

#!/usr/bin/env bash
# SPDX-License-Identifier: LGPL-2.1-or-later
set -eux
set -o pipefail
if ! systemd-detect-virt -qc && [[ "${TEST_CMDLINE_NEWLINE:-}" != bar ]]; then
cat /proc/cmdline
echo >&2 "Expected TEST_CMDLINE_NEWLINE=bar from the kernel command line"
exit 1
fi
if [[ -z "${TEST_MATCH_SUBTEST:-}" ]]; then
# If we're running with TEST_PREFER_NSPAWN=1 limit the set of tests we run
# in QEMU to only those that can't run in a container to avoid running
# the same tests again in a, most likely, very slow environment
if ! systemd-detect-virt -qc && [[ "${TEST_PREFER_NSPAWN:-0}" -ne 0 ]]; then
TEST_MATCH_SUBTEST="test-loop-block"
else
TEST_MATCH_SUBTEST="test-*"
fi
fi
NPROC=$(nproc)
MAX_QUEUE_SIZE=${NPROC:-2}
# Reset state
rm -fv /failed /skipped /testok
touch /lock
if ! systemd-detect-virt -qc; then
# Make sure ping works for unprivileged users (for test-bpf-firewall)
sysctl net.ipv4.ping_group_range="0 2147483647"
fi
# Check & report test results
# Arguments:
# $1: test path
# $2: test exit code
run_test() {
if [[ $# -ne 1 ]]; then
echo >&2 "run_test: missing arguments"
exit 1
fi
local test="$1"
local name="${test##*/}"
local environment=
echo "Executing test $name as unit $name.service"
case "$name" in
test-journal-flush)
environment="SYSTEMD_LOG_LEVEL=info"
;;
test-journal-verify)
environment="SYSTEMD_LOG_LEVEL=crit"
;;
esac
systemd-run \
--quiet \
--property Delegate=1 \
--property EnvironmentFile=-/usr/lib/systemd/systemd-asan-env \
--property "Environment=$environment" \
--unit="$name" \
--wait "$test" && ret=0 || ret=$?
exec {LOCK_FD}> /lock
flock --exclusive ${LOCK_FD}
if [[ $ret -eq 77 ]] || [[ $ret -eq 127 ]]; then
echo "$name skipped"
echo "$name" >>/skipped-tests
{
echo "--- $name begin ---"
journalctl --unit="$name" --no-hostname -o short-monotonic
echo "--- $name end ---"
} >>/skipped
elif [[ $ret -ne 0 ]]; then
echo "$name failed with $ret"
echo "$name" >>/failed-tests
{
echo "--- $name begin ---"
journalctl --unit="$name" --no-hostname -o short-monotonic
echo "--- $name end ---"
} >>/failed
else
echo "$name OK"
echo "$name" >>/testok
fi
exec {LOCK_FD}<&-
}
export -f run_test
find /usr/lib/systemd/tests/unit-tests/ -maxdepth 1 -type f -name "${TEST_MATCH_SUBTEST}" -print0 |
xargs -0 -I {} --max-procs="$MAX_QUEUE_SIZE" bash -ec "run_test {}"
# Write all pending messages, so they don't get mixed with the summaries below
journalctl --sync
# No need for full test logs in this case
if [[ -s /skipped-tests ]]; then
: "=== SKIPPED TESTS ==="
cat /skipped-tests
fi
if [[ -s /failed ]]; then
: "=== FAILED TESTS ==="
cat /failed
fi
# Test logs are sometimes lost, as the system shuts down immediately after
journalctl --sync
test ! -s /failed
touch /testok