diff options
author | Jerome Tollet <jtollet@cisco.com> | 2020-12-15 09:21:45 +0100 |
---|---|---|
committer | Beno�t Ganne <bganne@cisco.com> | 2020-12-16 08:13:42 +0000 |
commit | 6cbb111086a9fd74330d95511bc551128e1539ef (patch) | |
tree | f91563a8cbfcb358b106dd7dbe60cd2c79d4847f /test/test_l2bd_learnlimit.py | |
parent | 58a6e7725212188dc993c2d6ac9fb149f33ed0db (diff) |
l2: add l2 learn limit tests
Add a couple of tests to check l2bd learn limit behaviour
Type: test
Signed-off-by: Jerome Tollet <jtollet@cisco.com>
Change-Id: Iee16c81e5bb41066e3d6446d0e6ea4f389241270
Diffstat (limited to 'test/test_l2bd_learnlimit.py')
-rw-r--r-- | test/test_l2bd_learnlimit.py | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/test/test_l2bd_learnlimit.py b/test/test_l2bd_learnlimit.py new file mode 100644 index 00000000000..6a28664e522 --- /dev/null +++ b/test/test_l2bd_learnlimit.py @@ -0,0 +1,119 @@ +#!/usr/bin/env python3 + +import unittest +import random + +from scapy.packet import Raw +from scapy.layers.l2 import Ether +from scapy.layers.inet import IP, UDP + +from framework import VppTestCase, VppTestRunner, running_extended_tests +from util import Host, ppp + + +class TestL2LearnLimit(VppTestCase): + """ L2 Learn limit Test Case """ + + @classmethod + def setUpClass(self): + super(TestL2LearnLimit, self).setUpClass() + self.create_pg_interfaces(range(2)) + + @classmethod + def tearDownClass(cls): + super(TestL2LearnLimit, cls).tearDownClass() + + def create_hosts(self, pg_if, n_hosts_per_if, subnet): + """ + Create required number of host MAC addresses and distribute them among + interfaces. Create host IPv4 address for every host MAC address. + + :param int n_hosts_per_if: Number of per interface hosts to + create MAC/IPv4 addresses for. + """ + + hosts = dict() + swif = pg_if.sw_if_index + + def mac(j): return "00:00:%02x:ff:%02x:%02x" % (subnet, swif, j) + + def ip(j): return "172.%02u.1%02x.%u" % (subnet, swif, j) + + def h(j): return Host(mac(j), ip(j)) + hosts[swif] = [h(j) for j in range(n_hosts_per_if)] + + return hosts + + def learn_hosts(self, pg_if, bd_id, hosts): + """ + Create and send per interface L2 MAC broadcast packet stream to + let the bridge domain learn these MAC addresses. + + :param int bd_id: BD to teach + :param dict hosts: dict of hosts per interface + """ + + self.vapi.bridge_flags(bd_id=bd_id, is_set=1, flags=1) + + swif = pg_if.sw_if_index + packets = [Ether(dst="ff:ff:ff:ff:ff:ff", src=host.mac) + for host in hosts[swif]] + pg_if.add_stream(packets) + self.logger.info("Sending broadcast eth frames for MAC learning") + self.pg_start() + + def test_l2bd_learnlimit01(self): + """ L2BD test without learn Limit + """ + hosts = self.create_hosts(self.pg_interfaces[0], 20, 1) + self.learn_hosts(self.pg_interfaces[0], 1, hosts) + lfs = self.vapi.l2_fib_table_dump(1) + + # check that 20 macs are learned. + self.assertEqual(len(lfs), 20) + + def test_l2bd_learnlimit02(self): + """ L2BD test with learn Limit + """ + self.vapi.want_l2_macs_events(enable_disable=1, learn_limit=10) + hosts = self.create_hosts(self.pg_interfaces[0], 20, 1) + fhosts = self.create_hosts(self.pg_interfaces[1], 1, 2) + + # inject 20 mac addresses on bd1 + self.learn_hosts(self.pg_interfaces[0], 1, hosts) + + # inject 1 mac address on bd2 + self.learn_hosts(self.pg_interfaces[1], 2, fhosts) + + lfs1 = self.vapi.l2_fib_table_dump(1) + lfs2 = self.vapi.l2_fib_table_dump(2) + + # check that only 10 macs are learned. + self.assertEqual(len(lfs1), 10) + + # check that bd2 was not able to learn + self.assertEqual(len(lfs2), 0) + + def setUp(self): + super(TestL2LearnLimit, self).setUp() + + self.vapi.bridge_domain_add_del(bd_id=1) + self.vapi.bridge_domain_add_del(bd_id=2) + + self.vapi.sw_interface_set_l2_bridge( + self.pg_interfaces[0].sw_if_index, bd_id=1) + self.vapi.sw_interface_set_l2_bridge( + self.pg_interfaces[1].sw_if_index, bd_id=2) + + def tearDown(self): + for i in self.pg_interfaces[:2]: + self.vapi.sw_interface_set_l2_bridge(rx_sw_if_index=i.sw_if_index, + bd_id=1, enable=0) + self.vapi.bridge_domain_add_del(bd_id=1, is_add=0) + self.vapi.bridge_domain_add_del(bd_id=2, is_add=0) + + super(TestL2LearnLimit, self).tearDown() + + +if __name__ == '__main__': + unittest.main(testRunner=VppTestRunner) |