Merge "Prevent force delete if the volume is attached"
This commit is contained in:
commit
17ed858455
cinder
@ -175,6 +175,9 @@ class VolumeController(wsgi.Controller):
|
|||||||
self.volume_api.delete(context, volume)
|
self.volume_api.delete(context, volume)
|
||||||
except exception.NotFound:
|
except exception.NotFound:
|
||||||
raise exc.HTTPNotFound()
|
raise exc.HTTPNotFound()
|
||||||
|
except exception.VolumeAttached:
|
||||||
|
explanation = 'Volume cannot be deleted while in attached state'
|
||||||
|
raise exc.HTTPBadRequest(explanation=explanation)
|
||||||
return webob.Response(status_int=202)
|
return webob.Response(status_int=202)
|
||||||
|
|
||||||
@wsgi.serializers(xml=VolumesTemplate)
|
@wsgi.serializers(xml=VolumesTemplate)
|
||||||
|
@ -658,6 +658,16 @@ class VolumeApiTest(test.TestCase):
|
|||||||
resp = self.controller.delete(req, 1)
|
resp = self.controller.delete(req, 1)
|
||||||
self.assertEqual(resp.status_int, 202)
|
self.assertEqual(resp.status_int, 202)
|
||||||
|
|
||||||
|
def test_volume_delete_attached(self):
|
||||||
|
def stub_volume_attached(self, context, volume, force=False):
|
||||||
|
raise exception.VolumeAttached(volume_id=volume['id'])
|
||||||
|
self.stubs.Set(volume_api.API, "delete", stub_volume_attached)
|
||||||
|
|
||||||
|
req = fakes.HTTPRequest.blank('/v2/volumes/1')
|
||||||
|
self.assertRaises(webob.exc.HTTPBadRequest,
|
||||||
|
self.controller.delete,
|
||||||
|
req, 1)
|
||||||
|
|
||||||
def test_volume_delete_no_volume(self):
|
def test_volume_delete_no_volume(self):
|
||||||
self.stubs.Set(volume_api.API, "get", stubs.stub_volume_get_notfound)
|
self.stubs.Set(volume_api.API, "get", stubs.stub_volume_get_notfound)
|
||||||
|
|
||||||
|
@ -561,6 +561,24 @@ class VolumeTestCase(test.TestCase):
|
|||||||
# clean up
|
# clean up
|
||||||
self.volume.delete_volume(self.context, volume['id'])
|
self.volume.delete_volume(self.context, volume['id'])
|
||||||
|
|
||||||
|
def test_cant_force_delete_attached_volume(self):
|
||||||
|
"""Test volume can't be force delete in attached state"""
|
||||||
|
volume = self._create_volume()
|
||||||
|
self.volume.create_volume(self.context, volume['id'])
|
||||||
|
volume['status'] = 'in-use'
|
||||||
|
volume['attach_status'] = 'attached'
|
||||||
|
volume['host'] = 'fakehost'
|
||||||
|
|
||||||
|
volume_api = cinder.volume.api.API()
|
||||||
|
|
||||||
|
self.assertRaises(exception.VolumeAttached,
|
||||||
|
volume_api.delete,
|
||||||
|
self.context,
|
||||||
|
volume,
|
||||||
|
force=True)
|
||||||
|
|
||||||
|
self.volume.delete_volume(self.context, volume['id'])
|
||||||
|
|
||||||
def test_cant_delete_volume_with_snapshots(self):
|
def test_cant_delete_volume_with_snapshots(self):
|
||||||
"""Test volume can't be deleted with dependent snapshots."""
|
"""Test volume can't be deleted with dependent snapshots."""
|
||||||
volume = self._create_volume()
|
volume = self._create_volume()
|
||||||
|
@ -320,6 +320,10 @@ class API(base.Base):
|
|||||||
msg = _("Volume status must be available or error")
|
msg = _("Volume status must be available or error")
|
||||||
raise exception.InvalidVolume(reason=msg)
|
raise exception.InvalidVolume(reason=msg)
|
||||||
|
|
||||||
|
if volume['attach_status'] == "attached":
|
||||||
|
# Volume is still attached, need to detach first
|
||||||
|
raise exception.VolumeAttached(volume_id=volume_id)
|
||||||
|
|
||||||
snapshots = self.db.snapshot_get_all_for_volume(context, volume_id)
|
snapshots = self.db.snapshot_get_all_for_volume(context, volume_id)
|
||||||
if len(snapshots):
|
if len(snapshots):
|
||||||
msg = _("Volume still has %d dependent snapshots") % len(snapshots)
|
msg = _("Volume still has %d dependent snapshots") % len(snapshots)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user