mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-03 01:17:45 +03:00
Merge pull request #2579 from evverx/TEST-1981
tests: add test for https://github.com/systemd/systemd/issues/1981
This commit is contained in:
commit
71ab0faceb
@ -5769,6 +5769,14 @@ EXTRA_DIST += \
|
|||||||
test/TEST-05-RLIMITS/Makefile \
|
test/TEST-05-RLIMITS/Makefile \
|
||||||
test/TEST-05-RLIMITS/test-rlimits.sh \
|
test/TEST-05-RLIMITS/test-rlimits.sh \
|
||||||
test/TEST-05-RLIMITS/test.sh \
|
test/TEST-05-RLIMITS/test.sh \
|
||||||
|
test/TEST-06-SELINUX/Makefile \
|
||||||
|
test/TEST-06-SELINUX/test-selinux-checks.sh \
|
||||||
|
test/TEST-06-SELINUX/test.sh \
|
||||||
|
test/TEST-06-SELINUX/systemd_test.te \
|
||||||
|
test/TEST-06-SELINUX/systemd_test.if \
|
||||||
|
test/TEST-07-ISSUE-1981/Makefile \
|
||||||
|
test/TEST-07-ISSUE-1981/test-segfault.sh \
|
||||||
|
test/TEST-07-ISSUE-1981/test.sh \
|
||||||
test/test-functions
|
test/test-functions
|
||||||
|
|
||||||
EXTRA_DIST += \
|
EXTRA_DIST += \
|
||||||
|
1
test/TEST-07-ISSUE-1981/Makefile
Symbolic link
1
test/TEST-07-ISSUE-1981/Makefile
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../TEST-01-BASIC/Makefile
|
36
test/TEST-07-ISSUE-1981/test-segfault.sh
Executable file
36
test/TEST-07-ISSUE-1981/test-segfault.sh
Executable file
@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -x
|
||||||
|
set -e
|
||||||
|
|
||||||
|
>/failed
|
||||||
|
|
||||||
|
cat <<'EOL' >/lib/systemd/system/my.service
|
||||||
|
[Service]
|
||||||
|
Type=oneshot
|
||||||
|
ExecStart=/bin/echo Timer runs me
|
||||||
|
EOL
|
||||||
|
|
||||||
|
cat <<'EOL' >/lib/systemd/system/my.timer
|
||||||
|
[Timer]
|
||||||
|
OnBootSec=10s
|
||||||
|
OnUnitInactiveSec=1h
|
||||||
|
EOL
|
||||||
|
|
||||||
|
systemctl unmask my.timer
|
||||||
|
|
||||||
|
systemctl start my.timer
|
||||||
|
|
||||||
|
mkdir -p /etc/systemd/system/my.timer.d/
|
||||||
|
cat <<'EOL' >/etc/systemd/system/my.timer.d/override.conf
|
||||||
|
[Timer]
|
||||||
|
OnBootSec=10s
|
||||||
|
OnUnitInactiveSec=1h
|
||||||
|
EOL
|
||||||
|
|
||||||
|
systemctl daemon-reload
|
||||||
|
|
||||||
|
systemctl mask my.timer
|
||||||
|
|
||||||
|
touch /testok
|
||||||
|
rm /failed
|
58
test/TEST-07-ISSUE-1981/test.sh
Executable file
58
test/TEST-07-ISSUE-1981/test.sh
Executable file
@ -0,0 +1,58 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
|
||||||
|
# ex: ts=8 sw=4 sts=4 et filetype=sh
|
||||||
|
TEST_DESCRIPTION="https://github.com/systemd/systemd/issues/1981"
|
||||||
|
|
||||||
|
. $TEST_BASE_DIR/test-functions
|
||||||
|
|
||||||
|
test_run() {
|
||||||
|
dwarn "skipping QEMU"
|
||||||
|
if check_nspawn; then
|
||||||
|
timeout --foreground 30s systemd-nspawn --kill-signal=SIGKILL --boot --directory=$TESTDIR/nspawn-root $ROOTLIBDIR/systemd $KERNEL_APPEND
|
||||||
|
check_result_nspawn || return 1
|
||||||
|
else
|
||||||
|
dwarn "can't run systemd-nspawn, skipping"
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
test_setup() {
|
||||||
|
create_empty_image
|
||||||
|
mkdir -p $TESTDIR/root
|
||||||
|
mount ${LOOPDEV}p1 $TESTDIR/root
|
||||||
|
|
||||||
|
# Create what will eventually be our root filesystem onto an overlay
|
||||||
|
(
|
||||||
|
LOG_LEVEL=5
|
||||||
|
eval $(udevadm info --export --query=env --name=${LOOPDEV}p2)
|
||||||
|
|
||||||
|
setup_basic_environment
|
||||||
|
|
||||||
|
# setup the testsuite service
|
||||||
|
cat >$initdir/etc/systemd/system/testsuite.service <<EOF
|
||||||
|
[Unit]
|
||||||
|
Description=Testsuite service
|
||||||
|
After=multi-user.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
ExecStart=/test-segfault.sh
|
||||||
|
Type=oneshot
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cp test-segfault.sh $initdir/
|
||||||
|
|
||||||
|
setup_testsuite
|
||||||
|
) || return 1
|
||||||
|
setup_nspawn_root
|
||||||
|
|
||||||
|
ddebug "umount $TESTDIR/root"
|
||||||
|
umount $TESTDIR/root
|
||||||
|
}
|
||||||
|
|
||||||
|
test_cleanup() {
|
||||||
|
umount $TESTDIR/root 2>/dev/null
|
||||||
|
[[ $LOOPDEV ]] && losetup -d $LOOPDEV
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
do_test "$@"
|
@ -13,8 +13,8 @@ if ! ROOTLIBDIR=$(pkg-config --variable=systemdutildir systemd); then
|
|||||||
ROOTLIBDIR=/usr/lib/systemd
|
ROOTLIBDIR=/usr/lib/systemd
|
||||||
fi
|
fi
|
||||||
|
|
||||||
BASICTOOLS="sh bash setsid loadkeys setfont login sulogin gzip sleep echo mount umount cryptsetup date dmsetup modprobe sed cmp tee"
|
BASICTOOLS="sh bash setsid loadkeys setfont login sulogin gzip sleep echo mount umount cryptsetup date dmsetup modprobe sed cmp tee rm"
|
||||||
DEBUGTOOLS="df free ls stty cat ps ln ip route dmesg dhclient mkdir cp ping dhclient strace less grep id tty touch du sort hostname"
|
DEBUGTOOLS="df free ls stty cat ps ln ip route dmesg dhclient mkdir cp ping dhclient strace less grep id tty touch du sort hostname find"
|
||||||
|
|
||||||
function find_qemu_bin() {
|
function find_qemu_bin() {
|
||||||
# SUSE and Red Hat call the binary qemu-kvm
|
# SUSE and Red Hat call the binary qemu-kvm
|
||||||
|
Loading…
Reference in New Issue
Block a user