Merge "Add cinder.CreatQosAssociateAndDisassociateType"
This commit is contained in:
commit
bc8c77145d
@ -1115,6 +1115,28 @@
|
|||||||
failure_rate:
|
failure_rate:
|
||||||
max: 0
|
max: 0
|
||||||
|
|
||||||
|
CinderQos.create_qos_associate_and_disassociate_type:
|
||||||
|
-
|
||||||
|
args:
|
||||||
|
consumer: "both"
|
||||||
|
write_iops_sec: "10"
|
||||||
|
read_iops_sec: "1000"
|
||||||
|
runner:
|
||||||
|
type: "constant"
|
||||||
|
times: 2
|
||||||
|
concurrency: 1
|
||||||
|
context:
|
||||||
|
users:
|
||||||
|
tenants: 1
|
||||||
|
users_per_tenant: 1
|
||||||
|
volume_types: [
|
||||||
|
"test_type1",
|
||||||
|
"test_type2"
|
||||||
|
]
|
||||||
|
sla:
|
||||||
|
failure_rate:
|
||||||
|
max: 0
|
||||||
|
|
||||||
CinderVolumeTypes.create_get_and_delete_encryption_type:
|
CinderVolumeTypes.create_get_and_delete_encryption_type:
|
||||||
-
|
-
|
||||||
args:
|
args:
|
||||||
|
@ -99,3 +99,36 @@ class CreateAndSetQos(cinder_utils.CinderBasic):
|
|||||||
|
|
||||||
qos = self.admin_cinder.create_qos(create_specs)
|
qos = self.admin_cinder.create_qos(create_specs)
|
||||||
self.admin_cinder.set_qos(qos=qos, set_specs_args=set_specs)
|
self.admin_cinder.set_qos(qos=qos, set_specs_args=set_specs)
|
||||||
|
|
||||||
|
|
||||||
|
@validation.add("required_services", services=[consts.Service.CINDER])
|
||||||
|
@validation.add("required_platform", platform="openstack", admin=True)
|
||||||
|
@validation.add("required_contexts", contexts=("volume_types"))
|
||||||
|
@scenario.configure(
|
||||||
|
context={"admin_cleanup": ["cinder"]},
|
||||||
|
name="CinderQos.create_qos_associate_and_disassociate_type",
|
||||||
|
platform="openstack")
|
||||||
|
class CreateQosAssociateAndDisassociateType(cinder_utils.CinderBasic):
|
||||||
|
def run(self, consumer, write_iops_sec, read_iops_sec):
|
||||||
|
"""Create a qos, Associate and Disassociate the qos from volume type.
|
||||||
|
|
||||||
|
:param consumer: Consumer behavior
|
||||||
|
:param write_iops_sec: random write limitation
|
||||||
|
:param read_iops_sec: random read limitation
|
||||||
|
"""
|
||||||
|
specs = {
|
||||||
|
"consumer": consumer,
|
||||||
|
"write_iops_sec": write_iops_sec,
|
||||||
|
"read_iops_sec": read_iops_sec
|
||||||
|
}
|
||||||
|
|
||||||
|
qos = self.admin_cinder.create_qos(specs)
|
||||||
|
|
||||||
|
vt_idx = self.context["iteration"] % len(self.context["volume_types"])
|
||||||
|
volume_type = self.context["volume_types"][vt_idx]
|
||||||
|
|
||||||
|
self.admin_cinder.qos_associate_type(qos_specs=qos,
|
||||||
|
volume_type=volume_type["id"])
|
||||||
|
|
||||||
|
self.admin_cinder.qos_disassociate_type(qos_specs=qos,
|
||||||
|
volume_type=volume_type["id"])
|
||||||
|
@ -228,6 +228,26 @@ class BlockStorage(service.UnifiedService):
|
|||||||
return self._impl.set_qos(qos=qos,
|
return self._impl.set_qos(qos=qos,
|
||||||
set_specs_args=set_specs_args)
|
set_specs_args=set_specs_args)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def qos_associate_type(self, qos_specs, volume_type):
|
||||||
|
"""Associate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be associated with
|
||||||
|
:param volume_type: The volume type id to be associated with
|
||||||
|
:rtype: :class:`QoSSpecs`
|
||||||
|
"""
|
||||||
|
return self._impl.qos_associate_type(qos_specs, volume_type)
|
||||||
|
|
||||||
|
@service.should_be_overridden
|
||||||
|
def qos_disassociate_type(self, qos_specs, volume_type):
|
||||||
|
"""Disassociate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be associated with
|
||||||
|
:param volume_type: The volume type id to be disassociated with
|
||||||
|
:rtype: :class:`QoSSpecs`
|
||||||
|
"""
|
||||||
|
return self._impl.qos_disassociate_type(qos_specs, volume_type)
|
||||||
|
|
||||||
@service.should_be_overridden
|
@service.should_be_overridden
|
||||||
def create_snapshot(self, volume_id, force=False,
|
def create_snapshot(self, volume_id, force=False,
|
||||||
name=None, description=None, metadata=None):
|
name=None, description=None, metadata=None):
|
||||||
|
@ -249,6 +249,34 @@ class CinderMixin(object):
|
|||||||
return self._get_client().qos_specs.set_keys(qos_id,
|
return self._get_client().qos_specs.set_keys(qos_id,
|
||||||
set_specs_args)
|
set_specs_args)
|
||||||
|
|
||||||
|
def qos_associate_type(self, qos_specs, vol_type_id):
|
||||||
|
"""Associate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be associated with
|
||||||
|
:param vol_type_id: The volume type id to be associated with
|
||||||
|
:returns: base on client response return True if the request
|
||||||
|
has been accepted or not
|
||||||
|
"""
|
||||||
|
aname = "cinder_v%s.qos_associate_type" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
tuple_res = self._get_client().qos_specs.associate(qos_specs,
|
||||||
|
vol_type_id)
|
||||||
|
return (tuple_res[0].status_code == 202)
|
||||||
|
|
||||||
|
def qos_disassociate_type(self, qos_specs, vol_type_id):
|
||||||
|
"""Disassociate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be disassociated with
|
||||||
|
:param vol_type_id: The volume type id to be disassociated with
|
||||||
|
:returns: base on client response return True if the request
|
||||||
|
has been accepted or not
|
||||||
|
"""
|
||||||
|
aname = "cinder_v%s.qos_disassociate_type" % self.version
|
||||||
|
with atomic.ActionTimer(self, aname):
|
||||||
|
tuple_res = self._get_client().qos_specs.disassociate(qos_specs,
|
||||||
|
vol_type_id)
|
||||||
|
return (tuple_res[0].status_code == 202)
|
||||||
|
|
||||||
def delete_snapshot(self, snapshot):
|
def delete_snapshot(self, snapshot):
|
||||||
"""Delete the given snapshot.
|
"""Delete the given snapshot.
|
||||||
|
|
||||||
@ -559,6 +587,24 @@ class UnifiedCinderMixin(object):
|
|||||||
self._impl.set_qos(qos.id, set_specs_args)
|
self._impl.set_qos(qos.id, set_specs_args)
|
||||||
return self._unify_qos(qos)
|
return self._unify_qos(qos)
|
||||||
|
|
||||||
|
def qos_associate_type(self, qos_specs, vol_type_id):
|
||||||
|
"""Associate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be associated with
|
||||||
|
:param vol_type_id: The volume type id to be associated with
|
||||||
|
"""
|
||||||
|
self._impl.qos_associate_type(qos_specs, vol_type_id)
|
||||||
|
return self._unify_qos(qos_specs)
|
||||||
|
|
||||||
|
def qos_disassociate_type(self, qos_specs, vol_type_id):
|
||||||
|
"""Disassociate qos specs from volume type.
|
||||||
|
|
||||||
|
:param qos_specs: The qos specs to be disassociated with
|
||||||
|
:param vol_type_id: The volume type id to be disassociated with
|
||||||
|
"""
|
||||||
|
self._impl.qos_disassociate_type(qos_specs, vol_type_id)
|
||||||
|
return self._unify_qos(qos_specs)
|
||||||
|
|
||||||
def delete_snapshot(self, snapshot):
|
def delete_snapshot(self, snapshot):
|
||||||
"""Delete the given backup.
|
"""Delete the given backup.
|
||||||
|
|
||||||
|
@ -0,0 +1,34 @@
|
|||||||
|
{
|
||||||
|
"CinderQos.create_qos_associate_and_disassociate_type": [
|
||||||
|
{
|
||||||
|
"args": {
|
||||||
|
"consumer": "both",
|
||||||
|
"write_iops_sec": "10",
|
||||||
|
"read_iops_sec": "1000"
|
||||||
|
},
|
||||||
|
"runner": {
|
||||||
|
"type": "constant",
|
||||||
|
"times": 5,
|
||||||
|
"concurrency": 2
|
||||||
|
},
|
||||||
|
"context": {
|
||||||
|
"users": {
|
||||||
|
"tenants": 2,
|
||||||
|
"users_per_tenant": 2
|
||||||
|
},
|
||||||
|
"volume_types": [
|
||||||
|
"test_type1",
|
||||||
|
"test_type2",
|
||||||
|
"test_type3",
|
||||||
|
"test_type4",
|
||||||
|
"test_type5"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"sla": {
|
||||||
|
"failure_rate": {
|
||||||
|
"max": 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -0,0 +1,25 @@
|
|||||||
|
---
|
||||||
|
CinderQos.create_qos_associate_and_disassociate_type:
|
||||||
|
-
|
||||||
|
args:
|
||||||
|
consumer: "both"
|
||||||
|
write_iops_sec: "10"
|
||||||
|
read_iops_sec: "1000"
|
||||||
|
runner:
|
||||||
|
type: "constant"
|
||||||
|
times: 5
|
||||||
|
concurrency: 2
|
||||||
|
context:
|
||||||
|
users:
|
||||||
|
tenants: 2
|
||||||
|
users_per_tenant: 2
|
||||||
|
volume_types: [
|
||||||
|
"test_type1",
|
||||||
|
"test_type2",
|
||||||
|
"test_type3",
|
||||||
|
"test_type4",
|
||||||
|
"test_type5",
|
||||||
|
]
|
||||||
|
sla:
|
||||||
|
failure_rate:
|
||||||
|
max: 0
|
@ -110,3 +110,26 @@ class CinderQosTestCase(test.ScenarioTestCase):
|
|||||||
mock_service.create_qos.assert_called_once_with(create_specs_args)
|
mock_service.create_qos.assert_called_once_with(create_specs_args)
|
||||||
mock_service.set_qos.assert_called_once_with(
|
mock_service.set_qos.assert_called_once_with(
|
||||||
qos=qos, set_specs_args=set_specs_args)
|
qos=qos, set_specs_args=set_specs_args)
|
||||||
|
|
||||||
|
def test_create_qos_associate_and_disassociate_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})
|
||||||
|
|
||||||
|
qos = mock.MagicMock()
|
||||||
|
specs = {"consumer": "both",
|
||||||
|
"write_iops_sec": "10",
|
||||||
|
"read_iops_sec": "1000"}
|
||||||
|
|
||||||
|
scenario = qos_specs.CreateQosAssociateAndDisassociateType(context)
|
||||||
|
mock_service.create_qos.return_value = qos
|
||||||
|
|
||||||
|
scenario.run("both", "10", "1000")
|
||||||
|
mock_service.create_qos.assert_called_once_with(specs)
|
||||||
|
mock_service.qos_associate_type.assert_called_once_with(
|
||||||
|
qos_specs=qos, volume_type="fake_id")
|
||||||
|
mock_service.qos_disassociate_type.assert_called_once_with(
|
||||||
|
qos_specs=qos, volume_type="fake_id")
|
||||||
|
@ -145,6 +145,22 @@ class BlockTestCase(test.TestCase):
|
|||||||
self.service._impl.set_qos.assert_called_once_with(
|
self.service._impl.set_qos.assert_called_once_with(
|
||||||
qos="qos", set_specs_args=set_specs_args)
|
qos="qos", set_specs_args=set_specs_args)
|
||||||
|
|
||||||
|
def test_qos_associate_type(self):
|
||||||
|
self.assertEqual(
|
||||||
|
self.service._impl.qos_associate_type.return_value,
|
||||||
|
self.service.qos_associate_type(qos_specs="fake_qos",
|
||||||
|
volume_type="fake_type"))
|
||||||
|
self.service._impl.qos_associate_type.assert_called_once_with(
|
||||||
|
"fake_qos", "fake_type")
|
||||||
|
|
||||||
|
def test_qos_disassociate_type(self):
|
||||||
|
self.assertEqual(
|
||||||
|
self.service._impl.qos_disassociate_type.return_value,
|
||||||
|
self.service.qos_disassociate_type(qos_specs="fake_qos",
|
||||||
|
volume_type="fake_type"))
|
||||||
|
self.service._impl.qos_disassociate_type.assert_called_once_with(
|
||||||
|
"fake_qos", "fake_type")
|
||||||
|
|
||||||
def test_create_snapshot(self):
|
def test_create_snapshot(self):
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
self.service._impl.create_snapshot.return_value,
|
self.service._impl.create_snapshot.return_value,
|
||||||
|
@ -267,6 +267,16 @@ class CinderMixinTestCase(test.ScenarioTestCase):
|
|||||||
self.cinder.qos_specs.set_keys.assert_called_once_with("qos",
|
self.cinder.qos_specs.set_keys.assert_called_once_with("qos",
|
||||||
set_specs_args)
|
set_specs_args)
|
||||||
|
|
||||||
|
def test_qos_associate_type(self):
|
||||||
|
self.service.qos_associate_type("qos", "type_id")
|
||||||
|
self.cinder.qos_specs.associate.assert_called_once_with(
|
||||||
|
"qos", "type_id")
|
||||||
|
|
||||||
|
def test_qos_disassociate_type(self):
|
||||||
|
self.service.qos_disassociate_type("qos", "type_id")
|
||||||
|
self.cinder.qos_specs.disassociate.assert_called_once_with(
|
||||||
|
"qos", "type_id")
|
||||||
|
|
||||||
def test_delete_snapshot(self):
|
def test_delete_snapshot(self):
|
||||||
snapshot = mock.Mock()
|
snapshot = mock.Mock()
|
||||||
self.service.delete_snapshot(snapshot)
|
self.service.delete_snapshot(snapshot)
|
||||||
@ -571,6 +581,24 @@ class UnifiedCinderMixinTestCase(test.TestCase):
|
|||||||
set_specs_args)
|
set_specs_args)
|
||||||
self.service._unify_qos.assert_called_once_with(qos)
|
self.service._unify_qos.assert_called_once_with(qos)
|
||||||
|
|
||||||
|
def test_qos_associate_type(self):
|
||||||
|
self.service._unify_qos = mock.MagicMock()
|
||||||
|
self.assertEqual(
|
||||||
|
self.service._unify_qos.return_value,
|
||||||
|
self.service.qos_associate_type("qos", "type_id"))
|
||||||
|
self.service._impl.qos_associate_type.assert_called_once_with(
|
||||||
|
"qos", "type_id")
|
||||||
|
self.service._unify_qos.assert_called_once_with("qos")
|
||||||
|
|
||||||
|
def test_qos_disassociate_type(self):
|
||||||
|
self.service._unify_qos = mock.MagicMock()
|
||||||
|
self.assertEqual(
|
||||||
|
self.service._unify_qos.return_value,
|
||||||
|
self.service.qos_disassociate_type("qos", "type_id"))
|
||||||
|
self.service._impl.qos_disassociate_type.assert_called_once_with(
|
||||||
|
"qos", "type_id")
|
||||||
|
self.service._unify_qos.assert_called_once_with("qos")
|
||||||
|
|
||||||
def test_delete_snapshot(self):
|
def test_delete_snapshot(self):
|
||||||
self.service.delete_snapshot("snapshot")
|
self.service.delete_snapshot("snapshot")
|
||||||
self.service._impl.delete_snapshot.assert_called_once_with("snapshot")
|
self.service._impl.delete_snapshot.assert_called_once_with("snapshot")
|
||||||
|
Loading…
Reference in New Issue
Block a user