2022-05-25 14:02:09 +00:00
|
|
|
#!/bin/sh
|
|
|
|
set -eu
|
|
|
|
export LC_ALL=C.UTF-8
|
|
|
|
if [ ! -e /mmdebstrap-testenv ]; then
|
|
|
|
echo "this test modifies the system and should only be run inside a container" >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
2022-06-04 06:30:53 +00:00
|
|
|
# https://www.etalabs.net/sh_tricks.html
|
|
|
|
quote () { printf %s\\n "$1" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/'/" ; }
|
2022-05-25 14:02:09 +00:00
|
|
|
adduser --gecos user --disabled-password user
|
|
|
|
sysctl -w kernel.unprivileged_userns_clone=1
|
|
|
|
homedir=$(runuser -u user -- sh -c 'cd && pwd')
|
2022-06-04 06:30:53 +00:00
|
|
|
# apt:test/integration/test-apt-key
|
|
|
|
TMPDIR_ADD="This is fü\$\$ing cràzy, \$(apt -v)\$!"
|
|
|
|
runuser -u user -- mkdir "$homedir/$TMPDIR_ADD"
|
2022-08-28 06:16:28 +00:00
|
|
|
# make sure the unshared user can traverse into the TMPDIR
|
|
|
|
chmod 711 "$homedir"
|
|
|
|
# set permissions and sticky bit like the real /tmp
|
|
|
|
chmod 1777 "$homedir/$TMPDIR_ADD"
|
2022-06-04 06:30:53 +00:00
|
|
|
runuser -u user -- env TMPDIR="$homedir/$TMPDIR_ADD" {{ CMD }} --mode=unshare --variant=apt \
|
|
|
|
--setup-hook='case "$1" in '"$(quote "$homedir/$TMPDIR_ADD/mmdebstrap.")"'??????????) exit 0;; *) echo "$1"; exit 1;; esac' \
|
2022-05-25 14:02:09 +00:00
|
|
|
{{ DIST }} /tmp/debian-chroot.tar {{ MIRROR }}
|
|
|
|
tar -tf /tmp/debian-chroot.tar | sort | diff -u tar1.txt -
|
|
|
|
# use rmdir as a quick check that nothing is remaining in TMPDIR
|
2022-06-04 06:30:53 +00:00
|
|
|
runuser -u user -- rmdir "$homedir/$TMPDIR_ADD"
|
2022-05-25 14:02:09 +00:00
|
|
|
rm /tmp/debian-chroot.tar
|