Set global skipped result flag for looped tasks (#67847)
This allows for the skipped filter to be used on a registered looped task results. Fixes #16949
This commit is contained in:
parent
2bbcbe99fd
commit
d083307e36
3 changed files with 9 additions and 2 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
minor_changes:
|
||||||
|
- Allow for the skipped filter to be used on a registered looped task results. (https://github.com/ansible/ansible/issues/16949)
|
|
@ -122,10 +122,13 @@ class TaskExecutor:
|
||||||
# create the overall result item
|
# create the overall result item
|
||||||
res = dict(results=item_results)
|
res = dict(results=item_results)
|
||||||
|
|
||||||
# loop through the item results, and set the global changed/failed result flags based on any item.
|
# loop through the item results and set the global changed/failed/skipped result flags based on any item.
|
||||||
|
res['skipped'] = True
|
||||||
for item in item_results:
|
for item in item_results:
|
||||||
if 'changed' in item and item['changed'] and not res.get('changed'):
|
if 'changed' in item and item['changed'] and not res.get('changed'):
|
||||||
res['changed'] = True
|
res['changed'] = True
|
||||||
|
if res['skipped'] and ('skipped' not in item or ('skipped' in item and not item['skipped'])):
|
||||||
|
res['skipped'] = False
|
||||||
if 'failed' in item and item['failed']:
|
if 'failed' in item and item['failed']:
|
||||||
item_ignore = item.pop('_ansible_ignore_errors')
|
item_ignore = item.pop('_ansible_ignore_errors')
|
||||||
if not res.get('failed'):
|
if not res.get('failed'):
|
||||||
|
@ -147,6 +150,8 @@ class TaskExecutor:
|
||||||
|
|
||||||
if not res.get('failed', False):
|
if not res.get('failed', False):
|
||||||
res['msg'] = 'All items completed'
|
res['msg'] = 'All items completed'
|
||||||
|
if res['skipped']:
|
||||||
|
res['msg'] = 'All items skipped'
|
||||||
else:
|
else:
|
||||||
res = dict(changed=False, skipped=True, skipped_reason='No items in the list', results=[])
|
res = dict(changed=False, skipped=True, skipped_reason='No items in the list', results=[])
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -39,7 +39,7 @@
|
||||||
- name: verify with_subelements in subkeys results
|
- name: verify with_subelements in subkeys results
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- _subelements_missing_subkeys.skipped is not defined
|
- _subelements_missing_subkeys is not skipped
|
||||||
- _subelements_missing_subkeys.results|length == 2
|
- _subelements_missing_subkeys.results|length == 2
|
||||||
- "_xk == 'k'"
|
- "_xk == 'k'"
|
||||||
- "_xl == 'l'"
|
- "_xl == 'l'"
|
||||||
|
|
Loading…
Reference in a new issue