Add codepipeline.untag_resource
This commit is contained in:
		
							parent
							
								
									b96a46b98f
								
							
						
					
					
						commit
						8331d480ba
					
				| @ -1374,7 +1374,7 @@ | |||||||
| - [ ] update_profiling_group | - [ ] update_profiling_group | ||||||
| 
 | 
 | ||||||
| ## codepipeline | ## codepipeline | ||||||
| 13% implemented | 22% implemented | ||||||
| - [ ] acknowledge_job | - [ ] acknowledge_job | ||||||
| - [ ] acknowledge_third_party_job | - [ ] acknowledge_third_party_job | ||||||
| - [ ] create_custom_action_type | - [ ] create_custom_action_type | ||||||
| @ -1394,7 +1394,7 @@ | |||||||
| - [ ] list_action_types | - [ ] list_action_types | ||||||
| - [ ] list_pipeline_executions | - [ ] list_pipeline_executions | ||||||
| - [X] list_pipelines | - [X] list_pipelines | ||||||
| - [ ] list_tags_for_resource | - [X] list_tags_for_resource | ||||||
| - [ ] list_webhooks | - [ ] list_webhooks | ||||||
| - [ ] poll_for_jobs | - [ ] poll_for_jobs | ||||||
| - [ ] poll_for_third_party_jobs | - [ ] poll_for_third_party_jobs | ||||||
| @ -1408,8 +1408,8 @@ | |||||||
| - [ ] register_webhook_with_third_party | - [ ] register_webhook_with_third_party | ||||||
| - [ ] retry_stage_execution | - [ ] retry_stage_execution | ||||||
| - [ ] start_pipeline_execution | - [ ] start_pipeline_execution | ||||||
| - [ ] tag_resource | - [X] tag_resource | ||||||
| - [ ] untag_resource | - [X] untag_resource | ||||||
| - [X] update_pipeline | - [X] update_pipeline | ||||||
| 
 | 
 | ||||||
| ## codestar | ## codestar | ||||||
|  | |||||||
| @ -192,6 +192,20 @@ class CodePipelineBackend(BaseBackend): | |||||||
|         for tag in tags: |         for tag in tags: | ||||||
|             pipeline.tags.update({tag["key"]: tag["value"]}) |             pipeline.tags.update({tag["key"]: tag["value"]}) | ||||||
| 
 | 
 | ||||||
|  |     def untag_resource(self, arn, tag_keys): | ||||||
|  |         name = arn.split(":")[-1] | ||||||
|  |         pipeline = self.pipelines.get(name) | ||||||
|  | 
 | ||||||
|  |         if not pipeline: | ||||||
|  |             raise ResourceNotFoundException( | ||||||
|  |                 "The account with id '{0}' does not include a pipeline with the name '{1}'".format( | ||||||
|  |                     ACCOUNT_ID, name | ||||||
|  |                 ) | ||||||
|  |             ) | ||||||
|  | 
 | ||||||
|  |         for key in tag_keys: | ||||||
|  |             pipeline.tags.pop(key, None) | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| codepipeline_backends = {} | codepipeline_backends = {} | ||||||
| for region in Session().get_available_regions("codepipeline"): | for region in Session().get_available_regions("codepipeline"): | ||||||
|  | |||||||
| @ -53,3 +53,10 @@ class CodePipelineResponse(BaseResponse): | |||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         return "" |         return "" | ||||||
|  | 
 | ||||||
|  |     def untag_resource(self): | ||||||
|  |         self.codepipeline_backend.untag_resource( | ||||||
|  |             self._get_param("resourceArn"), self._get_param("tagKeys") | ||||||
|  |         ) | ||||||
|  | 
 | ||||||
|  |         return "" | ||||||
|  | |||||||
| @ -602,6 +602,52 @@ def test_tag_resource_errors(): | |||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @mock_codepipeline | ||||||
|  | def test_untag_resource(): | ||||||
|  |     client = boto3.client("codepipeline", region_name="us-east-1") | ||||||
|  |     name = "test-pipeline" | ||||||
|  |     create_basic_codepipeline(client, name) | ||||||
|  | 
 | ||||||
|  |     response = client.list_tags_for_resource( | ||||||
|  |         resourceArn="arn:aws:codepipeline:us-east-1:123456789012:{}".format(name) | ||||||
|  |     ) | ||||||
|  |     response["tags"].should.equal([{"key": "key", "value": "value"}]) | ||||||
|  | 
 | ||||||
|  |     client.untag_resource( | ||||||
|  |         resourceArn="arn:aws:codepipeline:us-east-1:123456789012:{}".format(name), | ||||||
|  |         tagKeys=["key"], | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  |     response = client.list_tags_for_resource( | ||||||
|  |         resourceArn="arn:aws:codepipeline:us-east-1:123456789012:{}".format(name) | ||||||
|  |     ) | ||||||
|  |     response["tags"].should.have.length_of(0) | ||||||
|  | 
 | ||||||
|  |     # removing a not existing tag should raise no exception | ||||||
|  |     client.untag_resource( | ||||||
|  |         resourceArn="arn:aws:codepipeline:us-east-1:123456789012:{}".format(name), | ||||||
|  |         tagKeys=["key"], | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @mock_codepipeline | ||||||
|  | def test_untag_resource_errors(): | ||||||
|  |     client = boto3.client("codepipeline", region_name="us-east-1") | ||||||
|  | 
 | ||||||
|  |     with assert_raises(ClientError) as e: | ||||||
|  |         client.untag_resource( | ||||||
|  |             resourceArn="arn:aws:codepipeline:us-east-1:123456789012:not-existing", | ||||||
|  |             tagKeys=["key"], | ||||||
|  |         ) | ||||||
|  |     ex = e.exception | ||||||
|  |     ex.operation_name.should.equal("UntagResource") | ||||||
|  |     ex.response["ResponseMetadata"]["HTTPStatusCode"].should.equal(400) | ||||||
|  |     ex.response["Error"]["Code"].should.contain("ResourceNotFoundException") | ||||||
|  |     ex.response["Error"]["Message"].should.equal( | ||||||
|  |         "The account with id '123456789012' does not include a pipeline with the name 'not-existing'" | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| @mock_iam | @mock_iam | ||||||
| def get_role_arn(): | def get_role_arn(): | ||||||
|     client = boto3.client("iam", region_name="us-east-1") |     client = boto3.client("iam", region_name="us-east-1") | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user