mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-14 19:24:13 +03:00
c84d1c9822
Let's keep the debug logs in the journal, while logging only testsute-*.sh stdout/stderr to the console (ba7abf7). This should make the test output log a bit more readable and potentially the tests itself a bit faster by avoiding console oversaturation. Also, it should significantly reduce the size of artifacts kept by CIs.
167 lines
5.1 KiB
Bash
Executable File
167 lines
5.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# SPDX-License-Identifier: LGPL-2.1-or-later
|
|
set -eux
|
|
set -o pipefail
|
|
|
|
systemd-analyze log-level debug
|
|
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Start a test process inside of our own cgroup
|
|
sleep infinity &
|
|
INTERNALPID=$!
|
|
disown
|
|
|
|
# Start a test process outside of our own cgroup
|
|
systemd-run -p DynamicUser=1 --unit=test20-sleep.service /bin/sleep infinity
|
|
EXTERNALPID="$(systemctl show -P MainPID test20-sleep.service)"
|
|
|
|
# Update our own main PID to the external test PID, this should work
|
|
systemd-notify MAINPID="$EXTERNALPID"
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq "$EXTERNALPID"
|
|
|
|
# Update our own main PID to the internal test PID, this should work, too
|
|
systemd-notify MAINPID=$INTERNALPID
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq "$INTERNALPID"
|
|
|
|
# Update it back to our own PID, this should also work
|
|
systemd-notify MAINPID=$$
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Try to set it to PID 1, which it should ignore, because that's the manager
|
|
systemd-notify MAINPID=1
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Try to set it to PID 0, which is invalid and should be ignored
|
|
systemd-notify MAINPID=0
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Try to set it to a valid but non-existing PID, which should be ignored. (Note
|
|
# that we set the PID to a value well above any known /proc/sys/kernel/pid_max,
|
|
# which means we can be pretty sure it doesn't exist by coincidence)
|
|
systemd-notify MAINPID=1073741824
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Change it again to the external PID, without privileges this time. This should be ignored, because the PID is from outside of our cgroup and we lack privileges.
|
|
systemd-notify --uid=1000 MAINPID="$EXTERNALPID"
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
# Change it again to the internal PID, without privileges this time. This should work, as the process is on our cgroup, and that's enough even if we lack privileges.
|
|
systemd-notify --uid=1000 MAINPID="$INTERNALPID"
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq "$INTERNALPID"
|
|
|
|
# Update it back to our own PID, this should also work
|
|
systemd-notify --uid=1000 MAINPID=$$
|
|
test "$(systemctl show -P MainPID testsuite-20.service)" -eq $$
|
|
|
|
cat >/tmp/test20-mainpid.sh <<EOF
|
|
#!/usr/bin/env bash
|
|
|
|
set -eux
|
|
set -o pipefail
|
|
|
|
# Create a number of children, and make one the main one
|
|
sleep infinity &
|
|
disown
|
|
|
|
sleep infinity &
|
|
MAINPID=\$!
|
|
disown
|
|
|
|
sleep infinity &
|
|
disown
|
|
|
|
echo \$MAINPID >/run/mainpidsh/pid
|
|
EOF
|
|
chmod +x /tmp/test20-mainpid.sh
|
|
|
|
systemd-run --unit=test20-mainpidsh.service -p StandardOutput=tty -p StandardError=tty -p Type=forking -p RuntimeDirectory=mainpidsh -p PIDFile=/run/mainpidsh/pid /tmp/test20-mainpid.sh
|
|
test "$(systemctl show -P MainPID test20-mainpidsh.service)" -eq "$(cat /run/mainpidsh/pid)"
|
|
|
|
cat >/tmp/test20-mainpid2.sh <<EOF
|
|
#!/usr/bin/env bash
|
|
|
|
set -eux
|
|
set -o pipefail
|
|
|
|
# Create a number of children, and make one the main one
|
|
sleep infinity &
|
|
disown
|
|
|
|
sleep infinity &
|
|
MAINPID=\$!
|
|
disown
|
|
|
|
sleep infinity &
|
|
disown
|
|
|
|
echo \$MAINPID >/run/mainpidsh2/pid
|
|
chown 1001:1001 /run/mainpidsh2/pid
|
|
EOF
|
|
chmod +x /tmp/test20-mainpid2.sh
|
|
|
|
systemd-run --unit=test20-mainpidsh2.service -p StandardOutput=tty -p StandardError=tty -p Type=forking -p RuntimeDirectory=mainpidsh2 -p PIDFile=/run/mainpidsh2/pid /tmp/test20-mainpid2.sh
|
|
test "$(systemctl show -P MainPID test20-mainpidsh2.service)" -eq "$(cat /run/mainpidsh2/pid)"
|
|
|
|
cat >/dev/shm/test20-mainpid3.sh <<EOF
|
|
#!/usr/bin/env bash
|
|
|
|
set -eux
|
|
set -o pipefail
|
|
|
|
sleep infinity &
|
|
disown
|
|
|
|
sleep infinity &
|
|
disown
|
|
|
|
sleep infinity &
|
|
disown
|
|
|
|
# Let's try to play games, and link up a privileged PID file
|
|
ln -s ../mainpidsh/pid /run/mainpidsh3/pid
|
|
|
|
# Quick assertion that the link isn't dead
|
|
test -f /run/mainpidsh3/pid
|
|
EOF
|
|
chmod 755 /dev/shm/test20-mainpid3.sh
|
|
|
|
# This has to fail, as we shouldn't accept the dangerous PID file, and then
|
|
# inotify-wait on it to be corrected which we never do.
|
|
systemd-run --unit=test20-mainpidsh3.service \
|
|
-p StandardOutput=tty \
|
|
-p StandardError=tty \
|
|
-p Type=forking \
|
|
-p RuntimeDirectory=mainpidsh3 \
|
|
-p PIDFile=/run/mainpidsh3/pid \
|
|
-p DynamicUser=1 \
|
|
-p TimeoutStartSec=2s \
|
|
/dev/shm/test20-mainpid3.sh \
|
|
&& { echo 'unexpected success'; exit 1; }
|
|
|
|
# Test that this failed due to timeout, and not some other error
|
|
test "$(systemctl show -P Result test20-mainpidsh3.service)" = timeout
|
|
|
|
# Test that scope units work
|
|
systemd-run --scope --unit test20-true.scope /bin/true
|
|
test "$(systemctl show -P Result test20-true.scope)" = success
|
|
|
|
# Test that user scope units work as well
|
|
|
|
runas() {
|
|
declare userid=$1
|
|
shift
|
|
# shellcheck disable=SC2016
|
|
su "$userid" -s /bin/sh -c 'XDG_RUNTIME_DIR=/run/user/$UID exec "$@"' -- sh "$@"
|
|
}
|
|
|
|
systemctl start user@4711.service
|
|
runas testuser systemd-run --scope --user --unit test20-true.scope /bin/true
|
|
test "$(systemctl show -P Result test20-true.scope)" = success
|
|
|
|
systemd-analyze log-level info
|
|
|
|
echo OK >/testok
|
|
|
|
exit 0
|