Merge pull request #3072 from bblommers/cloudformation-check-name-in-use
CloudFormation - Check stack name in use
This commit is contained in:
		
						commit
						09c061e8a8
					
				| @ -50,6 +50,12 @@ class CloudFormationResponse(BaseResponse): | ||||
|             for item in self._get_list_prefix("Tags.member") | ||||
|         ) | ||||
| 
 | ||||
|         if self.stack_name_exists(new_stack_name=stack_name): | ||||
|             template = self.response_template( | ||||
|                 CREATE_STACK_NAME_EXISTS_RESPONSE_TEMPLATE | ||||
|             ) | ||||
|             return 400, {"status": 400}, template.render(name=stack_name) | ||||
| 
 | ||||
|         # Hack dict-comprehension | ||||
|         parameters = dict( | ||||
|             [ | ||||
| @ -82,6 +88,12 @@ class CloudFormationResponse(BaseResponse): | ||||
|             template = self.response_template(CREATE_STACK_RESPONSE_TEMPLATE) | ||||
|             return template.render(stack=stack) | ||||
| 
 | ||||
|     def stack_name_exists(self, new_stack_name): | ||||
|         for stack in self.cloudformation_backend.stacks.values(): | ||||
|             if stack.name == new_stack_name: | ||||
|                 return True | ||||
|         return False | ||||
| 
 | ||||
|     @amzn_request_id | ||||
|     def create_change_set(self): | ||||
|         stack_name = self._get_param("StackName") | ||||
| @ -564,6 +576,15 @@ CREATE_STACK_RESPONSE_TEMPLATE = """<CreateStackResponse> | ||||
| </CreateStackResponse> | ||||
| """ | ||||
| 
 | ||||
| CREATE_STACK_NAME_EXISTS_RESPONSE_TEMPLATE = """<ErrorResponse xmlns="http://cloudformation.amazonaws.com/doc/2010-05-15/"> | ||||
|   <Error> | ||||
|     <Type>Sender</Type> | ||||
|     <Code>AlreadyExistsException</Code> | ||||
|     <Message>Stack [{{ name }}] already exists</Message> | ||||
|   </Error> | ||||
|   <RequestId>950ff8d7-812a-44b3-bb0c-9b271b954104</RequestId> | ||||
| </ErrorResponse>""" | ||||
| 
 | ||||
| UPDATE_STACK_RESPONSE_TEMPLATE = """<UpdateStackResponse xmlns="http://cloudformation.amazonaws.com/doc/2010-05-15/"> | ||||
|   <UpdateStackResult> | ||||
|     <StackId>{{ stack.stack_id }}</StackId> | ||||
|  | ||||
| @ -98,12 +98,12 @@ def test_create_stack_hosted_zone_by_id(): | ||||
|         }, | ||||
|     } | ||||
|     conn.create_stack( | ||||
|         "test_stack", template_body=json.dumps(dummy_template), parameters={}.items() | ||||
|         "test_stack1", template_body=json.dumps(dummy_template), parameters={}.items() | ||||
|     ) | ||||
|     r53_conn = boto.connect_route53() | ||||
|     zone_id = r53_conn.get_zones()[0].id | ||||
|     conn.create_stack( | ||||
|         "test_stack", | ||||
|         "test_stack2", | ||||
|         template_body=json.dumps(dummy_template2), | ||||
|         parameters={"ZoneId": zone_id}.items(), | ||||
|     ) | ||||
|  | ||||
| @ -919,7 +919,9 @@ def test_execute_change_set_w_name(): | ||||
| def test_describe_stack_pagination(): | ||||
|     conn = boto3.client("cloudformation", region_name="us-east-1") | ||||
|     for i in range(100): | ||||
|         conn.create_stack(StackName="test_stack", TemplateBody=dummy_template_json) | ||||
|         conn.create_stack( | ||||
|             StackName="test_stack_{}".format(i), TemplateBody=dummy_template_json | ||||
|         ) | ||||
| 
 | ||||
|     resp = conn.describe_stacks() | ||||
|     stacks = resp["Stacks"] | ||||
| @ -1211,7 +1213,8 @@ def test_list_exports_with_token(): | ||||
|         # Add index to ensure name is unique | ||||
|         dummy_output_template["Outputs"]["StackVPC"]["Export"]["Name"] += str(i) | ||||
|         cf.create_stack( | ||||
|             StackName="test_stack", TemplateBody=json.dumps(dummy_output_template) | ||||
|             StackName="test_stack_{}".format(i), | ||||
|             TemplateBody=json.dumps(dummy_output_template), | ||||
|         ) | ||||
|     exports = cf.list_exports() | ||||
|     exports["Exports"].should.have.length_of(100) | ||||
| @ -1273,3 +1276,16 @@ def test_non_json_redrive_policy(): | ||||
| 
 | ||||
|     stack.Resource("MainQueue").resource_status.should.equal("CREATE_COMPLETE") | ||||
|     stack.Resource("DeadLetterQueue").resource_status.should.equal("CREATE_COMPLETE") | ||||
| 
 | ||||
| 
 | ||||
| @mock_cloudformation | ||||
| def test_boto3_create_duplicate_stack(): | ||||
|     cf_conn = boto3.client("cloudformation", region_name="us-east-1") | ||||
|     cf_conn.create_stack( | ||||
|         StackName="test_stack", TemplateBody=dummy_template_json, | ||||
|     ) | ||||
| 
 | ||||
|     with assert_raises(ClientError): | ||||
|         cf_conn.create_stack( | ||||
|             StackName="test_stack", TemplateBody=dummy_template_json, | ||||
|         ) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user