Added an async 'started' test (like 'finished') (#43445)

This commit is contained in:
Dag Wieers 2018-08-24 01:29:34 +02:00 committed by GitHub
parent cc2164f92a
commit 3d70274864
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 20 additions and 3 deletions

View file

@ -84,16 +84,30 @@ def skipped(result):
return result.get('skipped', False) return result.get('skipped', False)
def started(result):
''' Test if async task has started '''
if not isinstance(result, MutableMapping):
raise errors.AnsibleFilterError("The 'started' test expects a dictionary")
if 'started' in result:
# For async tasks, return status
# NOTE: The value of started is 0 or 1, not False or True :-/
return result.get('started', 0) == 1
else:
# For non-async tasks, warn user, but return as if started
display.warning("The 'started' test expects an async task, but a non-async task was tested")
return True
def finished(result): def finished(result):
''' Test if async task has finished ''' ''' Test if async task has finished '''
if not isinstance(result, MutableMapping): if not isinstance(result, MutableMapping):
raise errors.AnsibleFilterError("The 'finished' test expects a dictionary") raise errors.AnsibleFilterError("The 'finished' test expects a dictionary")
if 'finished' in result: if 'finished' in result:
# For async tasks return status # For async tasks, return status
# NOTE: The value of finished it 0 or 1, not False or True :-/ # NOTE: The value of finished is 0 or 1, not False or True :-/
return result.get('finished', 0) == 1 return result.get('finished', 0) == 1
else: else:
# For non-async tasks warn user, but return as finished # For non-async tasks, warn user, but return as if finished
display.warning("The 'finished' test expects an async task, but a non-async task was tested") display.warning("The 'finished' test expects an async task, but a non-async task was tested")
return True return True
@ -175,6 +189,7 @@ class TestModule(object):
# async testing # async testing
'finished': finished, 'finished': finished,
'started': started,
# regex # regex
'match': match, 'match': match,

View file

@ -76,6 +76,7 @@
assert: assert:
that: that:
- fnf_task.started == 1 - fnf_task.started == 1
- fnf_task is started
- "'ansible_job_id' in fnf_task" - "'ansible_job_id' in fnf_task"
- name: 'check on task started as a "fire-and-forget"' - name: 'check on task started as a "fire-and-forget"'

View file

@ -14,6 +14,7 @@
that: that:
- asyncresult.ansible_job_id is match('\d+\.\d+') - asyncresult.ansible_job_id is match('\d+\.\d+')
- asyncresult.started == 1 - asyncresult.started == 1
- asyncresult is started
- asyncresult.finished == 0 - asyncresult.finished == 0
- asyncresult is not finished - asyncresult is not finished
- asyncresult.results_file is search('\.ansible_async.+\d+\.\d+') - asyncresult.results_file is search('\.ansible_async.+\d+\.\d+')