Skip to content

Commit

Permalink
tests: add test for unsafe symlinks
Browse files Browse the repository at this point in the history
Symlinks pointing outside of copied directory should be denied in both
filecopy modes

QubesOS/qubes-issues#8332
  • Loading branch information
marmarek committed Jun 6, 2024
1 parent 9384ec4 commit 46cff02
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions qubes/tests/integ/vm_qrexec_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -827,6 +827,36 @@ def test_140_qrexec_filecopy_unsafe_name(self):
except subprocess.CalledProcessError:
self.fail('source file got removed')

def test_141_qrexec_filecopy_unsafe_symlink(self):
self.loop.run_until_complete(asyncio.gather(
self.testvm1.start(),
self.testvm2.start()))

# symlinks are not allowed in either mode
name = "test"
self.loop.run_until_complete(self.testvm1.run_for_stdio(
f"ln -s /etc/passwd /tmp/{name}"))
self.loop.run_until_complete(self.testvm1.run_for_stdio(
f"ln -s ../etc/passwd /tmp/{name}2"))
with self.qrexec_policy('qubes.Filecopy+', self.testvm1, self.testvm2), \
self.qrexec_policy('qubes.UnsafeFileCopy', self.testvm1, self.testvm2):
with self.assertRaises(subprocess.CalledProcessError):
self.loop.run_until_complete(
self.testvm1.run_for_stdio(
f"qvm-copy-to-vm {self.testvm2!s} /tmp/{name}"))
with self.assertRaises(subprocess.CalledProcessError):
self.loop.run_until_complete(
self.testvm1.run_for_stdio(
f"qvm-copy-to-vm {self.testvm2!s} /tmp/{name}2"))

try:
self.loop.run_until_complete(self.testvm2.run_for_stdio(
f"! test -e /home/user/QubesIncoming/{self.testvm1!s}/{name}"))
self.loop.run_until_complete(self.testvm2.run_for_stdio(
f"! test -e /home/user/QubesIncoming/{self.testvm1!s}/{name}2"))
except subprocess.CalledProcessError:
self.fail('file with "unsafe" symlink was copied')

def test_200_timezone(self):
"""Test whether timezone setting is properly propagated to the VM"""
if "whonix" in self.template:
Expand Down

0 comments on commit 46cff02

Please sign in to comment.