[NSX|v3]: L2gateway fails to start when Bridge cluster configured

Recent change If2fe1e014b78703ff0a9cdff1e4e8d45f3a4a16d
broke L2GW driver for NSXv3. This patch makes sure that the driver
starts and creates bridge clusters using the new nsxlib.
This patch adds a callback to create default l2 gw after the core
plugin is initialized.

Change-Id: Iced699b13e265f515c23fcc952ba9bb1e64b5762
This commit is contained in:
Abhishek Raut 2016-08-19 16:28:36 -07:00 committed by Gary Kotton
parent 58dc54f52a
commit c3b287d4b8
2 changed files with 43 additions and 40 deletions

View File

@ -53,7 +53,6 @@ class NsxV3Driver(l2gateway_db.L2GatewayMixin):
super(NsxV3Driver, self).__init__() super(NsxV3Driver, self).__init__()
self._plugin = plugin self._plugin = plugin
LOG.debug("Starting service plugin for NSX L2Gateway") LOG.debug("Starting service plugin for NSX L2Gateway")
self._ensure_default_l2_gateway()
self.subscribe_callback_notifications() self.subscribe_callback_notifications()
LOG.debug("Initialization complete for NSXv3 driver for " LOG.debug("Initialization complete for NSXv3 driver for "
"L2 gateway service plugin.") "L2 gateway service plugin.")
@ -65,8 +64,10 @@ class NsxV3Driver(l2gateway_db.L2GatewayMixin):
def subscribe_callback_notifications(self): def subscribe_callback_notifications(self):
registry.subscribe(self._prevent_l2gw_port_delete, resources.PORT, registry.subscribe(self._prevent_l2gw_port_delete, resources.PORT,
events.BEFORE_DELETE) events.BEFORE_DELETE)
registry.subscribe(self._ensure_default_l2_gateway, resources.PROCESS,
events.BEFORE_SPAWN)
def _ensure_default_l2_gateway(self): def _ensure_default_l2_gateway(self, resource, event, trigger, **kwargs):
""" """
Create a default logical L2 gateway. Create a default logical L2 gateway.

View File

@ -24,6 +24,9 @@ from oslo_config import cfg
from oslo_utils import importutils from oslo_utils import importutils
from oslo_utils import uuidutils from oslo_utils import uuidutils
from neutron.callbacks import events
from neutron.callbacks import registry
from neutron.callbacks import resources
from neutron import context from neutron import context
from neutron.tests import base from neutron.tests import base
@ -65,51 +68,50 @@ class TestNsxV3L2GatewayDriver(test_l2gw_db.L2GWTestCase,
def test_nsxl2gw_driver_init(self): def test_nsxl2gw_driver_init(self):
with mock.patch.object(nsx_v3_driver.NsxV3Driver, with mock.patch.object(nsx_v3_driver.NsxV3Driver,
'_ensure_default_l2_gateway') as def_gw: 'subscribe_callback_notifications') as sub:
with mock.patch.object(nsx_v3_driver.NsxV3Driver, with mock.patch.object(nsx_v3_driver.LOG,
'subscribe_callback_notifications') as sub: 'debug') as debug:
with mock.patch.object(nsx_v3_driver.LOG, nsx_v3_driver.NsxV3Driver(mock.MagicMock())
'debug') as debug: self.assertTrue(sub.called)
nsx_v3_driver.NsxV3Driver(mock.MagicMock()) self.assertTrue(debug.called)
self.assertTrue(def_gw.called)
self.assertTrue(sub.called)
self.assertTrue(debug.called)
def test_create_default_l2_gateway(self): def test_create_default_l2_gateway(self):
def_bridge_cluster_name = nsx_v3_mocks.NSX_BRIDGE_CLUSTER_NAME def_bridge_cluster_name = nsx_v3_mocks.NSX_BRIDGE_CLUSTER_NAME
with mock.patch.object(nsx_v3_driver.NsxV3Driver, cfg.CONF.set_override("default_bridge_cluster",
'subscribe_callback_notifications'): def_bridge_cluster_name,
cfg.CONF.set_override("default_bridge_cluster", "nsx_v3")
def_bridge_cluster_name, nsx_v3_driver.NsxV3Driver(mock.MagicMock())
"nsx_v3") # fake the callback invoked after init
nsx_v3_driver.NsxV3Driver(mock.MagicMock()) registry.notify(resources.PROCESS, events.BEFORE_SPAWN,
l2gws = self.driver._get_l2_gateways(self.context) mock.MagicMock())
def_bridge_cluster_id = ( l2gws = self.driver._get_l2_gateways(self.context)
self.nsxlib.get_bridge_cluster_id_by_name_or_id( def_bridge_cluster_id = (
def_bridge_cluster_name)) self.nsxlib.get_bridge_cluster_id_by_name_or_id(
def_l2gw = None def_bridge_cluster_name))
for l2gw in l2gws: def_l2gw = None
for device in l2gw['devices']: for l2gw in l2gws:
if device['device_name'] == def_bridge_cluster_id: for device in l2gw['devices']:
def_l2gw = l2gw if device['device_name'] == def_bridge_cluster_id:
self.assertIsNotNone(def_l2gw) def_l2gw = l2gw
self.assertTrue(def_l2gw.devices[0].device_name, self.assertIsNotNone(def_l2gw)
def_bridge_cluster_id) self.assertTrue(def_l2gw.devices[0].device_name,
self.assertTrue(def_l2gw.devices[0].interfaces[0].interface_name, def_bridge_cluster_id)
'default-bridge-cluster') self.assertTrue(def_l2gw.devices[0].interfaces[0].interface_name,
'default-bridge-cluster')
def test_create_duplicate_default_l2_gateway_noop(self): def test_create_duplicate_default_l2_gateway_noop(self):
def_bridge_cluster_name = nsx_v3_mocks.NSX_BRIDGE_CLUSTER_NAME def_bridge_cluster_name = nsx_v3_mocks.NSX_BRIDGE_CLUSTER_NAME
with mock.patch.object(nsx_v3_driver.NsxV3Driver, cfg.CONF.set_override("default_bridge_cluster",
'subscribe_callback_notifications'): def_bridge_cluster_name,
cfg.CONF.set_override("default_bridge_cluster", "nsx_v3")
def_bridge_cluster_name, for i in range(0, 2):
"nsx_v3")
nsx_v3_driver.NsxV3Driver(mock.MagicMock()) nsx_v3_driver.NsxV3Driver(mock.MagicMock())
nsx_v3_driver.NsxV3Driver(mock.MagicMock()) # fake the callback invoked after init
l2gws = self.driver._get_l2_gateways(self.context) registry.notify(resources.PROCESS, events.BEFORE_SPAWN,
# Verify whether only one default L2 gateway is created mock.MagicMock())
self.assertEqual(1, len(l2gws)) l2gws = self.driver._get_l2_gateways(self.context)
# Verify whether only one default L2 gateway is created
self.assertEqual(1, len(l2gws))
def test_create_default_l2_gateway_no_bc_uuid_noop(self): def test_create_default_l2_gateway_no_bc_uuid_noop(self):
with mock.patch.object(nsx_v3_driver.NsxV3Driver, with mock.patch.object(nsx_v3_driver.NsxV3Driver,