2.51. test_l2_fib module¶
L2 FIB Test Case HLD:
- config 1
- add 4 pg-l2 interfaces
- configure them into l2bd
- configure 100 MAC entries in L2 fib - 25 MACs per interface
- L2 MAC learning and unknown unicast flooding disabled in l2bd
- configure 100 MAC entries in L2 fib - 25 MACs per interface
- test 1
- send L2 MAC frames between all 4 pg-l2 interfaces for all of 100 MAC entries in the FIB
- verify 1
- all packets received correctly
- config 2
- delete 12 MAC entries - 3 MACs per interface
- test 2a
- send L2 MAC frames between all 4 pg-l2 interfaces for non-deleted MAC entries
- verify 2a
- all packets received correctly
- test 2b
- send L2 MAC frames between all 4 pg-l2 interfaces for all of 12 deleted MAC entries
- verify 2b
- no packet received on all 4 pg-l2 interfaces
- config 3
- configure new 100 MAC entries in L2 fib - 25 MACs per interface
- test 3
- send L2 MAC frames between all 4 pg-l2 interfaces for all of 188 MAC entries in the FIB
- verify 3
- all packets received correctly
- config 4
- delete 160 MAC entries, 40 MACs per interface
- test 4a
- send L2 MAC frames between all 4 pg-l2 interfaces for all of 28 non-deleted MAC entries
- verify 4a
- all packets received correctly
- test 4b
- try send L2 MAC frames between all 4 pg-l2 interfaces for all of 172 deleted MAC entries
- verify 4b
- no packet received on all 4 pg-l2 interfaces
-
class
test_l2_fib.
TestL2fib
(methodName='runTest')¶ Bases:
framework.VppTestCase
L2 FIB Test Case
-
classmethod
bd_ifs
(bd_id)¶
-
config_l2_fib_entries
(bd_id, hosts)¶ Config required number of L2 FIB entries.
Parameters: - bd_id (int) – BD’s id
- count (int) – Number of L2 FIB entries to be created.
- start (int) – Starting index of the host list. (Default value = 0)
-
create_hosts
(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.
Parameters: n_hosts_per_if (int) – Number of per interface hosts to create MAC/IPv4 addresses for.
-
create_stream
(src_if, packet_sizes, if_src_hosts, if_dst_hosts)¶ Create input packet stream for defined interface using hosts or deleted_hosts list.
Parameters: - src_if (object) – Interface to create packet stream for.
- packet_sizes (list) – List of required packet sizes.
- deleted (boolean) – Set to True if deleted_hosts list required.
Returns: Stream of packets.
-
delete_l2_fib_entry
(bd_id, hosts)¶ Delete required number of L2 FIB entries.
Parameters: count (int) – Number of L2 FIB entries to be created.
-
flush_all
()¶ Flush All L2 FIB entries.
-
flush_bd
(bd_id, learned_hosts)¶ Flush bd_id L2 FIB entries.
Parameters: bd_id (int) – Bridge Domain id.
-
flush_int
(swif, learned_hosts)¶ Flush swif L2 FIB entries.
Parameters: swif (int) – sw if index.
-
learn_hosts
(bd_id, hosts)¶ Create and send per interface L2 MAC broadcast packet stream to let the bridge domain learn these MAC addresses.
Parameters: - bd_id (int) – BD to teach
- hosts (dict) – dict of hosts per interface
-
run_verify_negat_test
(bd_id, src_hosts, dst_hosts)¶
-
run_verify_test
(bd_id, src_hosts, dst_hosts)¶
-
setUp
()¶ Clear trace 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.
Variables: bd_id (int) – Bridge domain ID.
-
split_hosts
(hosts, n)¶
-
tearDown
()¶ Show various debug prints after each test.
-
test_l2_fib_add100_add100
()¶ L2 FIB - program 100 + 100 MACs
-
test_l2_fib_delete12
()¶ L2 FIB - program 100 + delete 12 MACs
-
test_l2_fib_flush_all
()¶ L2 FIB - flush all
-
test_l2_fib_flush_bd
()¶ L2 FIB - flush BD
-
test_l2_fib_flush_int
()¶ L2 FIB - flush interface
-
test_l2_fib_mac_learn_evs
()¶ L2 FIB - mac learning events
-
test_l2_fib_macs_learn_max
()¶ L2 FIB - mac learning max macs in event
-
test_l2_fib_program100
()¶ L2 FIB - program 100 MACs
-
test_l2_fib_program10_learn10
()¶ L2 FIB - Program 10 MACs, learn 10
-
verify_capture
(pg_if, capture)¶ Verify captured input packet stream for defined interface.
Parameters: - pg_if (object) – Interface to verify captured packet stream for.
- capture (list) – Captured packet stream.
-
classmethod