diff --git a/coverage.txt b/coverage.txt index cc7c2ab..6efbb9d 100644 --- a/coverage.txt +++ b/coverage.txt @@ -369,3 +369,6 @@ Test: empty-sources.list Test: merged-fakechroot-inside-unmerged-chroot Needs-Root: true + +Test: auto-mode-as-normal-user +Modes: auto diff --git a/tests/auto-mode-as-normal-user b/tests/auto-mode-as-normal-user new file mode 100644 index 0000000..e8ab828 --- /dev/null +++ b/tests/auto-mode-as-normal-user @@ -0,0 +1,22 @@ +#!/bin/sh +set -eu +export LC_ALL=C.UTF-8 + +trap "rm -f /tmp/debian-chroot.tar.gz" EXIT INT TERM + +[ {{ MODE }} = "auto" ] + +prefix= +if [ "$(id -u)" -eq 0 ]; then + if ! id "${SUDO_USER:-user}" >/dev/null 2>&1; then + if [ ! -e /mmdebstrap-testenv ]; then + echo "this test modifies the system and should only be run inside a container" >&2 + exit 1 + fi + useradd --home-dir "/home/${SUDO_USER:-user}" --create-home "${SUDO_USER:-user}" + fi + prefix="runuser -u ${SUDO_USER:-user} --" +fi + +$prefix {{ CMD }} --mode={{ MODE }} --variant=apt {{ DIST }} /tmp/debian-chroot.tar.gz {{ MIRROR }} +tar -tf /tmp/debian-chroot.tar.gz | sort | diff -u tar1.txt -