internal client unicode paths
made internal client handle unicode path parts by adding make_path method fixed pep8 problems in internal client and its test moved internal client unit test file to correct directory Change-Id: Id1c81c9cb0db05342e4e8a8393db93552fda4647
This commit is contained in:
parent
5b02fded4e
commit
e7f3a9865e
@ -53,8 +53,9 @@ class CompressingFileReader(object):
|
||||
|
||||
def __init__(self, file_obj, compresslevel=9):
|
||||
self._f = file_obj
|
||||
self._compressor = compressobj(compresslevel, zlib.DEFLATED,
|
||||
-zlib.MAX_WBITS, zlib.DEF_MEM_LEVEL, 0)
|
||||
self._compressor = compressobj(
|
||||
compresslevel, zlib.DEFLATED, -zlib.MAX_WBITS, zlib.DEF_MEM_LEVEL,
|
||||
0)
|
||||
self.done = False
|
||||
self.first = True
|
||||
self.crc32 = 0
|
||||
@ -118,8 +119,8 @@ class InternalClient(object):
|
||||
self.user_agent = user_agent
|
||||
self.request_tries = request_tries
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses, body_file=None):
|
||||
"""
|
||||
Makes a request to Swift with retries.
|
||||
|
||||
@ -142,8 +143,8 @@ class InternalClient(object):
|
||||
headers['user-agent'] = self.user_agent
|
||||
resp = exc_type = exc_value = exc_traceback = None
|
||||
for attempt in xrange(self.request_tries):
|
||||
req = Request.blank(path, environ={'REQUEST_METHOD': method},
|
||||
headers=headers)
|
||||
req = Request.blank(
|
||||
path, environ={'REQUEST_METHOD': method}, headers=headers)
|
||||
if body_file is not None:
|
||||
if hasattr(body_file, 'seek'):
|
||||
body_file.seek(0)
|
||||
@ -157,14 +158,14 @@ class InternalClient(object):
|
||||
exc_type, exc_value, exc_traceback = exc_info()
|
||||
sleep(2 ** (attempt + 1))
|
||||
if resp:
|
||||
raise UnexpectedResponse(_('Unexpected response: %s' %
|
||||
(resp.status,)), resp)
|
||||
raise UnexpectedResponse(
|
||||
_('Unexpected response: %s' % (resp.status,)), resp)
|
||||
if exc_type:
|
||||
# To make pep8 tool happy, in place of raise t, v, tb:
|
||||
raise exc_type(*exc_value.args), None, exc_traceback
|
||||
|
||||
def _get_metadata(self, path, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
def _get_metadata(
|
||||
self, path, metadata_prefix='', acceptable_statuses=(2,)):
|
||||
"""
|
||||
Gets metadata by doing a HEAD on a path and using the metadata_prefix
|
||||
to get values from the headers returned.
|
||||
@ -192,7 +193,8 @@ class InternalClient(object):
|
||||
metadata[k[len(metadata_prefix):]] = v
|
||||
return metadata
|
||||
|
||||
def _iter_items(self, path, marker='', end_marker='',
|
||||
def _iter_items(
|
||||
self, path, marker='', end_marker='',
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Returns an iterator of items from a json listing. Assumes listing has
|
||||
@ -212,8 +214,8 @@ class InternalClient(object):
|
||||
"""
|
||||
|
||||
while True:
|
||||
resp = self.make_request('GET',
|
||||
'%s?format=json&marker=%s&end_marker=%s' %
|
||||
resp = self.make_request(
|
||||
'GET', '%s?format=json&marker=%s&end_marker=%s' %
|
||||
(path, quote(marker), quote(end_marker)),
|
||||
{}, acceptable_statuses)
|
||||
if resp.status_int != 200:
|
||||
@ -225,7 +227,40 @@ class InternalClient(object):
|
||||
yield item
|
||||
marker = data[-1]['name']
|
||||
|
||||
def _set_metadata(self, path, metadata, metadata_prefix='',
|
||||
def make_path(self, account, container=None, obj=None):
|
||||
"""
|
||||
Returns a swift path for a request quoting and utf-8 encoding the path
|
||||
parts as need be.
|
||||
|
||||
:param account: swift account
|
||||
:param container: container, defaults to None
|
||||
:param obj: object, defaults to None
|
||||
|
||||
:raises ValueError: Is raised if obj is specified and container is
|
||||
not.
|
||||
"""
|
||||
|
||||
if isinstance(account, unicode):
|
||||
account = account.encode('utf-8')
|
||||
|
||||
if isinstance(container, unicode):
|
||||
container = container.encode('utf-8')
|
||||
|
||||
if isinstance(obj, unicode):
|
||||
obj = obj.encode('utf-8')
|
||||
|
||||
path = '/v1/%s' % quote(account)
|
||||
if container:
|
||||
path += '/%s' % quote(container)
|
||||
|
||||
if obj:
|
||||
path += '/%s' % quote(obj)
|
||||
elif obj:
|
||||
raise ValueError('Object specified without container')
|
||||
return path
|
||||
|
||||
def _set_metadata(
|
||||
self, path, metadata, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Sets metadata on path using metadata_prefix to set values in headers of
|
||||
@ -255,7 +290,8 @@ class InternalClient(object):
|
||||
|
||||
# account methods
|
||||
|
||||
def iter_containers(self, account, marker='', end_marker='',
|
||||
def iter_containers(
|
||||
self, account, marker='', end_marker='',
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Returns an iterator of containers dicts from an account.
|
||||
@ -273,11 +309,11 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s' % (quote(account),)
|
||||
path = self.make_path(account)
|
||||
return self._iter_items(path, marker, end_marker, acceptable_statuses)
|
||||
|
||||
def get_account_info(self, account,
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
def get_account_info(
|
||||
self, account, acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Returns (container_count, object_count) for an account.
|
||||
|
||||
@ -291,13 +327,13 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s' % (quote(account),)
|
||||
path = self.make_path(account)
|
||||
resp = self.make_request('HEAD', path, {}, acceptable_statuses)
|
||||
return (int(resp.headers.get('x-account-container-count', 0)),
|
||||
int(resp.headers.get('x-account-object-count', 0)))
|
||||
|
||||
def get_account_metadata(self, account, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
def get_account_metadata(
|
||||
self, account, metadata_prefix='', acceptable_statuses=(2,)):
|
||||
"""
|
||||
Gets account metadata.
|
||||
|
||||
@ -316,10 +352,11 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s' % (quote(account))
|
||||
path = self.make_path(account)
|
||||
return self._get_metadata(path, metadata_prefix, acceptable_statuses)
|
||||
|
||||
def set_account_metadata(self, account, metadata, metadata_prefix='',
|
||||
def set_account_metadata(
|
||||
self, account, metadata, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Sets account metadata. A call to this will add to the account
|
||||
@ -341,9 +378,9 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s' % (quote(account))
|
||||
self._set_metadata(path, metadata, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
path = self.make_path(account)
|
||||
self._set_metadata(
|
||||
path, metadata, metadata_prefix, acceptable_statuses)
|
||||
|
||||
# container methods
|
||||
|
||||
@ -362,12 +399,12 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
path = self.make_path(account, container)
|
||||
resp = self.make_request('HEAD', path, {}, (2, HTTP_NOT_FOUND))
|
||||
return resp.status_int != HTTP_NOT_FOUND
|
||||
|
||||
def create_container(self, account, container, headers=None,
|
||||
acceptable_statuses=(2,)):
|
||||
def create_container(
|
||||
self, account, container, headers=None, acceptable_statuses=(2,)):
|
||||
"""
|
||||
Creates container.
|
||||
|
||||
@ -384,11 +421,11 @@ class InternalClient(object):
|
||||
"""
|
||||
|
||||
headers = headers or {}
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
path = self.make_path(account, container)
|
||||
self.make_request('PUT', path, headers, acceptable_statuses)
|
||||
|
||||
def delete_container(self, account, container,
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
def delete_container(
|
||||
self, account, container, acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Deletes a container.
|
||||
|
||||
@ -403,10 +440,11 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
path = self.make_path(account, container)
|
||||
self.make_request('DELETE', path, {}, acceptable_statuses)
|
||||
|
||||
def get_container_metadata(self, account, container, metadata_prefix='',
|
||||
def get_container_metadata(
|
||||
self, account, container, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Gets container metadata.
|
||||
@ -427,10 +465,11 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
path = self.make_path(account, container)
|
||||
return self._get_metadata(path, metadata_prefix, acceptable_statuses)
|
||||
|
||||
def iter_objects(self, account, container, marker='', end_marker='',
|
||||
def iter_objects(
|
||||
self, account, container, marker='', end_marker='',
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Returns an iterator of object dicts from a container.
|
||||
@ -449,11 +488,12 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
path = self.make_path(account, container)
|
||||
return self._iter_items(path, marker, end_marker, acceptable_statuses)
|
||||
|
||||
def set_container_metadata(self, account, container, metadata,
|
||||
metadata_prefix='', acceptable_statuses=(2,)):
|
||||
def set_container_metadata(
|
||||
self, account, container, metadata, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Sets container metadata. A call to this will add to the container
|
||||
metadata and not overwrite all of it with values in the metadata dict.
|
||||
@ -475,20 +515,21 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s' % (quote(account), quote(container))
|
||||
self._set_metadata(path, metadata, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
path = self.make_path(account, container)
|
||||
self._set_metadata(
|
||||
path, metadata, metadata_prefix, acceptable_statuses)
|
||||
|
||||
# object methods
|
||||
|
||||
def delete_object(self, account, container, object_name,
|
||||
def delete_object(
|
||||
self, account, container, obj,
|
||||
acceptable_statuses=(2, HTTP_NOT_FOUND)):
|
||||
"""
|
||||
Deletes an object.
|
||||
|
||||
:param account: The object's account.
|
||||
:param container: The object's container.
|
||||
:param object_name: The object.
|
||||
:param obj: The object.
|
||||
:param acceptable_statuses: List of status for valid responses,
|
||||
defaults to (2, HTTP_NOT_FOUND).
|
||||
|
||||
@ -498,18 +539,18 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s/%s' % (quote(account), quote(container),
|
||||
quote(object_name))
|
||||
path = self.make_path(account, container, obj)
|
||||
self.make_request('DELETE', path, {}, acceptable_statuses)
|
||||
|
||||
def get_object_metadata(self, account, container, object_name,
|
||||
metadata_prefix='', acceptable_statuses=(2,)):
|
||||
def get_object_metadata(
|
||||
self, account, container, obj, metadata_prefix='',
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Gets object metadata.
|
||||
|
||||
:param account: The object's account.
|
||||
:param container: The object's container.
|
||||
:param object_name: The object.
|
||||
:param obj: The object.
|
||||
:param metadata_prefix: Used to filter values from the headers
|
||||
returned. Will strip that prefix from the
|
||||
keys in the dict returned. Defaults to ''.
|
||||
@ -524,11 +565,11 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s/%s' % (quote(account), quote(container),
|
||||
quote(object_name))
|
||||
path = self.make_path(account, container, obj)
|
||||
return self._get_metadata(path, metadata_prefix, acceptable_statuses)
|
||||
|
||||
def iter_object_lines(self, account, container, object_name, headers=None,
|
||||
def iter_object_lines(
|
||||
self, account, container, obj, headers=None,
|
||||
acceptable_statuses=(2,)):
|
||||
"""
|
||||
Returns an iterator of object lines from an uncompressed or compressed
|
||||
@ -549,13 +590,12 @@ class InternalClient(object):
|
||||
"""
|
||||
|
||||
headers = headers or {}
|
||||
path = '/v1/%s/%s/%s' % (quote(account), quote(container),
|
||||
quote(object_name))
|
||||
path = self.make_path(account, container, obj)
|
||||
|
||||
resp = self.make_request('GET', path, headers, acceptable_statuses)
|
||||
|
||||
last_part = ''
|
||||
compressed = object_name.endswith('.gz')
|
||||
compressed = obj.endswith('.gz')
|
||||
# magic in the following zlib.decompressobj argument is courtesy of
|
||||
# Python decompressing gzip chunk-by-chunk
|
||||
# http://stackoverflow.com/questions/2423866
|
||||
@ -574,7 +614,8 @@ class InternalClient(object):
|
||||
if last_part:
|
||||
yield last_part
|
||||
|
||||
def set_object_metadata(self, account, container, object_name, metadata,
|
||||
def set_object_metadata(
|
||||
self, account, container, obj, metadata,
|
||||
metadata_prefix='', acceptable_statuses=(2,)):
|
||||
"""
|
||||
Sets an object's metadata. The object's metadata will be overwritten
|
||||
@ -582,7 +623,7 @@ class InternalClient(object):
|
||||
|
||||
:param account: The object's account.
|
||||
:param container: The object's container.
|
||||
:param object_name: The object.
|
||||
:param obj: The object.
|
||||
:param metadata: Dict of metadata to set.
|
||||
:param metadata_prefix: Prefix used to set metadata values in headers
|
||||
of requests, used to prefix keys in metadata
|
||||
@ -596,18 +637,17 @@ class InternalClient(object):
|
||||
unexpected way.
|
||||
"""
|
||||
|
||||
path = '/v1/%s/%s/%s' % (quote(account), quote(container),
|
||||
quote(object_name))
|
||||
self._set_metadata(path, metadata, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
path = self.make_path(account, container, obj)
|
||||
self._set_metadata(
|
||||
path, metadata, metadata_prefix, acceptable_statuses)
|
||||
|
||||
def upload_object(self, fobj, account, container, object_name,
|
||||
headers=None):
|
||||
def upload_object(
|
||||
self, fobj, account, container, obj, headers=None):
|
||||
"""
|
||||
:param fobj: File object to read object's content from.
|
||||
:param account: The object's account.
|
||||
:param container: The object's container.
|
||||
:param object_name: The object.
|
||||
:param obj: The object.
|
||||
:param headers: Headers to send with request, defaults ot empty dict.
|
||||
|
||||
:raises UnexpectedResponse: Exception raised when requests fail
|
||||
@ -618,6 +658,5 @@ class InternalClient(object):
|
||||
|
||||
headers = dict(headers or {})
|
||||
headers['Transfer-Encoding'] = 'chunked'
|
||||
path = '/v1/%s/%s/%s' % (quote(account), quote(container),
|
||||
quote(object_name))
|
||||
path = self.make_path(account, container, obj)
|
||||
self.make_request('PUT', path, headers, (2,), fobj)
|
||||
|
@ -16,6 +16,7 @@
|
||||
import json
|
||||
from StringIO import StringIO
|
||||
import unittest
|
||||
from urllib import quote
|
||||
import zlib
|
||||
|
||||
from swift.common import internal_client
|
||||
@ -25,6 +26,31 @@ def not_sleep(seconds):
|
||||
pass
|
||||
|
||||
|
||||
def unicode_string(start, length):
|
||||
return u''.join([unichr(x) for x in xrange(start, start + length)])
|
||||
|
||||
|
||||
def path_parts():
|
||||
account = unicode_string(1000, 4) + ' ' + unicode_string(1000, 4)
|
||||
container = unicode_string(1000, 4) + ' ' + unicode_string(1000, 4)
|
||||
obj = unicode_string(1000, 4) + ' ' + unicode_string(1000, 4)
|
||||
return account, container, obj
|
||||
|
||||
|
||||
def make_path(account, container=None, obj=None):
|
||||
path = '/v1/%s' % quote(account.encode('utf-8'))
|
||||
if container:
|
||||
path += '/%s' % quote(container.encode('utf-8'))
|
||||
if obj:
|
||||
path += '/%s' % quote(obj.encode('utf-8'))
|
||||
return path
|
||||
|
||||
|
||||
class InternalClient(internal_client.InternalClient):
|
||||
def __init__(self):
|
||||
pass
|
||||
|
||||
|
||||
class GetMetadataInternalClient(internal_client.InternalClient):
|
||||
def __init__(self, test, path, metadata_prefix, acceptable_statuses):
|
||||
self.test = test
|
||||
@ -43,8 +69,8 @@ class GetMetadataInternalClient(internal_client.InternalClient):
|
||||
|
||||
|
||||
class SetMetadataInternalClient(internal_client.InternalClient):
|
||||
def __init__(self, test, path, metadata, metadata_prefix,
|
||||
acceptable_statuses):
|
||||
def __init__(
|
||||
self, test, path, metadata, metadata_prefix, acceptable_statuses):
|
||||
self.test = test
|
||||
self.path = path
|
||||
self.metadata = metadata
|
||||
@ -53,7 +79,8 @@ class SetMetadataInternalClient(internal_client.InternalClient):
|
||||
self.set_metadata_called = 0
|
||||
self.metadata = 'some_metadata'
|
||||
|
||||
def _set_metadata(self, path, metadata, metadata_prefix='',
|
||||
def _set_metadata(
|
||||
self, path, metadata, metadata_prefix='',
|
||||
acceptable_statuses=None):
|
||||
self.set_metadata_called += 1
|
||||
self.test.assertEquals(self.path, path)
|
||||
@ -63,8 +90,8 @@ class SetMetadataInternalClient(internal_client.InternalClient):
|
||||
|
||||
|
||||
class IterInternalClient(internal_client.InternalClient):
|
||||
def __init__(self, test, path, marker, end_marker, acceptable_statuses,
|
||||
items):
|
||||
def __init__(
|
||||
self, test, path, marker, end_marker, acceptable_statuses, items):
|
||||
self.test = test
|
||||
self.path = path
|
||||
self.marker = marker
|
||||
@ -72,8 +99,8 @@ class IterInternalClient(internal_client.InternalClient):
|
||||
self.acceptable_statuses = acceptable_statuses
|
||||
self.items = items
|
||||
|
||||
def _iter_items(self, path, marker='', end_marker='',
|
||||
acceptable_statuses=None):
|
||||
def _iter_items(
|
||||
self, path, marker='', end_marker='', acceptable_statuses=None):
|
||||
self.test.assertEquals(self.path, path)
|
||||
self.test.assertEquals(self.marker, marker)
|
||||
self.test.assertEquals(self.end_marker, end_marker)
|
||||
@ -94,8 +121,8 @@ class TestCompressingfileReader(unittest.TestCase):
|
||||
return self
|
||||
|
||||
try:
|
||||
compressobj = CompressObj(self, 9, zlib.DEFLATED, -zlib.MAX_WBITS,
|
||||
zlib.DEF_MEM_LEVEL, 0)
|
||||
compressobj = CompressObj(
|
||||
self, 9, zlib.DEFLATED, -zlib.MAX_WBITS, zlib.DEF_MEM_LEVEL, 0)
|
||||
|
||||
old_compressobj = internal_client.compressobj
|
||||
internal_client.compressobj = compressobj.method
|
||||
@ -146,8 +173,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
request_tries = 'some_request_tries'
|
||||
|
||||
try:
|
||||
client = internal_client.InternalClient(conf_path, user_agent,
|
||||
request_tries)
|
||||
client = internal_client.InternalClient(
|
||||
conf_path, user_agent, request_tries)
|
||||
finally:
|
||||
internal_client.loadapp = old_loadapp
|
||||
|
||||
@ -185,8 +212,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
def fake_app(self, env, start_response):
|
||||
self.tries += 1
|
||||
if self.tries < self.request_tries:
|
||||
start_response('500 Internal Server Error',
|
||||
[('Content-Length', '0')])
|
||||
start_response(
|
||||
'500 Internal Server Error', [('Content-Length', '0')])
|
||||
else:
|
||||
start_response('200 Ok', [('Content-Length', '0')])
|
||||
return []
|
||||
@ -318,8 +345,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
try:
|
||||
old_sleep = internal_client.sleep
|
||||
internal_client.sleep = not_sleep
|
||||
self.assertRaises(Exception,
|
||||
client.make_request, 'GET', '/', {}, (2,))
|
||||
self.assertRaises(
|
||||
Exception, client.make_request, 'GET', '/', {}, (2,))
|
||||
finally:
|
||||
internal_client.sleep = old_sleep
|
||||
|
||||
@ -335,7 +362,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.resp_headers = resp_headers
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('HEAD', method)
|
||||
@ -364,6 +392,17 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.assertEquals(exp_metadata, metadata)
|
||||
self.assertEquals(1, client.make_request_called)
|
||||
|
||||
def test_make_path(self):
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container, obj)
|
||||
|
||||
c = InternalClient()
|
||||
self.assertEquals(path, c.make_path(account, container, obj))
|
||||
|
||||
def test_make_path_exception(self):
|
||||
c = InternalClient()
|
||||
self.assertRaises(ValueError, c.make_path, 'account', None, 'obj')
|
||||
|
||||
def test_iter_items(self):
|
||||
class Response(object):
|
||||
def __init__(self, status_int, body):
|
||||
@ -376,7 +415,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.responses = responses
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
return self.responses.pop(0)
|
||||
@ -392,7 +432,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
exp_items = []
|
||||
responses = []
|
||||
for i in xrange(3):
|
||||
data = [{'name': 'item%02d' % (2 * i)},
|
||||
data = [
|
||||
{'name': 'item%02d' % (2 * i)},
|
||||
{'name': 'item%02d' % (2 * i + 1)}]
|
||||
responses.append(Response(200, json.dumps(data)))
|
||||
exp_items.extend(data)
|
||||
@ -416,7 +457,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.paths = paths
|
||||
self.responses = responses
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
exp_path = self.paths.pop(0)
|
||||
self.test.assertEquals(exp_path, path)
|
||||
@ -449,7 +491,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.exp_headers = exp_headers
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('POST', method)
|
||||
@ -476,16 +519,17 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.assertEquals(1, client.make_request_called)
|
||||
|
||||
def test_iter_containers(self):
|
||||
account = 'some_account'
|
||||
path = '/v1/%s' % (account)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account)
|
||||
items = '0 1 2'.split()
|
||||
marker = 'some_marker'
|
||||
end_marker = 'some_end_marker'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = IterInternalClient(self, path, marker, end_marker,
|
||||
acceptable_statuses, items)
|
||||
client = IterInternalClient(
|
||||
self, path, marker, end_marker, acceptable_statuses, items)
|
||||
ret_items = []
|
||||
for container in client.iter_containers(account, marker, end_marker,
|
||||
for container in client.iter_containers(
|
||||
account, marker, end_marker,
|
||||
acceptable_statuses=acceptable_statuses):
|
||||
ret_items.append(container)
|
||||
self.assertEquals(items, ret_items)
|
||||
@ -504,7 +548,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.path = path
|
||||
self.resp = resp
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.test.assertEquals('HEAD', method)
|
||||
self.test.assertEquals(self.path, path)
|
||||
@ -513,35 +558,35 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals(None, body_file)
|
||||
return self.resp
|
||||
|
||||
account = 'some_account'
|
||||
path = '/v1/%s' % (account)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account)
|
||||
containers, objects = 10, 100
|
||||
client = InternalClient(self, path, Response(containers, objects))
|
||||
info = client.get_account_info(account)
|
||||
self.assertEquals((containers, objects), info)
|
||||
|
||||
def test_get_account_metadata(self):
|
||||
account = 'some_account'
|
||||
path = '/v1/%s' % (account)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account)
|
||||
acceptable_statuses = 'some_status_list'
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
client = GetMetadataInternalClient(self, path, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
metadata = client.get_account_metadata(account, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
client = GetMetadataInternalClient(
|
||||
self, path, metadata_prefix, acceptable_statuses)
|
||||
metadata = client.get_account_metadata(
|
||||
account, metadata_prefix, acceptable_statuses)
|
||||
self.assertEquals(client.metadata, metadata)
|
||||
self.assertEquals(1, client.get_metadata_called)
|
||||
|
||||
def test_set_account_metadata(self):
|
||||
account = 'some_account'
|
||||
path = '/v1/%s' % (account)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account)
|
||||
metadata = 'some_metadata'
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = SetMetadataInternalClient(self, path, metadata,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client.set_account_metadata(account, metadata, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
client = SetMetadataInternalClient(
|
||||
self, path, metadata, metadata_prefix, acceptable_statuses)
|
||||
client.set_account_metadata(
|
||||
account, metadata, metadata_prefix, acceptable_statuses)
|
||||
self.assertEquals(1, client.set_metadata_called)
|
||||
|
||||
def test_container_exists(self):
|
||||
@ -556,7 +601,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.make_request_called = 0
|
||||
self.resp = resp
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('HEAD', method)
|
||||
@ -566,9 +612,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals(None, body_file)
|
||||
return self.resp
|
||||
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
|
||||
client = InternalClient(self, path, Response(200))
|
||||
self.assertEquals(True, client.container_exists(account, container))
|
||||
@ -586,7 +631,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.headers = headers
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('PUT', method)
|
||||
@ -595,9 +641,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals((2,), acceptable_statuses)
|
||||
self.test.assertEquals(None, body_file)
|
||||
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
headers = 'some_headers'
|
||||
client = InternalClient(self, path, headers)
|
||||
client.create_container(account, container, headers)
|
||||
@ -610,7 +655,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.path = path
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('DELETE', method)
|
||||
@ -619,53 +665,49 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals((2, 404), acceptable_statuses)
|
||||
self.test.assertEquals(None, body_file)
|
||||
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
client = InternalClient(self, path)
|
||||
client.delete_container(account, container)
|
||||
self.assertEquals(1, client.make_request_called)
|
||||
|
||||
def test_get_container_metadata(self):
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = GetMetadataInternalClient(self, path, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
metadata = client.get_container_metadata(account, container,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client = GetMetadataInternalClient(
|
||||
self, path, metadata_prefix, acceptable_statuses)
|
||||
metadata = client.get_container_metadata(
|
||||
account, container, metadata_prefix, acceptable_statuses)
|
||||
self.assertEquals(client.metadata, metadata)
|
||||
self.assertEquals(1, client.get_metadata_called)
|
||||
|
||||
def test_iter_objects(self):
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
marker = 'some_maker'
|
||||
end_marker = 'some_end_marker'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
items = '0 1 2'.split()
|
||||
client = IterInternalClient(self, path, marker, end_marker,
|
||||
acceptable_statuses, items)
|
||||
client = IterInternalClient(
|
||||
self, path, marker, end_marker, acceptable_statuses, items)
|
||||
ret_items = []
|
||||
for obj in client.iter_objects(account, container, marker, end_marker,
|
||||
acceptable_statuses):
|
||||
for obj in client.iter_objects(
|
||||
account, container, marker, end_marker, acceptable_statuses):
|
||||
ret_items.append(obj)
|
||||
self.assertEquals(items, ret_items)
|
||||
|
||||
def test_set_container_metadata(self):
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
path = '/v1/%s/%s' % (account, container)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container)
|
||||
metadata = 'some_metadata'
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = SetMetadataInternalClient(self, path, metadata,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client.set_container_metadata(account, container, metadata,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client = SetMetadataInternalClient(
|
||||
self, path, metadata, metadata_prefix, acceptable_statuses)
|
||||
client.set_container_metadata(
|
||||
account, container, metadata, metadata_prefix, acceptable_statuses)
|
||||
self.assertEquals(1, client.set_metadata_called)
|
||||
|
||||
def test_delete_object(self):
|
||||
@ -675,7 +717,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.path = path
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals('DELETE', method)
|
||||
@ -684,26 +727,23 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals((2, 404), acceptable_statuses)
|
||||
self.test.assertEquals(None, body_file)
|
||||
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
object_name = 'some_object'
|
||||
path = '/v1/%s/%s/%s' % (account, container, object_name)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container, obj)
|
||||
|
||||
client = InternalClient(self, path)
|
||||
client.delete_object(account, container, object_name)
|
||||
client.delete_object(account, container, obj)
|
||||
self.assertEquals(1, client.make_request_called)
|
||||
|
||||
def test_get_object_metadata(self):
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
object_name = 'some_object'
|
||||
path = '/v1/%s/%s/%s' % (account, container, object_name)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container, obj)
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = GetMetadataInternalClient(self, path, metadata_prefix,
|
||||
client = GetMetadataInternalClient(
|
||||
self, path, metadata_prefix, acceptable_statuses)
|
||||
metadata = client.get_object_metadata(
|
||||
account, container, obj, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
metadata = client.get_object_metadata(account, container, object_name,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
self.assertEquals(client.metadata, metadata)
|
||||
self.assertEquals(1, client.get_metadata_called)
|
||||
|
||||
@ -742,23 +782,22 @@ class TestInternalClient(unittest.TestCase):
|
||||
lines = 'line1 line2 line3'.split()
|
||||
client = InternalClient(lines)
|
||||
ret_lines = []
|
||||
for line in client.iter_object_lines('account', 'container',
|
||||
'object.gz'):
|
||||
for line in client.iter_object_lines(
|
||||
'account', 'container', 'object.gz'):
|
||||
ret_lines.append(line)
|
||||
self.assertEquals(lines, ret_lines)
|
||||
|
||||
def test_set_object_metadata(self):
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
object_name = 'some_object'
|
||||
path = '/v1/%s/%s/%s' % (account, container, object_name)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container, obj)
|
||||
metadata = 'some_metadata'
|
||||
metadata_prefix = 'some_metadata_prefix'
|
||||
acceptable_statuses = 'some_status_list'
|
||||
client = SetMetadataInternalClient(self, path, metadata,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client.set_object_metadata(account, container, object_name, metadata,
|
||||
metadata_prefix, acceptable_statuses)
|
||||
client = SetMetadataInternalClient(
|
||||
self, path, metadata, metadata_prefix, acceptable_statuses)
|
||||
client.set_object_metadata(
|
||||
account, container, obj, metadata, metadata_prefix,
|
||||
acceptable_statuses)
|
||||
self.assertEquals(1, client.set_metadata_called)
|
||||
|
||||
def test_upload_object(self):
|
||||
@ -770,7 +809,8 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.fobj = fobj
|
||||
self.make_request_called = 0
|
||||
|
||||
def make_request(self, method, path, headers, acceptable_statuses,
|
||||
def make_request(
|
||||
self, method, path, headers, acceptable_statuses,
|
||||
body_file=None):
|
||||
self.make_request_called += 1
|
||||
self.test.assertEquals(self.path, path)
|
||||
@ -780,14 +820,12 @@ class TestInternalClient(unittest.TestCase):
|
||||
self.test.assertEquals(self.fobj, fobj)
|
||||
|
||||
fobj = 'some_fobj'
|
||||
account = 'some_account'
|
||||
container = 'some_container'
|
||||
object_name = 'some_object'
|
||||
path = '/v1/%s/%s/%s' % (account, container, object_name)
|
||||
account, container, obj = path_parts()
|
||||
path = make_path(account, container, obj)
|
||||
headers = {'key': 'value'}
|
||||
|
||||
client = InternalClient(self, path, headers, fobj)
|
||||
client.upload_object(fobj, account, container, object_name, headers)
|
||||
client.upload_object(fobj, account, container, obj, headers)
|
||||
self.assertEquals(1, client.make_request_called)
|
||||
|
||||
if __name__ == '__main__':
|
Loading…
x
Reference in New Issue
Block a user