Added an async 'started' test (like 'finished') (#43445)
This commit is contained in:
parent
cc2164f92a
commit
3d70274864
3 changed files with 20 additions and 3 deletions
|
@ -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,
|
||||||
|
|
|
@ -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"'
|
||||||
|
|
|
@ -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+')
|
||||||
|
|
Loading…
Add table
Reference in a new issue