2023-05-10 14:58:13 +03:00
#!/usr/bin/env bash
# SPDX-License-Identifier: LGPL-2.1-or-later
set -eux
set -o pipefail
# SocketGroup lost on daemon-reload with unit moving away temporarily
# Issue: https://github.com/systemd/systemd/issues/3171
echo "g adm - - -" | systemd-sysusers -
U = /run/systemd/system/issue-3171.socket
cat >$U <<EOF
[ Unit]
Description = Test 12 socket
[ Socket]
Accept = yes
ListenStream = /run/issue-3171.socket
SocketGroup = adm
SocketMode = 0660
EOF
cat >/run/systemd/system/issue-3171@.service <<EOF
[ Unit]
Description = Test service
[ Service]
StandardInput = socket
2024-01-04 17:24:52 +03:00
ExecStart = sh -x -c cat
2023-05-10 14:58:13 +03:00
EOF
systemctl start issue-3171.socket
systemctl is-active issue-3171.socket
[ [ " $( stat --format= '%G' /run/issue-3171.socket) " = = adm ] ]
2024-07-05 11:27:56 +03:00
echo A | ncat -w1 -U /run/issue-3171.socket
2023-05-10 14:58:13 +03:00
mv $U ${ U } .disabled
systemctl daemon-reload
systemctl is-active issue-3171.socket
[ [ " $( stat --format= '%G' /run/issue-3171.socket) " = = adm ] ]
2024-07-05 11:27:56 +03:00
echo B | ncat -w1 -U /run/issue-3171.socket && exit 1
2023-05-10 14:58:13 +03:00
mv ${ U } .disabled $U
systemctl daemon-reload
systemctl is-active issue-3171.socket
2024-07-05 11:27:56 +03:00
echo C | ncat -w1 -U /run/issue-3171.socket && exit 1
2023-05-10 14:58:13 +03:00
[ [ " $( stat --format= '%G' /run/issue-3171.socket) " = = adm ] ]
systemctl restart issue-3171.socket
systemctl is-active issue-3171.socket
2024-07-05 11:27:56 +03:00
echo D | ncat -w1 -U /run/issue-3171.socket
2023-05-10 14:58:13 +03:00
[ [ " $( stat --format= '%G' /run/issue-3171.socket) " = = adm ] ]