Fix gather_facts error/skipped reporting (#58927)

now give back full output from each module executed
 fixes #57204

(cherry picked from commit adea964c3e)
This commit is contained in:
Brian Coca 2019-07-11 14:18:32 -04:00 committed by Toshio Kuratomi
parent 0f292cd886
commit e6c93bea0d
2 changed files with 8 additions and 8 deletions

View file

@ -0,0 +1,2 @@
bugfixes:
- gather_facts now correctly passes back the full output of modules on error and skipped, fixes #57204

View file

@ -65,9 +65,9 @@ class ActionModule(ActionBase):
mod_args = self._get_module_args(fact_module, task_vars) mod_args = self._get_module_args(fact_module, task_vars)
res = self._execute_module(module_name=fact_module, module_args=mod_args, task_vars=task_vars, wrap_async=False) res = self._execute_module(module_name=fact_module, module_args=mod_args, task_vars=task_vars, wrap_async=False)
if res.get('failed', False): if res.get('failed', False):
failed[fact_module] = res.get('msg') failed[fact_module] = res
elif res.get('skipped', False): elif res.get('skipped', False):
skipped[fact_module] = res.get('msg') skipped[fact_module] = res
else: else:
result = combine_vars(result, {'ansible_facts': res.get('ansible_facts', {})}) result = combine_vars(result, {'ansible_facts': res.get('ansible_facts', {})})
@ -87,9 +87,9 @@ class ActionModule(ActionBase):
res = self._execute_module(module_name='async_status', module_args=poll_args, task_vars=task_vars, wrap_async=False) res = self._execute_module(module_name='async_status', module_args=poll_args, task_vars=task_vars, wrap_async=False)
if res.get('finished', 0) == 1: if res.get('finished', 0) == 1:
if res.get('failed', False): if res.get('failed', False):
failed[module] = res.get('msg') failed[module] = res
elif res.get('skipped', False): elif res.get('skipped', False):
skipped[module] = res.get('msg') skipped[module] = res
else: else:
result = combine_vars(result, {'ansible_facts': res.get('ansible_facts', {})}) result = combine_vars(result, {'ansible_facts': res.get('ansible_facts', {})})
del jobs[module] del jobs[module]
@ -101,16 +101,14 @@ class ActionModule(ActionBase):
if skipped: if skipped:
result['msg'] = "The following modules were skipped: %s\n" % (', '.join(skipped.keys())) result['msg'] = "The following modules were skipped: %s\n" % (', '.join(skipped.keys()))
for skip in skipped: result['skipped_modules'] = skipped
result['msg'] += ' %s: %s\n' % (skip, skipped[skip])
if len(skipped) == len(modules): if len(skipped) == len(modules):
result['skipped'] = True result['skipped'] = True
if failed: if failed:
result['failed'] = True result['failed'] = True
result['msg'] = "The following modules failed to execute: %s\n" % (', '.join(failed.keys())) result['msg'] = "The following modules failed to execute: %s\n" % (', '.join(failed.keys()))
for fail in failed: result['failed_modules'] = failed
result['msg'] += ' %s: %s\n' % (fail, failed[fail])
# tell executor facts were gathered # tell executor facts were gathered
result['ansible_facts']['_ansible_facts_gathered'] = True result['ansible_facts']['_ansible_facts_gathered'] = True