feat: implement logs untag_log_group
This commit is contained in:
parent
0561a0050f
commit
9c66839f85
@ -4092,7 +4092,7 @@
|
|||||||
- [ ] stop_query
|
- [ ] stop_query
|
||||||
- [X] tag_log_group
|
- [X] tag_log_group
|
||||||
- [ ] test_metric_filter
|
- [ ] test_metric_filter
|
||||||
- [ ] untag_log_group
|
- [X] untag_log_group
|
||||||
|
|
||||||
## machinelearning
|
## machinelearning
|
||||||
0% implemented
|
0% implemented
|
||||||
|
@ -240,6 +240,10 @@ class LogGroup:
|
|||||||
else:
|
else:
|
||||||
self.tags = tags
|
self.tags = tags
|
||||||
|
|
||||||
|
def untag(self, tags_to_remove):
|
||||||
|
if self.tags:
|
||||||
|
self.tags = {k: v for (k, v) in self.tags.items() if k not in tags_to_remove}
|
||||||
|
|
||||||
|
|
||||||
class LogsBackend(BaseBackend):
|
class LogsBackend(BaseBackend):
|
||||||
def __init__(self, region_name):
|
def __init__(self, region_name):
|
||||||
@ -343,5 +347,11 @@ class LogsBackend(BaseBackend):
|
|||||||
log_group = self.groups[log_group_name]
|
log_group = self.groups[log_group_name]
|
||||||
log_group.tag(tags)
|
log_group.tag(tags)
|
||||||
|
|
||||||
|
def untag_log_group(self, log_group_name, tags):
|
||||||
|
if log_group_name not in self.groups:
|
||||||
|
raise ResourceNotFoundException()
|
||||||
|
log_group = self.groups[log_group_name]
|
||||||
|
log_group.untag(tags)
|
||||||
|
|
||||||
|
|
||||||
logs_backends = {region.name: LogsBackend(region.name) for region in boto.logs.regions()}
|
logs_backends = {region.name: LogsBackend(region.name) for region in boto.logs.regions()}
|
||||||
|
@ -147,3 +147,9 @@ class LogsResponse(BaseResponse):
|
|||||||
tags = self._get_param('tags')
|
tags = self._get_param('tags')
|
||||||
self.logs_backend.tag_log_group(log_group_name, tags)
|
self.logs_backend.tag_log_group(log_group_name, tags)
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
|
def untag_log_group(self):
|
||||||
|
log_group_name = self._get_param('logGroupName')
|
||||||
|
tags = self._get_param('tags')
|
||||||
|
self.logs_backend.untag_log_group(log_group_name, tags)
|
||||||
|
return ''
|
||||||
|
@ -267,3 +267,23 @@ def test_tag_log_group():
|
|||||||
assert response['tags'] == tags_with_updated_value
|
assert response['tags'] == tags_with_updated_value
|
||||||
|
|
||||||
response = conn.delete_log_group(logGroupName=log_group_name)
|
response = conn.delete_log_group(logGroupName=log_group_name)
|
||||||
|
|
||||||
|
|
||||||
|
@mock_logs
|
||||||
|
def test_untag_log_group():
|
||||||
|
conn = boto3.client('logs', 'us-west-2')
|
||||||
|
log_group_name = 'dummy'
|
||||||
|
response = conn.create_log_group(logGroupName=log_group_name)
|
||||||
|
|
||||||
|
tags = {'tag_key_1': 'tag_value_1', 'tag_key_2': 'tag_value_2'}
|
||||||
|
response = conn.tag_log_group(logGroupName=log_group_name, tags=tags)
|
||||||
|
response = conn.list_tags_log_group(logGroupName=log_group_name)
|
||||||
|
assert response['tags'] == tags
|
||||||
|
|
||||||
|
tags_to_remove = ['tag_key_1']
|
||||||
|
remaining_tags = {'tag_key_2': 'tag_value_2'}
|
||||||
|
response = conn.untag_log_group(logGroupName=log_group_name, tags=tags_to_remove)
|
||||||
|
response = conn.list_tags_log_group(logGroupName=log_group_name)
|
||||||
|
assert response['tags'] == remaining_tags
|
||||||
|
|
||||||
|
response = conn.delete_log_group(logGroupName=log_group_name)
|
||||||
|
Loading…
Reference in New Issue
Block a user