2.79. test_l2bd_multi_instance module¶
L2BD Multi-instance Test Case HLD:
- NOTES:
higher number of pg-l2 interfaces causes problems => only 15 pg-l2 interfaces in 5 bridge domains are tested
jumbo packets in configuration with 14 l2-pg interfaces leads to problems too
- config 1
add 15 pg-l2 interfaces
configure one host per pg-l2 interface
configure 5 bridge domains (BD)
add 3 pg-l2 interfaces per BD
- test 1
send L2 MAC frames between all pg-l2 interfaces of all BDs
- verify 1
check BD data by parsing output of bridge_domain_dump API command
all packets received correctly
- config 2
- update data of 5 BD
disable learning, forwarding, flooding and uu_flooding for BD1
disable forwarding for BD2
disable flooding for BD3
disable uu_flooding for BD4
disable learning for BD5
- verify 2
check BD data by parsing output of bridge_domain_dump API command
- config 3
delete 2 BDs
- test 3
send L2 MAC frames between all pg-l2 interfaces of all BDs
send L2 MAC frames between all pg-l2 interfaces formerly assigned to deleted BDs
- verify 3
check BD data by parsing output of bridge_domain_dump API command
all packets received correctly on all 3 pg-l2 interfaces assigned to BDs
no packet received on all 3 pg-l2 interfaces of all deleted BDs
- config 4
add 2 BDs
add 3 pg-l2 interfaces per BD
- test 4
send L2 MAC frames between all pg-l2 interfaces of all BDs
- verify 4
check BD data by parsing output of bridge_domain_dump API command
all packets received correctly
- config 5
delete 5 BDs
- verify 5
check BD data by parsing output of bridge_domain_dump API command
- class test_l2bd_multi_instance.TestL2bdMultiInst(methodName='runTest')¶
Bases:
framework.VppTestCase
L2BD Multi-instance Test Case
- classmethod bd_if_range(b)¶
- create_bd_and_mac_learn(count, start=1)¶
Create required number of bridge domains with MAC learning enabled, put 3 l2-pg interfaces to every bridge domain and send MAC learning packets.
- Parameters
count (int) – Number of bridge domains to be created.
start (int) – Starting number of the bridge domain ID. (Default value = 1)
- classmethod create_hosts(hosts_per_if)¶
Create required number of host MAC addresses and distribute them among interfaces. Create host IPv4 address for every host MAC address.
- Parameters
hosts_per_if (int) – Number of hosts per if to create MAC/IPv4 addresses for.
- create_stream(src_if)¶
Create input packet stream for defined interface using hosts list.
- Parameters
src_if (object) – Interface to create packet stream for.
packet_sizes (list) – List of required packet sizes.
- Returns
Stream of packets.
- delete_bd(count, start=1)¶
Delete required number of bridge domains.
- Parameters
count (int) – Number of bridge domains to be created.
start (int) – Starting number of the bridge domain ID. (Default value = 1)
- run_verify_test()¶
- Create packet streams for all configured l2-pg interfaces, send all prepared packet streams and verify that:
all packets received correctly on all pg-l2 interfaces assigned to bridge domains
no packet received on all pg-l2 interfaces not assigned to bridge domains
- Raises
RuntimeError – if no packet captured on l2-pg interface assigned to the bridge domain or if any packet is captured on l2-pg interface not assigned to the bridge domain.
- setUp()¶
Clear trace and packet infos before running each test.
- classmethod setUpClass()¶
Perform standard class setup (defined by class method setUpClass in class VppTestCase) before running the test case, set test case related variables and configure VPP.
- set_bd_flags(bd_id, **args)¶
Enable/disable defined feature(s) of the bridge domain.
- Parameters
bd_id (int) – Bridge domain ID.
args (list) – List of feature/status pairs. Allowed features: learn, forward, flood, uu_flood and arp_term. Status False means disable, status True means enable the feature.
- Raise
ValueError in case of unknown feature in the input.
- tearDown()¶
Show various debug prints after each test.
- classmethod tearDownClass()¶
Perform final cleanup after running all tests in this test-case
- test_l2bd_inst_01()¶
L2BD Multi-instance test 1 - create 5 BDs
- test_l2bd_inst_02()¶
L2BD Multi-instance test 2 - update data of 5 BDs
- test_l2bd_inst_03()¶
L2BD Multi-instance test 3 - delete 2 BDs
- test_l2bd_inst_04()¶
L2BD Multi-instance test 4 - add 2 BDs
- test_l2bd_inst_05()¶
L2BD Multi-instance test 5 - delete 5 BDs
- verify_bd(bd_id, **args)¶
Check if the bridge domain is configured and verify expected status of listed features.
- Parameters
bd_id (int) – Bridge domain ID.
args (list) – List of feature/status pairs. Allowed features: learn, forward, flood, uu_flood and arp_term. Status False means disable, status True means enable the feature.
- Returns
1 if bridge domain is configured, otherwise return 0.
- Raise
ValueError in case of unknown feature in the input.
- verify_capture(dst_if)¶
Verify captured input packet stream for defined interface.
- Parameters
dst_if (object) – Interface to verify captured packet stream for.