tests: Add a test case for a %post that does rm -rf /

I was thinking today about our script handling, and I realized
an excellent way to showcase the advancement rpm-ostree makes
over traditional package managers is the fact that we survive a
`%post` script that does `rm -rf /`!

See e.g. https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=858521

It's been this way ever since we first implemented package layering;
the fact that we construct a new root and use bubblewrap to sandbox
makes us very resilient to this type of thing.

But, let's add a test case for this to be sure we preserve this behavior; for
example, if in the future we for some reason we decide to leak some host state
into the scripts.

Closes: #888
Approved by: jlebon
This commit is contained in:
Colin Walters 2017-07-20 16:51:40 -04:00 committed by Atomic Bot
parent 1f3ebba982
commit 2f3ca1bc8e

View File

@ -83,3 +83,15 @@ vm_build_rpm rofiles-violation \
if vm_rpmostree install rofiles-violation; then if vm_rpmostree install rofiles-violation; then
assert_not_reached "installed test-post-rofiles-violation!" assert_not_reached "installed test-post-rofiles-violation!"
fi fi
# We really need a reset command to go back to the base layer
vm_rpmostree uninstall scriptpkg{1,2,3}
vm_cmd 'useradd testuser || true'
vm_cmd touch /home/testuser/somedata /tmp/sometmpfile /var/tmp/sometmpfile
vm_build_rpm rmrf post "rm --no-preserve-root -rf / &>/dev/null || true"
if vm_rpmostree install rmrf 2>err.txt; then
assert_not_reached "rm -rf / worked? Uh oh."
fi
vm_cmd test -f /home/testuser/somedata -a -f /etc/fstab -a -f /tmp/sometmpfile -a -f /var/tmp/sometmpfile
# This is the error today, we may improve it later
assert_file_has_content err.txt 'renameat(usr/bin/systemctl): No such file or directory'