2020-04-30 23:22:08 +02: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
2020-04-30 23:22:08 +02:00
2021-04-08 00:09:55 +02:00
echo "MARKER_FIXED" >/run/testservice-49-fixed
2021-03-05 18:36:04 +09:00
mkdir -p /run/inaccessible
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
systemctl start testsuite-49-namespaced.service
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
# Ensure that inaccessible paths aren't bypassed by the runtime setup
set +e
systemctl bind --mkdir testsuite-49-namespaced.service /run/testservice-49-fixed /run/inaccessible/testfile_fixed && exit 1
set -e
2020-04-30 23:22:08 +02:00
2021-04-08 00:09:55 +02:00
echo "MARKER_RUNTIME" >/run/testservice-49-runtime
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
systemctl bind --mkdir testsuite-49-namespaced.service /run/testservice-49-runtime /tmp/testfile_runtime
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
while systemctl show -P SubState testsuite-49-namespaced.service | grep -q running
do
sleep 0.1
done
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
systemctl is-active testsuite-49-namespaced.service
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
# Now test that systemctl bind fails when attempted on a non-namespaced unit
systemctl start testsuite-49-non-namespaced.service
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
set +e
systemctl bind --mkdir testsuite-49-non-namespaced.service /run/testservice-49-runtime /tmp/testfile_runtime && exit 1
set -e
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
while systemctl show -P SubState testsuite-49-non-namespaced.service | grep -q running
do
sleep 0.1
done
2020-04-30 23:22:08 +02:00
2021-03-05 18:36:04 +09:00
set +e
systemctl is-active testsuite-49-non-namespaced.service && exit 1
set -e
2020-04-30 23:22:08 +02:00
2021-04-08 00:09:55 +02:00
echo OK >/testok
2020-04-30 23:22:08 +02:00
exit 0