Check volume status before extending size
Added test for Volume Set as well. Change-Id: I8e6794f67b160ca328fcafa8f1d67138b4f3becd Closes-Bug: #1415182
This commit is contained in:
parent
0cc3955f0a
commit
8968bc0979
openstackclient
@ -52,13 +52,34 @@ class FakeStdout(object):
|
|||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
class FakeLog(object):
|
||||||
|
def __init__(self):
|
||||||
|
self.messages = {}
|
||||||
|
|
||||||
|
def debug(self, msg):
|
||||||
|
self.messages['debug'] = msg
|
||||||
|
|
||||||
|
def info(self, msg):
|
||||||
|
self.messages['info'] = msg
|
||||||
|
|
||||||
|
def warning(self, msg):
|
||||||
|
self.messages['warning'] = msg
|
||||||
|
|
||||||
|
def error(self, msg):
|
||||||
|
self.messages['error'] = msg
|
||||||
|
|
||||||
|
def critical(self, msg):
|
||||||
|
self.messages['critical'] = msg
|
||||||
|
|
||||||
|
|
||||||
class FakeApp(object):
|
class FakeApp(object):
|
||||||
def __init__(self, _stdout):
|
def __init__(self, _stdout, _log):
|
||||||
self.stdout = _stdout
|
self.stdout = _stdout
|
||||||
self.client_manager = None
|
self.client_manager = None
|
||||||
self.stdin = sys.stdin
|
self.stdin = sys.stdin
|
||||||
self.stdout = _stdout or sys.stdout
|
self.stdout = _stdout or sys.stdout
|
||||||
self.stderr = sys.stderr
|
self.stderr = sys.stderr
|
||||||
|
self.log = _log
|
||||||
|
|
||||||
|
|
||||||
class FakeClient(object):
|
class FakeClient(object):
|
||||||
|
@ -80,7 +80,8 @@ class TestCommand(TestCase):
|
|||||||
super(TestCommand, self).setUp()
|
super(TestCommand, self).setUp()
|
||||||
# Build up a fake app
|
# Build up a fake app
|
||||||
self.fake_stdout = fakes.FakeStdout()
|
self.fake_stdout = fakes.FakeStdout()
|
||||||
self.app = fakes.FakeApp(self.fake_stdout)
|
self.fake_log = fakes.FakeLog()
|
||||||
|
self.app = fakes.FakeApp(self.fake_stdout, self.fake_log)
|
||||||
self.app.client_manager = fakes.FakeClientManager()
|
self.app.client_manager = fakes.FakeClientManager()
|
||||||
|
|
||||||
def check_parser(self, cmd, args, verify_args):
|
def check_parser(self, cmd, args, verify_args):
|
||||||
|
@ -23,6 +23,7 @@ from openstackclient.tests import utils
|
|||||||
volume_id = 'vvvvvvvv-vvvv-vvvv-vvvvvvvv'
|
volume_id = 'vvvvvvvv-vvvv-vvvv-vvvvvvvv'
|
||||||
volume_name = 'nigel'
|
volume_name = 'nigel'
|
||||||
volume_description = 'Nigel Tufnel'
|
volume_description = 'Nigel Tufnel'
|
||||||
|
volume_status = 'available'
|
||||||
volume_size = 120
|
volume_size = 120
|
||||||
volume_type = 'to-eleven'
|
volume_type = 'to-eleven'
|
||||||
volume_zone = 'stonehenge'
|
volume_zone = 'stonehenge'
|
||||||
@ -38,7 +39,7 @@ VOLUME = {
|
|||||||
'display_name': volume_name,
|
'display_name': volume_name,
|
||||||
'display_description': volume_description,
|
'display_description': volume_description,
|
||||||
'size': volume_size,
|
'size': volume_size,
|
||||||
'status': '',
|
'status': volume_status,
|
||||||
'attach_status': 'detached',
|
'attach_status': 'detached',
|
||||||
'availability_zone': volume_zone,
|
'availability_zone': volume_zone,
|
||||||
'volume_type': volume_type,
|
'volume_type': volume_type,
|
||||||
|
@ -114,7 +114,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -178,7 +178,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -253,7 +253,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -328,7 +328,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -389,7 +389,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -455,7 +455,7 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
@ -521,7 +521,189 @@ class TestVolumeCreate(TestVolume):
|
|||||||
volume_fakes.volume_id,
|
volume_fakes.volume_id,
|
||||||
volume_fakes.volume_metadata_str,
|
volume_fakes.volume_metadata_str,
|
||||||
volume_fakes.volume_size,
|
volume_fakes.volume_size,
|
||||||
'',
|
volume_fakes.volume_status,
|
||||||
volume_fakes.volume_type,
|
volume_fakes.volume_type,
|
||||||
)
|
)
|
||||||
self.assertEqual(datalist, data)
|
self.assertEqual(datalist, data)
|
||||||
|
|
||||||
|
|
||||||
|
class TestVolumeSet(TestVolume):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestVolumeSet, self).setUp()
|
||||||
|
|
||||||
|
self.volumes_mock.get.return_value = fakes.FakeResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(volume_fakes.VOLUME),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.volumes_mock.update.return_value = fakes.FakeResource(
|
||||||
|
None,
|
||||||
|
copy.deepcopy(volume_fakes.VOLUME),
|
||||||
|
loaded=True,
|
||||||
|
)
|
||||||
|
# Get the command object to test
|
||||||
|
self.cmd = volume.SetVolume(self.app, None)
|
||||||
|
|
||||||
|
def test_volume_set_no_options(self):
|
||||||
|
arglist = [
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', None),
|
||||||
|
('size', None),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
result = self.cmd.run(parsed_args)
|
||||||
|
self.assertEqual(0, result)
|
||||||
|
self.assertEqual("No changes requested\n",
|
||||||
|
self.app.log.messages.get('error'))
|
||||||
|
|
||||||
|
def test_volume_set_name(self):
|
||||||
|
arglist = [
|
||||||
|
'--name', 'qwerty',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', 'qwerty'),
|
||||||
|
('description', None),
|
||||||
|
('size', None),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Set expected values
|
||||||
|
kwargs = {
|
||||||
|
'display_name': 'qwerty',
|
||||||
|
}
|
||||||
|
self.volumes_mock.update.assert_called_with(
|
||||||
|
volume_fakes.volume_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_volume_set_description(self):
|
||||||
|
arglist = [
|
||||||
|
'--description', 'new desc',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', 'new desc'),
|
||||||
|
('size', None),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Set expected values
|
||||||
|
kwargs = {
|
||||||
|
'display_description': 'new desc',
|
||||||
|
}
|
||||||
|
self.volumes_mock.update.assert_called_with(
|
||||||
|
volume_fakes.volume_id,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_volume_set_size(self):
|
||||||
|
arglist = [
|
||||||
|
'--size', '130',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', None),
|
||||||
|
('size', 130),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Set expected values
|
||||||
|
size = 130
|
||||||
|
|
||||||
|
self.volumes_mock.extend.assert_called_with(
|
||||||
|
volume_fakes.volume_id,
|
||||||
|
size
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_volume_set_size_smaller(self):
|
||||||
|
arglist = [
|
||||||
|
'--size', '100',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', None),
|
||||||
|
('size', 100),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
result = self.cmd.run(parsed_args)
|
||||||
|
self.assertEqual(0, result)
|
||||||
|
self.assertEqual("New size must be greater than %s GB" %
|
||||||
|
volume_fakes.volume_size,
|
||||||
|
self.app.log.messages.get('error'))
|
||||||
|
|
||||||
|
def test_volume_set_size_not_available(self):
|
||||||
|
self.volumes_mock.get.return_value.status = 'error'
|
||||||
|
arglist = [
|
||||||
|
'--size', '130',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', None),
|
||||||
|
('size', 130),
|
||||||
|
('property', None),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
result = self.cmd.run(parsed_args)
|
||||||
|
self.assertEqual(0, result)
|
||||||
|
self.assertEqual("Volume is in %s state, it must be available before "
|
||||||
|
"size can be extended" % 'error',
|
||||||
|
self.app.log.messages.get('error'))
|
||||||
|
|
||||||
|
def test_volume_set_property(self):
|
||||||
|
arglist = [
|
||||||
|
'--property', 'myprop=myvalue',
|
||||||
|
volume_fakes.volume_name,
|
||||||
|
]
|
||||||
|
verifylist = [
|
||||||
|
('name', None),
|
||||||
|
('description', None),
|
||||||
|
('size', None),
|
||||||
|
('property', {'myprop': 'myvalue'}),
|
||||||
|
('volume', volume_fakes.volume_name),
|
||||||
|
]
|
||||||
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
|
# DisplayCommandBase.take_action() returns two tuples
|
||||||
|
self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
|
# Set expected values
|
||||||
|
metadata = {
|
||||||
|
'myprop': 'myvalue'
|
||||||
|
}
|
||||||
|
self.volumes_mock.set_metadata.assert_called_with(
|
||||||
|
volume_fakes.volume_id,
|
||||||
|
metadata
|
||||||
|
)
|
||||||
|
@ -348,6 +348,11 @@ class SetVolume(command.Command):
|
|||||||
volume = utils.find_resource(volume_client.volumes, parsed_args.volume)
|
volume = utils.find_resource(volume_client.volumes, parsed_args.volume)
|
||||||
|
|
||||||
if parsed_args.size:
|
if parsed_args.size:
|
||||||
|
if volume.status != 'available':
|
||||||
|
self.app.log.error("Volume is in %s state, it must be "
|
||||||
|
"available before size can be extended" %
|
||||||
|
volume.status)
|
||||||
|
return
|
||||||
if parsed_args.size <= volume.size:
|
if parsed_args.size <= volume.size:
|
||||||
self.app.log.error("New size must be greater than %s GB" %
|
self.app.log.error("New size must be greater than %s GB" %
|
||||||
volume.size)
|
volume.size)
|
||||||
|
Loading…
Reference in New Issue
Block a user