[CI] Fix Cinder update volume type scenario & service

Now it's required to provide name (non backward compatible change
from Cinder team) this patch address the problem and unblocks our gate

Change-Id: I71874c7789c55d655262f131ace4c8eacc835bd8
This commit is contained in:
Boris Pavlovic 2017-12-31 15:46:07 -08:00
parent a3d120e5c1
commit c2b57d6a63
4 changed files with 29 additions and 30 deletions

View File

@ -93,7 +93,7 @@ class CreateAndUpdateVolumeType(scenario.OpenStackScenario):
service.update_volume_type( service.update_volume_type(
volume_type, volume_type,
update_name=update_name, name=volume_type.name if not update_name else False,
description=update_description, description=update_description,
is_public=update_is_public) is_public=update_is_public)
@ -127,10 +127,10 @@ class CreateAndListVolumeTypes(cinder_utils.CinderBasic):
@validation.add("required_params", params=[("create_specs", "provider")]) @validation.add("required_params", params=[("create_specs", "provider")])
@validation.add("required_services", services=[consts.Service.CINDER]) @validation.add("required_services", services=[consts.Service.CINDER])
@validation.add("required_platform", platform="openstack", admin=True) @validation.add("required_platform", platform="openstack", admin=True)
@scenario.configure(context={"admin_cleanup@openstack": ["cinder"]}, @scenario.configure(
name="CinderVolumeTypes.create_volume_type" context={"admin_cleanup@openstack": ["cinder"]},
"_and_encryption_type", name="CinderVolumeTypes.create_volume_type_and_encryption_type",
platform="openstack") platform="openstack")
class CreateVolumeTypeAndEncryptionType(cinder_utils.CinderBasic): class CreateVolumeTypeAndEncryptionType(cinder_utils.CinderBasic):
def run(self, create_specs=None, provider=None, cipher=None, def run(self, create_specs=None, provider=None, cipher=None,
@ -175,10 +175,10 @@ class CreateVolumeTypeAndEncryptionType(cinder_utils.CinderBasic):
@validation.add("required_params", params=[("create_specs", "provider")]) @validation.add("required_params", params=[("create_specs", "provider")])
@validation.add("required_services", services=[consts.Service.CINDER]) @validation.add("required_services", services=[consts.Service.CINDER])
@validation.add("required_platform", platform="openstack", admin=True) @validation.add("required_platform", platform="openstack", admin=True)
@scenario.configure(context={"admin_cleanup@openstack": ["cinder"]}, @scenario.configure(
name="CinderVolumeTypes.create_and_list_" context={"admin_cleanup@openstack": ["cinder"]},
"encryption_type", name="CinderVolumeTypes.create_and_list_encryption_type",
platform="openstack") platform="openstack")
class CreateAndListEncryptionType(cinder_utils.CinderBasic): class CreateAndListEncryptionType(cinder_utils.CinderBasic):
def run(self, create_specs=None, provider=None, cipher=None, def run(self, create_specs=None, provider=None, cipher=None,
@ -243,10 +243,10 @@ class CreateAndSetVolumeTypeKeys(cinder_utils.CinderBasic):
@validation.add("required_services", services=[consts.Service.CINDER]) @validation.add("required_services", services=[consts.Service.CINDER])
@validation.add("required_contexts", contexts="volume_types") @validation.add("required_contexts", contexts="volume_types")
@validation.add("required_platform", platform="openstack", admin=True) @validation.add("required_platform", platform="openstack", admin=True)
@scenario.configure(context={"admin_cleanup@openstack": ["cinder"]}, @scenario.configure(
name="CinderVolumeTypes.create_get_and_delete_" context={"admin_cleanup@openstack": ["cinder"]},
"encryption_type", name="CinderVolumeTypes.create_get_and_delete_encryption_type",
platform="openstack") platform="openstack")
class CreateGetAndDeleteEncryptionType(cinder_utils.CinderBasic): class CreateGetAndDeleteEncryptionType(cinder_utils.CinderBasic):
def run(self, provider=None, cipher=None, def run(self, provider=None, cipher=None,
@ -284,10 +284,10 @@ class CreateGetAndDeleteEncryptionType(cinder_utils.CinderBasic):
@validation.add("required_contexts", contexts="volume_types") @validation.add("required_contexts", contexts="volume_types")
@validation.add("required_params", params=[("create_specs", "provider")]) @validation.add("required_params", params=[("create_specs", "provider")])
@validation.add("required_platform", platform="openstack", admin=True) @validation.add("required_platform", platform="openstack", admin=True)
@scenario.configure(context={"admin_cleanup@openstack": ["cinder"]}, @scenario.configure(
name="CinderVolumeTypes.create_and_delete_" context={"admin_cleanup@openstack": ["cinder"]},
"encryption_type", name="CinderVolumeTypes.create_and_delete_encryption_type",
platform="openstack") platform="openstack")
class CreateAndDeleteEncryptionType(cinder_utils.CinderBasic): class CreateAndDeleteEncryptionType(cinder_utils.CinderBasic):
def run(self, create_specs=None, provider=None, cipher=None, def run(self, create_specs=None, provider=None, cipher=None,
@ -381,10 +381,10 @@ class CreateAndUpdateEncryptionType(cinder_utils.CinderBasic):
@validation.add("required_platform", platform="openstack", admin=True) @validation.add("required_platform", platform="openstack", admin=True)
@validation.add("required_api_versions", component="cinder", versions=["2"]) @validation.add("required_api_versions", component="cinder", versions=["2"])
@validation.add("required_services", services=consts.Service.CINDER) @validation.add("required_services", services=consts.Service.CINDER)
@scenario.configure(context={"admin_cleanup@openstack": ["cinder"]}, @scenario.configure(
name="CinderVolumeTypes.create_volume_type_" context={"admin_cleanup@openstack": ["cinder"]},
"add_and_list_type_access", name="CinderVolumeTypes.create_volume_type_add_and_list_type_access",
platform="openstack") platform="openstack")
class CreateVolumeTypeAddAndListTypeAccess(scenario.OpenStackScenario): class CreateVolumeTypeAddAndListTypeAccess(scenario.OpenStackScenario):
def run(self, description=None, is_public=False): def run(self, description=None, is_public=False):

View File

@ -176,20 +176,18 @@ class CinderV2Service(service.Service, cinder_common.CinderMixin):
return self._get_client().volume_types.create(**kwargs) return self._get_client().volume_types.create(**kwargs)
@atomic.action_timer("cinder_v2.update_volume_type") @atomic.action_timer("cinder_v2.update_volume_type")
def update_volume_type(self, volume_type, update_name=False, def update_volume_type(self, volume_type, name=None,
description=None, is_public=None): description=None, is_public=None):
"""Update the name and/or description for a volume type. """Update the name and/or description for a volume type.
:param volume_type: The ID or a instance of the :class:`VolumeType` :param volume_type: The ID or a instance of the :class:`VolumeType`
to update. to update.
:param update_name: if True, can update name by generating random name. :param name: if None, updates name by generating random name.
if False, don't update name. else updates name with provided name
:param description: Description of the the volume type. :param description: Description of the the volume type.
:rtype: :class:`VolumeType` :rtype: :class:`VolumeType`
""" """
name = None name = name or self.generate_random_name()
if update_name:
name = self.generate_random_name()
return self._get_client().volume_types.update(volume_type, name, return self._get_client().volume_types.update(volume_type, name,
description, is_public) description, is_public)

View File

@ -162,7 +162,8 @@ class CinderVolumeTypesTestCase(test.ScenarioTestCase):
def test_create_and_update_volume_type(self, mock_update_volume_type, def test_create_and_update_volume_type(self, mock_update_volume_type,
mock_create_volume_type): mock_create_volume_type):
scenario = volume_types.CreateAndUpdateVolumeType(self._get_context()) scenario = volume_types.CreateAndUpdateVolumeType(self._get_context())
fake_type = mock.Mock() fake_type = mock.MagicMock()
fake_type.name = "any"
create_description = "test create" create_description = "test create"
update_description = "test update" update_description = "test update"
mock_create_volume_type.return_value = fake_type mock_create_volume_type.return_value = fake_type
@ -173,7 +174,7 @@ class CinderVolumeTypesTestCase(test.ScenarioTestCase):
description=create_description, description=create_description,
is_public=True) is_public=True)
mock_update_volume_type.assert_called_once_with( mock_update_volume_type.assert_called_once_with(
fake_type, update_name=False, fake_type, name="any",
description=update_description, description=update_description,
is_public=None) is_public=None)

View File

@ -231,7 +231,7 @@ class CinderV2ServiceTestCase(test.ScenarioTestCase):
result = self.service.update_volume_type(volume_type, result = self.service.update_volume_type(volume_type,
description=description, description=description,
update_name=True, name=None,
is_public=None) is_public=None)
self.assertEqual( self.assertEqual(
self.cinder.volume_types.update.return_value, self.cinder.volume_types.update.return_value,