Merged from trunk

This commit is contained in:
gholt 2011-07-14 18:43:08 +00:00
commit f4fa3d626c
5 changed files with 17 additions and 9 deletions

View File

@ -228,7 +228,7 @@ class AccountController(object):
(name, object_count, bytes_used)) (name, object_count, bytes_used))
account_list = '[' + ','.join(json_out) + ']' account_list = '[' + ','.join(json_out) + ']'
elif out_content_type.endswith('/xml'): elif out_content_type.endswith('/xml'):
output_list = ['<?xml version="1.0" encoding="UTF-8"?>', output_list = ['<?xml version="1.1" encoding="UTF-8"?>',
'<account name="%s">' % account] '<account name="%s">' % account]
for (name, object_count, bytes_used, is_subdir) in account_list: for (name, object_count, bytes_used, is_subdir) in account_list:
name = saxutils.escape(name, XML_EXTRA_ENTITIES) name = saxutils.escape(name, XML_EXTRA_ENTITIES)

View File

@ -342,7 +342,7 @@ class ContainerController(object):
'<last_modified>%s</last_modified></object>' % \ '<last_modified>%s</last_modified></object>' % \
(name, etag, size, content_type, created_at)) (name, etag, size, content_type, created_at))
container_list = ''.join([ container_list = ''.join([
'<?xml version="1.0" encoding="UTF-8"?>\n', '<?xml version="1.1" encoding="UTF-8"?>\n',
'<container name=%s>' % '<container name=%s>' %
saxutils.quoteattr(container, XML_EXTRA_ENTITIES), saxutils.quoteattr(container, XML_EXTRA_ENTITIES),
''.join(xml_output), '</container>']) ''.join(xml_output), '</container>'])

View File

@ -611,9 +611,10 @@ class ObjectController(object):
if_modified_since: if_modified_since:
file.close() file.close()
return HTTPNotModified(request=request) return HTTPNotModified(request=request)
response = Response(content_type=file.metadata.get('Content-Type', response = Response(app_iter=file,
'application/octet-stream'), app_iter=file,
request=request, conditional_response=True) request=request, conditional_response=True)
response.headers['Content-Type'] = file.metadata.get('Content-Type',
'application/octet-stream')
for key, value in file.metadata.iteritems(): for key, value in file.metadata.iteritems():
if key.lower().startswith('x-object-meta-') or \ if key.lower().startswith('x-object-meta-') or \
key.lower() in self.allowed_headers: key.lower() in self.allowed_headers:
@ -651,8 +652,9 @@ class ObjectController(object):
except (DiskFileError, DiskFileNotExist): except (DiskFileError, DiskFileNotExist):
file.quarantine() file.quarantine()
return HTTPNotFound(request=request) return HTTPNotFound(request=request)
response = Response(content_type=file.metadata['Content-Type'], response = Response(request=request, conditional_response=True)
request=request, conditional_response=True) response.headers['Content-Type'] = file.metadata.get('Content-Type',
'application/octet-stream')
for key, value in file.metadata.iteritems(): for key, value in file.metadata.iteritems():
if key.lower().startswith('x-object-meta-') or \ if key.lower().startswith('x-object-meta-') or \
key.lower() in self.allowed_headers: key.lower() in self.allowed_headers:

View File

@ -901,7 +901,13 @@ class ObjectController(Controller):
req.headers['X-Copy-From'] = '/%s/%s' % (self.container_name, req.headers['X-Copy-From'] = '/%s/%s' % (self.container_name,
self.object_name) self.object_name)
req.headers['X-Fresh-Metadata'] = 'true' req.headers['X-Fresh-Metadata'] = 'true'
return self.PUT(req) resp = self.PUT(req)
# Older editions returned 202 Accepted on object POSTs, so we'll
# convert any 201 Created responses to that for compatibility with
# picky clients.
if resp.status_int != 201:
return resp
return HTTPAccepted(request=req)
else: else:
error_response = check_metadata(req, 'object') error_response = check_metadata(req, 'object')
if error_response: if error_response:

View File

@ -608,7 +608,7 @@ class TestContainerController(unittest.TestCase):
'HTTP_X_SIZE': 0}) 'HTTP_X_SIZE': 0})
resp = self.controller.PUT(req) resp = self.controller.PUT(req)
self.assertEquals(resp.status_int, 201) self.assertEquals(resp.status_int, 201)
xml_body = '<?xml version="1.0" encoding="UTF-8"?>\n' \ xml_body = '<?xml version="1.1" encoding="UTF-8"?>\n' \
'<container name="xmlc">' \ '<container name="xmlc">' \
'<object><name>0&#x1;</name><hash>x</hash><bytes>0</bytes>' \ '<object><name>0&#x1;</name><hash>x</hash><bytes>0</bytes>' \
'<content_type>text/plain</content_type>' \ '<content_type>text/plain</content_type>' \
@ -752,7 +752,7 @@ class TestContainerController(unittest.TestCase):
req = Request.blank('/sda1/p/a/c?prefix=US-&delimiter=-&format=xml', req = Request.blank('/sda1/p/a/c?prefix=US-&delimiter=-&format=xml',
environ={'REQUEST_METHOD': 'GET'}) environ={'REQUEST_METHOD': 'GET'})
resp = self.controller.GET(req) resp = self.controller.GET(req)
self.assertEquals(resp.body, '<?xml version="1.0" encoding="UTF-8"?>' self.assertEquals(resp.body, '<?xml version="1.1" encoding="UTF-8"?>'
'\n<container name="c"><subdir name="US-OK-"><name>US-OK-</name></subdir>' '\n<container name="c"><subdir name="US-OK-"><name>US-OK-</name></subdir>'
'<subdir name="US-TX-"><name>US-TX-</name></subdir>' '<subdir name="US-TX-"><name>US-TX-</name></subdir>'
'<subdir name="US-UT-"><name>US-UT-</name></subdir></container>') '<subdir name="US-UT-"><name>US-UT-</name></subdir></container>')