mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	Ensure exit_json returns failed = False
This is required for modules that may return a non-zero `rc` value for a successful run, similar to #24865 for Windows fixing **win_chocolatey**. We also disable the dependency on `rc` value only, even if `failed` was set. Adapted unit and integration tests to the new scheme. Updated raw, shell, script, expect to take `rc` into account.
This commit is contained in:
		
					parent
					
						
							
								1f78715848
							
						
					
				
			
			
				commit
				
					
						0e160d5c7e
					
				
			
		
					 17 changed files with 68 additions and 56 deletions
				
			
		|  | @ -111,7 +111,6 @@ | |||
| - name: assert new EIP was assigned | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
|       - '"public_ip" in result' | ||||
| 
 | ||||
| 
 | ||||
|  | @ -128,10 +127,6 @@ | |||
|     instance_id={{ instance_id }} | ||||
|   register: result | ||||
| 
 | ||||
| - name: assert success disassociate EIP associated with instance | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
| 
 | ||||
| # eip allocated:1 assigned:0 | ||||
| 
 | ||||
|  | @ -152,7 +147,6 @@ | |||
| - name: assert new EIP was assigned | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
|       - '"public_ip" in result' | ||||
| 
 | ||||
| 
 | ||||
|  | @ -176,11 +170,6 @@ | |||
|     ec2_secret_key={{ ec2_secret_key }} | ||||
|   register: result | ||||
| 
 | ||||
| - name: assert EIP deactivated | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
| 
 | ||||
| 
 | ||||
| # eip allocated:0 assigned:0 | ||||
| 
 | ||||
|  | @ -205,7 +194,6 @@ | |||
| - name: assert provision EIP with instance_id | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
|       - '"public_ip" in result' | ||||
| 
 | ||||
| 
 | ||||
|  | @ -245,7 +233,6 @@ | |||
| - name: assert VPC EIP creation | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
|       - '"public_ip" in result' | ||||
| 
 | ||||
| 
 | ||||
|  | @ -268,7 +255,6 @@ | |||
| #- name: assert new VPC EIP was assigned | ||||
| #  assert: | ||||
| #    that: | ||||
| #      - '"failed" not in result' | ||||
| #      - '"public_ip" in result' | ||||
| # | ||||
| # | ||||
|  | @ -307,7 +293,6 @@ | |||
| - name: assert environment variable EC2_REGION | ||||
|   assert: | ||||
|     that: | ||||
|       - '"failed" not in result' | ||||
|       - '"public_ip" in result' | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -60,7 +60,6 @@ | |||
|     - assert: | ||||
|         that: | ||||
|           - 'info.changed' | ||||
|           - '"failed" not in info' | ||||
|           - 'info.elb.status == "created"' | ||||
|           - '"us-east-1c" in info.elb.zones' | ||||
|           - '"us-east-1d" in info.elb.zones' | ||||
|  | @ -124,7 +123,6 @@ | |||
| 
 | ||||
|     - assert: | ||||
|         that: | ||||
|           - '"failed" not in info' | ||||
|           - 'info.elb.status == "ok"' | ||||
|           - 'info.changed' | ||||
|           - 'info.elb.zones[0] == "us-east-1b"' | ||||
|  | @ -154,7 +152,6 @@ | |||
| 
 | ||||
|     - assert: | ||||
|         that: | ||||
|           - '"failed" not in info' | ||||
|           - 'info.changed' | ||||
|           - 'info.elb.status == "ok"' | ||||
|           - '"us-east-1b" in info.elb.zones' | ||||
|  | @ -187,7 +184,6 @@ | |||
| 
 | ||||
|     - assert: | ||||
|         that: | ||||
|           - '"failed" not in info' | ||||
|           - 'info.elb.status == "ok"' | ||||
|           - 'info.changed' | ||||
|           - '[80, 81, "HTTP", "HTTP"] in info.elb.listeners' | ||||
|  | @ -220,7 +216,6 @@ | |||
| 
 | ||||
|     - assert: | ||||
|         that: | ||||
|           - '"failed" not in info' | ||||
|           - 'info.elb.status == "ok"' | ||||
|           - 'info.changed' | ||||
|           - '[80, 81, "HTTP", "HTTP"] in info.elb.listeners' | ||||
|  |  | |||
|  | @ -188,11 +188,6 @@ | |||
|         state=absent | ||||
|       register: result | ||||
| 
 | ||||
|     - name: assert state=absent | ||||
|       assert: | ||||
|         that: | ||||
|            - '"failed" not in result' | ||||
| 
 | ||||
|     # ============================================================ | ||||
|     - name: test state=present (expected changed=true) | ||||
|       ec2_group: | ||||
|  |  | |||
|  | @ -157,11 +157,6 @@ | |||
|         state=absent | ||||
|       register: result | ||||
| 
 | ||||
|     - name: assert state=absent with key_material | ||||
|       assert: | ||||
|         that: | ||||
|            - '"failed" not in result' | ||||
| 
 | ||||
|     # ============================================================ | ||||
|     - name: test state=present without key_material | ||||
|       ec2_key: | ||||
|  | @ -177,7 +172,6 @@ | |||
|       assert: | ||||
|         that: | ||||
|            - 'result.changed' | ||||
|            - '"failed" not in result' | ||||
|            - '"key" in result' | ||||
|            - '"name" in result.key' | ||||
|            - '"fingerprint" in result.key' | ||||
|  | @ -200,7 +194,6 @@ | |||
|       assert: | ||||
|         that: | ||||
|            - 'result.changed' | ||||
|            - '"failed" not in result' | ||||
|            - '"key" in result' | ||||
|            - 'result.key == None' | ||||
| 
 | ||||
|  | @ -220,7 +213,6 @@ | |||
|     - name: assert state=present with key_material | ||||
|       assert: | ||||
|         that: | ||||
|            - '"failed" not in result' | ||||
|            - 'result.changed == True' | ||||
|            - '"key" in result' | ||||
|            - '"name" in result.key' | ||||
|  | @ -246,7 +238,6 @@ | |||
|       assert: | ||||
|         that: | ||||
|            - 'result.changed' | ||||
|            - '"failed" not in result' | ||||
|            - '"key" in result' | ||||
|            - 'result.key == None' | ||||
| 
 | ||||
|  | @ -324,7 +315,6 @@ | |||
|       assert: | ||||
|         that: | ||||
|            - 'result.changed' | ||||
|            - '"failed" not in result' | ||||
|            - '"key" in result' | ||||
|            - 'result.key == None' | ||||
| 
 | ||||
|  | @ -345,6 +335,5 @@ | |||
|       assert: | ||||
|         that: | ||||
|            - 'not result.changed' | ||||
|            - '"failed" not in result' | ||||
|            - '"key" in result' | ||||
|            - 'result.key == None' | ||||
|  |  | |||
|  | @ -23,7 +23,7 @@ | |||
| 
 | ||||
| - assert: | ||||
|     that: | ||||
|       - "'failed' not in result" | ||||
|       - "'failed' in result and not result.failed" | ||||
| 
 | ||||
| - name: command rc 0 failed_when_result False | ||||
|   shell: exit 0 | ||||
|  |  | |||
|  | @ -95,7 +95,7 @@ | |||
| - name: check fetch directory result | ||||
|   assert: | ||||
|     that: | ||||
|       - "failed_fetch_dir['failed']" | ||||
|       - "failed_fetch_dir|failed" | ||||
|       - "fetch_dir.msg" | ||||
| 
 | ||||
| - name: create symlink to a file that we can fetch | ||||
|  |  | |||
|  | @ -111,7 +111,7 @@ | |||
| - name: Assert that the file was not downloaded | ||||
|   assert: | ||||
|     that: | ||||
|       - "result.failed == true" | ||||
|       - "result|failed" | ||||
|       - "'Failed to validate the SSL certificate' in result.msg" | ||||
|       - "stat_result.stat.exists == false" | ||||
| 
 | ||||
|  | @ -150,14 +150,13 @@ | |||
|   assert: | ||||
|     that: | ||||
|       - 'data_result.rc == 0' | ||||
|       - '"failed" not in get_url_result' | ||||
|   when: "{{ python_has_ssl_context }}" | ||||
| 
 | ||||
| # If the client doesn't support SNI then get_url should have failed with a certificate mismatch | ||||
| - name: Assert that hostname verification failed because SNI is not supported on this version of python | ||||
|   assert: | ||||
|     that: | ||||
|       - 'get_url_result["failed"]' | ||||
|       - 'get_url_result|failed' | ||||
|   when: "{{ not python_has_ssl_context }}" | ||||
| 
 | ||||
| # These tests are just side effects of how the site is hosted.  It's not | ||||
|  | @ -178,14 +177,14 @@ | |||
|   assert: | ||||
|     that: | ||||
|       - 'data_result.rc == 0' | ||||
|       - '"failed" not in get_url_result' | ||||
|       - 'not get_url_result|failed' | ||||
|   when: "{{ python_has_ssl_context }}" | ||||
| 
 | ||||
| # If the client doesn't support SNI then get_url should have failed with a certificate mismatch | ||||
| - name: Assert that hostname verification failed because SNI is not supported on this version of python | ||||
|   assert: | ||||
|     that: | ||||
|       - 'get_url_result["failed"]' | ||||
|       - 'get_url_result|failed' | ||||
|   when: "{{ not python_has_ssl_context }}" | ||||
| # End hacky SNI test section | ||||
| 
 | ||||
|  |  | |||
|  | @ -155,6 +155,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 5 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  | @ -237,6 +238,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 11 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: "Hidden, Archive", | ||||
|  | @ -278,6 +280,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 5 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  | @ -315,6 +318,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 8 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  | @ -383,6 +387,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 10 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  | @ -465,6 +470,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 2 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: False, | ||||
|           attributes: Directory, | ||||
|  | @ -529,6 +535,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 5 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  | @ -571,6 +578,7 @@ | |||
|     expected: | ||||
|       changed: False | ||||
|       examined: 5 | ||||
|       failed: False | ||||
|       files: | ||||
|       - { isarchive: True, | ||||
|           attributes: Archive, | ||||
|  |  | |||
|  | @ -52,6 +52,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       properties: | ||||
|         binary: { raw_value: ["0x01", "0x16"], type: 'REG_BINARY', value: [1, 22] } | ||||
|         dword: { raw_value: 1, type: 'REG_DWORD', value: 1 } | ||||
|  | @ -79,6 +80,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       properties: | ||||
|         none: { raw_value: [], type: 'REG_NONE', value: [] } | ||||
|         none1: { raw_value: ["0x00"], type: 'REG_NONE', value: [0] } | ||||
|  | @ -101,6 +103,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       properties: {} | ||||
|       sub_keys: [] | ||||
|   register: expected | ||||
|  | @ -120,6 +123,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: false | ||||
|       failed: false | ||||
| 
 | ||||
| - name: validate test | ||||
|   assert: | ||||
|  | @ -137,6 +141,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: 'test' | ||||
|       type: 'REG_SZ' | ||||
|       value: 'test' | ||||
|  | @ -157,6 +162,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: '%windir%\dir' | ||||
|       type: 'REG_EXPAND_SZ' | ||||
|       value: "{{win_dir_value.stdout_lines[0]}}\\dir" | ||||
|  | @ -177,6 +183,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: ['a, b', 'c'] | ||||
|       type: 'REG_MULTI_SZ' | ||||
|       value: ['a, b', 'c'] | ||||
|  | @ -197,6 +204,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: ["0x01", "0x16"] | ||||
|       type: 'REG_BINARY' | ||||
|       value: [1, 22] | ||||
|  | @ -217,6 +225,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: 1 | ||||
|       type: 'REG_DWORD' | ||||
|       value: 1 | ||||
|  | @ -237,6 +246,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: 1 | ||||
|       type: 'REG_QWORD' | ||||
|       value: 1 | ||||
|  | @ -257,6 +267,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: [] | ||||
|       type: 'REG_NONE' | ||||
|       value: [] | ||||
|  | @ -277,6 +288,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: true | ||||
|       failed: false | ||||
|       raw_value: ["0x00"] | ||||
|       type: 'REG_NONE' | ||||
|       value: [0] | ||||
|  | @ -297,6 +309,7 @@ | |||
|     expected: | ||||
|       changed: false | ||||
|       exists: false | ||||
|       failed: false | ||||
| 
 | ||||
| - name: validate test | ||||
|   assert: | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue