Cleaning up inventory bugs from earlier group change

pull/12401/merge
James Cammarata 9 years ago
parent 8b56bc1c01
commit 11c27078c0

@ -60,16 +60,14 @@ class Inventory(object):
self._vars_per_host = {}
self._vars_per_group = {}
self._hosts_cache = {}
self._groups_list = {}
self._pattern_cache = {}
self._vars_plugins = []
self._groups_cache = {}
# to be set by calling set_playbook_basedir by playbook code
self._playbook_basedir = None
# the inventory object holds a list of groups
self.groups = []
self.groups = {}
# a list of host(names) to contain current inquiries to
self._restriction = None
@ -111,9 +109,7 @@ class Inventory(object):
self.parser = get_file_parser(host_list, self.groups, self._loader)
vars_loader.add_directory(self.basedir(), with_subdir=True)
if self.parser:
self.groups = self.parser.groups.values()
else:
if not self.parser:
# should never happen, but JIC
raise AnsibleError("Unable to parse %s as an inventory source" % host_list)
@ -122,7 +118,7 @@ class Inventory(object):
# FIXME: shouldn't be required, since the group/host vars file
# management will be done in VariableManager
# get group vars from group_vars/ files and vars plugins
for group in self.groups:
for group in self.groups.values():
group.vars = combine_vars(group.vars, self.get_group_variables(group.name))
# get host vars from host_vars/ files and vars plugins
@ -372,7 +368,7 @@ class Inventory(object):
results.append(host)
groups = self.get_groups()
for group in groups:
for group in groups.values():
if pattern == 'all':
for host in group.get_hosts():
__append_host_to_results(host)
@ -408,19 +404,6 @@ class Inventory(object):
else:
return []
def groups_list(self):
if not self._groups_list:
groups = {}
for g in self.groups:
groups[g.name] = [h.name for h in g.get_hosts()]
ancestors = g.get_ancestors()
for a in ancestors:
if a.name not in groups:
groups[a.name] = [h.name for h in a.get_hosts()]
self._groups_list = groups
self._groups_cache = {}
return self._groups_list
def get_groups(self):
return self.groups
@ -439,7 +422,7 @@ class Inventory(object):
return host
return self._create_implicit_localhost(hostname)
matching_host = None
for group in self.groups:
for group in self.groups.values():
for host in group.get_hosts():
if hostname == host.name:
matching_host = host
@ -447,11 +430,7 @@ class Inventory(object):
return matching_host
def get_group(self, groupname):
if not self._groups_cache:
for group in self.groups:
self._groups_cache[group.name] = group
return self._groups_cache.get(groupname)
return self.groups[groupname]
def get_group_variables(self, groupname, update_cached=False, vault_password=None):
if groupname not in self._vars_per_group or update_cached:
@ -522,10 +501,8 @@ class Inventory(object):
return vars
def add_group(self, group):
if group.name not in self.groups_list():
self.groups.append(group)
self._groups_list = None # invalidate internal cache
self._groups_cache = {}
if group.name not in self.groups:
self.groups[group.name] = group
else:
raise AnsibleError("group already in inventory: %s" % group.name)
@ -539,7 +516,7 @@ class Inventory(object):
return result
def list_groups(self):
return sorted([ g.name for g in self.groups ], key=lambda x: x)
return sorted(self.groups.keys(), key=lambda x: x)
def restrict_to_hosts(self, restriction):
"""
@ -703,8 +680,6 @@ class Inventory(object):
self._hosts_cache = {}
self._vars_per_host = {}
self._vars_per_group = {}
self._groups_list = {}
self._groups_cache = {}
self.groups = []
self.groups = {}
self.parse_inventory(self.host_list)

@ -261,10 +261,10 @@ class VariableManager:
all_vars['playbook_dir'] = loader.get_basedir()
if host:
all_vars['groups'] = [group.name for group in host.get_groups()]
all_vars['group_names'] = [group.name for group in host.get_groups()]
if self._inventory is not None:
all_vars['groups'] = self._inventory.groups_list()
all_vars['groups'] = self._inventory.groups.keys()
if include_hostvars:
hostvars = HostVars(vars_manager=self, play=play, inventory=self._inventory, loader=loader)
all_vars['hostvars'] = hostvars

Loading…
Cancel
Save