Add organizations.list_tags_for_resource

This commit is contained in:
gruebel 2019-11-17 15:10:38 +01:00
parent febec75364
commit c10afa3ab5
4 changed files with 59 additions and 1 deletions

View File

@ -4762,7 +4762,7 @@
- [X] list_policies - [X] list_policies
- [X] list_policies_for_target - [X] list_policies_for_target
- [X] list_roots - [X] list_roots
- [ ] list_tags_for_resource - [x] list_tags_for_resource
- [X] list_targets_for_policy - [X] list_targets_for_policy
- [X] move_account - [X] move_account
- [ ] remove_account_from_organization - [ ] remove_account_from_organization

View File

@ -455,5 +455,17 @@ class OrganizationsBackend(BaseBackend):
new_tags = {tag["Key"]: tag["Value"] for tag in kwargs["Tags"]} new_tags = {tag["Key"]: tag["Value"] for tag in kwargs["Tags"]}
account.tags.update(new_tags) account.tags.update(new_tags)
def list_tags_for_resource(self, **kwargs):
account = next((a for a in self.accounts if a.id == kwargs["ResourceId"]), None)
if account is None:
raise RESTError(
"InvalidInputException",
"You provided a value that does not match the required pattern.",
)
tags = [{"Key": key, "Value": value} for key, value in account.tags.items()]
return dict(Tags=tags)
organizations_backend = OrganizationsBackend() organizations_backend = OrganizationsBackend()

View File

@ -124,3 +124,8 @@ class OrganizationsResponse(BaseResponse):
return json.dumps( return json.dumps(
self.organizations_backend.tag_resource(**self.request_params) self.organizations_backend.tag_resource(**self.request_params)
) )
def list_tags_for_resource(self):
return json.dumps(
self.organizations_backend.list_tags_for_resource(**self.request_params)
)

View File

@ -618,6 +618,17 @@ def test_tag_resource():
client.tag_resource(ResourceId=account_id, Tags=[{"Key": "key", "Value": "value"}]) client.tag_resource(ResourceId=account_id, Tags=[{"Key": "key", "Value": "value"}])
response = client.list_tags_for_resource(ResourceId=account_id)
response["Tags"].should.equal([{"Key": "key", "Value": "value"}])
# adding a tag with an existing key, will update the value
client.tag_resource(
ResourceId=account_id, Tags=[{"Key": "key", "Value": "new-value"}]
)
response = client.list_tags_for_resource(ResourceId=account_id)
response["Tags"].should.equal([{"Key": "key", "Value": "new-value"}])
@mock_organizations @mock_organizations
def test_tag_resource_errors(): def test_tag_resource_errors():
@ -635,3 +646,33 @@ def test_tag_resource_errors():
ex.response["Error"]["Message"].should.contain( ex.response["Error"]["Message"].should.contain(
"You provided a value that does not match the required pattern." "You provided a value that does not match the required pattern."
) )
@mock_organizations
def test_list_tags_for_resource():
client = boto3.client("organizations", region_name="us-east-1")
client.create_organization(FeatureSet="ALL")
account_id = client.create_account(AccountName=mockname, Email=mockemail)[
"CreateAccountStatus"
]["AccountId"]
client.tag_resource(ResourceId=account_id, Tags=[{"Key": "key", "Value": "value"}])
response = client.list_tags_for_resource(ResourceId=account_id)
response["Tags"].should.equal([{"Key": "key", "Value": "value"}])
@mock_organizations
def test_list_tags_for_resource_errors():
client = boto3.client("organizations", region_name="us-east-1")
client.create_organization(FeatureSet="ALL")
with assert_raises(ClientError) as e:
client.list_tags_for_resource(ResourceId="000000000000")
ex = e.exception
ex.operation_name.should.equal("ListTagsForResource")
ex.response["Error"]["Code"].should.equal("400")
ex.response["Error"]["Message"].should.contain("InvalidInputException")
ex.response["Error"]["Message"].should.contain(
"You provided a value that does not match the required pattern."
)