Remove wrapper methods from object_client
There are few methods in object_clients which are wrapper on PUT API with different combination of headers. As object_client is going to be declared as lib interface it is better to remove these wrapper. NOTE: Those methods are not being used outside of Tempest. Partially implements blueprint consistent-service-method-names Change-Id: Ia70ef3913c1650fad7b8f6b9019378b074c88155
This commit is contained in:
parent
cf4880e7dc
commit
88eadcf26d
@ -48,8 +48,9 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
data_segments = [data + str(i) for i in range(segments)]
|
data_segments = [data + str(i) for i in range(segments)]
|
||||||
# uploading segments
|
# uploading segments
|
||||||
for i in range(segments):
|
for i in range(segments):
|
||||||
self.object_client.create_object_segments(
|
obj_name = "%s/%s" % (object_name, i)
|
||||||
self.container_name, object_name, i, data_segments[i])
|
self.object_client.create_object(
|
||||||
|
self.container_name, obj_name, data_segments[i])
|
||||||
|
|
||||||
return object_name, data_segments
|
return object_name, data_segments
|
||||||
|
|
||||||
@ -184,12 +185,15 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
# create object with transfer_encoding
|
# create object with transfer_encoding
|
||||||
object_name = data_utils.rand_name(name='TestObject')
|
object_name = data_utils.rand_name(name='TestObject')
|
||||||
data = data_utils.random_bytes(1024)
|
data = data_utils.random_bytes(1024)
|
||||||
_, _, resp_headers = self.object_client.put_object_with_chunk(
|
headers = {'Transfer-Encoding': 'chunked'}
|
||||||
container=self.container_name,
|
resp, _ = self.object_client.create_object(
|
||||||
name=object_name,
|
self.container_name,
|
||||||
contents=data_utils.chunkify(data, 512)
|
object_name,
|
||||||
)
|
data=data_utils.chunkify(data, 512),
|
||||||
self.assertHeaders(resp_headers, 'Object', 'PUT')
|
headers=headers,
|
||||||
|
chunked=True)
|
||||||
|
|
||||||
|
self.assertHeaders(resp, 'Object', 'PUT')
|
||||||
|
|
||||||
# check uploaded content
|
# check uploaded content
|
||||||
_, body = self.object_client.get_object(self.container_name,
|
_, body = self.object_client.get_object(self.container_name,
|
||||||
@ -728,8 +732,13 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
dst_object_name,
|
dst_object_name,
|
||||||
dst_data)
|
dst_data)
|
||||||
# copy source object to destination
|
# copy source object to destination
|
||||||
resp, _ = self.object_client.copy_object_in_same_container(
|
headers = {}
|
||||||
self.container_name, src_object_name, dst_object_name)
|
headers['X-Copy-From'] = "%s/%s" % (str(self.container_name),
|
||||||
|
str(src_object_name))
|
||||||
|
resp, body = self.object_client.create_object(self.container_name,
|
||||||
|
dst_object_name,
|
||||||
|
data=None,
|
||||||
|
headers=headers)
|
||||||
self.assertHeaders(resp, 'Object', 'PUT')
|
self.assertHeaders(resp, 'Object', 'PUT')
|
||||||
|
|
||||||
# check data
|
# check data
|
||||||
@ -749,8 +758,14 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
# change the content type of the object
|
# change the content type of the object
|
||||||
metadata = {'content-type': 'text/plain; charset=UTF-8'}
|
metadata = {'content-type': 'text/plain; charset=UTF-8'}
|
||||||
self.assertNotEqual(resp_tmp['content-type'], metadata['content-type'])
|
self.assertNotEqual(resp_tmp['content-type'], metadata['content-type'])
|
||||||
resp, _ = self.object_client.copy_object_in_same_container(
|
headers = {}
|
||||||
self.container_name, object_name, object_name, metadata)
|
headers['X-Copy-From'] = "%s/%s" % (str(self.container_name),
|
||||||
|
str(object_name))
|
||||||
|
resp, body = self.object_client.create_object(self.container_name,
|
||||||
|
object_name,
|
||||||
|
data=None,
|
||||||
|
metadata=metadata,
|
||||||
|
headers=headers)
|
||||||
self.assertHeaders(resp, 'Object', 'PUT')
|
self.assertHeaders(resp, 'Object', 'PUT')
|
||||||
|
|
||||||
# check the content type
|
# check the content type
|
||||||
@ -808,9 +823,13 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
self.assertHeaders(resp, 'Object', 'POST')
|
self.assertHeaders(resp, 'Object', 'POST')
|
||||||
|
|
||||||
# copy object from source container to destination container
|
# copy object from source container to destination container
|
||||||
resp, _ = self.object_client.copy_object_across_containers(
|
headers = {}
|
||||||
src_container_name, object_name, dst_container_name,
|
headers['X-Copy-From'] = "%s/%s" % (str(src_container_name),
|
||||||
object_name)
|
str(object_name))
|
||||||
|
resp, body = self.object_client.create_object(dst_container_name,
|
||||||
|
object_name,
|
||||||
|
data=None,
|
||||||
|
headers=headers)
|
||||||
self.assertHeaders(resp, 'Object', 'PUT')
|
self.assertHeaders(resp, 'Object', 'PUT')
|
||||||
|
|
||||||
# check if object is present in destination container
|
# check if object is present in destination container
|
||||||
@ -897,8 +916,9 @@ class ObjectTest(base.BaseObjectTest):
|
|||||||
data_segments = [data + str(i) for i in range(segments)]
|
data_segments = [data + str(i) for i in range(segments)]
|
||||||
# uploading segments
|
# uploading segments
|
||||||
for i in range(segments):
|
for i in range(segments):
|
||||||
resp, _ = self.object_client.create_object_segments(
|
obj_name = "%s/%s" % (object_name, i)
|
||||||
self.container_name, object_name, i, data_segments[i])
|
resp, _ = self.object_client.create_object(
|
||||||
|
self.container_name, obj_name, data_segments[i])
|
||||||
# creating a manifest file
|
# creating a manifest file
|
||||||
metadata = {'X-Object-Manifest': '%s/%s/'
|
metadata = {'X-Object-Manifest': '%s/%s/'
|
||||||
% (self.container_name, object_name)}
|
% (self.container_name, object_name)}
|
||||||
|
@ -23,7 +23,8 @@ from tempest.lib import exceptions
|
|||||||
class ObjectClient(rest_client.RestClient):
|
class ObjectClient(rest_client.RestClient):
|
||||||
|
|
||||||
def create_object(self, container, object_name, data,
|
def create_object(self, container, object_name, data,
|
||||||
params=None, metadata=None, headers=None):
|
params=None, metadata=None, headers=None,
|
||||||
|
chunked=False):
|
||||||
"""Create storage object."""
|
"""Create storage object."""
|
||||||
|
|
||||||
if headers is None:
|
if headers is None:
|
||||||
@ -37,7 +38,7 @@ class ObjectClient(rest_client.RestClient):
|
|||||||
if params:
|
if params:
|
||||||
url += '?%s' % urlparse.urlencode(params)
|
url += '?%s' % urlparse.urlencode(params)
|
||||||
|
|
||||||
resp, body = self.put(url, data, headers)
|
resp, body = self.put(url, data, headers, chunked=chunked)
|
||||||
self.expected_success(201, resp.status)
|
self.expected_success(201, resp.status)
|
||||||
return resp, body
|
return resp, body
|
||||||
|
|
||||||
@ -84,41 +85,6 @@ class ObjectClient(rest_client.RestClient):
|
|||||||
self.expected_success([200, 206], resp.status)
|
self.expected_success([200, 206], resp.status)
|
||||||
return resp, body
|
return resp, body
|
||||||
|
|
||||||
def copy_object_in_same_container(self, container, src_object_name,
|
|
||||||
dest_object_name, metadata=None):
|
|
||||||
"""Copy storage object's data to the new object using PUT."""
|
|
||||||
|
|
||||||
url = "{0}/{1}".format(container, dest_object_name)
|
|
||||||
headers = {}
|
|
||||||
headers['X-Copy-From'] = "%s/%s" % (str(container),
|
|
||||||
str(src_object_name))
|
|
||||||
headers['content-length'] = '0'
|
|
||||||
if metadata:
|
|
||||||
for key in metadata:
|
|
||||||
headers[str(key)] = metadata[key]
|
|
||||||
|
|
||||||
resp, body = self.put(url, None, headers=headers)
|
|
||||||
self.expected_success(201, resp.status)
|
|
||||||
return resp, body
|
|
||||||
|
|
||||||
def copy_object_across_containers(self, src_container, src_object_name,
|
|
||||||
dst_container, dst_object_name,
|
|
||||||
metadata=None):
|
|
||||||
"""Copy storage object's data to the new object using PUT."""
|
|
||||||
|
|
||||||
url = "{0}/{1}".format(dst_container, dst_object_name)
|
|
||||||
headers = {}
|
|
||||||
headers['X-Copy-From'] = "%s/%s" % (str(src_container),
|
|
||||||
str(src_object_name))
|
|
||||||
headers['content-length'] = '0'
|
|
||||||
if metadata:
|
|
||||||
for key in metadata:
|
|
||||||
headers[str(key)] = metadata[key]
|
|
||||||
|
|
||||||
resp, body = self.put(url, None, headers=headers)
|
|
||||||
self.expected_success(201, resp.status)
|
|
||||||
return resp, body
|
|
||||||
|
|
||||||
def copy_object_2d_way(self, container, src_object_name, dest_object_name,
|
def copy_object_2d_way(self, container, src_object_name, dest_object_name,
|
||||||
metadata=None):
|
metadata=None):
|
||||||
"""Copy storage object's data to the new object using COPY."""
|
"""Copy storage object's data to the new object using COPY."""
|
||||||
@ -135,38 +101,6 @@ class ObjectClient(rest_client.RestClient):
|
|||||||
self.expected_success(201, resp.status)
|
self.expected_success(201, resp.status)
|
||||||
return resp, body
|
return resp, body
|
||||||
|
|
||||||
def create_object_segments(self, container, object_name, segment, data):
|
|
||||||
"""Creates object segments."""
|
|
||||||
url = "{0}/{1}/{2}".format(container, object_name, segment)
|
|
||||||
resp, body = self.put(url, data)
|
|
||||||
self.expected_success(201, resp.status)
|
|
||||||
return resp, body
|
|
||||||
|
|
||||||
def put_object_with_chunk(self, container, name, contents):
|
|
||||||
"""Put an object with Transfer-Encoding header
|
|
||||||
|
|
||||||
:param container: name of the container
|
|
||||||
:type container: string
|
|
||||||
:param name: name of the object
|
|
||||||
:type name: string
|
|
||||||
:param contents: object data
|
|
||||||
:type contents: iterable
|
|
||||||
"""
|
|
||||||
headers = {'Transfer-Encoding': 'chunked'}
|
|
||||||
if self.token:
|
|
||||||
headers['X-Auth-Token'] = self.token
|
|
||||||
|
|
||||||
url = "%s/%s" % (container, name)
|
|
||||||
resp, body = self.put(
|
|
||||||
url, headers=headers,
|
|
||||||
body=contents,
|
|
||||||
chunked=True
|
|
||||||
)
|
|
||||||
|
|
||||||
self._error_checker(resp, body)
|
|
||||||
self.expected_success(201, resp.status)
|
|
||||||
return resp.status, resp.reason, resp
|
|
||||||
|
|
||||||
def create_object_continue(self, container, object_name,
|
def create_object_continue(self, container, object_name,
|
||||||
data, metadata=None):
|
data, metadata=None):
|
||||||
"""Put an object using Expect:100-continue"""
|
"""Put an object using Expect:100-continue"""
|
||||||
|
Loading…
Reference in New Issue
Block a user