Enable "cinder delete" can delete multiple volumes in one request
"nova delete" can delete multiple servers in one request but "cinder delete" can only delete one volume in one request, it is better to enhance cinder client to support remove multiple volumes in one request. Change-Id: I6a63aa3d7e4c152ae5e45bf2b36d862bdcd6df33 Closes-Bug: #1241941
This commit is contained in:
parent
7fa5bc3005
commit
4ce8e800c4
@ -297,13 +297,17 @@ class FakeHTTPClient(base_client.HTTPClient):
|
|||||||
# at the very least it's not complete
|
# at the very least it's not complete
|
||||||
def get_volumes_detail(self, **kw):
|
def get_volumes_detail(self, **kw):
|
||||||
return (200, {}, {"volumes": [
|
return (200, {}, {"volumes": [
|
||||||
{'id': 1234,
|
{'id': kw.get('id', 1234),
|
||||||
'name': 'sample-volume',
|
'name': 'sample-volume',
|
||||||
'attachments': [{'server_id': 1234}]},
|
'attachments': [{'server_id': 1234}]},
|
||||||
]})
|
]})
|
||||||
|
|
||||||
def get_volumes_1234(self, **kw):
|
def get_volumes_1234(self, **kw):
|
||||||
r = {'volume': self.get_volumes_detail()[2]['volumes'][0]}
|
r = {'volume': self.get_volumes_detail(id=1234)[2]['volumes'][0]}
|
||||||
|
return (200, {}, r)
|
||||||
|
|
||||||
|
def get_volumes_5678(self, **kw):
|
||||||
|
r = {'volume': self.get_volumes_detail(id=5678)[2]['volumes'][0]}
|
||||||
return (200, {}, r)
|
return (200, {}, r)
|
||||||
|
|
||||||
def get_volumes_1234_encryption(self, **kw):
|
def get_volumes_1234_encryption(self, **kw):
|
||||||
@ -350,6 +354,9 @@ class FakeHTTPClient(base_client.HTTPClient):
|
|||||||
def delete_volumes_1234(self, **kw):
|
def delete_volumes_1234(self, **kw):
|
||||||
return (202, {}, None)
|
return (202, {}, None)
|
||||||
|
|
||||||
|
def delete_volumes_5678(self, **kw):
|
||||||
|
return (202, {}, None)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Quotas
|
# Quotas
|
||||||
#
|
#
|
||||||
|
@ -117,6 +117,10 @@ class ShellTest(utils.TestCase):
|
|||||||
self.run_command('delete 1234')
|
self.run_command('delete 1234')
|
||||||
self.assert_called('DELETE', '/volumes/1234')
|
self.assert_called('DELETE', '/volumes/1234')
|
||||||
|
|
||||||
|
def test_delete_multiple(self):
|
||||||
|
self.run_command('delete 1234 5678')
|
||||||
|
self.assert_called('DELETE', '/volumes/5678')
|
||||||
|
|
||||||
def test_backup(self):
|
def test_backup(self):
|
||||||
self.run_command('backup-create 1234')
|
self.run_command('backup-create 1234')
|
||||||
self.assert_called('POST', '/backups')
|
self.assert_called('POST', '/backups')
|
||||||
|
@ -304,13 +304,17 @@ class FakeHTTPClient(base_client.HTTPClient):
|
|||||||
# at the very least it's not complete
|
# at the very least it's not complete
|
||||||
def get_volumes_detail(self, **kw):
|
def get_volumes_detail(self, **kw):
|
||||||
return (200, {}, {"volumes": [
|
return (200, {}, {"volumes": [
|
||||||
{'id': 1234,
|
{'id': kw.get('id', 1234),
|
||||||
'name': 'sample-volume',
|
'name': 'sample-volume',
|
||||||
'attachments': [{'server_id': 1234}]},
|
'attachments': [{'server_id': 1234}]},
|
||||||
]})
|
]})
|
||||||
|
|
||||||
def get_volumes_1234(self, **kw):
|
def get_volumes_1234(self, **kw):
|
||||||
r = {'volume': self.get_volumes_detail()[2]['volumes'][0]}
|
r = {'volume': self.get_volumes_detail(id=1234)[2]['volumes'][0]}
|
||||||
|
return (200, {}, r)
|
||||||
|
|
||||||
|
def get_volumes_5678(self, **kw):
|
||||||
|
r = {'volume': self.get_volumes_detail(id=5678)[2]['volumes'][0]}
|
||||||
return (200, {}, r)
|
return (200, {}, r)
|
||||||
|
|
||||||
def get_volumes_1234_encryption(self, **kw):
|
def get_volumes_1234_encryption(self, **kw):
|
||||||
@ -357,6 +361,9 @@ class FakeHTTPClient(base_client.HTTPClient):
|
|||||||
def delete_volumes_1234(self, **kw):
|
def delete_volumes_1234(self, **kw):
|
||||||
return (202, {}, None)
|
return (202, {}, None)
|
||||||
|
|
||||||
|
def delete_volumes_5678(self, **kw):
|
||||||
|
return (202, {}, None)
|
||||||
|
|
||||||
#
|
#
|
||||||
# Quotas
|
# Quotas
|
||||||
#
|
#
|
||||||
|
@ -95,6 +95,10 @@ class ShellTest(utils.TestCase):
|
|||||||
self.run_command('delete 1234')
|
self.run_command('delete 1234')
|
||||||
self.assert_called('DELETE', '/volumes/1234')
|
self.assert_called('DELETE', '/volumes/1234')
|
||||||
|
|
||||||
|
def test_delete_multiple(self):
|
||||||
|
self.run_command('delete 1234 5678')
|
||||||
|
self.assert_called('DELETE', '/volumes/5678')
|
||||||
|
|
||||||
def test_backup(self):
|
def test_backup(self):
|
||||||
self.run_command('backup-create 1234')
|
self.run_command('backup-create 1234')
|
||||||
self.assert_called('POST', '/backups')
|
self.assert_called('POST', '/backups')
|
||||||
|
@ -277,22 +277,38 @@ def do_create(cs, args):
|
|||||||
_print_volume(volume)
|
_print_volume(volume)
|
||||||
|
|
||||||
|
|
||||||
@utils.arg('volume', metavar='<volume>',
|
@utils.arg('volume', metavar='<volume>', nargs='+',
|
||||||
help='Name or ID of the volume to delete.')
|
help='Name or ID of the volume(s) to delete.')
|
||||||
@utils.service_type('volume')
|
@utils.service_type('volume')
|
||||||
def do_delete(cs, args):
|
def do_delete(cs, args):
|
||||||
"""Remove a volume."""
|
"""Remove volume(s)."""
|
||||||
volume = utils.find_volume(cs, args.volume)
|
failure_count = 0
|
||||||
volume.delete()
|
for volume in args.volume:
|
||||||
|
try:
|
||||||
|
utils.find_volume(cs, volume).delete()
|
||||||
|
except Exception as e:
|
||||||
|
failure_count += 1
|
||||||
|
print("Delete for volume %s failed: %s" % (volume, e))
|
||||||
|
if failure_count == len(args.volume):
|
||||||
|
raise exceptions.CommandError("Unable to delete any of the specified "
|
||||||
|
"volumes.")
|
||||||
|
|
||||||
|
|
||||||
@utils.arg('volume', metavar='<volume>',
|
@utils.arg('volume', metavar='<volume>', nargs='+',
|
||||||
help='Name or ID of the volume to delete.')
|
help='Name or ID of the volume(s) to delete.')
|
||||||
@utils.service_type('volume')
|
@utils.service_type('volume')
|
||||||
def do_force_delete(cs, args):
|
def do_force_delete(cs, args):
|
||||||
"""Attempt forced removal of a volume, regardless of its state."""
|
"""Attempt forced removal of volume(s), regardless of the state(s)."""
|
||||||
volume = utils.find_volume(cs, args.volume)
|
failure_count = 0
|
||||||
volume.force_delete()
|
for volume in args.volume:
|
||||||
|
try:
|
||||||
|
utils.find_volume(cs, volume).force_delete()
|
||||||
|
except Exception as e:
|
||||||
|
failure_count += 1
|
||||||
|
print("Delete for volume %s failed: %s" % (volume, e))
|
||||||
|
if failure_count == len(args.volume):
|
||||||
|
raise exceptions.CommandError("Unable to force delete any of the "
|
||||||
|
"specified volumes.")
|
||||||
|
|
||||||
|
|
||||||
@utils.arg('volume', metavar='<volume>',
|
@utils.arg('volume', metavar='<volume>',
|
||||||
|
@ -304,23 +304,39 @@ def do_create(cs, args):
|
|||||||
|
|
||||||
|
|
||||||
@utils.arg('volume',
|
@utils.arg('volume',
|
||||||
metavar='<volume>',
|
metavar='<volume>', nargs='+',
|
||||||
help='Name or ID of the volume to delete.')
|
help='Name or ID of the volume(s) to delete.')
|
||||||
@utils.service_type('volumev2')
|
@utils.service_type('volumev2')
|
||||||
def do_delete(cs, args):
|
def do_delete(cs, args):
|
||||||
"""Remove a volume."""
|
"""Remove a volume(s)."""
|
||||||
volume = utils.find_volume(cs, args.volume)
|
failure_count = 0
|
||||||
volume.delete()
|
for volume in args.volume:
|
||||||
|
try:
|
||||||
|
utils.find_volume(cs, volume).delete()
|
||||||
|
except Exception as e:
|
||||||
|
failure_count += 1
|
||||||
|
print("Delete for volume %s failed: %s" % (volume, e))
|
||||||
|
if failure_count == len(args.volume):
|
||||||
|
raise exceptions.CommandError("Unable to delete any of the specified "
|
||||||
|
"volumes.")
|
||||||
|
|
||||||
|
|
||||||
@utils.arg('volume',
|
@utils.arg('volume',
|
||||||
metavar='<volume>',
|
metavar='<volume>', nargs='+',
|
||||||
help='Name or ID of the volume to delete.')
|
help='Name or ID of the volume(s) to delete.')
|
||||||
@utils.service_type('volumev2')
|
@utils.service_type('volumev2')
|
||||||
def do_force_delete(cs, args):
|
def do_force_delete(cs, args):
|
||||||
"""Attempt forced removal of a volume, regardless of its state."""
|
"""Attempt forced removal of volume(s), regardless of the state(s)."""
|
||||||
volume = utils.find_volume(cs, args.volume)
|
failure_count = 0
|
||||||
volume.force_delete()
|
for volume in args.volume:
|
||||||
|
try:
|
||||||
|
utils.find_volume(cs, volume).force_delete()
|
||||||
|
except Exception as e:
|
||||||
|
failure_count += 1
|
||||||
|
print("Delete for volume %s failed: %s" % (volume, e))
|
||||||
|
if failure_count == len(args.volume):
|
||||||
|
raise exceptions.CommandError("Unable to force delete any of the "
|
||||||
|
"specified volumes.")
|
||||||
|
|
||||||
|
|
||||||
@utils.arg('volume', metavar='<volume>',
|
@utils.arg('volume', metavar='<volume>',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user