mirror of
https://github.com/systemd/systemd.git
synced 2025-01-10 05:18:17 +03:00
aa7507ea4a
Then, we can easily test specific unit tests in qemu or container.
119 lines
3.1 KiB
Bash
Executable File
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
|