diff options
author | Lennart Poettering <lennart@poettering.net> | 2021-11-23 16:34:40 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2021-11-23 22:55:49 +0100 |
commit | 9ead4184132c373612fda67fa623a1e3e1c4dfb6 (patch) | |
tree | 2733569d9d751f7156638724feefd729cb449c5f /test/units/testsuite-29.sh | |
parent | 994c9c70a166c5e5c383cf651b6cb4077e8f183e (diff) | |
download | systemd-9ead4184132c373612fda67fa623a1e3e1c4dfb6.tar.gz |
test: test new SYSEXT_SCOPE=/PORTABLE_PREFIXES= fields in TEST-29
Diffstat (limited to 'test/units/testsuite-29.sh')
-rwxr-xr-x | test/units/testsuite-29.sh | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/test/units/testsuite-29.sh b/test/units/testsuite-29.sh index 11f1832aa4..0e0c8cf41d 100755 --- a/test/units/testsuite-29.sh +++ b/test/units/testsuite-29.sh @@ -12,6 +12,11 @@ if [[ -v ASAN_OPTIONS || -v UBSAN_OPTIONS ]]; then ARGS+=(--profile=trusted) fi +systemd-dissect --no-pager /usr/share/minimal_0.raw | grep -q '✓ portable service' +systemd-dissect --no-pager /usr/share/minimal_1.raw | grep -q '✓ portable service' +systemd-dissect --no-pager /usr/share/app0.raw | grep -q '✓ extension for portable service' +systemd-dissect --no-pager /usr/share/app1.raw | grep -q '✓ extension for portable service' + export SYSTEMD_LOG_LEVEL=debug mkdir -p /run/systemd/system/systemd-portabled.service.d/ cat <<EOF >/run/systemd/system/systemd-portabled.service.d/override.conf @@ -98,10 +103,19 @@ portablectl detach --now --runtime --extension /usr/share/app1.raw /usr/share/mi # portablectl also works with directory paths rather than images -mkdir /tmp/rootdir /tmp/app1 /tmp/overlay +mkdir /tmp/rootdir /tmp/app1 /tmp/overlay /tmp/os-release-fix /tmp/os-release-fix/etc mount /usr/share/app1.raw /tmp/app1 mount /usr/share/minimal_0.raw /tmp/rootdir -mount -t overlay overlay -o lowerdir=/tmp/app1:/tmp/rootdir /tmp/overlay + +# Fix up os-release to drop the valid PORTABLE_SERVICES field (because we are +# bypassing the sysext logic in portabled here it will otherwise not see the +# extensions additional valid prefix) +grep -v "^PORTABLE_PREFIXES=" /tmp/rootdir/etc/os-release > /tmp/os-release-fix/etc/os-release + +mount -t overlay overlay -o lowerdir=/tmp/os-release-fix:/tmp/app1:/tmp/rootdir /tmp/overlay + +grep . /tmp/overlay/usr/lib/extension-release.d/* +grep . /tmp/overlay/etc/os-release portablectl "${ARGS[@]}" attach --copy=symlink --now --runtime /tmp/overlay app1 |