From f099a41bedfc668e9bb637257c04f3ca9d94ca1a Mon Sep 17 00:00:00 2001 From: Gary Kotton Date: Sun, 3 Mar 2013 14:47:31 +0000 Subject: [PATCH] Prevent exception with VIP deletion Fixes bug 1137697 Change-Id: I6de55c674da1202eb9c1e2e11eda2e6de554750c --- .../services/agent_loadbalancer/plugin.py | 27 +++++++++++++------ 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/quantum/plugins/services/agent_loadbalancer/plugin.py b/quantum/plugins/services/agent_loadbalancer/plugin.py index 3b7b48ec77..0a09255dd6 100644 --- a/quantum/plugins/services/agent_loadbalancer/plugin.py +++ b/quantum/plugins/services/agent_loadbalancer/plugin.py @@ -123,10 +123,15 @@ class LoadBalancerCallbacks(object): if not port_id: return - port = self.plugin._core_plugin.get_port( - context, - port_id - ) + try: + port = self.plugin._core_plugin.get_port( + context, + port_id + ) + except q_exc.PortNotFound: + msg = _('Unable to find port %s to plug.') + LOG.debug(msg, port_id) + return port['admin_state_up'] = True port['device_owner'] = 'quantum:' + constants.LOADBALANCER @@ -142,10 +147,16 @@ class LoadBalancerCallbacks(object): if not port_id: return - port = self.plugin._core_plugin.get_port( - context, - port_id - ) + try: + port = self.plugin._core_plugin.get_port( + context, + port_id + ) + except q_exc.PortNotFound: + msg = _('Unable to find port %s to unplug. This can occur when ' + 'the Vip has been deleted first.') + LOG.debug(msg, port_id) + return port['admin_state_up'] = False port['device_owner'] = ''