diff options
| author | Christian Breunig <christian@breunig.cc> | 2023-10-03 20:51:21 +0200 | 
|---|---|---|
| committer | Christian Breunig <christian@breunig.cc> | 2023-10-03 21:05:20 +0200 | 
| commit | e357258e645cf85de0035d4ecfbf99db4dd90f7e (patch) | |
| tree | 84651d28202e8c6abb4de5b4783bd2f3293902df | |
| parent | e062a8c11856f213983f5b41f50d4f9dbc0dde0f (diff) | |
| download | vyos-1x-e357258e645cf85de0035d4ecfbf99db4dd90f7e.tar.gz vyos-1x-e357258e645cf85de0035d4ecfbf99db4dd90f7e.zip | |
pppoe: T5630: verify MRU is less or equal then MTU
| -rwxr-xr-x | smoketest/scripts/cli/test_interfaces_pppoe.py | 7 | ||||
| -rwxr-xr-x | src/conf_mode/interfaces-pppoe.py | 5 | 
2 files changed, 11 insertions, 1 deletions
| diff --git a/smoketest/scripts/cli/test_interfaces_pppoe.py b/smoketest/scripts/cli/test_interfaces_pppoe.py index 0685833fb..7b702759f 100755 --- a/smoketest/scripts/cli/test_interfaces_pppoe.py +++ b/smoketest/scripts/cli/test_interfaces_pppoe.py @@ -64,7 +64,7 @@ class PPPoEInterfaceTest(VyOSUnitTestSHIM.TestCase):              self.cli_set(base_path + [interface, 'authentication', 'username', user])              self.cli_set(base_path + [interface, 'authentication', 'password', passwd])              self.cli_set(base_path + [interface, 'mtu', mtu]) -            self.cli_set(base_path + [interface, 'mru', mru]) +            self.cli_set(base_path + [interface, 'mru', '9000'])              self.cli_set(base_path + [interface, 'no-peer-dns'])              # check validate() - a source-interface is required @@ -72,6 +72,11 @@ class PPPoEInterfaceTest(VyOSUnitTestSHIM.TestCase):                  self.cli_commit()              self.cli_set(base_path + [interface, 'source-interface', self._source_interface]) +            # check validate() - MRU needs to be less or equal then MTU +            with self.assertRaises(ConfigSessionError): +                self.cli_commit() +            self.cli_set(base_path + [interface, 'mru', mru]) +          # commit changes          self.cli_commit() diff --git a/src/conf_mode/interfaces-pppoe.py b/src/conf_mode/interfaces-pppoe.py index fca91253c..0a03a172c 100755 --- a/src/conf_mode/interfaces-pppoe.py +++ b/src/conf_mode/interfaces-pppoe.py @@ -77,6 +77,11 @@ def verify(pppoe):      if {'connect_on_demand', 'vrf'} <= set(pppoe):          raise ConfigError('On-demand dialing and VRF can not be used at the same time') +    # both MTU and MRU have default values, thus we do not need to check +    # if the key exists +    if int(pppoe['mru']) > int(pppoe['mtu']): +        raise ConfigError('PPPoE MRU needs to be lower then MTU!') +      return None  def generate(pppoe): | 
