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:
Adit Sarfaty 2016-05-30 15:30:33 +03:00 committed by Kobi Samoray
parent d06001273a
commit 99fe293163
2 changed files with 32 additions and 4 deletions

View File

@ -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])

View File

@ -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: