diff --git a/tests/chrootless-fakeroot b/tests/chrootless-fakeroot index 1c3b68b..8eaf153 100644 --- a/tests/chrootless-fakeroot +++ b/tests/chrootless-fakeroot @@ -18,18 +18,23 @@ if [ "$(id -u)" -eq 0 ] && [ "{{ MODE }}" != "root" ] && [ "{{ MODE }}" != "auto prefix="runuser -u ${SUDO_USER:-user} --" fi +MMTARFILTER= +[ -x /usr/bin/mmtarfilter ] && MMTARFILTER=/usr/bin/mmtarfilter +[ -x ./tarfilter ] && MMTARFILTER=./tarfilter + # we need --hook-dir=./hooks/merged-usr because usrmerge does not understand # DPKG_ROOT # permissions drwxr-sr-x and extended attributes of ./var/log/journal/ cannot # be preserved under fakeroot +# this applies to 'z' lines in files in /usr/lib/tmpfiles.d/ for INCLUDE in '' 'apt' 'apt,build-essential' 'systemd-sysv'; do {{ CMD }} --variant={{ VARIANT }} --hook-dir=./hooks/merged-usr \ - --customize-hook='if [ -d "$1"/var/log/journal ]; then rmdir "$1"/var/log/journal; mkdir --mode=2755 "$1"/var/log/journal; chroot "$1" chown root:systemd-journal /var/log/journal; fi' \ + --customize-hook="if [ \"$INCLUDE\" = systemd-sysv ]; then for f in var/log/journal etc/credstore etc/credstore.encrypted; do chmod 00755 \"\$1/\$f\"; done; fi" \ ${INCLUDE:+--include="$INCLUDE"} \ - {{ DIST }} /tmp/root.tar {{ MIRROR }} + {{ DIST }} - {{ MIRROR }} | "$MMTARFILTER" --pax-exclude='*' >/tmp/root.tar $prefix fakeroot {{ CMD }} --mode={{ MODE }} --variant={{ VARIANT }} --hook-dir=./hooks/merged-usr \ ${INCLUDE:+--include="$INCLUDE"} \ - {{ DIST }} /tmp/chrootless.tar {{ MIRROR }} + {{ DIST }} - {{ MIRROR }} | "$MMTARFILTER" > /tmp/chrootless.tar cmp /tmp/root.tar /tmp/chrootless.tar || diffoscope /tmp/root.tar /tmp/chrootless.tar rm /tmp/chrootless.tar /tmp/root.tar done