From 5bb65f5dd006a47900a2a656874ebd54f78e4589 Mon Sep 17 00:00:00 2001 From: Justin Lamp Date: Thu, 19 Oct 2023 16:11:26 +0200 Subject: [PATCH] Fix [EVPN-Driver] Cannot remove routes pyroute2 update breaks getting some route information. Closes-Bug: #2038819 Change-Id: I17f6882b54314a65bdb05760609dbda1dcc82e6b Signed-off-by: Justin Lamp --- ovn_bgp_agent/drivers/openstack/ovn_evpn_driver.py | 9 +++++---- ovn_bgp_agent/utils/linux_net.py | 6 +++--- 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/ovn_bgp_agent/drivers/openstack/ovn_evpn_driver.py b/ovn_bgp_agent/drivers/openstack/ovn_evpn_driver.py index 2b8d4adb..67690740 100644 --- a/ovn_bgp_agent/drivers/openstack/ovn_evpn_driver.py +++ b/ovn_bgp_agent/drivers/openstack/ovn_evpn_driver.py @@ -766,16 +766,17 @@ class OVNEVPNDriver(driver_api.AgentDriverBase): if 'gateway' in route_info['route'].keys(): # subnet route possible_matchings = [ r for r in vrf_routes - if (r['dst'] == route_info['route']['dst'] and + if (r.get('dst') == route_info['route']['dst'] and r['dst_len'] == route_info['route']['dst_len'] and - r['gateway'] == route_info['route']['gateway'] and + r.get('gateway') == ( + route_info['route']['gateway']) and r['table'] == route_info['route']['table'])] else: # cr-lrp possible_matchings = [ r for r in vrf_routes - if (r['dst'] == route_info['route']['dst'] and + if (r.get('dst') == route_info['route']['dst'] and r['dst_len'] == route_info['route']['dst_len'] and - r['oif'] == oif and + r.get('oif') == oif and r['table'] == route_info['route']['table'])] for r in possible_matchings: vrf_routes.remove(r) diff --git a/ovn_bgp_agent/utils/linux_net.py b/ovn_bgp_agent/utils/linux_net.py index 24c1f464..9b5e1064 100644 --- a/ovn_bgp_agent/utils/linux_net.py +++ b/ovn_bgp_agent/utils/linux_net.py @@ -528,11 +528,11 @@ def get_routes_on_tables(table_ids): def delete_ip_routes(routes): for route in routes: - r_info = {'dst': route['dst'], + r_info = {'dst': route.get('dst'), 'dst_len': route['dst_len'], 'family': route['family'], - 'oif': route['oif'], - 'gateway': route['gateway'], + 'oif': route.get('oif'), + 'gateway': route.get('gateway'), 'table': route['table']} ovn_bgp_agent.privileged.linux_net.route_delete(r_info)