Add 2.0-2.3 facts api compat (ansible_facts(), get_all_facts()) (#27294)
* Add 2.0-2.3 facts api compat (ansible_facts(), get_all_facts()) These are intended to provide compatibilty for modules that use 'ansible.module_utils.facts.ansible_facts' and 'ansible.module_utils.facts.get_all_facts' from 2.0-2.3 facts API. Fixes #25686 Some related changes/fixes needed to provide the compat api: * rm ansible.constants import from module_utils.facts.compat Just use a hard coded default for gather_subset/gather_timeout instead of trying to load it from non existent config if the module params dont include it. * include 'external' collectors in compat ansible_facts() * Add facter/ohai back to the valid collector classes facter/ohai had gotten removed from the default_collectors class used as the default list for all_collector_classes by setup.py and compat.py That made gather_subset['facter'] fail.
This commit is contained in:
parent
3db768f393
commit
17ab546c48
6 changed files with 157 additions and 3 deletions
|
@ -0,0 +1,21 @@
|
||||||
|
# This file is part of Ansible
|
||||||
|
#
|
||||||
|
# Ansible is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# Ansible is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
# import from the compat api because 2.0-2.3 had a module_utils.facts.ansible_facts
|
||||||
|
# and get_all_facts in top level namespace
|
||||||
|
from ansible.module_utils.facts.compat import ansible_facts, get_all_facts # noqa
|
75
lib/ansible/module_utils/facts/compat.py
Normal file
75
lib/ansible/module_utils/facts/compat.py
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
# This file is part of Ansible
|
||||||
|
#
|
||||||
|
# Ansible is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# Ansible is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
from ansible.module_utils.facts.namespace import PrefixFactNamespace
|
||||||
|
from ansible.module_utils.facts import default_collectors
|
||||||
|
from ansible.module_utils.facts import ansible_collector
|
||||||
|
|
||||||
|
|
||||||
|
def get_all_facts(module):
|
||||||
|
'''compat api for ansible 2.2/2.3 module_utils.facts.get_all_facts method
|
||||||
|
|
||||||
|
Expects module to be an instance of AnsibleModule, with a 'gather_subset' param.
|
||||||
|
|
||||||
|
returns a dict mapping the bare fact name ('default_ipv4' with no 'ansible_' namespace) to
|
||||||
|
the fact value.'''
|
||||||
|
|
||||||
|
gather_subset = module.params['gather_subset']
|
||||||
|
return ansible_facts(module, gather_subset=gather_subset)
|
||||||
|
|
||||||
|
|
||||||
|
def ansible_facts(module, gather_subset=None):
|
||||||
|
'''Compat api for ansible 2.0/2.2/2.3 module_utils.facts.ansible_facts method
|
||||||
|
|
||||||
|
2.3/2.3 expects a gather_subset arg.
|
||||||
|
2.0/2.1 does not except a gather_subset arg
|
||||||
|
|
||||||
|
So make gather_subsets an optional arg, defaulting to configured DEFAULT_GATHER_TIMEOUT
|
||||||
|
|
||||||
|
'module' should be an instance of an AnsibleModule.
|
||||||
|
|
||||||
|
returns a dict mapping the bare fact name ('default_ipv4' with no 'ansible_' namespace) to
|
||||||
|
the fact value.
|
||||||
|
'''
|
||||||
|
|
||||||
|
gather_subset = gather_subset or module.params.get('gather_subset', ['all'])
|
||||||
|
gather_timeout = module.params.get('gather_timeout', 10)
|
||||||
|
filter_spec = module.params.get('filter', '*')
|
||||||
|
|
||||||
|
minimal_gather_subset = frozenset(['apparmor', 'caps', 'cmdline', 'date_time',
|
||||||
|
'distribution', 'dns', 'env', 'fips', 'local', 'lsb',
|
||||||
|
'pkg_mgr', 'platform', 'python', 'selinux',
|
||||||
|
'service_mgr', 'ssh_pub_keys', 'user'])
|
||||||
|
|
||||||
|
all_collector_classes = default_collectors.collectors
|
||||||
|
|
||||||
|
# don't add a prefix
|
||||||
|
namespace = PrefixFactNamespace(namespace_name='ansible',
|
||||||
|
prefix='')
|
||||||
|
|
||||||
|
fact_collector = \
|
||||||
|
ansible_collector.get_ansible_collector(all_collector_classes=all_collector_classes,
|
||||||
|
namespace=namespace,
|
||||||
|
filter_spec=filter_spec,
|
||||||
|
gather_subset=gather_subset,
|
||||||
|
gather_timeout=gather_timeout,
|
||||||
|
minimal_gather_subset=minimal_gather_subset)
|
||||||
|
|
||||||
|
facts_dict = fact_collector.collect(module=module)
|
||||||
|
|
||||||
|
return facts_dict
|
|
@ -123,7 +123,7 @@ collectors = [ApparmorFactCollector,
|
||||||
OpenBSDVirtualCollector,
|
OpenBSDVirtualCollector,
|
||||||
NetBSDVirtualCollector,
|
NetBSDVirtualCollector,
|
||||||
SunOSVirtualCollector,
|
SunOSVirtualCollector,
|
||||||
HPUXVirtualCollector]
|
HPUXVirtualCollector,
|
||||||
|
|
||||||
external_collectors = [FacterFactCollector,
|
FacterFactCollector,
|
||||||
OhaiFactCollector]
|
OhaiFactCollector]
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
- 'ansible_mounts|default("UNDEF_NET") != "UNDEF_HW"'
|
- 'ansible_mounts|default("UNDEF_NET") != "UNDEF_HW"'
|
||||||
- 'ansible_virtualization_role|default("UNDEF_VIRT") != "UNDEF_VIRT"'
|
- 'ansible_virtualization_role|default("UNDEF_VIRT") != "UNDEF_VIRT"'
|
||||||
|
|
||||||
|
|
||||||
- hosts: facthost19
|
- hosts: facthost19
|
||||||
tags: [ 'fact_min' ]
|
tags: [ 'fact_min' ]
|
||||||
connection: local
|
connection: local
|
||||||
|
@ -260,3 +261,18 @@
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- '"{{ ansible_local.testfact.fact_dir }}" == "custom"'
|
- '"{{ ansible_local.testfact.fact_dir }}" == "custom"'
|
||||||
|
|
||||||
|
- hosts: facthost20
|
||||||
|
tags: [ 'fact_facter_ohai' ]
|
||||||
|
connection: local
|
||||||
|
gather_subset:
|
||||||
|
- facter
|
||||||
|
- ohai
|
||||||
|
gather_facts: yes
|
||||||
|
tasks:
|
||||||
|
- name: Test that retrieving facter and ohai doesnt fail
|
||||||
|
assert:
|
||||||
|
# not much to assert here, aside from not crashing, since test images dont have
|
||||||
|
# facter/ohai
|
||||||
|
that:
|
||||||
|
- 'ansible_user_id|default("UNDEF_MIN") != "UNDEF_MIN"'
|
||||||
|
|
|
@ -293,3 +293,21 @@ class TestMinimalCollectedFacts(TestCollectedFacts):
|
||||||
expected_facts = ['gather_subset',
|
expected_facts = ['gather_subset',
|
||||||
'module_setup']
|
'module_setup']
|
||||||
not_expected_facts = ['lsb']
|
not_expected_facts = ['lsb']
|
||||||
|
|
||||||
|
|
||||||
|
class TestFacterCollectedFacts(TestCollectedFacts):
|
||||||
|
gather_subset = ['!all', 'facter']
|
||||||
|
min_fact_count = 1
|
||||||
|
max_fact_count = 10
|
||||||
|
expected_facts = ['gather_subset',
|
||||||
|
'module_setup']
|
||||||
|
not_expected_facts = ['lsb']
|
||||||
|
|
||||||
|
|
||||||
|
class TestOhaiCollectedFacts(TestCollectedFacts):
|
||||||
|
gather_subset = ['!all', 'ohai']
|
||||||
|
min_fact_count = 1
|
||||||
|
max_fact_count = 10
|
||||||
|
expected_facts = ['gather_subset',
|
||||||
|
'module_setup']
|
||||||
|
not_expected_facts = ['lsb']
|
||||||
|
|
|
@ -155,6 +155,30 @@ class TestCollectorClassesFromGatherSubset(unittest.TestCase):
|
||||||
self.assertIsInstance(res, list)
|
self.assertIsInstance(res, list)
|
||||||
self.assertEqual(res, [default_collectors.EnvFactCollector])
|
self.assertEqual(res, [default_collectors.EnvFactCollector])
|
||||||
|
|
||||||
|
def test_facter(self):
|
||||||
|
res = self._classes(all_collector_classes=default_collectors.collectors,
|
||||||
|
gather_subset=set(['env', 'facter']))
|
||||||
|
self.assertIsInstance(res, list)
|
||||||
|
self.assertEqual(set(res),
|
||||||
|
set([default_collectors.EnvFactCollector,
|
||||||
|
default_collectors.FacterFactCollector]))
|
||||||
|
|
||||||
|
def test_facter_ohai(self):
|
||||||
|
res = self._classes(all_collector_classes=default_collectors.collectors,
|
||||||
|
gather_subset=set(['env', 'facter', 'ohai']))
|
||||||
|
self.assertIsInstance(res, list)
|
||||||
|
self.assertEqual(set(res),
|
||||||
|
set([default_collectors.EnvFactCollector,
|
||||||
|
default_collectors.FacterFactCollector,
|
||||||
|
default_collectors.OhaiFactCollector]))
|
||||||
|
|
||||||
|
def test_just_facter(self):
|
||||||
|
res = self._classes(all_collector_classes=default_collectors.collectors,
|
||||||
|
gather_subset=set(['facter']))
|
||||||
|
self.assertIsInstance(res, list)
|
||||||
|
self.assertEqual(set(res),
|
||||||
|
set([default_collectors.FacterFactCollector]))
|
||||||
|
|
||||||
def test_collector_specified_multiple_times(self):
|
def test_collector_specified_multiple_times(self):
|
||||||
res = self._classes(all_collector_classes=default_collectors.collectors,
|
res = self._classes(all_collector_classes=default_collectors.collectors,
|
||||||
gather_subset=set(['platform', 'all', 'machine']))
|
gather_subset=set(['platform', 'all', 'machine']))
|
||||||
|
|
Loading…
Reference in a new issue