Make VMWare data source test host independent and expand testing#1308
Merged
Conversation
- At present the test to get the host info is dependent on the network of the host on which the test is run. If there is no network the test will fail. Make the test host independent by applying appropriate mocks and expand the test to cover ipv4, ipv6, and dual stack setups.
Contributor
TheRealFalcon
left a comment
There was a problem hiding this comment.
Overall LGTM. Since we're already defining common mocks in a fixture, would you mind doing something like this instead?
diff --git a/tests/unittests/sources/test_vmware.py b/tests/unittests/sources/test_vmware.py
index 7b661aaf..3579041a 100644
--- a/tests/unittests/sources/test_vmware.py
+++ b/tests/unittests/sources/test_vmware.py
@@ -7,6 +7,7 @@
import base64
import gzip
import os
+from contextlib import ExitStack
import pytest
@@ -59,13 +60,26 @@ runcmd:
@pytest.fixture(autouse=True)
def common_patches():
- with mock.patch("cloudinit.util.platform.platform", return_value="Linux"):
- with mock.patch.multiple(
+ mocks = [
+ mock.patch("cloudinit.util.platform.platform", return_value="Linux"),
+ mock.patch.multiple(
"cloudinit.dmi",
is_container=mock.Mock(return_value=False),
is_FreeBSD=mock.Mock(return_value=False),
- ):
- yield
+ ),
+ mock.patch(
+ "cloudinit.sources.DataSourceVMware.netifaces.interfaces",
+ return_value=[],
+ ),
+ mock.patch(
+ "cloudinit.sources.DataSourceVMware.getfqdn",
+ return_value="host.cloudinit.test",
+ ),
+ ]
+ with ExitStack() as stack:
+ for some_mock in mocks:
+ stack.enter_context(some_mock)
+ yield
class TestDataSourceVMware(CiTestCase):
@@ -83,13 +97,9 @@ class TestDataSourceVMware(CiTestCase):
ret = ds.get_data()
self.assertFalse(ret)
- @mock.patch("cloudinit.sources.DataSourceVMware.netifaces.interfaces")
@mock.patch("cloudinit.sources.DataSourceVMware.get_default_ip_addrs")
- @mock.patch("cloudinit.sources.DataSourceVMware.getfqdn")
- def test_get_host_info_ipv4(self, m_fn_fqdn, m_fn_ipaddr, m_fn_ifaces):
- m_fn_fqdn.return_value = "host.cloudinit.test"
+ def test_get_host_info_ipv4(self, m_fn_ipaddr):
m_fn_ipaddr.return_value = ("10.10.10.1", None)
- m_fn_ifaces.return_value = []
host_info = DataSourceVMware.get_host_info()
self.assertTrue(host_info)
self.assertTrue(host_info["hostname"])
@@ -100,13 +110,9 @@ class TestDataSourceVMware(CiTestCase):
self.assertTrue(host_info[DataSourceVMware.LOCAL_IPV4] == "10.10.10.1")
self.assertFalse(host_info.get(DataSourceVMware.LOCAL_IPV6))
- @mock.patch("cloudinit.sources.DataSourceVMware.netifaces.interfaces")
@mock.patch("cloudinit.sources.DataSourceVMware.get_default_ip_addrs")
- @mock.patch("cloudinit.sources.DataSourceVMware.getfqdn")
- def test_get_host_info_ipv6(self, m_fn_fqdn, m_fn_ipaddr, m_fn_ifaces):
- m_fn_fqdn.return_value = "host.cloudinit.test"
+ def test_get_host_info_ipv6(self, m_fn_ipaddr):
m_fn_ipaddr.return_value = (None, "2001:db8::::::8888")
- m_fn_ifaces.return_value = []
host_info = DataSourceVMware.get_host_info()
self.assertTrue(host_info)
self.assertTrue(host_info["hostname"])
@@ -119,13 +125,9 @@ class TestDataSourceVMware(CiTestCase):
)
self.assertFalse(host_info.get(DataSourceVMware.LOCAL_IPV4))
- @mock.patch("cloudinit.sources.DataSourceVMware.netifaces.interfaces")
@mock.patch("cloudinit.sources.DataSourceVMware.get_default_ip_addrs")
- @mock.patch("cloudinit.sources.DataSourceVMware.getfqdn")
- def test_get_host_info_dual(self, m_fn_fqdn, m_fn_ipaddr, m_fn_ifaces):
- m_fn_fqdn.return_value = "host.cloudinit.test"
+ def test_get_host_info_dual(self, m_fn_ipaddr):
m_fn_ipaddr.return_value = ("10.10.10.1", "2001:db8::::::8888")
- m_fn_ifaces.return_value = []
host_info = DataSourceVMware.get_host_info()
self.assertTrue(host_info)
self.assertTrue(host_info["hostname"])
Contributor
Author
|
@TheRealFalcon np, since you already have the diff, feel free to apply it. Thanks |
Contributor
Author
|
@TheRealFalcon thanks for the help with the tests. |
This was referenced May 12, 2023
Closed
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Proposed Commit Message
Make VMWare data source test host independent and expand testing
Additional Context
Test Steps
Checklist: