2016-05-07 00:05:59 +03:00
#!/bin/bash
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
# ex: ts=8 sw=4 sts=4 et filetype=sh
2017-08-07 22:09:21 +03:00
set -e
2016-05-07 00:05:59 +03:00
TEST_DESCRIPTION = "https://github.com/systemd/systemd/issues/3171"
2017-08-04 15:34:14 +03:00
TEST_NO_QEMU = 1
2016-05-07 00:05:59 +03:00
. $TEST_BASE_DIR /test-functions
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
dracut_install cat mv stat nc
2018-11-01 11:26:36 +03:00
# mask some services that we do not want to run in these tests
ln -fs /dev/null $initdir /etc/systemd/system/systemd-hwdb-update.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-journal-catalog-update.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-networkd.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-networkd.socket
ln -fs /dev/null $initdir /etc/systemd/system/systemd-resolved.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-machined.service
2016-05-07 00:05:59 +03:00
# setup the testsuite service
cat >$initdir /etc/systemd/system/testsuite.service <<EOF
[ Unit]
Description = Testsuite service
After = multi-user.target
[ Service]
ExecStart = /test-socket-group.sh
Type = oneshot
EOF
cat >$initdir /test-socket-group.sh <<'EOF'
#!/bin/bash
set -x
set -e
set -o pipefail
U = /run/systemd/system/test.socket
cat <<'EOL' >$U
[ Unit]
Description = Test socket
[ Socket]
Accept = yes
ListenStream = /run/test.socket
SocketGroup = adm
SocketMode = 0660
EOL
cat <<'EOL' > /run/systemd/system/test@.service
[ Unit]
Description = Test service
[ Service]
StandardInput = socket
ExecStart = /bin/sh -x -c cat
EOL
systemctl start test.socket
systemctl is-active test.socket
[ [ " $( stat --format= '%G' /run/test.socket) " = = adm ] ]
2017-04-11 22:34:29 +03:00
echo A | nc -w1 -U /run/test.socket
2016-05-07 00:05:59 +03:00
mv $U ${ U } .disabled
systemctl daemon-reload
systemctl is-active test.socket
[ [ " $( stat --format= '%G' /run/test.socket) " = = adm ] ]
2017-04-11 22:34:29 +03:00
echo B | nc -w1 -U /run/test.socket && exit 1
2016-05-07 00:05:59 +03:00
mv ${ U } .disabled $U
systemctl daemon-reload
systemctl is-active test.socket
2017-04-11 22:34:29 +03:00
echo C | nc -w1 -U /run/test.socket && exit 1
2016-05-07 00:05:59 +03:00
[ [ " $( stat --format= '%G' /run/test.socket) " = = adm ] ]
systemctl restart test.socket
systemctl is-active test.socket
2017-04-11 22:34:29 +03:00
echo D | nc -w1 -U /run/test.socket
2016-05-07 00:05:59 +03:00
[ [ " $( stat --format= '%G' /run/test.socket) " = = adm ] ]
touch /testok
EOF
chmod 0755 $initdir /test-socket-group.sh
setup_testsuite
) || return 1
setup_nspawn_root
ddebug " umount $TESTDIR /root "
umount $TESTDIR /root
}
do_test " $@ "