summaryrefslogtreecommitdiff
path: root/src/conf_mode/vrf.py
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2021-07-19 20:49:32 +0200
committerChristian Poessinger <christian@poessinger.com>2021-07-19 20:53:45 +0200
commit2975c5e835fd323ef5d47bebec27e4d08e04dd7a (patch)
tree7649223f3d4900b28e921c2a7aa44f5391c582c5 /src/conf_mode/vrf.py
parenta2e708384f1e1136016ceb7c45494a9a3ddaeb49 (diff)
downloadvyos-1x-2975c5e835fd323ef5d47bebec27e4d08e04dd7a.tar.gz
vyos-1x-2975c5e835fd323ef5d47bebec27e4d08e04dd7a.zip
vrf: T3655: fix potential error when removing VRF connection tracking table
This extends commit 22791e26 ("VRF: T3655: proper connection tracking for VRFs") so that when the netfilter table is removed, we first check if it exists at all, and if it does not exist we do not remove it. This fixes the smoketest error: PermissionError: [Errno 1] failed to run command: nft delete table inet vrf_zones
Diffstat (limited to 'src/conf_mode/vrf.py')
-rwxr-xr-xsrc/conf_mode/vrf.py7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/conf_mode/vrf.py b/src/conf_mode/vrf.py
index fbfce646f..82956b219 100755
--- a/src/conf_mode/vrf.py
+++ b/src/conf_mode/vrf.py
@@ -27,9 +27,10 @@ from vyos.template import render
from vyos.template import render_to_string
from vyos.util import call
from vyos.util import cmd
-from vyos.util import popen
from vyos.util import dict_search
from vyos.util import get_interface_config
+from vyos.util import popen
+from vyos.util import run
from vyos import ConfigError
from vyos import frr
from vyos import airbag
@@ -237,7 +238,9 @@ def apply(vrf):
if 1000 in [r.get('priority') for r in list_rules() if r.get('priority') == 1000]:
call(f'ip {af} rule del pref 1000')
# Remove VRF zones table from nftables
- cmd('nft delete table inet vrf_zones')
+ tmp = run('nft list table inet vrf_zones')
+ if tmp == 0:
+ cmd('nft delete table inet vrf_zones')
# add configuration to FRR
frr_cfg = frr.FRRConfig()