Merge pull request #2134 from ogckw/master
Fix #2129 EC2 tag should raise ClientError when resource is empty
This commit is contained in:
		
						commit
						d8dbc6a49c
					
				| @ -134,6 +134,8 @@ def utc_date_and_time(): | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def validate_resource_ids(resource_ids): | def validate_resource_ids(resource_ids): | ||||||
|  |     if not resource_ids: | ||||||
|  |         raise MissingParameterError(parameter='resourceIdSet') | ||||||
|     for resource_id in resource_ids: |     for resource_id in resource_ids: | ||||||
|         if not is_valid_resource_id(resource_id): |         if not is_valid_resource_id(resource_id): | ||||||
|             raise InvalidID(resource_id=resource_id) |             raise InvalidID(resource_id=resource_id) | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import itertools | |||||||
| 
 | 
 | ||||||
| import boto | import boto | ||||||
| import boto3 | import boto3 | ||||||
|  | from botocore.exceptions import ClientError | ||||||
| from boto.exception import EC2ResponseError | from boto.exception import EC2ResponseError | ||||||
| from boto.ec2.instance import Reservation | from boto.ec2.instance import Reservation | ||||||
| import sure  # noqa | import sure  # noqa | ||||||
| @ -451,3 +452,31 @@ def test_create_snapshot_with_tags(): | |||||||
|     }] |     }] | ||||||
| 
 | 
 | ||||||
|     assert snapshot['Tags'] == expected_tags |     assert snapshot['Tags'] == expected_tags | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @mock_ec2 | ||||||
|  | def test_create_tag_empty_resource(): | ||||||
|  |     # create ec2 client in us-west-1 | ||||||
|  |     client = boto3.client('ec2', region_name='us-west-1') | ||||||
|  |     # create tag with empty resource | ||||||
|  |     with assert_raises(ClientError) as ex: | ||||||
|  |         client.create_tags( | ||||||
|  |             Resources=[], | ||||||
|  |             Tags=[{'Key': 'Value'}] | ||||||
|  |         ) | ||||||
|  |     ex.exception.response['Error']['Code'].should.equal('MissingParameter') | ||||||
|  |     ex.exception.response['Error']['Message'].should.equal('The request must contain the parameter resourceIdSet') | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @mock_ec2 | ||||||
|  | def test_delete_tag_empty_resource(): | ||||||
|  |     # create ec2 client in us-west-1 | ||||||
|  |     client = boto3.client('ec2', region_name='us-west-1') | ||||||
|  |     # delete tag with empty resource | ||||||
|  |     with assert_raises(ClientError) as ex: | ||||||
|  |         client.delete_tags( | ||||||
|  |             Resources=[], | ||||||
|  |             Tags=[{'Key': 'Value'}] | ||||||
|  |         ) | ||||||
|  |     ex.exception.response['Error']['Code'].should.equal('MissingParameter') | ||||||
|  |     ex.exception.response['Error']['Message'].should.equal('The request must contain the parameter resourceIdSet') | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user