Merge "[OVN] Bump the port revision number in trunk driver"
This commit is contained in:
commit
c178c28fb8
@ -22,6 +22,8 @@ from oslo_config import cfg
|
|||||||
from oslo_log import log
|
from oslo_log import log
|
||||||
|
|
||||||
from neutron.common.ovn import constants as ovn_const
|
from neutron.common.ovn import constants as ovn_const
|
||||||
|
from neutron.db import db_base_plugin_common
|
||||||
|
from neutron.db import ovn_revision_numbers_db as db_rev
|
||||||
from neutron.objects import ports as port_obj
|
from neutron.objects import ports as port_obj
|
||||||
from neutron.services.trunk.drivers import base as trunk_base
|
from neutron.services.trunk.drivers import base as trunk_base
|
||||||
|
|
||||||
@ -47,20 +49,23 @@ class OVNTrunkHandler(object):
|
|||||||
context = n_context.get_admin_context()
|
context = n_context.get_admin_context()
|
||||||
db_parent_port = port_obj.Port.get_object(context, id=parent_port)
|
db_parent_port = port_obj.Port.get_object(context, id=parent_port)
|
||||||
parent_port_status = db_parent_port.status
|
parent_port_status = db_parent_port.status
|
||||||
for port in subports:
|
for subport in subports:
|
||||||
with db_api.CONTEXT_WRITER.using(context), (
|
with db_api.CONTEXT_WRITER.using(context), (
|
||||||
txn(check_error=True)) as ovn_txn:
|
txn(check_error=True)) as ovn_txn:
|
||||||
self._set_binding_profile(context, port, parent_port,
|
port = self._set_binding_profile(context, subport, parent_port,
|
||||||
parent_port_status, ovn_txn)
|
parent_port_status, ovn_txn)
|
||||||
|
db_rev.bump_revision(context, port, ovn_const.TYPE_PORTS)
|
||||||
|
|
||||||
def _unset_sub_ports(self, subports):
|
def _unset_sub_ports(self, subports):
|
||||||
txn = self.plugin_driver.nb_ovn.transaction
|
txn = self.plugin_driver.nb_ovn.transaction
|
||||||
context = n_context.get_admin_context()
|
context = n_context.get_admin_context()
|
||||||
for port in subports:
|
for subport in subports:
|
||||||
with db_api.CONTEXT_WRITER.using(context), (
|
with db_api.CONTEXT_WRITER.using(context), (
|
||||||
txn(check_error=True)) as ovn_txn:
|
txn(check_error=True)) as ovn_txn:
|
||||||
self._unset_binding_profile(context, port, ovn_txn)
|
port = self._unset_binding_profile(context, subport, ovn_txn)
|
||||||
|
db_rev.bump_revision(context, port, ovn_const.TYPE_PORTS)
|
||||||
|
|
||||||
|
@db_base_plugin_common.convert_result_to_dict
|
||||||
def _set_binding_profile(self, context, subport, parent_port,
|
def _set_binding_profile(self, context, subport, parent_port,
|
||||||
parent_port_status, ovn_txn):
|
parent_port_status, ovn_txn):
|
||||||
LOG.debug("Setting parent %s for subport %s",
|
LOG.debug("Setting parent %s for subport %s",
|
||||||
@ -71,6 +76,9 @@ class OVNTrunkHandler(object):
|
|||||||
"binding_profile: %s",
|
"binding_profile: %s",
|
||||||
subport.port_id)
|
subport.port_id)
|
||||||
return
|
return
|
||||||
|
check_rev_cmd = self.plugin_driver.nb_ovn.check_revision_number(
|
||||||
|
db_port.id, db_port, ovn_const.TYPE_PORTS)
|
||||||
|
ovn_txn.add(check_rev_cmd)
|
||||||
try:
|
try:
|
||||||
# NOTE(flaviof): We expect binding's host to be set. Otherwise,
|
# NOTE(flaviof): We expect binding's host to be set. Otherwise,
|
||||||
# sub-port will not transition from DOWN to ACTIVE.
|
# sub-port will not transition from DOWN to ACTIVE.
|
||||||
@ -103,7 +111,9 @@ class OVNTrunkHandler(object):
|
|||||||
))
|
))
|
||||||
LOG.debug("Done setting parent %s for subport %s",
|
LOG.debug("Done setting parent %s for subport %s",
|
||||||
parent_port, subport.port_id)
|
parent_port, subport.port_id)
|
||||||
|
return db_port
|
||||||
|
|
||||||
|
@db_base_plugin_common.convert_result_to_dict
|
||||||
def _unset_binding_profile(self, context, subport, ovn_txn):
|
def _unset_binding_profile(self, context, subport, ovn_txn):
|
||||||
LOG.debug("Unsetting parent for subport %s", subport.port_id)
|
LOG.debug("Unsetting parent for subport %s", subport.port_id)
|
||||||
db_port = port_obj.Port.get_object(context, id=subport.port_id)
|
db_port = port_obj.Port.get_object(context, id=subport.port_id)
|
||||||
@ -112,6 +122,9 @@ class OVNTrunkHandler(object):
|
|||||||
"binding_profile: %s",
|
"binding_profile: %s",
|
||||||
subport.port_id)
|
subport.port_id)
|
||||||
return
|
return
|
||||||
|
check_rev_cmd = self.plugin_driver.nb_ovn.check_revision_number(
|
||||||
|
db_port.id, db_port, ovn_const.TYPE_PORTS)
|
||||||
|
ovn_txn.add(check_rev_cmd)
|
||||||
try:
|
try:
|
||||||
db_port.device_owner = ''
|
db_port.device_owner = ''
|
||||||
for binding in db_port.bindings:
|
for binding in db_port.bindings:
|
||||||
@ -140,6 +153,7 @@ class OVNTrunkHandler(object):
|
|||||||
external_ids_update=ext_ids,
|
external_ids_update=ext_ids,
|
||||||
))
|
))
|
||||||
LOG.debug("Done unsetting parent for subport %s", subport.port_id)
|
LOG.debug("Done unsetting parent for subport %s", subport.port_id)
|
||||||
|
return db_port
|
||||||
|
|
||||||
def trunk_created(self, trunk):
|
def trunk_created(self, trunk):
|
||||||
# Check if parent port is handled by OVN.
|
# Check if parent port is handled by OVN.
|
||||||
|
@ -64,10 +64,13 @@ class TestOVNTrunkDriver(base.TestOVNFunctionalBase):
|
|||||||
if row.parent_name and row.tag:
|
if row.parent_name and row.tag:
|
||||||
device_owner = row.external_ids[
|
device_owner = row.external_ids[
|
||||||
ovn_const.OVN_DEVICE_OWNER_EXT_ID_KEY]
|
ovn_const.OVN_DEVICE_OWNER_EXT_ID_KEY]
|
||||||
|
revision_number = row.external_ids[
|
||||||
|
ovn_const.OVN_REV_NUM_EXT_ID_KEY]
|
||||||
ovn_trunk_info.append({'port_id': row.name,
|
ovn_trunk_info.append({'port_id': row.name,
|
||||||
'parent_port_id': row.parent_name,
|
'parent_port_id': row.parent_name,
|
||||||
'tag': row.tag,
|
'tag': row.tag,
|
||||||
'device_owner': device_owner,
|
'device_owner': device_owner,
|
||||||
|
'revision_number': revision_number,
|
||||||
})
|
})
|
||||||
return ovn_trunk_info
|
return ovn_trunk_info
|
||||||
|
|
||||||
@ -80,6 +83,7 @@ class TestOVNTrunkDriver(base.TestOVNFunctionalBase):
|
|||||||
'parent_port_id': [trunk['port_id']],
|
'parent_port_id': [trunk['port_id']],
|
||||||
'tag': [subport['segmentation_id']],
|
'tag': [subport['segmentation_id']],
|
||||||
'device_owner': trunk_consts.TRUNK_SUBPORT_OWNER,
|
'device_owner': trunk_consts.TRUNK_SUBPORT_OWNER,
|
||||||
|
'revision_number': '2',
|
||||||
})
|
})
|
||||||
# Check that the subport has the binding is active.
|
# Check that the subport has the binding is active.
|
||||||
binding = obj_reg.load_class('PortBinding').get_object(
|
binding = obj_reg.load_class('PortBinding').get_object(
|
||||||
|
@ -87,6 +87,8 @@ class TestTrunkHandler(base.BaseTestCase):
|
|||||||
"neutron.objects.ports.PortBinding.update_object").start()
|
"neutron.objects.ports.PortBinding.update_object").start()
|
||||||
self.mock_clear_levels = mock.patch(
|
self.mock_clear_levels = mock.patch(
|
||||||
"neutron.objects.ports.PortBindingLevel.delete_objects").start()
|
"neutron.objects.ports.PortBindingLevel.delete_objects").start()
|
||||||
|
self.mock_bump_revision = mock.patch(
|
||||||
|
"neutron.db.ovn_revision_numbers_db.bump_revision").start()
|
||||||
|
|
||||||
def _get_fake_port_obj(self, port_id):
|
def _get_fake_port_obj(self, port_id):
|
||||||
with mock.patch('uuid.UUID') as mock_uuid:
|
with mock.patch('uuid.UUID') as mock_uuid:
|
||||||
|
Loading…
Reference in New Issue
Block a user