mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-05-05 08:41:29 -07:00
Cleanups to the common.sys_info API
* Move get_all_subclasses out of sys_info as it is unrelated to system information. * get_all_subclasses now returns a set() instead of a list. * Don't port get_platform to sys_info as it is deprecated. Code using the common API should just use platform.system() directly. * Rename load_platform_subclass() to get_platform_subclass and do not instantiate the rturned class. * Test the compat shims in module_utils/basic.py separately from the new API in module_utils/common/sys_info.py and module_utils/common/_utils.py
This commit is contained in:
parent
79dc9a75c3
commit
5844c8c7f0
7 changed files with 284 additions and 47 deletions
|
@ -16,11 +16,11 @@ from units.compat.mock import patch
|
|||
from ansible.module_utils.six.moves import builtins
|
||||
|
||||
# Functions being tested
|
||||
from ansible.module_utils.common.sys_info import get_all_subclasses
|
||||
from ansible.module_utils.common.sys_info import get_distribution
|
||||
from ansible.module_utils.common.sys_info import get_distribution_version
|
||||
from ansible.module_utils.common.sys_info import get_platform
|
||||
from ansible.module_utils.common.sys_info import load_platform_subclass
|
||||
from ansible.module_utils.basic import get_platform
|
||||
from ansible.module_utils.basic import get_all_subclasses
|
||||
from ansible.module_utils.basic import get_distribution
|
||||
from ansible.module_utils.basic import get_distribution_version
|
||||
from ansible.module_utils.basic import load_platform_subclass
|
||||
|
||||
|
||||
realimport = builtins.__import__
|
||||
|
@ -104,7 +104,7 @@ class TestLoadPlatformSubclass:
|
|||
|
||||
def test_not_linux(self):
|
||||
# if neither match, the fallback should be the top-level class
|
||||
with patch('ansible.module_utils.common.sys_info.get_platform', return_value="Foo"):
|
||||
with patch('platform.system', return_value="Foo"):
|
||||
with patch('ansible.module_utils.common.sys_info.get_distribution', return_value=None):
|
||||
assert isinstance(load_platform_subclass(self.LinuxTest), self.LinuxTest)
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue