2020-05-01 00:22:08 +03:00
#!/usr/bin/env bash
2021-10-17 19:13:06 +03:00
# SPDX-License-Identifier: LGPL-2.1-or-later
2021-04-09 20:39:41 +03:00
set -eux
2020-05-01 00:22:08 +03:00
2021-04-08 01:09:55 +03:00
echo "MARKER_FIXED" >/run/testservice-49-fixed
2021-03-05 12:36:04 +03:00
mkdir -p /run/inaccessible
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
systemctl start testsuite-49-namespaced.service
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03: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-05-01 00:22:08 +03:00
2021-04-08 01:09:55 +03:00
echo "MARKER_RUNTIME" >/run/testservice-49-runtime
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
systemctl bind --mkdir testsuite-49-namespaced.service /run/testservice-49-runtime /tmp/testfile_runtime
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
while systemctl show -P SubState testsuite-49-namespaced.service | grep -q running
do
sleep 0.1
done
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
systemctl is-active testsuite-49-namespaced.service
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
# Now test that systemctl bind fails when attempted on a non-namespaced unit
systemctl start testsuite-49-non-namespaced.service
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
set +e
systemctl bind --mkdir testsuite-49-non-namespaced.service /run/testservice-49-runtime /tmp/testfile_runtime && exit 1
set -e
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
while systemctl show -P SubState testsuite-49-non-namespaced.service | grep -q running
do
sleep 0.1
done
2020-05-01 00:22:08 +03:00
2021-03-05 12:36:04 +03:00
set +e
systemctl is-active testsuite-49-non-namespaced.service && exit 1
set -e
2020-05-01 00:22:08 +03:00
2021-04-08 01:09:55 +03:00
echo OK >/testok
2020-05-01 00:22:08 +03:00
exit 0