- Add an extra call to `/bin/false` and explicitly set the `check` argument for both `run()` calls. - Compare full call_args_list. This checks that all the options are as expected, that the `check` argument is set properly, and that the full order of all the calls is as expected, including the chroot path. Co-authored-by: Michael Vogt <michael.vogt@gmail.com>
42 lines
1.4 KiB
Python
42 lines
1.4 KiB
Python
#
|
|
# Test for util/chroot.py
|
|
#
|
|
|
|
import os
|
|
from unittest.mock import call, patch
|
|
|
|
from osbuild.util.chroot import Chroot
|
|
|
|
|
|
class RunReturn:
|
|
"""
|
|
Class to be returned from mocked run() call so that the returncode is always 0.
|
|
"""
|
|
|
|
@property
|
|
def returncode(self):
|
|
return 0
|
|
|
|
|
|
@patch("subprocess.run", return_value=RunReturn())
|
|
def test_chroot_context(mocked_run, tmp_path):
|
|
|
|
with Chroot(os.fspath(tmp_path)) as chroot:
|
|
chroot.run(["/bin/true"], check=True)
|
|
chroot.run(["/bin/false"], check=False)
|
|
|
|
assert mocked_run.call_args_list == [
|
|
call(["/usr/bin/mount", "-t", "proc", "-o", "nosuid,noexec,nodev",
|
|
"proc", os.fspath(tmp_path / "proc")], check=True),
|
|
call(["/usr/bin/mount", "-t", "devtmpfs", "-o", "mode=0755,noexec,nosuid,strictatime",
|
|
"devtmpfs", os.fspath(tmp_path / "dev")], check=True),
|
|
call(["/usr/bin/mount", "-t", "sysfs", "-o", "nosuid,noexec,nodev",
|
|
"sysfs", os.fspath(tmp_path / "sys")], check=True),
|
|
|
|
call(["/usr/sbin/chroot", os.fspath(tmp_path), "/bin/true"], check=True),
|
|
call(["/usr/sbin/chroot", os.fspath(tmp_path), "/bin/false"], check=False),
|
|
|
|
call(["/usr/bin/umount", "--lazy", os.fspath(tmp_path / "proc")], check=False),
|
|
call(["/usr/bin/umount", "--lazy", os.fspath(tmp_path / "dev")], check=False),
|
|
call(["/usr/bin/umount", "--lazy", os.fspath(tmp_path / "sys")], check=False),
|
|
]
|