diff options
| author | Christian Breunig <christian@breunig.cc> | 2024-12-18 19:35:11 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-12-18 19:35:11 +0100 | 
| commit | 90773748365e7ba1447f39b67fbe4e2f0862f084 (patch) | |
| tree | 1de85dcd97ba53da73af311e96cfc02a5413c637 /smoketest/scripts/cli/test_qos.py | |
| parent | 60743702bf2f2c4bdbf7402baa4e66a1e4f8ec38 (diff) | |
| parent | f2b346c5391651cc38f870304ce9117c72c123bf (diff) | |
| download | vyos-1x-90773748365e7ba1447f39b67fbe4e2f0862f084.tar.gz vyos-1x-90773748365e7ba1447f39b67fbe4e2f0862f084.zip | |
Merge pull request #4223 from HollyGurza/T6874
T6874: [QoS] Add class filter by ether
Diffstat (limited to 'smoketest/scripts/cli/test_qos.py')
| -rwxr-xr-x | smoketest/scripts/cli/test_qos.py | 66 | 
1 files changed, 66 insertions, 0 deletions
| diff --git a/smoketest/scripts/cli/test_qos.py b/smoketest/scripts/cli/test_qos.py index 7714cd3e0..231743344 100755 --- a/smoketest/scripts/cli/test_qos.py +++ b/smoketest/scripts/cli/test_qos.py @@ -1237,6 +1237,72 @@ class TestQoS(VyOSUnitTestSHIM.TestCase):          self.assertIn('filter parent ffff: protocol all pref 255 basic chain 0', tc_filters)          self.assertIn('action order 1:  police 0x2 rate 1Gbit burst 125000000b mtu 2Kb action drop overhead 0b', tc_filters) +    def test_24_policy_shaper_match_ether(self): +        interface = self._interfaces[0] +        bandwidth = 250 +        default_bandwidth = 20 +        default_ceil = 30 +        class_bandwidth = 50 +        class_ceil = 80 + +        shaper_name = f'qos-shaper-{interface}' + +        self.cli_set(base_path + ['interface', interface, 'egress', shaper_name]) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'bandwidth', f'{bandwidth}mbit']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'default', 'bandwidth', f'{default_bandwidth}mbit']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'default', 'ceiling', f'{default_ceil}mbit']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'default', 'queue-type', 'fair-queue']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'class', '23', 'bandwidth', f'{class_bandwidth}mbit']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'class', '23', 'ceiling', f'{class_ceil}mbit']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'class', '23', 'match', '10', 'ether', 'protocol', 'all']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'class', '23', 'match', '10', 'ether', 'destination', '0c:89:0a:2e:00:00']) +        self.cli_set(base_path + ['policy', 'shaper', shaper_name, 'class', '23', 'match', '10', 'ether', 'source', '0c:89:0a:2e:00:01']) + +        # commit changes +        self.cli_commit() + +        config_entries = ( +            f'root rate {bandwidth}Mbit ceil {bandwidth}Mbit', +            f'prio 0 rate {class_bandwidth}Mbit ceil {class_ceil}Mbit', +            f'prio 7 rate {default_bandwidth}Mbit ceil {default_ceil}Mbit' +        ) + +        output = cmd(f'tc class show dev {interface}') + +        for config_entry in config_entries: +            self.assertIn(config_entry, output) + +        filter = get_tc_filter_details(interface) +        self.assertIn('match 0c890a2e/ffffffff at -8', filter) +        self.assertIn('match 00010000/ffff0000 at -4', filter) +        self.assertIn('match 00000c89/0000ffff at -16', filter) +        self.assertIn('match 0a2e0000/ffffffff at -12', filter) + +        for proto in ['802.1Q', '802_2', '802_3', 'aarp', 'aoe', 'arp', 'atalk', +                      'dec', 'ip', 'ipv6', 'ipx', 'lat', 'localtalk', 'rarp', +                      'snap', 'x25', 1, 255, 65535]: +            self.cli_set( +                base_path + ['policy', 'shaper', shaper_name, 'class', '23', +                             'match', '10', 'ether', 'protocol', str(proto)]) +            self.cli_commit() + +            if isinstance(proto, int): +                if proto == 1: +                    self.assertIn(f'filter parent 1: protocol 802_3 pref', +                                  get_tc_filter_details(interface)) +                else: +                    self.assertIn(f'filter parent 1: protocol [{proto}] pref', +                                  get_tc_filter_details(interface)) + +            elif proto == '0x000C': +                # see other codes in the iproute2 eg https://github.com/iproute2/iproute2/blob/413cf4f03a9b6a219c94b86f41d67992b0a14b82/include/uapi/linux/if_ether.h#L130 +                self.assertIn(f'filter parent 1: protocol can pref', +                              get_tc_filter_details(interface)) + +            else: +                self.assertIn(f'filter parent 1: protocol {proto} pref', +                              get_tc_filter_details(interface)) +  if __name__ == '__main__':      unittest.main(verbosity=2) | 
