Refactor the code about container force delete in api

In [1], we split two method about delete to disallow non-admin
user to force delete containers. It creates a lot of duplicated
code, which will be a burden for further work. This patch will
try to refactor it.

[1] https://review.openstack.org/#/c/498767/

Change-Id: Icfb9fb25c3ce763a44e83209502da935c63d77a4
This commit is contained in:
miaohb 2017-10-10 00:53:03 -07:00 committed by Hongbin Lu
parent e2bdfa13f5
commit adc0d449e2
2 changed files with 8 additions and 33 deletions

View File

@ -428,36 +428,6 @@ class ContainersController(base.Controller):
container.save(context) container.save(context)
return view.format_container(pecan.request.host_url, container) return view.format_container(pecan.request.host_url, container)
@base.Controller.api_version("1.1", "1.6")
@pecan.expose('json')
@exception.wrap_pecan_controller_exception
@validation.validate_query_param(pecan.request, schema.query_param_delete)
def delete(self, container_ident, force=False, **kwargs):
"""Delete a container.
:param container_ident: UUID or Name of a container.
"""
context = pecan.request.context
if utils.is_all_tenants(kwargs):
policy.enforce(context, "container:delete_all_tenants",
action="container:delete_all_tenants")
context.all_tenants = True
container = utils.get_container(container_ident)
check_policy_on_container(container.as_dict(), "container:delete")
try:
force = strutils.bool_from_string(force, strict=True)
except ValueError:
msg = _('Valid force values are true, false, 0, 1, yes and no')
raise exception.InvalidValue(msg)
if not force:
utils.validate_container_state(container, 'delete')
else:
utils.validate_container_state(container, 'delete_force')
compute_api = pecan.request.compute_api
compute_api.container_delete(context, container, force)
pecan.response.status = 204
@base.Controller.api_version("1.7") # noqa
@pecan.expose('json') @pecan.expose('json')
@exception.wrap_pecan_controller_exception @exception.wrap_pecan_controller_exception
@validation.validate_query_param(pecan.request, schema.query_param_delete) @validation.validate_query_param(pecan.request, schema.query_param_delete)
@ -482,9 +452,12 @@ class ContainersController(base.Controller):
if not force: if not force:
utils.validate_container_state(container, 'delete') utils.validate_container_state(container, 'delete')
else: else:
utils.validate_container_state(container, 'delete_force') req_version = pecan.request.version
min_version = versions.Version('', '', '', '1.7')
if req_version >= min_version:
policy.enforce(context, "container:delete_force", policy.enforce(context, "container:delete_force",
action="container:delete_force") action="container:delete_force")
utils.validate_container_state(container, 'delete_force')
compute_api = pecan.request.compute_api compute_api = pecan.request.compute_api
container.status = consts.DELETING container.status = consts.DELETING
compute_api.container_delete(context, container, force) compute_api.container_delete(context, container, force)

View File

@ -1285,7 +1285,9 @@ class TestContainerController(api_base.FunctionalTest):
"Cannot delete container %s in Running state" % uuid): "Cannot delete container %s in Running state" % uuid):
self.delete('/v1/containers/%s' % (test_object.uuid)) self.delete('/v1/containers/%s' % (test_object.uuid))
def test_delete_force_by_uuid_invalid_state(self): @patch('zun.common.policy.enforce')
def test_delete_force_by_uuid_invalid_state(self, mock_policy):
mock_policy.return_value = True
uuid = uuidutils.generate_uuid() uuid = uuidutils.generate_uuid()
test_object = utils.create_test_container(context=self.context, test_object = utils.create_test_container(context=self.context,
uuid=uuid, status='Paused') uuid=uuid, status='Paused')