diff options
Diffstat (limited to 'cloudinit')
-rw-r--r-- | cloudinit/conftest.py | 35 | ||||
-rw-r--r-- | cloudinit/tests/test_conftest.py | 18 |
2 files changed, 53 insertions, 0 deletions
diff --git a/cloudinit/conftest.py b/cloudinit/conftest.py new file mode 100644 index 00000000..6a1c63e9 --- /dev/null +++ b/cloudinit/conftest.py @@ -0,0 +1,35 @@ +from unittest import mock + +import pytest + + +@pytest.yield_fixture(autouse=True) +def disable_subp_usage(request): + """ + Across all (pytest) tests, ensure that util.subp is not invoked. + + Note that this can only catch invocations where the util module is imported + and ``util.subp(...)`` is called. ``from cloudinit.util import subp`` + imports happen before the patching here (or the CiTestCase monkey-patching) + happens, so are left untouched. + + To allow a particular test method or class to use util.subp you can set the + parameter passed to this fixture to False using pytest.mark.parametrize:: + + @pytest.mark.parametrize("disable_subp_usage", [False], indirect=True) + def test_whoami(self): + util.subp(["whoami"]) + + This fixture (roughly) mirrors the functionality of + CiTestCase.allowed_subp. + + TODO: + * Enable select subp usage (i.e. allowed_subp=[...]) + """ + should_disable = getattr(request, "param", True) + if should_disable: + with mock.patch('cloudinit.util.subp', autospec=True) as m_subp: + m_subp.side_effect = AssertionError("Unexpectedly used util.subp") + yield + else: + yield diff --git a/cloudinit/tests/test_conftest.py b/cloudinit/tests/test_conftest.py new file mode 100644 index 00000000..62a5361d --- /dev/null +++ b/cloudinit/tests/test_conftest.py @@ -0,0 +1,18 @@ +import pytest + +from cloudinit import util + + +class TestDisableSubpUsage: + + def test_using_subp_raises_assertion_error(self): + with pytest.raises(AssertionError): + util.subp(["some", "args"]) + + def test_typeerrors_on_incorrect_usage(self): + with pytest.raises(TypeError): + util.subp() + + @pytest.mark.parametrize('disable_subp_usage', [False], indirect=True) + def test_subp_usage_can_be_reenabled(self): + util.subp(['whoami']) |