From 3fe80dc877e22c086b9e5bb4a68a122503c8c897 Mon Sep 17 00:00:00 2001 From: Or Friedmann Date: Thu, 3 Dec 2020 17:53:50 +0200 Subject: [PATCH] Add test for GetUsage api Signed-off-by: Or Friedmann (cherry picked from commit f4f7812efd5b42a3b255148ab67424a4a00ba2fb) --- s3tests_boto3/functional/test_s3.py | 41 +++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/s3tests_boto3/functional/test_s3.py b/s3tests_boto3/functional/test_s3.py index d15fbe0..7a8be35 100644 --- a/s3tests_boto3/functional/test_s3.py +++ b/s3tests_boto3/functional/test_s3.py @@ -1265,6 +1265,47 @@ def test_bucket_listv2_maxkeys_none(): eq(keys, key_names) eq(response['MaxKeys'], 1000) +def get_http_response_body(**kwargs): + global http_response_body + http_response_body = kwargs['http_response'].__dict__['_content'] + +def parseXmlToJson(xml): + response = {} + + for child in list(xml): + if len(list(child)) > 0: + response[child.tag] = parseXmlToJson(child) + else: + response[child.tag] = child.text or '' + + # one-liner equivalent + # response[child.tag] = parseXmlToJson(child) if len(list(child)) > 0 else child.text or '' + + return response + +@attr(resource='bucket') +@attr(method='get') +@attr(operation='get usage by client') +@attr(assertion='account usage api') +@attr('fails_on_aws') # allow-unordered is a non-standard extension +def test_account_usage(): + # boto3.set_stream_logger(name='botocore') + client = get_client() + # adds the unordered query parameter + def add_usage(**kwargs): + kwargs['params']['url'] += "?usage" + client.meta.events.register('before-call.s3.ListBuckets', add_usage) + client.meta.events.register('after-call.s3.ListBuckets', get_http_response_body) + client.list_buckets() + xml = ET.fromstring(http_response_body.decode('utf-8')) + parsed = parseXmlToJson(xml) + summary = parsed['Summary'] + eq(summary['QuotaMaxBytes'], '-1') + eq(summary['QuotaMaxBuckets'], '1000') + eq(summary['QuotaMaxObjCount'], '-1') + eq(summary['QuotaMaxBytesPerBucket'], '-1') + eq(summary['QuotaMaxObjCountPerBucket'], '-1') + @attr(resource='bucket') @attr(method='get') @attr(operation='list all keys')