mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -07:00 
			
		
		
		
	Fix ec2_snapshot_facts for python3
Avoid the following seen when running ec2_ami tests on python3,
presumably because the return type of `map` is different between
python2 and python3.
```
Traceback (most recent call last):
  File "/tmp/ansible_e44v27uj/ansible_module_ec2_snapshot_facts.py", line 242, in <module>
    main()
  File "/tmp/ansible_e44v27uj/ansible_module_ec2_snapshot_facts.py", line 238, in main
    list_ec2_snapshots(connection, module)
  File "/tmp/ansible_e44v27uj/ansible_module_ec2_snapshot_facts.py", line 193, in list_ec2_snapshots
    snapshots = connection.describe_snapshots(SnapshotIds=snapshot_ids, OwnerIds=owner_ids, RestorableByUserIds=restorable_by_user_ids, Filters=filters)
  File "/usr/local/lib/python3.5/dist-packages/botocore/client.py", line 312, in _api_call
    return self._make_api_call(operation_name, kwargs)
  File "/usr/local/lib/python3.5/dist-packages/botocore/client.py", line 575, in _make_api_call
    api_params, operation_model, context=request_context)
  File "/usr/local/lib/python3.5/dist-packages/botocore/client.py", line 630, in _convert_to_request_dict
    api_params, operation_model)
  File "/usr/local/lib/python3.5/dist-packages/botocore/validate.py", line 291, in serialize_to_request
    raise ParamValidationError(report=report.generate_report())
botocore.exceptions.ParamValidationError: Parameter validation failed:
Invalid type for parameter OwnerIds, value: <map object at 0x7ff577511048>, type: <class 'map'>, valid types: <class 'list'>, <class 'tuple'>
```
https://github.com/ansible/ansible/pull/30435#issuecomment-330750498
	
	
This commit is contained in:
		
					parent
					
						
							
								0a114436fc
							
						
					
				
			
			
				commit
				
					
						5900fee67a
					
				
			
		
					 2 changed files with 15 additions and 16 deletions
				
			
		|  | @ -185,8 +185,8 @@ from ansible.module_utils.ec2 import (ansible_dict_to_boto3_filter_list, | ||||||
| def list_ec2_snapshots(connection, module): | def list_ec2_snapshots(connection, module): | ||||||
| 
 | 
 | ||||||
|     snapshot_ids = module.params.get("snapshot_ids") |     snapshot_ids = module.params.get("snapshot_ids") | ||||||
|     owner_ids = map(str, module.params.get("owner_ids")) |     owner_ids = [str(owner_id) for owner_id in module.params.get("owner_ids")] | ||||||
|     restorable_by_user_ids = module.params.get("restorable_by_user_ids") |     restorable_by_user_ids = [str(user_id) for user_id in module.params.get("restorable_by_user_ids")] | ||||||
|     filters = ansible_dict_to_boto3_filter_list(module.params.get("filters")) |     filters = ansible_dict_to_boto3_filter_list(module.params.get("filters")) | ||||||
| 
 | 
 | ||||||
|     try: |     try: | ||||||
|  |  | ||||||
|  | @ -346,21 +346,20 @@ | ||||||
|           - "result.changed" |           - "result.changed" | ||||||
|           - "'image_id' not in result" |           - "'image_id' not in result" | ||||||
| 
 | 
 | ||||||
| # FIXME: in ec2_snapshot_facts OwnerIds is cast to a map, causing traceback (needs to be a list or tuple) |     - name: ensure the snapshot still exists | ||||||
| #    - name: ensure the snapshot still exists |       ec2_snapshot_facts: | ||||||
| #      ec2_snapshot_facts: |         snapshot_ids: | ||||||
| #        snapshot_ids: |           - '{{ ec2_ami_snapshot }}' | ||||||
| #          - '{{ ec2_ami_snapshot }}' |         ec2_region: '{{ec2_region}}' | ||||||
| #        ec2_region: '{{ec2_region}}' |         ec2_access_key: '{{ec2_access_key}}' | ||||||
| #        ec2_access_key: '{{ec2_access_key}}' |         ec2_secret_key: '{{ec2_secret_key}}' | ||||||
| #        ec2_secret_key: '{{ec2_secret_key}}' |         security_token: '{{security_token}}' | ||||||
| #        security_token: '{{security_token}}' |       register: snapshot_result | ||||||
| #      register: snapshot_result |  | ||||||
| 
 | 
 | ||||||
| #    - name: assert the snapshot wasn't deleted |     - name: assert the snapshot wasn't deleted | ||||||
| #      assert: |       assert: | ||||||
| #        that: |         that: | ||||||
| #          - "snapshot_result.snapshots[0].snapshot_id == ec2_ami_snapshot" |           - "snapshot_result.snapshots[0].snapshot_id == ec2_ami_snapshot" | ||||||
| 
 | 
 | ||||||
|     - name: delete ami for a second time |     - name: delete ami for a second time | ||||||
|       ec2_ami: |       ec2_ami: | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue