py3: port request_helpers

Change-Id: I6be1a1c618e4b4fa03b34dad96f378aca01e8e08
This commit is contained in:
Tim Burke 2018-09-15 01:33:34 -06:00
parent b4567e66ec
commit 2ef21ac05d
4 changed files with 36 additions and 38 deletions

View File

@ -35,7 +35,7 @@ from swift.common.exceptions import ListingIterError, SegmentError
from swift.common.http import is_success from swift.common.http import is_success
from swift.common.swob import HTTPBadRequest, \ from swift.common.swob import HTTPBadRequest, \
HTTPServiceUnavailable, Range, is_chunked, multi_range_iterator, \ HTTPServiceUnavailable, Range, is_chunked, multi_range_iterator, \
HTTPPreconditionFailed HTTPPreconditionFailed, wsgi_to_bytes
from swift.common.utils import split_path, validate_device_partition, \ from swift.common.utils import split_path, validate_device_partition, \
close_if_possible, maybe_multipart_byteranges_to_document_iters, \ close_if_possible, maybe_multipart_byteranges_to_document_iters, \
multipart_byteranges_to_document_iters, parse_content_type, \ multipart_byteranges_to_document_iters, parse_content_type, \
@ -262,7 +262,7 @@ def remove_items(headers, condition):
:returns: a dict, possibly empty, of headers that have been removed :returns: a dict, possibly empty, of headers that have been removed
""" """
removed = {} removed = {}
keys = filter(condition, headers) keys = [key for key in headers if condition(key)]
removed.update((key, headers.pop(key)) for key in keys) removed.update((key, headers.pop(key)) for key in keys)
return removed return removed
@ -651,7 +651,7 @@ def http_response_to_document_iters(response, read_chunk_size=4096):
# extracted from the Content-Type header. # extracted from the Content-Type header.
params = dict(params_list) params = dict(params_list)
return multipart_byteranges_to_document_iters( return multipart_byteranges_to_document_iters(
response, params['boundary'], read_chunk_size) response, wsgi_to_bytes(params['boundary']), read_chunk_size)
def update_etag_is_at_header(req, name): def update_etag_is_at_header(req, name):

View File

@ -142,16 +142,13 @@ class TestRequestHelpers(unittest.TestCase):
self.assertEqual(policy.policy_type, REPL_POLICY) self.assertEqual(policy.policy_type, REPL_POLICY)
req.headers['X-Backend-Storage-Policy-Index'] = 'foo' req.headers['X-Backend-Storage-Policy-Index'] = 'foo'
try: with self.assertRaises(HTTPException) as raised:
device, part, account, container, obj, policy = \ device, part, account, container, obj, policy = \
get_name_and_placement(req, 5, 5, True) get_name_and_placement(req, 5, 5, True)
except HTTPException as e: e = raised.exception
self.assertEqual(e.status_int, 503) self.assertEqual(e.status_int, 503)
self.assertEqual(str(e), '503 Service Unavailable') self.assertEqual(str(e), '503 Service Unavailable')
self.assertEqual(e.body, "No policy with index foo") self.assertEqual(e.body, b"No policy with index foo")
else:
self.fail('get_name_and_placement did not raise error '
'for invalid storage policy index')
@patch_policies(with_ec_default=True) @patch_policies(with_ec_default=True)
def test_get_name_and_placement_object_replication(self): def test_get_name_and_placement_object_replication(self):
@ -195,7 +192,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
fr = FakeResponse( fr = FakeResponse(
200, 200,
{'Content-Length': '10', 'Content-Type': 'application/lunch'}, {'Content-Length': '10', 'Content-Type': 'application/lunch'},
'sandwiches') b'sandwiches')
doc_iters = http_response_to_document_iters(fr) doc_iters = http_response_to_document_iters(fr)
first_byte, last_byte, length, headers, body = next(doc_iters) first_byte, last_byte, length, headers, body = next(doc_iters)
@ -205,7 +202,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Content-Length'), '10') self.assertEqual(header_dict.get('Content-Length'), '10')
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'sandwiches') self.assertEqual(body.read(), b'sandwiches')
self.assertRaises(StopIteration, next, doc_iters) self.assertRaises(StopIteration, next, doc_iters)
@ -213,7 +210,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
200, 200,
{'Transfer-Encoding': 'chunked', {'Transfer-Encoding': 'chunked',
'Content-Type': 'application/lunch'}, 'Content-Type': 'application/lunch'},
'sandwiches') b'sandwiches')
doc_iters = http_response_to_document_iters(fr) doc_iters = http_response_to_document_iters(fr)
first_byte, last_byte, length, headers, body = next(doc_iters) first_byte, last_byte, length, headers, body = next(doc_iters)
@ -223,7 +220,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Transfer-Encoding'), 'chunked') self.assertEqual(header_dict.get('Transfer-Encoding'), 'chunked')
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'sandwiches') self.assertEqual(body.read(), b'sandwiches')
self.assertRaises(StopIteration, next, doc_iters) self.assertRaises(StopIteration, next, doc_iters)
@ -232,7 +229,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
206, 206,
{'Content-Length': '8', 'Content-Type': 'application/lunch', {'Content-Length': '8', 'Content-Type': 'application/lunch',
'Content-Range': 'bytes 1-8/10'}, 'Content-Range': 'bytes 1-8/10'},
'andwiche') b'andwiche')
doc_iters = http_response_to_document_iters(fr) doc_iters = http_response_to_document_iters(fr)
first_byte, last_byte, length, headers, body = next(doc_iters) first_byte, last_byte, length, headers, body = next(doc_iters)
@ -242,7 +239,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Content-Length'), '8') self.assertEqual(header_dict.get('Content-Length'), '8')
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'andwiche') self.assertEqual(body.read(), b'andwiche')
self.assertRaises(StopIteration, next, doc_iters) self.assertRaises(StopIteration, next, doc_iters)
@ -252,7 +249,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
{'Transfer-Encoding': 'chunked', {'Transfer-Encoding': 'chunked',
'Content-Type': 'application/lunch', 'Content-Type': 'application/lunch',
'Content-Range': 'bytes 1-8/10'}, 'Content-Range': 'bytes 1-8/10'},
'andwiche') b'andwiche')
doc_iters = http_response_to_document_iters(fr) doc_iters = http_response_to_document_iters(fr)
first_byte, last_byte, length, headers, body = next(doc_iters) first_byte, last_byte, length, headers, body = next(doc_iters)
@ -261,7 +258,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
self.assertEqual(length, 10) self.assertEqual(length, 10)
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'andwiche') self.assertEqual(body.read(), b'andwiche')
self.assertRaises(StopIteration, next, doc_iters) self.assertRaises(StopIteration, next, doc_iters)
@ -269,17 +266,17 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
fr = FakeResponse( fr = FakeResponse(
206, 206,
{'Content-Type': 'multipart/byteranges; boundary=asdfasdfasdf'}, {'Content-Type': 'multipart/byteranges; boundary=asdfasdfasdf'},
("--asdfasdfasdf\r\n" (b"--asdfasdfasdf\r\n"
"Content-Type: application/lunch\r\n" b"Content-Type: application/lunch\r\n"
"Content-Range: bytes 0-3/10\r\n" b"Content-Range: bytes 0-3/10\r\n"
"\r\n" b"\r\n"
"sand\r\n" b"sand\r\n"
"--asdfasdfasdf\r\n" b"--asdfasdfasdf\r\n"
"Content-Type: application/lunch\r\n" b"Content-Type: application/lunch\r\n"
"Content-Range: bytes 6-9/10\r\n" b"Content-Range: bytes 6-9/10\r\n"
"\r\n" b"\r\n"
"ches\r\n" b"ches\r\n"
"--asdfasdfasdf--")) b"--asdfasdfasdf--"))
doc_iters = http_response_to_document_iters(fr) doc_iters = http_response_to_document_iters(fr)
@ -289,7 +286,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
self.assertEqual(length, 10) self.assertEqual(length, 10)
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'sand') self.assertEqual(body.read(), b'sand')
first_byte, last_byte, length, headers, body = next(doc_iters) first_byte, last_byte, length, headers, body = next(doc_iters)
self.assertEqual(first_byte, 6) self.assertEqual(first_byte, 6)
@ -297,7 +294,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
self.assertEqual(length, 10) self.assertEqual(length, 10)
header_dict = HeaderKeyDict(headers) header_dict = HeaderKeyDict(headers)
self.assertEqual(header_dict.get('Content-Type'), 'application/lunch') self.assertEqual(header_dict.get('Content-Type'), 'application/lunch')
self.assertEqual(body.read(), 'ches') self.assertEqual(body.read(), b'ches')
self.assertRaises(StopIteration, next, doc_iters) self.assertRaises(StopIteration, next, doc_iters)
@ -314,7 +311,7 @@ class TestHTTPResponseToDocumentIters(unittest.TestCase):
with self.assertRaises(ValueError) as cm: with self.assertRaises(ValueError) as cm:
update_etag_is_at_header(req, 'X-Object-Sysmeta-,-Bad') update_etag_is_at_header(req, 'X-Object-Sysmeta-,-Bad')
self.assertEqual('Header name must not contain commas', self.assertEqual('Header name must not contain commas',
cm.exception.message) cm.exception.args[0])
def test_resolve_etag_is_at_header(self): def test_resolve_etag_is_at_header(self):
def do_test(): def do_test():

View File

@ -4329,25 +4329,25 @@ cluster_dfw1 = http://dfw1.host/v1/
def test_get_redirect_data(self): def test_get_redirect_data(self):
ts_now = utils.Timestamp.now() ts_now = utils.Timestamp.now()
headers = {'X-Backend-Redirect-Timestamp': ts_now.internal} headers = {'X-Backend-Redirect-Timestamp': ts_now.internal}
response = FakeResponse(200, headers, '') response = FakeResponse(200, headers, b'')
self.assertIsNone(utils.get_redirect_data(response)) self.assertIsNone(utils.get_redirect_data(response))
headers = {'Location': '/a/c/o', headers = {'Location': '/a/c/o',
'X-Backend-Redirect-Timestamp': ts_now.internal} 'X-Backend-Redirect-Timestamp': ts_now.internal}
response = FakeResponse(200, headers, '') response = FakeResponse(200, headers, b'')
path, ts = utils.get_redirect_data(response) path, ts = utils.get_redirect_data(response)
self.assertEqual('a/c', path) self.assertEqual('a/c', path)
self.assertEqual(ts_now, ts) self.assertEqual(ts_now, ts)
headers = {'Location': '/a/c', headers = {'Location': '/a/c',
'X-Backend-Redirect-Timestamp': ts_now.internal} 'X-Backend-Redirect-Timestamp': ts_now.internal}
response = FakeResponse(200, headers, '') response = FakeResponse(200, headers, b'')
path, ts = utils.get_redirect_data(response) path, ts = utils.get_redirect_data(response)
self.assertEqual('a/c', path) self.assertEqual('a/c', path)
self.assertEqual(ts_now, ts) self.assertEqual(ts_now, ts)
def do_test(headers): def do_test(headers):
response = FakeResponse(200, headers, '') response = FakeResponse(200, headers, b'')
with self.assertRaises(ValueError) as cm: with self.assertRaises(ValueError) as cm:
utils.get_redirect_data(response) utils.get_redirect_data(response)
return cm.exception return cm.exception
@ -6470,7 +6470,7 @@ class FakeResponse(object):
def __init__(self, status, headers, body): def __init__(self, status, headers, body):
self.status = status self.status = status
self.headers = HeaderKeyDict(headers) self.headers = HeaderKeyDict(headers)
self.body = StringIO(body) self.body = BytesIO(body)
def getheader(self, header_name): def getheader(self, header_name):
return str(self.headers.get(header_name, '')) return str(self.headers.get(header_name, ''))

View File

@ -52,6 +52,7 @@ commands =
test/unit/common/test_linkat.py \ test/unit/common/test_linkat.py \
test/unit/common/test_manager.py \ test/unit/common/test_manager.py \
test/unit/common/test_memcached.py \ test/unit/common/test_memcached.py \
test/unit/common/test_request_helpers.py \
test/unit/common/test_splice.py \ test/unit/common/test_splice.py \
test/unit/common/test_storage_policy.py \ test/unit/common/test_storage_policy.py \
test/unit/common/test_swob.py \ test/unit/common/test_swob.py \