fixes bug lp 891247
added try/except around the accept header matcher to catch the assertionerror that was being thrown and return a more meaningful message. Change-Id: I64184be0a40f8696f8e7e3801763d555ec2526dd
This commit is contained in:
parent
f643a58d32
commit
dfb9a9f0a3
@ -214,10 +214,14 @@ class AccountController(object):
|
|||||||
content_type='text/plain', request=req)
|
content_type='text/plain', request=req)
|
||||||
if query_format:
|
if query_format:
|
||||||
req.accept = 'application/%s' % query_format.lower()
|
req.accept = 'application/%s' % query_format.lower()
|
||||||
|
try:
|
||||||
out_content_type = req.accept.best_match(
|
out_content_type = req.accept.best_match(
|
||||||
['text/plain', 'application/json',
|
['text/plain', 'application/json',
|
||||||
'application/xml', 'text/xml'],
|
'application/xml', 'text/xml'],
|
||||||
default_match='text/plain')
|
default_match='text/plain')
|
||||||
|
except AssertionError, err:
|
||||||
|
return HTTPBadRequest(body='bad accept header: %s' % req.accept,
|
||||||
|
content_type='text/plain', request=req)
|
||||||
account_list = broker.list_containers_iter(limit, marker, end_marker,
|
account_list = broker.list_containers_iter(limit, marker, end_marker,
|
||||||
prefix, delimiter)
|
prefix, delimiter)
|
||||||
if out_content_type == 'application/json':
|
if out_content_type == 'application/json':
|
||||||
|
@ -306,10 +306,14 @@ class ContainerController(object):
|
|||||||
content_type='text/plain', request=req)
|
content_type='text/plain', request=req)
|
||||||
if query_format:
|
if query_format:
|
||||||
req.accept = 'application/%s' % query_format.lower()
|
req.accept = 'application/%s' % query_format.lower()
|
||||||
|
try:
|
||||||
out_content_type = req.accept.best_match(
|
out_content_type = req.accept.best_match(
|
||||||
['text/plain', 'application/json',
|
['text/plain', 'application/json',
|
||||||
'application/xml', 'text/xml'],
|
'application/xml', 'text/xml'],
|
||||||
default_match='text/plain')
|
default_match='text/plain')
|
||||||
|
except AssertionError, err:
|
||||||
|
return HTTPBadRequest(body='bad accept header: %s' % req.accept,
|
||||||
|
content_type='text/plain', request=req)
|
||||||
container_list = broker.list_objects_iter(limit, marker, end_marker,
|
container_list = broker.list_objects_iter(limit, marker, end_marker,
|
||||||
prefix, delimiter, path)
|
prefix, delimiter, path)
|
||||||
if out_content_type == 'application/json':
|
if out_content_type == 'application/json':
|
||||||
|
@ -748,6 +748,23 @@ class TestAccountController(unittest.TestCase):
|
|||||||
self.assertEquals(resp.status_int, 200)
|
self.assertEquals(resp.status_int, 200)
|
||||||
self.assertEquals(resp.body, 'c1\n')
|
self.assertEquals(resp.body, 'c1\n')
|
||||||
|
|
||||||
|
def test_GET_accept_not_valid(self):
|
||||||
|
req = Request.blank('/sda1/p/a', environ={'REQUEST_METHOD': 'PUT',
|
||||||
|
'HTTP_X_TIMESTAMP': '0'})
|
||||||
|
self.controller.PUT(req)
|
||||||
|
req = Request.blank('/sda1/p/a/c1', environ={'REQUEST_METHOD': 'PUT'},
|
||||||
|
headers={'X-Put-Timestamp': '1',
|
||||||
|
'X-Delete-Timestamp': '0',
|
||||||
|
'X-Object-Count': '0',
|
||||||
|
'X-Bytes-Used': '0',
|
||||||
|
'X-Timestamp': normalize_timestamp(0)})
|
||||||
|
self.controller.PUT(req)
|
||||||
|
req = Request.blank('/sda1/p/a', environ={'REQUEST_METHOD': 'GET'})
|
||||||
|
req.accept = 'application/xml*'
|
||||||
|
resp = self.controller.GET(req)
|
||||||
|
self.assertEquals(resp.status_int, 400)
|
||||||
|
self.assertEquals(resp.body, 'bad accept header: application/xml*')
|
||||||
|
|
||||||
def test_GET_prefix_delimeter_plain(self):
|
def test_GET_prefix_delimeter_plain(self):
|
||||||
req = Request.blank('/sda1/p/a', environ={'REQUEST_METHOD': 'PUT',
|
req = Request.blank('/sda1/p/a', environ={'REQUEST_METHOD': 'PUT',
|
||||||
'HTTP_X_TIMESTAMP': '0'})
|
'HTTP_X_TIMESTAMP': '0'})
|
||||||
|
@ -734,6 +734,23 @@ class TestContainerController(unittest.TestCase):
|
|||||||
result = [x['content_type'] for x in simplejson.loads(resp.body)]
|
result = [x['content_type'] for x in simplejson.loads(resp.body)]
|
||||||
self.assertEquals(result, [u'\u2603', 'text/plain; "utf-8"'])
|
self.assertEquals(result, [u'\u2603', 'text/plain; "utf-8"'])
|
||||||
|
|
||||||
|
def test_GET_accept_not_valid(self):
|
||||||
|
req = Request.blank('/sda1/p/a/c', environ={'REQUEST_METHOD': 'PUT',
|
||||||
|
'HTTP_X_TIMESTAMP': '0'})
|
||||||
|
self.controller.PUT(req)
|
||||||
|
req = Request.blank('/sda1/p/a/c1', environ={'REQUEST_METHOD': 'PUT'},
|
||||||
|
headers={'X-Put-Timestamp': '1',
|
||||||
|
'X-Delete-Timestamp': '0',
|
||||||
|
'X-Object-Count': '0',
|
||||||
|
'X-Bytes-Used': '0',
|
||||||
|
'X-Timestamp': normalize_timestamp(0)})
|
||||||
|
self.controller.PUT(req)
|
||||||
|
req = Request.blank('/sda1/p/a/c', environ={'REQUEST_METHOD': 'GET'})
|
||||||
|
req.accept = 'application/xml*'
|
||||||
|
resp = self.controller.GET(req)
|
||||||
|
self.assertEquals(resp.status_int, 400)
|
||||||
|
self.assertEquals(resp.body, 'bad accept header: application/xml*')
|
||||||
|
|
||||||
def test_GET_limit(self):
|
def test_GET_limit(self):
|
||||||
# make a container
|
# make a container
|
||||||
req = Request.blank('/sda1/p/a/c', environ={'REQUEST_METHOD': 'PUT',
|
req = Request.blank('/sda1/p/a/c', environ={'REQUEST_METHOD': 'PUT',
|
||||||
|
Loading…
Reference in New Issue
Block a user