Add CinderVolumeTypes.create_volume_type_add_and_list_type_access

This scenario first creates a private volume type, then add project
access and list project access to it.

Change-Id: I78b1f3057197985acacfaa60a276d2a0bad39185
This commit is contained in:
maxinjian 2017-01-24 12:19:34 -05:00
parent 30b4a796c2
commit e1659895a2
7 changed files with 145 additions and 0 deletions

View File

@ -1209,3 +1209,19 @@
sla: sla:
failure_rate: failure_rate:
max: 0 max: 0
CinderVolumeTypes.create_volume_type_add_and_list_type_access:
-
args:
description: "rally tests creating types"
runner:
type: "constant"
times: 4
concurrency: 2
context:
users:
tenants: 2
users_per_tenant: 2
sla:
failure_rate:
max: 0

View File

@ -366,3 +366,30 @@ class CreateAndUpdateEncryptionType(cinder_utils.CinderBasic):
specs=create_specs) specs=create_specs)
self.admin_cinder.update_encryption_type(volume_type["id"], self.admin_cinder.update_encryption_type(volume_type["id"],
specs=update_specs) specs=update_specs)
@validation.add("required_platform", platform="openstack", admin=True)
@validation.add("required_api_versions", component="cinder", versions=["2"])
@validation.add("required_services", services=consts.Service.CINDER)
@scenario.configure(context={"admin_cleanup": ["cinder"]},
name="CinderVolumeTypes.create_volume_type_"
"add_and_list_type_access")
class CreateVolumeTypeAddAndListTypeAccess(scenario.OpenStackScenario):
def run(self, description=None, is_public=False):
"""Add and list volume type access for the given project.
This scenario first creates a private volume type, then add project
access and list project access to it.
:param description: Description of the volume type
:param is_public: Volume type visibility
"""
service = cinder_v2.CinderV2Service(self._admin_clients,
self.generate_random_name,
atomic_inst=self.atomic_actions())
volume_type = service.create_volume_type(description=description,
is_public=is_public)
service.add_type_access(volume_type,
project=self.context["tenant"]["id"])
service.list_type_access(volume_type)

View File

@ -194,6 +194,27 @@ class CinderV2Service(service.Service, cinder_common.CinderMixin):
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)
@atomic.action_timer("cinder_v2.add_type_access")
def add_type_access(self, volume_type, project):
"""Add a project to the given volume type access list.
:param volume_type: Volume type name or ID to add access for the given
project
:project: Project ID to add volume type access for
:return: An instance of cinderclient.apiclient.base.TupleWithMeta
"""
return self._get_client().volume_type_access.add_project_access(
volume_type, project)
@atomic.action_timer("cinder_v2.list_type_access")
def list_type_access(self, volume_type):
"""Print access information about the given volume type
:param volume_type: Filter results by volume type name or ID
:return: VolumeTypeAcces of specific project
"""
return self._get_client().volume_type_access.list(volume_type)
@service.compat_layer(CinderV2Service) @service.compat_layer(CinderV2Service)
class UnifiedCinderV2Service(cinder_common.UnifiedCinderMixin, class UnifiedCinderV2Service(cinder_common.UnifiedCinderMixin,

View File

@ -0,0 +1,25 @@
{
"CinderVolumeTypes.create_volume_type_add_and_list_type_access": [
{
"args": {
"description": "rally tests creating types"
},
"runner": {
"type": "constant",
"times": 4,
"concurrency": 2
},
"context": {
"users": {
"tenants": 2,
"users_per_tenant": 2
}
},
"sla": {
"failure_rate": {
"max": 0
}
}
}
]
}

View File

@ -0,0 +1,16 @@
---
CinderVolumeTypes.create_volume_type_add_and_list_type_access:
-
args:
description: "rally tests creating types"
runner:
type: "constant"
times: 4
concurrency: 2
context:
users:
tenants: 2
users_per_tenant: 2
sla:
failure_rate:
max: 0

View File

@ -290,3 +290,20 @@ class CinderVolumeTypesTestCase(test.ScenarioTestCase):
"fake_id", specs=create_specs) "fake_id", specs=create_specs)
mock_service.update_encryption_type.assert_called_once_with( mock_service.update_encryption_type.assert_called_once_with(
"fake_id", specs=update_specs) "fake_id", specs=update_specs)
@mock.patch("%s.list_type_access" % CINDER_V2_PATH)
@mock.patch("%s.add_type_access" % CINDER_V2_PATH)
@mock.patch("%s.create_volume_type" % CINDER_V2_PATH)
def test_create_volume_type_add_and_list_type_access(
self, mock_create_volume_type, mock_add_type_access,
mock_list_type_access):
scenario = volume_types.CreateVolumeTypeAddAndListTypeAccess(
self._get_context())
fake_type = mock.Mock()
mock_create_volume_type.return_value = fake_type
scenario.run(description=None, is_public=False)
mock_create_volume_type.assert_called_once_with(
description=None, is_public=False)
mock_add_type_access.assert_called_once_with(fake_type, project="fake")
mock_list_type_access.assert_called_once_with(fake_type)

View File

@ -239,6 +239,29 @@ class CinderV2ServiceTestCase(test.ScenarioTestCase):
self._test_atomic_action_timer(self.atomic_actions(), self._test_atomic_action_timer(self.atomic_actions(),
"cinder_v2.update_volume_type") "cinder_v2.update_volume_type")
def test_add_type_access(self):
volume_type = mock.Mock()
project = mock.Mock()
type_access = self.service.add_type_access(volume_type,
project=project)
add_project_access = self.cinder.volume_type_access.add_project_access
add_project_access.assert_called_once_with(
volume_type, project)
self.assertEqual(add_project_access.return_value,
type_access)
self._test_atomic_action_timer(self.atomic_actions(),
"cinder_v2.add_type_access")
def test_list_type_access(self):
volume_type = mock.Mock()
type_access = self.service.list_type_access(volume_type)
self.cinder.volume_type_access.list.assert_called_once_with(
volume_type)
self.assertEqual(self.cinder.volume_type_access.list.return_value,
type_access)
self._test_atomic_action_timer(self.atomic_actions(),
"cinder_v2.list_type_access")
class UnifiedCinderV2ServiceTestCase(test.TestCase): class UnifiedCinderV2ServiceTestCase(test.TestCase):
def setUp(self): def setUp(self):