1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

Path of group_vars and host_vars were getting the basedir added twice.

Fix inventory so this won't happen and fix DataLoader so that it will
test relative paths relative to self._basedir

Fixes #11789
This commit is contained in:
Toshio Kuratomi 2015-08-05 17:38:38 -07:00
parent e7b5cb8782
commit bae7a02be5
3 changed files with 12 additions and 4 deletions

View file

@ -640,6 +640,7 @@ class Inventory(object):
else: else:
basedirs = [self._playbook_basedir] basedirs = [self._playbook_basedir]
cur_loader_basedir = self._loader.get_basedir()
for basedir in basedirs: for basedir in basedirs:
# this can happen from particular API usages, particularly if not run # this can happen from particular API usages, particularly if not run
@ -660,13 +661,16 @@ class Inventory(object):
# FIXME: these should go to VariableManager # FIXME: these should go to VariableManager
if group and host is None: if group and host is None:
# load vars in dir/group_vars/name_of_group # load vars in dir/group_vars/name_of_group
base_path = os.path.join(basedir, "group_vars/%s" % group.name) self._loader.set_basedir(basedir)
base_path = os.path.join("group_vars", group.name)
results = self._variable_manager.add_group_vars_file(base_path, self._loader) results = self._variable_manager.add_group_vars_file(base_path, self._loader)
elif host and group is None: elif host and group is None:
# same for hostvars in dir/host_vars/name_of_host # same for hostvars in dir/host_vars/name_of_host
base_path = os.path.join(basedir, "host_vars/%s" % host.name) self._loader.set_basedir(basedir)
base_path = os.path.join("host_vars", host.name)
results = self._variable_manager.add_host_vars_file(base_path, self._loader) results = self._variable_manager.add_host_vars_file(base_path, self._loader)
self._loader.set_basedir(cur_loader_basedir)
# all done, results is a dictionary of variables for this particular host. # all done, results is a dictionary of variables for this particular host.
return results return results

View file

@ -112,15 +112,19 @@ class DataLoader():
return parsed_data return parsed_data
def path_exists(self, path): def path_exists(self, path):
path = self.path_dwim(path)
return os.path.exists(path) return os.path.exists(path)
def is_file(self, path): def is_file(self, path):
path = self.path_dwim(path)
return os.path.isfile(path) return os.path.isfile(path)
def is_directory(self, path): def is_directory(self, path):
path = self.path_dwim(path)
return os.path.isdir(path) return os.path.isdir(path)
def list_directory(self, path): def list_directory(self, path):
path = self.path_dwim(path)
return os.listdir(path) return os.listdir(path)
def _safe_load(self, stream, file_name=None): def _safe_load(self, stream, file_name=None):

View file

@ -29,11 +29,11 @@ class DictDataLoader(DataLoader):
def __init__(self, file_mapping=dict()): def __init__(self, file_mapping=dict()):
assert type(file_mapping) == dict assert type(file_mapping) == dict
super(DictDataLoader, self).__init__()
self._file_mapping = file_mapping self._file_mapping = file_mapping
self._build_known_directories() self._build_known_directories()
super(DictDataLoader, self).__init__()
def load_from_file(self, path): def load_from_file(self, path):
if path in self._file_mapping: if path in self._file_mapping:
return self.load(self._file_mapping[path], path) return self.load(self._file_mapping[path], path)