mirror of
https://github.com/systemd/systemd.git
synced 2025-01-05 13:18:06 +03:00
111 lines
4.2 KiB
Bash
Executable File
111 lines
4.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# SPDX-License-Identifier: LGPL-2.1-or-later
|
|
set -e
|
|
|
|
TEST_DESCRIPTION="Test various scenarios involving transition from/to initrd"
|
|
# Note: for debugging systemd.journald.max_level_console=debug might come in handy
|
|
# as well, but it's not used here since it's _very_ noisy and slows the test
|
|
# down a lot
|
|
KERNEL_APPEND="${KERNEL_APPEND:-} systemd.journald.forward_to_console=1"
|
|
TEST_NO_NSPAWN=1
|
|
|
|
# shellcheck source=test/test-functions
|
|
. "${TEST_BASE_DIR:?}/test-functions"
|
|
|
|
test_append_files() {
|
|
local workspace="${1:?}"
|
|
local exitrd file dir
|
|
|
|
# Create an exitrd
|
|
#
|
|
# This should provide coverage for exitrd related issues, see:
|
|
# - https://github.com/systemd/systemd/issues/28645
|
|
# - https://github.com/systemd/systemd/pull/28648
|
|
# - https://github.com/systemd/systemd/pull/28793
|
|
#
|
|
# This is a bit messier than I originally anticipated, as installing our own libraries
|
|
# is handled implicitly by install_systemd() which I don't want to use here, since
|
|
# I need only the systemd-shutdown binary
|
|
exitrd="$workspace/exitrd"
|
|
mkdir -p "$exitrd/etc" "$exitrd/usr"
|
|
initdir="$exitrd" image_install bash /usr/lib/os-release
|
|
ln -srf "$exitrd/usr/lib/os-release" "$exitrd/etc/initrd-release"
|
|
initdir="$exitrd" inst_binary "$workspace/usr/lib/systemd/systemd-shutdown" "/usr/lib/systemd/systemd-shutdown"
|
|
initdir="$exitrd" inst_libs "$exitrd/usr/lib/systemd/systemd-shutdown"
|
|
# We need to deal with libsystemd stuff explicitly, as we don't call install_systemd() here
|
|
while read -r file; do
|
|
initdir="$exitrd" inst_library "$file" "${file##"$workspace"}"
|
|
initdir="$exitrd" inst_libs "$file"
|
|
done < <(find "$workspace/usr/" -name "libsystemd*.so*")
|
|
# Call systemd-shutdown indirectly, so we can show a message that we can check for
|
|
# later to make sure the exitrd was actually executed
|
|
cat >"$exitrd/shutdown" <<\EOF
|
|
#!/usr/bin/bash -eu
|
|
echo "Hello from exitrd"
|
|
exec /usr/lib/systemd/systemd-shutdown "$@"
|
|
EOF
|
|
chmod +x "$exitrd/shutdown"
|
|
}
|
|
|
|
check_result_qemu_hook() {
|
|
local workspace="${1:?}"
|
|
local console_log="${TESTDIR:?}/console.log"
|
|
|
|
if [[ -e "$workspace/skipped" ]]; then
|
|
return 0
|
|
fi
|
|
|
|
if [[ ! -e "$console_log" ]]; then
|
|
dfatal "Missing console log - this shouldn't happen"
|
|
return 1
|
|
fi
|
|
|
|
# The console log should not contain messages like:
|
|
# [ 6.245000] systemd-shutdown[1]: Failed to move /run/initramfs to /: Invalid argument
|
|
# [ 6.245955] systemd-shutdown[1]: Failed to switch root to "/run/initramfs": Invalid argument
|
|
if grep -qE "systemd-shutdown.+: Failed to move /run/initramfs" "$console_log" ||
|
|
grep -qE "systemd-shutdown.+: Failed to switch root" "$console_log"; then
|
|
derror "sd-shutdown failed to switch root in exitrd"
|
|
return 1
|
|
fi
|
|
|
|
# Check if the exitrd was executed at all
|
|
if ! grep -q "Hello from exitrd" "$console_log"; then
|
|
derror "Missing 'hello' message from exitrd"
|
|
return 1
|
|
fi
|
|
|
|
return 0
|
|
}
|
|
|
|
# Setup a one shot service in initrd that creates a dummy bind mount under /run
|
|
# to check if the mount persists though the initrd transition. The "check" part
|
|
# is in the respective TEST-08-INITRD.sh script.
|
|
#
|
|
# See: https://github.com/systemd/systemd/issues/28452
|
|
run_qemu_hook() {
|
|
local extra="${TESTDIR:?}/initrd.extra"
|
|
|
|
mkdir -m 755 "$extra"
|
|
mkdir -m 755 "$extra/etc" "$extra/etc/systemd" "$extra/etc/systemd/system" "$extra/etc/systemd/system/initrd.target.wants"
|
|
|
|
cat >"$extra/etc/systemd/system/initrd-run-mount.service" <<EOF
|
|
[Unit]
|
|
Description=Create a mount in /run that should survive the transition from initrd
|
|
|
|
[Service]
|
|
Type=oneshot
|
|
RemainAfterExit=yes
|
|
ExecStart=mkdir /run/initrd-mount-source /run/initrd-mount-target
|
|
ExecStart=mount -v --bind /run/initrd-mount-source /run/initrd-mount-target
|
|
ExecStart=cp -v /etc/initrd-release /run/initrd-mount-target/hello-world
|
|
EOF
|
|
ln -svrf "$extra/etc/systemd/system/initrd-run-mount.service" "$extra/etc/systemd/system/initrd.target.wants/initrd-run-mount.service"
|
|
|
|
(cd "$extra" && find . | cpio -o -H newc -R root:root > "$extra.cpio")
|
|
|
|
INITRD_EXTRA="$extra.cpio"
|
|
}
|
|
|
|
do_test "$@"
|