Merge "Adjust Container override methods"

This commit is contained in:
Jenkins
2015-02-20 20:30:04 +00:00
committed by Gerrit Code Review
2 changed files with 64 additions and 31 deletions

View File

@@ -100,27 +100,78 @@ class Container(resource.Resource):
#: has a copy of the object before any data is sent. #: has a copy of the object before any data is sent.
if_none_match = resource.prop("if-none-match") if_none_match = resource.prop("if-none-match")
def _do_create_update(self, session, method): @classmethod
url = utils.urljoin(self.base_path, self.id) def _do_create_update(cls, method, session, attrs, resource_id):
"""Helper method to call put and post
The internals of create and update are the same exept for
the session method.
"""
url = utils.urljoin(cls.base_path, resource_id)
# Only send actual headers, not potentially set body values. # Only send actual headers, not potentially set body values.
headers = self._attrs.copy() headers = attrs.copy()
for val in ("name", "count", "bytes"): for val in ("name", "count", "bytes"):
headers.pop(val, None) headers.pop(val, None)
data = method(url, service=self.service, accept=None, return method(url, service=cls.service, accept=None,
headers=headers).headers headers=headers).headers
self._reset_dirty()
return data
def create(self, session): @classmethod
if not self.allow_create: def update_by_id(cls, session, resource_id, attrs, path_args=None):
raise exceptions.MethodNotSupported('create') """Update a Container with the given attributes.
return self._do_create_update(session, session.put) :param session: The session to use for making this request.
:type session: :class:`~openstack.session.Session`
:param resource_id: This resource's identifier, if needed by
the request. The default is ``None``.
:param dict attrs: The attributes to be sent in the body
of the request.
:param dict path_args: This parameter is sent by the base
class but is ignored for this method.
def update(self, session): :return: A ``dict`` representing the response headers.
if not self.allow_update: :raises: :exc:`~openstack.exceptions.MethodNotSupported` if
:data:`Resource.allow_update` is not set to ``True``.
"""
if not cls.allow_update:
raise exceptions.MethodNotSupported('update') raise exceptions.MethodNotSupported('update')
return self._do_create_update(session, session.post) return cls._do_create_update(session.post, session, attrs,
resource_id)
@classmethod
def create_by_id(cls, session, attrs, resource_id=None):
"""Create a Container from its attributes.
:param session: The session to use for making this request.
:type session: :class:`~openstack.session.Session`
:param dict attrs: The attributes to be sent in the body
of the request.
:param resource_id: This resource's identifier, if needed by
the request. The default is ``None``.
:return: A ``dict`` representing the response headers.
:raises: :exc:`~openstack.exceptions.MethodNotSupported` if
:data:`Resource.allow_create` is not set to ``True``.
"""
if not cls.allow_create:
raise exceptions.MethodNotSupported('create')
return cls._do_create_update(session.put, session, attrs,
resource_id)
def create(self, session):
"""Create a Container from this instance.
:param session: The session to use for making this request.
:type session: :class:`~openstack.session.Session`
:return: This :class:`~openstack.object_store.v1.container.Container`
instance.
:raises: :exc:`~openstack.exceptions.MethodNotSupported` if
:data:`Resource.allow_create` is not set to ``True``.
"""
self.create_by_id(session, self._attrs, self.id)
self._reset_dirty()
return self

View File

@@ -13,7 +13,6 @@
import mock import mock
import testtools import testtools
from openstack import exceptions
from openstack.object_store.v1 import container from openstack.object_store.v1 import container
@@ -179,20 +178,3 @@ class TestContainer(testtools.TestCase):
def test_update(self): def test_update(self):
sot = container.Container.new(name=CONTAINER_NAME) sot = container.Container.new(name=CONTAINER_NAME)
self._test_create_update(sot, sot.update, self.sess.post) self._test_create_update(sot, sot.update, self.sess.post)
def _test_cant(self, sot, call):
sot.allow_create = False
self.assertRaises(exceptions.MethodNotSupported,
call, self.sess)
def test_cant_create(self):
sot = container.Container.new(name=CONTAINER_NAME)
sot.allow_create = False
self.assertRaises(exceptions.MethodNotSupported,
sot.create, self.sess)
def test_cant_update(self):
sot = container.Container.new(name=CONTAINER_NAME)
sot.allow_update = False
self.assertRaises(exceptions.MethodNotSupported,
sot.update, self.sess)