Merge "Add validation of required QoS extensions in Neutron"

This commit is contained in:
Jenkins
2017-07-07 18:08:35 +00:00
committed by Gerrit Code Review
2 changed files with 196 additions and 6 deletions

View File

@@ -1745,6 +1745,9 @@ class OpenStackCloud(
:returns: A list of policies ``munch.Munch``.
"""
if not self._has_neutron_extension('qos'):
raise OpenStackCloudUnavailableExtension(
'QoS extension is not available on target cloud')
# Translate None from search interface to empty {} for kwargs below
if not filters:
filters = {}
@@ -3193,6 +3196,9 @@ class OpenStackCloud(
:returns: The QoS policy object.
:raises: OpenStackCloudException on operation error.
"""
if not self._has_neutron_extension('qos'):
raise OpenStackCloudUnavailableExtension(
'QoS extension is not available on target cloud')
policy = {}
if name:
policy['name'] = name
@@ -3200,10 +3206,12 @@ class OpenStackCloud(
policy['description'] = description
if shared is not None:
policy['shared'] = shared
# TODO(slaweq): this should be used only if proper API extension is
# available in Neutron
if default is not None:
policy['is_default'] = default
if self._has_neutron_extension('qos-default'):
policy['is_default'] = default
else:
self.log.debug("'qos-default' extension is not available on "
"target cloud")
if project_id:
policy['project_id'] = project_id
@@ -3229,6 +3237,9 @@ class OpenStackCloud(
:returns: The updated QoS policy object.
:raises: OpenStackCloudException on operation error.
"""
if not self._has_neutron_extension('qos'):
raise OpenStackCloudUnavailableExtension(
'QoS extension is not available on target cloud')
policy = {}
if policy_name:
policy['name'] = policy_name
@@ -3236,10 +3247,12 @@ class OpenStackCloud(
policy['description'] = description
if shared is not None:
policy['shared'] = shared
# TODO(slaweq): this should be used only if proper API extension is
# available in Neutron
if default is not None:
policy['is_default'] = default
if self._has_neutron_extension('qos-default'):
policy['is_default'] = default
else:
self.log.debug("'qos-default' extension is not available on "
"target cloud")
if not policy:
self.log.debug("No QoS policy data to update")
@@ -3265,6 +3278,9 @@ class OpenStackCloud(
:raises: OpenStackCloudException on operation error.
"""
if not self._has_neutron_extension('qos'):
raise OpenStackCloudUnavailableExtension(
'QoS extension is not available on target cloud')
policy = self.get_qos_policy(name_or_id)
if not policy:
self.log.debug("QoS policy %s not found for deleting", name_or_id)

View File

@@ -36,8 +36,30 @@ class TestQosPolicy(base.RequestsMockTestCase):
'is_default': False
}
qos_extension = {
"updated": "2015-06-08T10:00:00-00:00",
"name": "Quality of Service",
"links": [],
"alias": "qos",
"description": "The Quality of Service extension."
}
qos_default_extension = {
"updated": "2017-041-06T10:00:00-00:00",
"name": "QoS default policy",
"links": [],
"alias": "qos-default",
"description": "Expose the QoS default policy per project"
}
enabled_neutron_extensions = [qos_extension, qos_default_extension]
def test_get_qos_policy(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -49,8 +71,24 @@ class TestQosPolicy(base.RequestsMockTestCase):
self.assertDictEqual(self.mock_policy, r)
self.assert_calls()
def test_get_qos_policy_no_qos_extension(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': []})
])
self.assertRaises(
exc.OpenStackCloudException,
self.cloud.get_qos_policy, self.policy_name)
self.assert_calls()
def test_create_qos_policy(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='POST',
uri=self.get_mock_url(
'network', 'public',
@@ -62,8 +100,53 @@ class TestQosPolicy(base.RequestsMockTestCase):
self.assertDictEqual(self.mock_policy, policy)
self.assert_calls()
def test_create_qos_policy_no_qos_extension(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': []})
])
self.assertRaises(
exc.OpenStackCloudException,
self.cloud.create_qos_policy, name=self.policy_name)
self.assert_calls()
def test_create_qos_policy_no_qos_default_extension(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': [self.qos_extension]}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': [self.qos_extension]}),
dict(method='POST',
uri=self.get_mock_url(
'network', 'public',
append=['v2.0', 'qos', 'policies.json']),
json={'policy': self.mock_policy},
validate=dict(
json={'policy': {
'name': self.policy_name,
'project_id': self.project_id}}))
])
policy = self.cloud.create_qos_policy(
name=self.policy_name, project_id=self.project_id, default=True)
self.assertDictEqual(self.mock_policy, policy)
self.assert_calls()
def test_delete_qos_policy(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -79,8 +162,28 @@ class TestQosPolicy(base.RequestsMockTestCase):
self.assertTrue(self.cloud.delete_qos_policy(self.policy_name))
self.assert_calls()
def test_delete_qos_policy_no_qos_extension(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': []})
])
self.assertRaises(
exc.OpenStackCloudException,
self.cloud.delete_qos_policy, self.policy_name)
self.assert_calls()
def test_delete_qos_policy_not_found(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -94,6 +197,14 @@ class TestQosPolicy(base.RequestsMockTestCase):
policy1 = dict(id='123', name=self.policy_name)
policy2 = dict(id='456', name=self.policy_name)
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -109,6 +220,14 @@ class TestQosPolicy(base.RequestsMockTestCase):
policy1 = self.mock_policy
policy2 = dict(id='456', name=self.policy_name)
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -128,6 +247,14 @@ class TestQosPolicy(base.RequestsMockTestCase):
expected_policy = copy.copy(self.mock_policy)
expected_policy['name'] = 'goofy'
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': self.enabled_neutron_extensions}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
@@ -146,3 +273,50 @@ class TestQosPolicy(base.RequestsMockTestCase):
self.policy_id, policy_name='goofy')
self.assertDictEqual(expected_policy, policy)
self.assert_calls()
def test_update_qos_policy_no_qos_extension(self):
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': []})
])
self.assertRaises(
exc.OpenStackCloudException,
self.cloud.update_qos_policy, self.policy_id, policy_name="goofy")
self.assert_calls()
def test_update_qos_policy_no_qos_default_extension(self):
expected_policy = copy.copy(self.mock_policy)
expected_policy['name'] = 'goofy'
self.register_uris([
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': [self.qos_extension]}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': [self.qos_extension]}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public', append=['v2.0', 'extensions.json']),
json={'extensions': [self.qos_extension]}),
dict(method='GET',
uri=self.get_mock_url(
'network', 'public',
append=['v2.0', 'qos', 'policies.json']),
json={'policies': [self.mock_policy]}),
dict(method='PUT',
uri=self.get_mock_url(
'network', 'public',
append=['v2.0', 'qos', 'policies',
'%s.json' % self.policy_id]),
json={'policy': expected_policy},
validate=dict(
json={'policy': {'name': "goofy"}}))
])
policy = self.cloud.update_qos_policy(
self.policy_id, policy_name='goofy', default=True)
self.assertDictEqual(expected_policy, policy)
self.assert_calls()