summaryrefslogtreecommitdiff
path: root/cloudinit
diff options
context:
space:
mode:
Diffstat (limited to 'cloudinit')
-rw-r--r--cloudinit/conftest.py35
-rw-r--r--cloudinit/tests/test_conftest.py18
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'])