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:
Martin Krizek 2020-08-28 08:01:26 +02:00 committed by GitHub
parent 2bbcbe99fd
commit d083307e36
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 9 additions and 2 deletions

View file

@ -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)

View file

@ -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:

View file

@ -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'"