Skip to content

Commit

Permalink
CLI: Added line permutation check for file loaded config
Browse files Browse the repository at this point in the history
Sometimes instructions in the loaded config does not match
the same instructions in the running config. In this case
frr-reload.py removes the line.
For example:
pppoe-server(config-vrf)# ip route 10.0.0.0/8 blackhole tag 220 250
pppoe-server(config-vrf)# ip route 10.0.0.0/8 blackhole 250 tag 220

This leads to config loss and unpredictable FRR functionality.

Signed-off-by: Yaroslav Kholod <[email protected]>
  • Loading branch information
Yaroslav Kholod committed Dec 30, 2024
1 parent 30467f8 commit 3e28dfc
Showing 1 changed file with 29 additions and 1 deletion.
30 changes: 29 additions & 1 deletion tools/frr-reload.py
Original file line number Diff line number Diff line change
Expand Up @@ -1701,6 +1701,33 @@ def ignore_unconfigurable_lines(lines_to_add, lines_to_del):
return (lines_to_add, lines_to_del)


def is_line_permutated(test_line, conf):
"""
Verify if test_line permutations are present in conf
"""

for conf_line in conf:
# If length of both strings is not same,
# then they cannot be Permutation
# Look for the lines with the same length!
if len(test_line) == len(conf_line):
# Sort both lines
test_line_sorted = sorted(
test_line
) # This is not the fastest code, however, this is a rare action :)
conf_line_sorted = sorted(conf_line)
# Compare sorted lines
if test_line_sorted == conf_line_sorted:
log.info(
"Skip line %s, because it is a permutation of configuration line %s.",
line,
conf_line,
)
return True

return False


def compare_context_objects(newconf, running):
"""
Create a context diff for the two specified contexts
Expand Down Expand Up @@ -1934,7 +1961,8 @@ def compare_context_objects(newconf, running):

for line in running_ctx.lines:
if line not in newconf_ctx.dlines:
lines_to_del.append((newconf_ctx_keys, line))
if not is_line_permutated(line, newconf_ctx.dlines):
lines_to_del.append((newconf_ctx_keys, line))

for newconf_ctx_keys, newconf_ctx in iteritems(newconf.contexts):
if newconf_ctx_keys not in running.contexts:
Expand Down

0 comments on commit 3e28dfc

Please sign in to comment.