diff options
| -rwxr-xr-x | smoketest/scripts/cli/test_system_ipv6.py | 19 | ||||
| -rwxr-xr-x | smoketest/scripts/cli/test_vrf.py | 54 | 
2 files changed, 67 insertions, 6 deletions
| diff --git a/smoketest/scripts/cli/test_system_ipv6.py b/smoketest/scripts/cli/test_system_ipv6.py index 3112d2e46..6fe58701b 100755 --- a/smoketest/scripts/cli/test_system_ipv6.py +++ b/smoketest/scripts/cli/test_system_ipv6.py @@ -17,7 +17,11 @@  import unittest  from base_vyostest_shim import VyOSUnitTestSHIM + +from vyos.template import is_ipv4  from vyos.util import read_file +from vyos.util import is_ipv6_enabled +from vyos.validate import is_intf_addr_assigned  base_path = ['system', 'ipv6'] @@ -42,6 +46,14 @@ class TestSystemIPv6(VyOSUnitTestSHIM.TestCase):          self.assertEqual(read_file(file_forwarding), '0')      def test_system_ipv6_disable(self): +        # Verify previous "enable" state +        self.assertEqual(read_file(file_disable), '0') +        self.assertTrue(is_ipv6_enabled()) + +        loopbacks = ['127.0.0.1', '::1'] +        for addr in loopbacks: +            self.assertTrue(is_intf_addr_assigned('lo', addr)) +          # Do not assign any IPv6 address on interfaces, this requires a reboot          # which can not be tested, but we can read the config file :)          self.cli_set(base_path + ['disable']) @@ -49,6 +61,13 @@ class TestSystemIPv6(VyOSUnitTestSHIM.TestCase):          # Verify configuration file          self.assertEqual(read_file(file_disable), '1') +        self.assertFalse(is_ipv6_enabled()) + +        for addr in loopbacks: +            if is_ipv4(addr): +                self.assertTrue(is_intf_addr_assigned('lo', addr)) +            else: +                self.assertFalse(is_intf_addr_assigned('lo', addr))      def test_system_ipv6_strict_dad(self):          # This defaults to 1 diff --git a/smoketest/scripts/cli/test_vrf.py b/smoketest/scripts/cli/test_vrf.py index 5ffa9c086..5daea589c 100755 --- a/smoketest/scripts/cli/test_vrf.py +++ b/smoketest/scripts/cli/test_vrf.py @@ -1,6 +1,6 @@  #!/usr/bin/env python3  # -# Copyright (C) 2020-2021 VyOS maintainers and contributors +# Copyright (C) 2020-2022 VyOS maintainers and contributors  #  # This program is free software; you can redistribute it and/or modify  # it under the terms of the GNU General Public License version 2 or later as @@ -25,9 +25,10 @@ from base_vyostest_shim import VyOSUnitTestSHIM  from vyos.configsession import ConfigSessionError  from vyos.ifconfig import Interface  from vyos.ifconfig import Section -from vyos.template import is_ipv6 +from vyos.template import is_ipv4  from vyos.util import cmd  from vyos.util import read_file +from vyos.util import get_interface_config  from vyos.validate import is_intf_addr_assigned  base_path = ['vrf'] @@ -105,10 +106,13 @@ class VRFTest(VyOSUnitTestSHIM.TestCase):              frrconfig = self.getFRRconfig(f'vrf {vrf}')              self.assertIn(f' vni {table}', frrconfig) +            tmp = get_interface_config(vrf) +            self.assertEqual(int(table), tmp['linkinfo']['info_data']['table']) +              # Increment table ID for the next run              table = str(int(table) + 1) -    def test_vrf_loopback_ips(self): +    def test_vrf_loopbacks_ips(self):          table = '2000'          for vrf in vrfs:              base = base_path + ['name', vrf] @@ -119,10 +123,48 @@ class VRFTest(VyOSUnitTestSHIM.TestCase):          self.cli_commit()          # Verify VRF configuration +        loopbacks = ['127.0.0.1', '::1']          for vrf in vrfs: -            self.assertTrue(vrf in interfaces()) -            self.assertTrue(is_intf_addr_assigned(vrf, '127.0.0.1')) -            self.assertTrue(is_intf_addr_assigned(vrf, '::1')) +            # Ensure VRF was created +            self.assertIn(vrf, interfaces()) +            # Test for proper loopback IP assignment +            for addr in loopbacks: +                self.assertTrue(is_intf_addr_assigned(vrf, addr)) + +    def test_vrf_loopbacks_no_ipv6(self): +        table = '2002' +        for vrf in vrfs: +            base = base_path + ['name', vrf] +            self.cli_set(base + ['table', str(table)]) +            table = str(int(table) + 1) + +        # Globally disable IPv6 - this will remove all IPv6 interface addresses +        self.cli_set(['system', 'ipv6', 'disable']) + +        # commit changes +        self.cli_commit() + +        # Verify VRF configuration +        table = '2002' +        loopbacks = ['127.0.0.1', '::1'] +        for vrf in vrfs: +            # Ensure VRF was created +            self.assertIn(vrf, interfaces()) + +            # Verify VRF table ID +            tmp = get_interface_config(vrf) +            self.assertEqual(int(table), tmp['linkinfo']['info_data']['table']) + +            # Test for proper loopback IP assignment +            for addr in loopbacks: +                if is_ipv4(addr): +                    self.assertTrue(is_intf_addr_assigned(vrf, addr)) +                else: +                    self.assertFalse(is_intf_addr_assigned(vrf, addr)) + +            table = str(int(table) + 1) + +        self.cli_delete(['system', 'ipv6'])      def test_vrf_bind_all(self):          table = '2000' | 
