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:
parent
e7b5cb8782
commit
bae7a02be5
3 changed files with 12 additions and 4 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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):
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue