Check volume status before extending size

Added test for Volume Set as well.

Change-Id: I8e6794f67b160ca328fcafa8f1d67138b4f3becd
Closes-Bug: #1415182
This commit is contained in:
lin-hua-cheng 2015-02-05 23:40:11 -08:00
parent 0cc3955f0a
commit 8968bc0979
5 changed files with 220 additions and 10 deletions
openstackclient

View File

@ -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):

View File

@ -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):

View File

@ -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,

View File

@ -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
)

View File

@ -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)