DPDK patches and discussions
 help / color / mirror / Atom feed
* [PATCH] dts: add l2fwd test suite
@ 2024-08-06 12:51 Luca Vizzarro
  2024-08-09 15:27 ` Jeremy Spewock
                   ` (7 more replies)
  0 siblings, 8 replies; 28+ messages in thread
From: Luca Vizzarro @ 2024-08-06 12:51 UTC (permalink / raw)
  To: dev
  Cc: Jeremy Spewock, Juraj Linkeš,
	Honnappa Nagarahalli, Luca Vizzarro, Paul Szczepanek

Add a basic L2 forwarding test suite which tests the correct
functionality of the forwarding facility built-in in the DPDK.

The tests are performed with different queues numbers per port.

Bugzilla ID: 1481

Signed-off-by: Luca Vizzarro <luca.vizzarro@arm.com>
Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
---
Depends-on: series-32714 ("dts: add pktgen and testpmd changes")
---
 dts/framework/config/conf_yaml_schema.json |  3 +-
 dts/tests/TestSuite_l2fwd.py               | 58 ++++++++++++++++++++++
 2 files changed, 60 insertions(+), 1 deletion(-)
 create mode 100644 dts/tests/TestSuite_l2fwd.py

diff --git a/dts/framework/config/conf_yaml_schema.json b/dts/framework/config/conf_yaml_schema.json
index df390e8ae2..58a719a923 100644
--- a/dts/framework/config/conf_yaml_schema.json
+++ b/dts/framework/config/conf_yaml_schema.json
@@ -187,7 +187,8 @@
       "enum": [
         "hello_world",
         "os_udp",
-        "pmd_buffer_scatter"
+        "pmd_buffer_scatter",
+        "l2fwd"
       ]
     },
     "test_target": {
diff --git a/dts/tests/TestSuite_l2fwd.py b/dts/tests/TestSuite_l2fwd.py
new file mode 100644
index 0000000000..46f07b78eb
--- /dev/null
+++ b/dts/tests/TestSuite_l2fwd.py
@@ -0,0 +1,58 @@
+"""Basic L2 forwarding test suite.
+
+This testing suites runs basic L2 forwarding on testpmd with different queue sizes per port.
+The forwarding test is performed with several packets being sent at once.
+"""
+
+from framework.params.testpmd import EthPeer, SimpleForwardingModes
+from framework.remote_session.testpmd_shell import TestPmdShell
+from framework.test_suite import TestSuite
+from framework.testbed_model.cpu import LogicalCoreCount
+from framework.utils import generate_random_packets
+
+
+class TestL2fwd(TestSuite):
+    """L2 forwarding test suite."""
+
+    #: The total number of packets to generate and send for forwarding.
+    NUMBER_OF_PACKETS_TO_SEND = 50
+    #: The payload size to use for the generated packets in bytes.
+    PAYLOAD_SIZE = 100
+
+    def set_up_suite(self) -> None:
+        """Set up the test suite.
+
+        Setup:
+            Verify that we have at least 2 ports in the current test. Generate the random packets
+            that will be sent and spawn a reusable testpmd shell.
+        """
+        self.verify(len(self.sut_node.ports) >= 2, "At least 2 ports are required for this test.")
+        self.packets = generate_random_packets(self.NUMBER_OF_PACKETS_TO_SEND, self.PAYLOAD_SIZE)
+
+    def test_l2fwd_integrity(self) -> None:
+        """Test the L2 forwarding integrity.
+
+        Test:
+            Configure a testpmd shell with a different numbers of queues per run. Start up L2
+            forwarding, send random packets from the TG and verify they were all received back.
+        """
+        queues = [1, 2, 4, 8]
+
+        with TestPmdShell(
+            self.sut_node,
+            lcore_filter_specifier=LogicalCoreCount(cores_per_socket=4),
+            forward_mode=SimpleForwardingModes.mac,
+            eth_peer=[EthPeer(1, self.tg_node.ports[1].mac_address)],
+            disable_device_start=True,
+        ) as shell:
+            for queues_num in queues:
+                self._logger.info(f"Testing L2 forwarding with {queues_num} queue(s)")
+                shell.set_ports_queues(queues_num)
+                shell.start()
+
+                received_packets = self.send_packets_and_capture(self.packets)
+
+                expected_packets = [self.get_expected_packet(packet) for packet in self.packets]
+                self.match_all_packets(expected_packets, received_packets)
+
+                shell.stop()
-- 
2.34.1


^ permalink raw reply	[flat|nested] 28+ messages in thread

end of thread, other threads:[~2024-11-13 20:01 UTC | newest]

Thread overview: 28+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-08-06 12:51 [PATCH] dts: add l2fwd test suite Luca Vizzarro
2024-08-09 15:27 ` Jeremy Spewock
2024-09-09 10:44   ` Luca Vizzarro
2024-09-04 18:11 ` Dean Marx
2024-09-09 15:05 ` Patrick Robb
2024-09-09 17:54 ` Nicholas Pratte
2024-10-30 15:03 ` [PATCH v2] " Thomas Wilks
2024-11-08 17:01 ` [PATCH v3 0/3] " Luca Vizzarro
2024-11-08 17:01   ` [PATCH v3 1/3] dts: fix adjust L2/L3 addresses behavior Luca Vizzarro
2024-11-12 17:11     ` Dean Marx
2024-11-13 15:36     ` Patrick Robb
2024-11-08 17:01   ` [PATCH v3 2/3] dts: allow to get multiple expected packets Luca Vizzarro
2024-11-12 17:16     ` Dean Marx
2024-11-13 15:36     ` Patrick Robb
2024-11-08 17:01   ` [PATCH v3 3/3] dts: add l2fwd test suite Luca Vizzarro
2024-11-13 15:37     ` Patrick Robb
2024-11-13 16:25 ` [PATCH v4 0/3] " Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 1/3] dts: allow to get multiple expected packets Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 1/3] dts: fix adjust L2/L3 addresses behavior Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 2/3] dts: add l2fwd test suite Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 2/3] dts: allow to get multiple expected packets Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 3/3] dts: add l2fwd test suite Luca Vizzarro
2024-11-13 16:25   ` [PATCH v4 3/3] fixup! dts: allow to get multiple expected packets Luca Vizzarro
2024-11-13 16:31 ` [PATCH v5 0/3] dts: add l2fwd test suite Luca Vizzarro
2024-11-13 16:31   ` [PATCH v5 1/3] dts: fix adjust L2/L3 addresses behavior Luca Vizzarro
2024-11-13 16:31   ` [PATCH v5 2/3] dts: allow to get multiple expected packets Luca Vizzarro
2024-11-13 16:31   ` [PATCH v5 3/3] dts: add l2fwd test suite Luca Vizzarro
2024-11-13 19:59     ` Patrick Robb

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).