Add CinderVolumeTypes.create_and_update_encryption_type

This scenario firstly creates a volume type, secondly creates an
encryption type for the volume type, thirdly updates the encryption
type.

Change-Id: If2e7468b3bc017581642e6f1bf92e093b6c706ca
This commit is contained in:
maxinjian 2017-01-17 06:41:50 -05:00
parent 545699db22
commit 6308975be4
9 changed files with 241 additions and 0 deletions

View File

@ -1124,3 +1124,32 @@
sla:
failure_rate:
max: 0
CinderVolumeTypes.create_and_update_encryption_type:
-
args:
create_provider: "LuksEncryptor"
create_cipher: "aes-xts-plain64"
create_key_size: 512
create_control_location: "front-end"
update_provider: "CryptsetupEncryptor"
update_cipher: "aes-xts-plain"
update_key_size: 256
update_control_location: "back-end"
runner:
type: "constant"
times: 4
concurrency: 1
context:
users:
tenants: 2
users_per_tenant: 2
volume_types: [
"test_type1",
"test_type2",
"test_type3",
"test_type4"
]
sla:
failure_rate:
max: 0

View File

@ -250,3 +250,55 @@ class CreateAndDeleteEncryptionType(cinder_utils.CinderBasic):
self.admin_cinder.create_encryption_type(volume_type["id"],
specs=specs)
self.admin_cinder.delete_encryption_type(volume_type["id"])
@validation.required_services(consts.Service.CINDER)
@validation.required_contexts("volume_types")
@validation.add("required_platform", platform="openstack", admin=True)
@scenario.configure(context={"admin_cleanup": ["cinder"]},
name="CinderVolumeTypes.create_and_update_encryption_type")
class CreateAndUpdateEncryptionType(cinder_utils.CinderBasic):
def run(self, create_provider=None, create_cipher=None,
create_key_size=None, create_control_location="front-end",
update_provider=None, update_cipher=None,
update_key_size=None, update_control_location=None):
"""Create and update encryption type
This scenario firstly creates a volume type, secondly creates an
encryption type for the volume type, thirdly updates the encryption
type.
:param create_provider: The class that provides encryption support. For
example, LuksEncryptor.
:param create_cipher: The encryption algorithm or mode.
:param create_key_size: Size of encryption key, in bits.
:param create_control_location: Notional service where encryption is
performed. Valid values are "front-end"
or "back-end."
:param update_provider: The class that provides encryption support. For
example, LuksEncryptor.
:param update_cipher: The encryption algorithm or mode.
:param update_key_size: Size of encryption key, in bits.
:param update_control_location: Notional service where encryption is
performed. Valid values are "front-end"
or "back-end."
"""
vt_idx = self.context["iteration"] % len(self.context["volume_types"])
volume_type = self.context["volume_types"][vt_idx]
create_specs = {
"provider": create_provider,
"cipher": create_cipher,
"key_size": create_key_size,
"control_location": create_control_location
}
update_specs = {
"provider": update_provider,
"cipher": update_cipher,
"key_size": update_key_size,
"control_location": update_control_location
}
self.admin_cinder.create_encryption_type(volume_type["id"],
specs=create_specs)
self.admin_cinder.update_encryption_type(volume_type["id"],
specs=update_specs)

View File

@ -400,3 +400,14 @@ class BlockStorage(service.UnifiedService):
must be deleted
"""
self._impl.delete_encryption_type(volume_type)
@service.should_be_overridden
def update_encryption_type(self, volume_type, specs):
"""Update the encryption type information for the specified volume type.
:param volume_type: the volume type whose encryption type information
will be updated
:param specs: the encryption type specifications to update
:return: an instance of :class: VolumeEncryptionType
"""
return self._impl.update_encryption_type(volume_type, specs=specs)

View File

@ -413,6 +413,19 @@ class CinderMixin(object):
if (resp[0].status_code != 202):
raise exceptions.EncryptionTypeDeleteException()
def update_encryption_type(self, volume_type, specs):
"""Update the encryption type information for the specified volume type.
:param volume_type: the volume type whose encryption type information
must be updated
:param specs: the encryption type specifications to update
:return: an instance of :class: VolumeEncryptionType
"""
aname = "cinder_v%s.update_encryption_type" % self.version
with atomic.ActionTimer(self, aname):
return self._get_client().volume_encryption_types.update(
volume_type, specs)
class UnifiedCinderMixin(object):
@ -633,3 +646,13 @@ class UnifiedCinderMixin(object):
must be deleted
"""
return self._impl.delete_encryption_type(volume_type)
def update_encryption_type(self, volume_type, specs):
"""Update the encryption type information for the specified volume type.
:param volume_type: the volume type whose encryption type information
must be updated
:param specs: the encryption type specifications to update
:return: an instance of :class: VolumeEncryptionType
"""
return self._impl.update_encryption_type(volume_type, specs=specs)

View File

@ -0,0 +1,38 @@
{
"CinderVolumeTypes.create_and_update_encryption_type": [
{
"args": {
"create_provider": "LuksEncryptor",
"create_cipher": "aes-xts-plain64",
"create_key_size": 512,
"create_control_location": "front-end",
"update_provider": "CryptsetupEncryptor",
"update_cipher": "aes-xts-plain",
"update_key_size": 256,
"update_control_location": "back-end"
},
"runner": {
"type": "constant",
"times": 4,
"concurrency": 1
},
"context": {
"users": {
"tenants": 2,
"users_per_tenant": 2
},
"volume_types": [
"test_type1",
"test_type2",
"test_type3",
"test_type4"
]
},
"sla": {
"failure_rate": {
"max": 0
}
}
}
]
}

View File

@ -0,0 +1,28 @@
CinderVolumeTypes.create_and_update_encryption_type:
-
args:
create_provider: "LuksEncryptor"
create_cipher: "aes-xts-plain64"
create_key_size: 512
create_control_location: "front-end"
update_provider: "CryptsetupEncryptor"
update_cipher: "aes-xts-plain"
update_key_size: 256
update_control_location: "back-end"
runner:
type: "constant"
times: 4
concurrency: 1
context:
users:
tenants: 2
users_per_tenant: 2
volume_types: [
"test_type1",
"test_type2",
"test_type3",
"test_type4"
]
sla:
failure_rate:
max: 0

View File

@ -188,3 +188,36 @@ class CinderVolumeTypesTestCase(test.ScenarioTestCase):
mock_service.set_volume_type_keys.assert_called_once_with(
mock_service.create_volume_type.return_value,
metadata=volume_type_key)
def test_create_and_update_encryption_type(self):
mock_service = self.mock_cinder.return_value
context = self._get_context()
context.update({
"volume_types": [{"id": "fake_id",
"name": "fake_name"}],
"iteration": 1})
scenario = volume_types.CreateAndUpdateEncryptionType(
context)
create_specs = {
"provider": "create_prov",
"cipher": "create_cip",
"key_size": "create_ks",
"control_location": "create_cl"
}
update_specs = {
"provider": "update_prov",
"cipher": "update_cip",
"key_size": "update_ks",
"control_location": "update_cl"
}
scenario.run(create_provider="create_prov", create_cipher="create_cip",
create_key_size="create_ks",
create_control_location="create_cl",
update_provider="update_prov", update_cipher="update_cip",
update_key_size="update_ks",
update_control_location="update_cl")
mock_service.create_encryption_type.assert_called_once_with(
"fake_id", specs=create_specs)
mock_service.update_encryption_type.assert_called_once_with(
"fake_id", specs=update_specs)

View File

@ -247,3 +247,10 @@ class BlockTestCase(test.TestCase):
self.service.delete_encryption_type("type")
self.service._impl.delete_encryption_type.assert_called_once_with(
"type")
def test_update_encryption_type(self):
self.assertEqual(
self.service._impl.update_encryption_type.return_value,
self.service.update_encryption_type("type", specs=3))
self.service._impl.update_encryption_type.assert_called_once_with(
"type", specs=3)

View File

@ -405,6 +405,21 @@ class CinderMixinTestCase(test.ScenarioTestCase):
self.cinder.volume_encryption_types.delete.assert_called_once_with(
"type")
def test_update_encryption_type(self):
volume_type = mock.Mock()
specs = {
"provider": "foo_pro",
"cipher": "foo_cip",
"key_size": 512,
"control_location": "foo_con"
}
result = self.service.update_encryption_type(volume_type, specs)
self.assertEqual(
self.cinder.volume_encryption_types.update.return_value, result)
self.cinder.volume_encryption_types.update.assert_called_once_with(
volume_type, specs)
class FullUnifiedCinder(cinder_common.UnifiedCinderMixin,
service.Service):
@ -633,3 +648,8 @@ class UnifiedCinderMixinTestCase(test.TestCase):
self.service.delete_encryption_type("type")
self.service._impl.delete_encryption_type.assert_called_once_with(
"type")
def test_update_encryption_type(self):
self.service.update_encryption_type("type", specs=3)
self.service._impl.update_encryption_type.assert_called_once_with(
"type", specs=3)