Add "qos_network_policy_id" to port definition

Added "qos_network_policy_id" key to port dictionary.

Change-Id: I75713e0e3924ad4c9177e7c9b04c58882e292dc0
Closes-Bug: #1851362
This commit is contained in:
Rodolfo Alonso Hernandez 2019-11-06 19:38:15 +00:00
parent 6c410b166a
commit f2b52b5e8f
4 changed files with 54 additions and 14 deletions

View File

@ -107,4 +107,10 @@ class QosCoreResourceExtension(base.CoreResourceExtension):
binding = resource['qos_policy_binding'] binding = resource['qos_policy_binding']
qos_policy_id = binding['policy_id'] if binding else None qos_policy_id = binding['policy_id'] if binding else None
return {qos_consts.QOS_POLICY_ID: qos_policy_id} retval = {qos_consts.QOS_POLICY_ID: qos_policy_id}
if resource_type == base.PORT:
network_binding = resource.get('qos_network_policy_binding')
qos_net_policy_id = (network_binding['policy_id'] if
network_binding else None)
retval[qos_consts.QOS_NETWORK_POLICY_ID] = qos_net_policy_id
return retval

View File

@ -0,0 +1,20 @@
# Copyright (c) 2020 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
from neutron_lib.api.definitions import qos_port_network_policy
from neutron_lib.api import extensions as api_extensions
class Qos_port_network_policy(api_extensions.APIExtensionDescriptor):
api_definition = qos_port_network_policy

View File

@ -20,6 +20,7 @@ from neutron_lib.api.definitions import qos as qos_apidef
from neutron_lib.api.definitions import qos_bw_limit_direction from neutron_lib.api.definitions import qos_bw_limit_direction
from neutron_lib.api.definitions import qos_bw_minimum_ingress from neutron_lib.api.definitions import qos_bw_minimum_ingress
from neutron_lib.api.definitions import qos_default from neutron_lib.api.definitions import qos_default
from neutron_lib.api.definitions import qos_port_network_policy
from neutron_lib.api.definitions import qos_rule_type_details from neutron_lib.api.definitions import qos_rule_type_details
from neutron_lib.api.definitions import qos_rules_alias from neutron_lib.api.definitions import qos_rules_alias
from neutron_lib.callbacks import events as callbacks_events from neutron_lib.callbacks import events as callbacks_events
@ -61,7 +62,8 @@ class QoSPlugin(qos.QoSPluginBase):
qos_rule_type_details.ALIAS, qos_rule_type_details.ALIAS,
port_resource_request.ALIAS, port_resource_request.ALIAS,
qos_bw_minimum_ingress.ALIAS, qos_bw_minimum_ingress.ALIAS,
qos_rules_alias.ALIAS] qos_rules_alias.ALIAS,
qos_port_network_policy.ALIAS]
__native_pagination_support = True __native_pagination_support = True
__native_sorting_support = True __native_sorting_support = True

View File

@ -13,6 +13,8 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import itertools
import mock import mock
from neutron_lib import context from neutron_lib import context
from neutron_lib.exceptions import qos as qos_exc from neutron_lib.exceptions import qos as qos_exc
@ -26,9 +28,14 @@ from neutron.objects.qos import policy
from neutron.tests import base from neutron.tests import base
def _get_test_dbdata(qos_policy_id): def _get_test_dbdata(qos_policy_id, qos_network_policy_id=None):
return {'id': None, 'qos_policy_binding': {'policy_id': qos_policy_id, retval = {'id': None,
'network_id': 'fake_net_id'}} 'qos_policy_binding': {'policy_id': qos_policy_id,
'network_id': 'fake_net_id'}}
if qos_network_policy_id:
retval['qos_network_policy_binding'] = {
'policy_id': qos_network_policy_id}
return retval
class QosCoreResourceExtensionTestCase(base.BaseTestCase): class QosCoreResourceExtensionTestCase(base.BaseTestCase):
@ -313,18 +320,23 @@ class QosCoreResourceExtensionTestCase(base.BaseTestCase):
fields = self.core_extension.extract_fields(None, None) fields = self.core_extension.extract_fields(None, None)
self.assertEqual({}, fields) self.assertEqual({}, fields)
def _test_extract_fields_for_port(self, qos_policy_id): def _test_extract_fields_for_port(self, qos_policy_id,
qos_network_policy_id=None):
with self._mock_plugin_loaded(True): with self._mock_plugin_loaded(True):
fields = self.core_extension.extract_fields( fields = self.core_extension.extract_fields(
base_core.PORT, _get_test_dbdata(qos_policy_id)) base_core.PORT, _get_test_dbdata(qos_policy_id,
self.assertEqual({qos_consts.QOS_POLICY_ID: qos_policy_id}, fields) qos_network_policy_id))
expected = {
qos_consts.QOS_POLICY_ID: qos_policy_id,
qos_consts.QOS_NETWORK_POLICY_ID: qos_network_policy_id}
self.assertEqual(expected, fields)
def test_extract_fields_no_port_policy(self): def test_extract_fields_for_port(self):
self._test_extract_fields_for_port(None) port_qos_policies = [None, uuidutils.generate_uuid()]
network_qos_policies = [None, uuidutils.generate_uuid()]
def test_extract_fields_port_policy_exists(self): for port_qos, net_qos in itertools.product(port_qos_policies,
qos_policy_id = mock.Mock() network_qos_policies):
self._test_extract_fields_for_port(qos_policy_id) self._test_extract_fields_for_port(port_qos, net_qos)
def _test_extract_fields_for_network(self, qos_policy_id): def _test_extract_fields_for_network(self, qos_policy_id):
with self._mock_plugin_loaded(True): with self._mock_plugin_loaded(True):