2020-03-04 09:35:06 +00:00
#!/usr/bin/env bash
2021-10-17 18:13:06 +02:00
# SPDX-License-Identifier: LGPL-2.1-or-later
2021-04-09 19:39:41 +02:00
set -eux
2019-08-10 16:03:07 +02:00
set -o pipefail
2023-05-08 22:38:34 +02:00
# Test ExecReload= (PR #13098)
2019-08-10 16:03:07 +02:00
systemd-analyze log-level debug
export SYSTEMD_PAGER =
SERVICE_PATH = " $( mktemp /etc/systemd/system/execreloadXXX.service) "
SERVICE_NAME = " ${ SERVICE_PATH ##*/ } "
echo "[#1] Failing ExecReload= should not kill the service"
2021-04-08 00:09:55 +02:00
cat >" $SERVICE_PATH " <<EOF
2019-08-10 16:03:07 +02:00
[ Service]
ExecStart = /bin/sleep infinity
ExecReload = /bin/false
EOF
systemctl daemon-reload
2021-04-09 19:49:32 +02:00
systemctl start " $SERVICE_NAME "
systemctl status " $SERVICE_NAME "
2019-08-10 16:03:07 +02:00
# The reload SHOULD fail but SHOULD NOT affect the service state
2023-04-05 15:50:42 +02:00
( ! systemctl reload " $SERVICE_NAME " )
2021-04-09 19:49:32 +02:00
systemctl status " $SERVICE_NAME "
systemctl stop " $SERVICE_NAME "
2019-08-10 16:03:07 +02:00
echo "[#2] Failing ExecReload= should not kill the service (multiple ExecReload=)"
2021-04-08 00:09:55 +02:00
cat >" $SERVICE_PATH " <<EOF
2019-08-10 16:03:07 +02:00
[ Service]
ExecStart = /bin/sleep infinity
ExecReload = /bin/true
ExecReload = /bin/false
ExecReload = /bin/true
EOF
systemctl daemon-reload
2021-04-09 19:49:32 +02:00
systemctl start " $SERVICE_NAME "
systemctl status " $SERVICE_NAME "
2019-08-10 16:03:07 +02:00
# The reload SHOULD fail but SHOULD NOT affect the service state
2023-04-05 15:50:42 +02:00
( ! systemctl reload " $SERVICE_NAME " )
2021-04-09 19:49:32 +02:00
systemctl status " $SERVICE_NAME "
systemctl stop " $SERVICE_NAME "
2019-08-10 16:03:07 +02:00
echo "[#3] Failing ExecReload=- should not affect reload's exit code"
2021-04-08 00:09:55 +02:00
cat >" $SERVICE_PATH " <<EOF
2019-08-10 16:03:07 +02:00
[ Service]
ExecStart = /bin/sleep infinity
ExecReload = -/bin/false
EOF
systemctl daemon-reload
2021-04-09 19:49:32 +02:00
systemctl start " $SERVICE_NAME "
systemctl status " $SERVICE_NAME "
systemctl reload " $SERVICE_NAME "
systemctl status " $SERVICE_NAME "
systemctl stop " $SERVICE_NAME "
2019-08-10 16:03:07 +02:00
systemd-analyze log-level info