summaryrefslogtreecommitdiff
path: root/openstackclient/tests/object/v1/lib
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2014-09-18 00:54:52 -0500
committerSteve Martinelli <stevemar@ca.ibm.com>2014-10-01 13:50:13 -0400
commit31018bf7c2c57c530d55ed1dd90b9b65d489d557 (patch)
tree79f991b2c0b6c54c54b97c54cdf6db00a904cf86 /openstackclient/tests/object/v1/lib
parente3b9b9658805f274283a498ed82014dce3833fe3 (diff)
downloadpython-openstackclient-31018bf7c2c57c530d55ed1dd90b9b65d489d557.tar.gz
Move object-store commands to low-level API
api.object_store.APIv1 now contains the formerly top-level functions implementing the object-store REST client. This replaces the old-style ObjectClientv1 that is no longer necessary. Change-Id: I7d8fea326b214481e7d6b24119bd41777c6aa968
Diffstat (limited to 'openstackclient/tests/object/v1/lib')
-rw-r--r--openstackclient/tests/object/v1/lib/__init__.py0
-rw-r--r--openstackclient/tests/object/v1/lib/test_container.py207
-rw-r--r--openstackclient/tests/object/v1/lib/test_object.py295
3 files changed, 0 insertions, 502 deletions
diff --git a/openstackclient/tests/object/v1/lib/__init__.py b/openstackclient/tests/object/v1/lib/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/openstackclient/tests/object/v1/lib/__init__.py
+++ /dev/null
diff --git a/openstackclient/tests/object/v1/lib/test_container.py b/openstackclient/tests/object/v1/lib/test_container.py
deleted file mode 100644
index ce70b835..00000000
--- a/openstackclient/tests/object/v1/lib/test_container.py
+++ /dev/null
@@ -1,207 +0,0 @@
-# Copyright 2013 Nebula Inc.
-#
-# Licensed under the Apache License, Version 2.0 (the "License"); you may
-# not use this file except in compliance with the License. You may obtain
-# a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
-# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
-# License for the specific language governing permissions and limitations
-# under the License.
-#
-
-"""Test Object API library module"""
-
-import mock
-
-from openstackclient.object.v1.lib import container as lib_container
-from openstackclient.tests import fakes
-from openstackclient.tests.object.v1 import fakes as object_fakes
-
-
-fake_account = 'q12we34r'
-fake_auth = '11223344556677889900'
-fake_url = 'http://gopher.com/v1/' + fake_account
-
-fake_container = 'rainbarrel'
-
-
-class FakeClient(object):
- def __init__(self, endpoint=None, **kwargs):
- self.endpoint = fake_url
- self.token = fake_auth
-
-
-class TestContainer(object_fakes.TestObjectv1):
-
- def setUp(self):
- super(TestContainer, self).setUp()
- self.app.client_manager.session = mock.MagicMock()
-
-
-class TestContainerList(TestContainer):
-
- def test_container_list_no_options(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- }
- )
- self.assertEqual(resp, data)
-
- def test_container_list_marker(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- marker='next',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- 'marker': 'next',
- }
- )
- self.assertEqual(resp, data)
-
- def test_container_list_limit(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- limit=5,
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- 'limit': 5,
- }
- )
- self.assertEqual(resp, data)
-
- def test_container_list_end_marker(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- end_marker='last',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- 'end_marker': 'last',
- }
- )
- self.assertEqual(resp, data)
-
- def test_container_list_prefix(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- prefix='foo/',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- 'prefix': 'foo/',
- }
- )
- self.assertEqual(resp, data)
-
- def test_container_list_full_listing(self):
- sess = self.app.client_manager.session
-
- def side_effect(*args, **kwargs):
- rv = sess.get().json.return_value
- sess.get().json.return_value = []
- sess.get().json.side_effect = None
- return rv
-
- resp = [{'name': 'is-name'}]
- sess.get().json.return_value = resp
- sess.get().json.side_effect = side_effect
-
- data = lib_container.list_containers(
- self.app.client_manager.session,
- fake_url,
- full_listing=True,
- )
-
- # Check expected values
- sess.get.assert_called_with(
- fake_url,
- params={
- 'format': 'json',
- 'marker': 'is-name',
- }
- )
- self.assertEqual(resp, data)
-
-
-class TestContainerShow(TestContainer):
-
- def test_container_show_no_options(self):
- resp = {
- 'X-Container-Meta-Owner': fake_account,
- 'x-container-object-count': 1,
- 'x-container-bytes-used': 577,
- }
- self.app.client_manager.session.head.return_value = \
- fakes.FakeResponse(headers=resp)
-
- data = lib_container.show_container(
- self.app.client_manager.session,
- fake_url,
- 'is-name',
- )
-
- # Check expected values
- self.app.client_manager.session.head.assert_called_with(
- fake_url + '/is-name',
- )
-
- data_expected = {
- 'account': fake_account,
- 'container': 'is-name',
- 'object_count': 1,
- 'bytes_used': 577,
- 'read_acl': None,
- 'write_acl': None,
- 'sync_to': None,
- 'sync_key': None,
- }
- self.assertEqual(data_expected, data)
diff --git a/openstackclient/tests/object/v1/lib/test_object.py b/openstackclient/tests/object/v1/lib/test_object.py
deleted file mode 100644
index f96732b4..00000000
--- a/openstackclient/tests/object/v1/lib/test_object.py
+++ /dev/null
@@ -1,295 +0,0 @@
-# Copyright 2013 Nebula Inc.
-#
-# Licensed under the Apache License, Version 2.0 (the "License"); you may
-# not use this file except in compliance with the License. You may obtain
-# a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
-# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
-# License for the specific language governing permissions and limitations
-# under the License.
-#
-
-"""Test Object API library module"""
-
-import mock
-
-from openstackclient.object.v1.lib import object as lib_object
-from openstackclient.tests import fakes
-from openstackclient.tests.object.v1 import fakes as object_fakes
-
-
-fake_account = 'q12we34r'
-fake_auth = '11223344556677889900'
-fake_url = 'http://gopher.com/v1/' + fake_account
-
-fake_container = 'rainbarrel'
-fake_object = 'raindrop'
-
-
-class FakeClient(object):
- def __init__(self, endpoint=None, **kwargs):
- self.endpoint = fake_url
- self.token = fake_auth
-
-
-class TestObject(object_fakes.TestObjectv1):
-
- def setUp(self):
- super(TestObject, self).setUp()
- self.app.client_manager.session = mock.MagicMock()
-
-
-class TestObjectListObjects(TestObject):
-
- def test_list_objects_no_options(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_marker(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- marker='next',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'marker': 'next',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_limit(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- limit=5,
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'limit': 5,
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_end_marker(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- end_marker='last',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'end_marker': 'last',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_delimiter(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- delimiter='|',
- )
-
- # Check expected values
- # NOTE(dtroyer): requests handles the URL encoding and we're
- # mocking that so use the otherwise-not-legal
- # pipe '|' char in the response.
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'delimiter': '|',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_prefix(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- prefix='foo/',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'prefix': 'foo/',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_path(self):
- resp = [{'name': 'is-name'}]
- self.app.client_manager.session.get().json.return_value = resp
-
- data = lib_object.list_objects(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- path='next',
- )
-
- # Check expected values
- self.app.client_manager.session.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'path': 'next',
- }
- )
- self.assertEqual(resp, data)
-
- def test_list_objects_full_listing(self):
- sess = self.app.client_manager.session
-
- def side_effect(*args, **kwargs):
- rv = sess.get().json.return_value
- sess.get().json.return_value = []
- sess.get().json.side_effect = None
- return rv
-
- resp = [{'name': 'is-name'}]
- sess.get().json.return_value = resp
- sess.get().json.side_effect = side_effect
-
- data = lib_object.list_objects(
- sess,
- fake_url,
- fake_container,
- full_listing=True,
- )
-
- # Check expected values
- sess.get.assert_called_with(
- fake_url + '/' + fake_container,
- params={
- 'format': 'json',
- 'marker': 'is-name',
- }
- )
- self.assertEqual(resp, data)
-
-
-class TestObjectShowObjects(TestObject):
-
- def test_object_show_no_options(self):
- resp = {
- 'content-type': 'text/alpha',
- 'x-container-meta-owner': fake_account,
- }
- self.app.client_manager.session.head.return_value = \
- fakes.FakeResponse(headers=resp)
-
- data = lib_object.show_object(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- fake_object,
- )
-
- # Check expected values
- self.app.client_manager.session.head.assert_called_with(
- fake_url + '/%s/%s' % (fake_container, fake_object),
- )
-
- data_expected = {
- 'account': fake_account,
- 'container': fake_container,
- 'object': fake_object,
- 'content-type': 'text/alpha',
- }
- self.assertEqual(data_expected, data)
-
- def test_object_show_all_options(self):
- resp = {
- 'content-type': 'text/alpha',
- 'content-length': 577,
- 'last-modified': '20130101',
- 'etag': 'qaz',
- 'x-container-meta-owner': fake_account,
- 'x-object-manifest': None,
- 'x-object-meta-wife': 'Wilma',
- 'x-tra-header': 'yabba-dabba-do',
- }
- self.app.client_manager.session.head.return_value = \
- fakes.FakeResponse(headers=resp)
-
- data = lib_object.show_object(
- self.app.client_manager.session,
- fake_url,
- fake_container,
- fake_object,
- )
-
- # Check expected values
- self.app.client_manager.session.head.assert_called_with(
- fake_url + '/%s/%s' % (fake_container, fake_object),
- )
-
- data_expected = {
- 'account': fake_account,
- 'container': fake_container,
- 'object': fake_object,
- 'content-type': 'text/alpha',
- 'content-length': 577,
- 'last-modified': '20130101',
- 'etag': 'qaz',
- 'x-object-manifest': None,
- 'wife': 'Wilma',
- 'x-tra-header': 'yabba-dabba-do',
- }
- self.assertEqual(data_expected, data)