From f9e38622adc6edb66c84c397ef4d0ae9e49e008e Mon Sep 17 00:00:00 2001 From: Christian Poessinger Date: Sat, 28 May 2022 22:59:17 +0200 Subject: rip: T4448: add support to set protocol version on an interface level --- data/templates/frr/ripd.frr.j2 | 6 +++++ interface-definitions/include/rip/version.xml.i | 19 ++++++++++++++ interface-definitions/protocols-rip.xml.in | 34 ++++++++++++------------- smoketest/scripts/cli/test_protocols_rip.py | 9 +++++++ src/conf_mode/protocols_rip.py | 15 +++++++++++ 5 files changed, 66 insertions(+), 17 deletions(-) create mode 100644 interface-definitions/include/rip/version.xml.i diff --git a/data/templates/frr/ripd.frr.j2 b/data/templates/frr/ripd.frr.j2 index e884ed85f..e9e484cc2 100644 --- a/data/templates/frr/ripd.frr.j2 +++ b/data/templates/frr/ripd.frr.j2 @@ -32,6 +32,12 @@ interface {{ iface }} {% if iface_config.split_horizon.poison_reverse is vyos_defined %} ip rip split-horizon poisoned-reverse {% endif %} +{% if iface_config.receive.version is vyos_defined %} + ip rip receive version {{ iface_config.receive.version }} +{% endif %} +{% if iface_config.send.version is vyos_defined %} + ip rip send version {{ iface_config.send.version }} +{% endif %} exit ! {% endfor %} diff --git a/interface-definitions/include/rip/version.xml.i b/interface-definitions/include/rip/version.xml.i new file mode 100644 index 000000000..f7d3eab0d --- /dev/null +++ b/interface-definitions/include/rip/version.xml.i @@ -0,0 +1,19 @@ + + + + RIP protocol version + + 1 + RIPv1 + + + 2 + RIPv2 + + + + + + 2 + + diff --git a/interface-definitions/protocols-rip.xml.in b/interface-definitions/protocols-rip.xml.in index 500af51e5..2195b0316 100644 --- a/interface-definitions/protocols-rip.xml.in +++ b/interface-definitions/protocols-rip.xml.in @@ -98,6 +98,22 @@ Password must be 16 characters or less + + + + + Advertisement reception + + + #include + + + + + Advertisement transmission + + + #include @@ -226,23 +242,7 @@ #include #include - - - RIP protocol version - - u32:1 - RIPv1 - - - u32:2 - RIPv2 - - - - - - 2 - + #include diff --git a/smoketest/scripts/cli/test_protocols_rip.py b/smoketest/scripts/cli/test_protocols_rip.py index ee882943b..8c100d537 100755 --- a/smoketest/scripts/cli/test_protocols_rip.py +++ b/smoketest/scripts/cli/test_protocols_rip.py @@ -160,8 +160,12 @@ class TestProtocolsRIP(VyOSUnitTestSHIM.TestCase): def test_rip_03_version(self): version = '1' + interface = 'eth0' self.cli_set(base_path + ['version', version]) + self.cli_set(base_path + ['interface', interface, 'send', 'version', version]) + self.cli_set(base_path + ['interface', interface, 'receive', 'version', version]) + # commit changes self.cli_commit() @@ -169,5 +173,10 @@ class TestProtocolsRIP(VyOSUnitTestSHIM.TestCase): frrconfig = self.getFRRconfig('router rip') self.assertIn(f'version {version}', frrconfig) + frrconfig = self.getFRRconfig(f'interface {interface}') + self.assertIn(f' ip rip receive version {version}', frrconfig) + self.assertIn(f' ip rip send version {version}', frrconfig) + + if __name__ == '__main__': unittest.main(verbosity=2) diff --git a/src/conf_mode/protocols_rip.py b/src/conf_mode/protocols_rip.py index c78d90396..e29b23765 100755 --- a/src/conf_mode/protocols_rip.py +++ b/src/conf_mode/protocols_rip.py @@ -56,9 +56,24 @@ def get_config(config=None): # We have gathered the dict representation of the CLI, but there are default # options which we need to update into the dictionary retrived. default_values = defaults(base) + + # T2665: we can not blend in default values of tagNodes - delete and add + # individual values later on ... + if 'interface' in default_values: + del default_values['interface'] # merge in remaining default values rip = dict_merge(default_values, rip) + # T2665: add individual per interface defaults + + # T2665: blend in per interface defaults + if 'interface' in rip: + default_values = defaults(base + ['interface']) + for interface in rip['interface']: + # merge in default values + rip['interface'][interface] = dict_merge(default_values, + rip['interface'][interface]) + # We also need some additional information from the config, prefix-lists # and route-maps for instance. They will be used in verify(). # -- cgit v1.2.3