Filter out router ports without IPs when gathering router sync data

Bug 1152050

Change-Id: Idd11d5f953129471c09f44b4f7c75dc9899d6783
This commit is contained in:
Salvatore Orlando 2013-03-07 12:32:32 +01:00
parent 4452f3a83b
commit 1955948570

View File

@ -929,10 +929,15 @@ class L3_NAT_db_mixin(l3.RouterPluginBase):
for port in ports: for port in ports:
fixed_ips = port.get('fixed_ips', []) fixed_ips = port.get('fixed_ips', [])
if len(fixed_ips) > 1: if len(fixed_ips) > 1:
LOG.error(_("Ignoring multiple IPs on router port %s"), LOG.info(_("Ignoring multiple IPs on router port %s"),
port['id'])
continue
elif not fixed_ips:
# Skip ports without IPs, which can occur if a subnet
# attached to a router is deleted
LOG.info(_("Skipping port %s as no IP is configure on it"),
port['id']) port['id'])
continue continue
# Empty fixed_ips should not happen
fixed_ip = fixed_ips[0] fixed_ip = fixed_ips[0]
my_ports = subnet_id_ports_dict.get(fixed_ip['subnet_id'], []) my_ports = subnet_id_ports_dict.get(fixed_ip['subnet_id'], [])
my_ports.append(port) my_ports.append(port)