NSX-V3: support qos policy in port/network get
Return the policy id when getting a port or a network Change-Id: Ic331caef09bc5d216b5931c933c1c34ffaf6e9f7
This commit is contained in:
parent
d06001273a
commit
99fe293163
@ -591,6 +591,9 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
created_net['id'],
|
created_net['id'],
|
||||||
net_data[qos_consts.QOS_POLICY_ID])
|
net_data[qos_consts.QOS_POLICY_ID])
|
||||||
|
|
||||||
|
created_net[qos_consts.QOS_POLICY_ID] = (
|
||||||
|
qos_utils.get_network_policy_id(context, created_net['id']))
|
||||||
|
|
||||||
return created_net
|
return created_net
|
||||||
|
|
||||||
def _retry_delete_network(self, context, network_id):
|
def _retry_delete_network(self, context, network_id):
|
||||||
@ -748,6 +751,11 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
|
|
||||||
return address_bindings
|
return address_bindings
|
||||||
|
|
||||||
|
def _extend_get_network_dict_provider(self, context, network):
|
||||||
|
self._extend_network_dict_provider(context, network)
|
||||||
|
network[qos_consts.QOS_POLICY_ID] = qos_utils.get_network_policy_id(
|
||||||
|
context, network['id'])
|
||||||
|
|
||||||
def get_network(self, context, id, fields=None):
|
def get_network(self, context, id, fields=None):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
# Get network from Neutron database
|
# Get network from Neutron database
|
||||||
@ -755,7 +763,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
# Don't do field selection here otherwise we won't be able to add
|
# Don't do field selection here otherwise we won't be able to add
|
||||||
# provider networks fields
|
# provider networks fields
|
||||||
net = self._make_network_dict(network, context=context)
|
net = self._make_network_dict(network, context=context)
|
||||||
self._extend_network_dict_provider(context, net)
|
self._extend_get_network_dict_provider(context, net)
|
||||||
return self._fields(net, fields)
|
return self._fields(net, fields)
|
||||||
|
|
||||||
def get_networks(self, context, filters=None, fields=None,
|
def get_networks(self, context, filters=None, fields=None,
|
||||||
@ -770,7 +778,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
limit, marker, page_reverse))
|
limit, marker, page_reverse))
|
||||||
# Add provider network fields
|
# Add provider network fields
|
||||||
for net in networks:
|
for net in networks:
|
||||||
self._extend_network_dict_provider(context, net)
|
self._extend_get_network_dict_provider(context, net)
|
||||||
return (networks if not fields else
|
return (networks if not fields else
|
||||||
[self._fields(network, fields) for network in networks])
|
[self._fields(network, fields) for network in networks])
|
||||||
|
|
||||||
@ -1345,9 +1353,17 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
|
|
||||||
return updated_port
|
return updated_port
|
||||||
|
|
||||||
|
def _extend_get_port_dict_binding(self, context, port):
|
||||||
|
self._extend_port_dict_binding(context, port)
|
||||||
|
|
||||||
|
# add the qos policy id from the DB
|
||||||
|
port[qos_consts.QOS_POLICY_ID] = qos_utils.get_port_policy_id(
|
||||||
|
context, port['id'])
|
||||||
|
|
||||||
def get_port(self, context, id, fields=None):
|
def get_port(self, context, id, fields=None):
|
||||||
port = super(NsxV3Plugin, self).get_port(context, id, fields=None)
|
port = super(NsxV3Plugin, self).get_port(context, id, fields=None)
|
||||||
self._extend_port_dict_binding(context, port)
|
self._extend_get_port_dict_binding(context, port)
|
||||||
|
|
||||||
return self._fields(port, fields)
|
return self._fields(port, fields)
|
||||||
|
|
||||||
def get_ports(self, context, filters=None, fields=None,
|
def get_ports(self, context, filters=None, fields=None,
|
||||||
@ -1361,7 +1377,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
|
|||||||
limit, marker, page_reverse))
|
limit, marker, page_reverse))
|
||||||
# Add port extensions
|
# Add port extensions
|
||||||
for port in ports:
|
for port in ports:
|
||||||
self._extend_port_dict_binding(context, port)
|
self._extend_get_port_dict_binding(context, port)
|
||||||
return (ports if not fields else
|
return (ports if not fields else
|
||||||
[self._fields(port, fields) for port in ports])
|
[self._fields(port, fields) for port in ports])
|
||||||
|
|
||||||
|
@ -279,6 +279,12 @@ class TestPortsV2(test_plugin.TestPortsV2, NsxV3PluginTestCaseMixin,
|
|||||||
with mock.patch.object(self.plugin, '_get_qos_profile_id'):
|
with mock.patch.object(self.plugin, '_get_qos_profile_id'):
|
||||||
port = self.plugin.create_port(self.ctx, data)
|
port = self.plugin.create_port(self.ctx, data)
|
||||||
self.assertEqual(policy_id, port['qos_policy_id'])
|
self.assertEqual(policy_id, port['qos_policy_id'])
|
||||||
|
# Get port should also return the qos policy id
|
||||||
|
with mock.patch('vmware_nsx.services.qos.nsx_v3.utils.'
|
||||||
|
'get_port_policy_id',
|
||||||
|
return_value=policy_id):
|
||||||
|
port = self.plugin.get_port(self.ctx, port['id'])
|
||||||
|
self.assertEqual(policy_id, port['qos_policy_id'])
|
||||||
|
|
||||||
def test_update_port_with_qos(self):
|
def test_update_port_with_qos(self):
|
||||||
with self.network() as network:
|
with self.network() as network:
|
||||||
@ -298,6 +304,12 @@ class TestPortsV2(test_plugin.TestPortsV2, NsxV3PluginTestCaseMixin,
|
|||||||
with mock.patch.object(self.plugin, '_get_qos_profile_id'):
|
with mock.patch.object(self.plugin, '_get_qos_profile_id'):
|
||||||
res = self.plugin.update_port(self.ctx, port['id'], data)
|
res = self.plugin.update_port(self.ctx, port['id'], data)
|
||||||
self.assertEqual(policy_id, res['qos_policy_id'])
|
self.assertEqual(policy_id, res['qos_policy_id'])
|
||||||
|
# Get port should also return the qos policy id
|
||||||
|
with mock.patch('vmware_nsx.services.qos.nsx_v3.utils.'
|
||||||
|
'get_port_policy_id',
|
||||||
|
return_value=policy_id):
|
||||||
|
res = self.plugin.get_port(self.ctx, port['id'])
|
||||||
|
self.assertEqual(policy_id, res['qos_policy_id'])
|
||||||
|
|
||||||
def test_create_ext_port_with_qos_fail(self):
|
def test_create_ext_port_with_qos_fail(self):
|
||||||
with self._create_l3_ext_network() as network:
|
with self._create_l3_ext_network() as network:
|
||||||
|
Loading…
Reference in New Issue
Block a user