mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-26 05:50:36 -07:00 
			
		
		
		
	Make use of Jinja tests 'finished' (#43233)
And also used 'changed' and 'failed' tests while we are at it.
This commit is contained in:
		
					parent
					
						
							
								1bab901966
							
						
					
				
			
			
				commit
				
					
						12e7e9650e
					
				
			
		
					 6 changed files with 29 additions and 21 deletions
				
			
		|  | @ -75,7 +75,7 @@ | ||||||
| - name: assert task was successfully started | - name: assert task was successfully started | ||||||
|   assert: |   assert: | ||||||
|     that: |     that: | ||||||
|     - fnf_task.started |     - fnf_task.started == 1 | ||||||
|     - "'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"' | ||||||
|  |  | ||||||
|  | @ -30,6 +30,7 @@ | ||||||
|     that: |     that: | ||||||
|     - async_result.ansible_job_id is match('\d+\.\d+') |     - async_result.ansible_job_id is match('\d+\.\d+') | ||||||
|     - async_result.finished == 1 |     - async_result.finished == 1 | ||||||
|     - async_result.changed == true |     - async_result is finished | ||||||
|  |     - async_result is changed | ||||||
|     - async_result is successful |     - async_result is successful | ||||||
|     - async_result.msg is search('succeeded') |     - async_result.msg is search('succeeded') | ||||||
|  |  | ||||||
|  | @ -336,19 +336,19 @@ | ||||||
|     - name: wait for async job 1 |     - name: wait for async job 1 | ||||||
|       async_status: jid={{ async_1.ansible_job_id }} |       async_status: jid={{ async_1.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
|     - name: wait for async job 2 |     - name: wait for async job 2 | ||||||
|       async_status: jid={{ async_1.ansible_job_id }} |       async_status: jid={{ async_1.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
|     - name: wait for async job 3 |     - name: wait for async job 3 | ||||||
|       async_status: jid={{ async_3.ansible_job_id }} |       async_status: jid={{ async_3.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -407,19 +407,19 @@ | ||||||
|     - name: wait for async job 1 |     - name: wait for async job 1 | ||||||
|       async_status: jid={{ async_1.ansible_job_id }} |       async_status: jid={{ async_1.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
|     - name: wait for async job 2 |     - name: wait for async job 2 | ||||||
|       async_status: jid={{ async_1.ansible_job_id }} |       async_status: jid={{ async_1.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
|     - name: wait for async job 3 |     - name: wait for async job 3 | ||||||
|       async_status: jid={{ async_3.ansible_job_id }} |       async_status: jid={{ async_3.ansible_job_id }} | ||||||
|       register: job_result |       register: job_result | ||||||
|       until: job_result.finished |       until: job_result is finished | ||||||
|       retries: 30 |       retries: 30 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -93,7 +93,7 @@ | ||||||
|       async_status: |       async_status: | ||||||
|         jid: "{{ test_async.ansible_job_id }}" |         jid: "{{ test_async.ansible_job_id }}" | ||||||
|       register: status |       register: status | ||||||
|       until: status.finished |       until: status is finished | ||||||
|       retries: 10 |       retries: 10 | ||||||
| 
 | 
 | ||||||
|     - name: check that roles file lookups work as expected |     - name: check that roles file lookups work as expected | ||||||
|  |  | ||||||
|  | @ -435,7 +435,7 @@ | ||||||
|     - name: Ensure ec2_asg task completes |     - name: Ensure ec2_asg task completes | ||||||
|       async_status: jid="{{ asg_job.ansible_job_id }}" |       async_status: jid="{{ asg_job.ansible_job_id }}" | ||||||
|       register: status |       register: status | ||||||
|       until: status.finished |       until: status is finished | ||||||
|       retries: 200 |       retries: 200 | ||||||
|       delay: 15 |       delay: 15 | ||||||
| 
 | 
 | ||||||
|  | @ -497,7 +497,7 @@ | ||||||
|     - name: Ensure ec2_asg task completes |     - name: Ensure ec2_asg task completes | ||||||
|       async_status: jid="{{ asg_job.ansible_job_id }}" |       async_status: jid="{{ asg_job.ansible_job_id }}" | ||||||
|       register: status |       register: status | ||||||
|       until: status.finished |       until: status is finished | ||||||
|       retries: 200 |       retries: 200 | ||||||
|       delay: 15 |       delay: 15 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -15,6 +15,7 @@ | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.started == 1 |     - asyncresult.started == 1 | ||||||
|     - asyncresult.finished == 0 |     - asyncresult.finished == 0 | ||||||
|  |     - asyncresult is not finished | ||||||
|     - asyncresult.results_file is search('\.ansible_async.+\d+\.\d+') |     - asyncresult.results_file is search('\.ansible_async.+\d+\.\d+') | ||||||
|      # ensure that async is actually async- this test will fail if # hosts > forks or if the target host is VERY slow |      # ensure that async is actually async- this test will fail if # hosts > forks or if the target host is VERY slow | ||||||
|     - (lookup('pipe', 'date +%s') | int) - (start_timestamp | int) < 8 |     - (lookup('pipe', 'date +%s') | int) - (start_timestamp | int) < 8 | ||||||
|  | @ -31,7 +32,8 @@ | ||||||
|     that: |     that: | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.finished == 1 |     - asyncresult.finished == 1 | ||||||
|     - asyncresult.changed == true |     - asyncresult is finished | ||||||
|  |     - asyncresult is changed | ||||||
|     - asyncresult.ansible_async_watchdog_pid is number |     - asyncresult.ansible_async_watchdog_pid is number | ||||||
| #    - asyncresult.module_tempdir is search('ansible-tmp-') | #    - asyncresult.module_tempdir is search('ansible-tmp-') | ||||||
|     - asyncresult.module_pid is number |     - asyncresult.module_pid is number | ||||||
|  | @ -68,7 +70,8 @@ | ||||||
|     that: |     that: | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.finished == 1 |     - asyncresult.finished == 1 | ||||||
|     - asyncresult.changed == true |     - asyncresult is finished | ||||||
|  |     - asyncresult is changed | ||||||
| #    - asyncresult.module_tempdir is search('ansible-tmp-') | #    - asyncresult.module_tempdir is search('ansible-tmp-') | ||||||
|     - asyncresult.module_pid is number |     - asyncresult.module_pid is number | ||||||
| 
 | 
 | ||||||
|  | @ -105,8 +108,9 @@ | ||||||
|     that: |     that: | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.finished == 1 |     - asyncresult.finished == 1 | ||||||
|     - asyncresult.changed == false |     - asyncresult is finished | ||||||
|     - asyncresult is failed == true |     - asyncresult is not changed | ||||||
|  |     - asyncresult is failed | ||||||
|     - asyncresult.msg is search('timed out') |     - asyncresult.msg is search('timed out') | ||||||
| 
 | 
 | ||||||
| - name: async poll graceful module failure | - name: async poll graceful module failure | ||||||
|  | @ -122,8 +126,9 @@ | ||||||
|     that: |     that: | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.finished == 1 |     - asyncresult.finished == 1 | ||||||
|     - asyncresult.changed == true |     - asyncresult is finished | ||||||
|     - asyncresult is failed == true |     - asyncresult is changed | ||||||
|  |     - asyncresult is failed | ||||||
|     - asyncresult.msg == 'failed gracefully' |     - asyncresult.msg == 'failed gracefully' | ||||||
| 
 | 
 | ||||||
| - name: async poll exception module failure | - name: async poll exception module failure | ||||||
|  | @ -139,8 +144,9 @@ | ||||||
|     that: |     that: | ||||||
|     - asyncresult.ansible_job_id is match('\d+\.\d+') |     - asyncresult.ansible_job_id is match('\d+\.\d+') | ||||||
|     - asyncresult.finished == 1 |     - asyncresult.finished == 1 | ||||||
|     - asyncresult.changed == false |     - asyncresult is finished | ||||||
|     - asyncresult is failed == true |     - asyncresult is not changed | ||||||
|  |     - asyncresult is failed | ||||||
| # TODO: re-enable after catastrophic failure behavior is cleaned up | # TODO: re-enable after catastrophic failure behavior is cleaned up | ||||||
| #    - asyncresult.msg is search('failing via exception') | #    - asyncresult.msg is search('failing via exception') | ||||||
| 
 | 
 | ||||||
|  | @ -184,7 +190,7 @@ | ||||||
| #  async_status: | #  async_status: | ||||||
| #    jid: "{{ item }}" | #    jid: "{{ item }}" | ||||||
| #  register: asyncout | #  register: asyncout | ||||||
| #  until: asyncout.finished == 1 | #  until: asyncout is finished | ||||||
| #  retries: 10 | #  retries: 10 | ||||||
| #  delay: 1 | #  delay: 1 | ||||||
| #  with_items: "{{ async_many.results | map(attribute='ansible_job_id') | list }}" | #  with_items: "{{ async_many.results | map(attribute='ansible_job_id') | list }}" | ||||||
|  | @ -193,8 +199,9 @@ | ||||||
| #  assert: | #  assert: | ||||||
| #    that: | #    that: | ||||||
| #    - item.finished == 1 | #    - item.finished == 1 | ||||||
|  | #    - item is finished | ||||||
| #    - item.slept_sec == 3 | #    - item.slept_sec == 3 | ||||||
| #    - item.changed == true | #    - item is changed | ||||||
| #    - item.ansible_job_id is match('\d+\.\d+') | #    - item.ansible_job_id is match('\d+\.\d+') | ||||||
| #  with_items: "{{ asyncout.results }}" | #  with_items: "{{ asyncout.results }}" | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue