From e93443ac0731f193424d7a33f0aec8459875a631 Mon Sep 17 00:00:00 2001 From: fang yuxiang Date: Wed, 7 Feb 2018 16:16:39 +0800 Subject: [PATCH] compression: add case to download range from big object Signed-off-by: fang yuxiang --- s3tests/functional/test_s3.py | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/s3tests/functional/test_s3.py b/s3tests/functional/test_s3.py index 12b065a..6e54549 100644 --- a/s3tests/functional/test_s3.py +++ b/s3tests/functional/test_s3.py @@ -6397,6 +6397,29 @@ def test_ranged_request_response_code(): eq(status, 206) eq(content_range, 'bytes 4-7/11') +@attr(resource='object') +@attr(method='get') +@attr(operation='range') +@attr(assertion='returns correct data, 206') +def test_ranged_big_request_response_code(): + + bucket = get_new_bucket() + key = bucket.new_key('testobj') + string = os.urandom(8 * 1024 * 1024) + key.set_contents_from_string(string) + + key.open('r', headers={'Range': 'bytes=3145728-5242880'}) + status = key.resp.status + content_range = key.resp.getheader('Content-Range') + fetched_content = '' + for data in key: + fetched_content += data; + key.close() + + eq(fetched_content, string[3145728:5242881]) + eq(status, 206) + eq(content_range, 'bytes 3145728-5242880/8388608') + @attr(resource='object') @attr(method='get') @attr(operation='range')