From 1e4e188318f92623f207b91d6187c2af0c410faf Mon Sep 17 00:00:00 2001 From: Brian Coca Date: Tue, 20 Sep 2016 15:05:11 -0400 Subject: [PATCH] changed missing file error to warning for lookups (#16800) * changed missing file error to warning for lookups * changed plugins that expected exception warning will still be displayed, they now work with None value --- lib/ansible/plugins/lookup/__init__.py | 3 +-- lib/ansible/plugins/lookup/fileglob.py | 5 +---- lib/ansible/plugins/lookup/first_found.py | 6 ++---- 3 files changed, 4 insertions(+), 10 deletions(-) diff --git a/lib/ansible/plugins/lookup/__init__.py b/lib/ansible/plugins/lookup/__init__.py index 7112b4ab0b..908135a4c7 100644 --- a/lib/ansible/plugins/lookup/__init__.py +++ b/lib/ansible/plugins/lookup/__init__.py @@ -22,7 +22,6 @@ __metaclass__ = type from abc import ABCMeta, abstractmethod from ansible.compat.six import with_metaclass -from ansible.errors import AnsibleFileNotFound try: from __main__ import display @@ -115,6 +114,6 @@ class LookupBase(with_metaclass(ABCMeta, object)): result = self._loader.path_dwim_relative_stack(paths, subdir, needle) if result is None: - raise AnsibleFileNotFound("Unable to find '%s' in expected paths." % needle) + self._display.warning("Unable to find '%s' in expected paths." % needle) return result diff --git a/lib/ansible/plugins/lookup/fileglob.py b/lib/ansible/plugins/lookup/fileglob.py index 3e0523fdd5..f9862f0e96 100644 --- a/lib/ansible/plugins/lookup/fileglob.py +++ b/lib/ansible/plugins/lookup/fileglob.py @@ -32,10 +32,7 @@ class LookupModule(LookupBase): ret = [] for term in terms: term_file = os.path.basename(term) - try: - dwimmed_path = self.find_file_in_search_path(variables, 'files', os.path.dirname(term)) - except AnsibleFileNotFound: - dwimmed_path = None + dwimmed_path = self.find_file_in_search_path(variables, 'files', os.path.dirname(term)) if dwimmed_path: globbed = glob.glob(to_bytes(os.path.join(dwimmed_path, term_file), errors='surrogate_or_strict')) ret.extend(to_text(g, errors='surrogate_or_strict') for g in globbed if os.path.isfile(g)) diff --git a/lib/ansible/plugins/lookup/first_found.py b/lib/ansible/plugins/lookup/first_found.py index c872d1595b..4fb7e35ea2 100644 --- a/lib/ansible/plugins/lookup/first_found.py +++ b/lib/ansible/plugins/lookup/first_found.py @@ -181,11 +181,9 @@ class LookupModule(LookupBase): # get subdir if set by task executor, default to files otherwise subdir = getattr(self, '_subdir', 'files') path = None - try: - path = self.find_file_in_search_path(variables, subdir, fn) + path = self.find_file_in_search_path(variables, subdir, fn) + if path is not None: return [path] - except AnsibleFileNotFound: - continue else: if skip: return []