[V2] tests/ntb: add support host and client pic list option in launch_ntb_fwd()

Message ID 20230629083752.632829-1-weix.ling@intel.com (mailing list archive)
State New
Headers
Series [V2] tests/ntb: add support host and client pic list option in launch_ntb_fwd() |

Checks

Context Check Description
ci/Intel-dts-format-test success Testing OK
ci/Intel-dts-pylama-test success Testing OK
ci/Intel-dts-suite-test warning SKIPPED

Commit Message

Ling, WeiX June 29, 2023, 8:37 a.m. UTC
1.TestCase 1 and 2 only need NTB pci, but testcase 3 need NTB pci and
  NIC pci to start dpdk-ntb app, so modify the launch_ntb_fwd() function
  to support host_ports and client_ports option.

2.Optimize the send_file_and_verify() to check the print info after
  execute `ntb> send /tmp/ntb.txt` command on host ntb server and client
  ntb server to verify the send and receive file sucessed or not.

Signed-off-by: Wei Ling <weix.ling@intel.com>
---
v1: 
   1)Add support host and client pic list option in launch_ntb_fwd()
     function.
   2)Optimize the send_file_and_verify() to check the print info.

v2:
   1)Add `-- -i ` to enter the interactive mode when start dpdk-ntb
     in testsuite sync with testplan.
   2)Add `--` before params, such as `--buf-size=65407` `--burst=32`
     in testsuite sync with testplan.

 tests/TestSuite_ntb.py | 57 ++++++++++++++++++++++++++++++++----------
 1 file changed, 44 insertions(+), 13 deletions(-)
  

Patch

diff --git a/tests/TestSuite_ntb.py b/tests/TestSuite_ntb.py
index 38d36689..72121ebd 100644
--- a/tests/TestSuite_ntb.py
+++ b/tests/TestSuite_ntb.py
@@ -114,19 +114,21 @@  class TestNtb(TestCase):
         ntb = self.get_ntb_port(self.ntb_client)
         ntb.bind_driver(driver)
 
-    def launch_ntb_fwd(self, **param):
+    def launch_ntb_fwd(self, host_ports, client_ports, **param):
         """
         launch ntb_fwd on ntb host and ntb client
         """
-        cmd_opt = " ".join(["{}={}".format(key, param[key]) for key in param.keys()])
+        cmd_opt = "-- -i " + " ".join(
+            ["--{}={}".format(key, param[key]) for key in param.keys()]
+        )
 
         self.get_core_list()
         app = self.dut.apps_name["ntb"]
         eal_host = self.ntb_host.create_eal_parameters(
-            cores=self.host_core_list, ports=[self.get_ntb_port(self.ntb_host).pci]
+            cores=self.host_core_list, ports=host_ports
         )
         eal_client = self.ntb_client.create_eal_parameters(
-            cores=self.client_core_list, ports=[self.get_ntb_port(self.ntb_client).pci]
+            cores=self.client_core_list, ports=client_ports
         )
         host_cmd_line = " ".join([app, eal_host, cmd_opt])
         client_cmd_line = " ".join([app, eal_client, cmd_opt])
@@ -219,17 +221,34 @@  class TestNtb(TestCase):
         src_file = "{}/ntb.txt".format(self.out_path)
         base_dir = self.ntb_client.base_dir.replace("~", "/root")
         dst_file = "{}/ntb_recv_file0".format(base_dir)
-        content = "ntb!123"
+        host_content = "ntb!123"
         self.ntb_client.alt_session.send_expect("rm {}".format(dst_file), "# ")
         self.ntb_host.alt_session.send_expect(
-            "echo '{}' >{}".format(content, src_file), "# "
+            "echo '{}' >{}".format(host_content, src_file), "# "
         )
-        self.ntb_host.send_expect("send {}".format(src_file), "ntb> ", 30)
-        time.sleep(3)
+        # check the print info after send file on NTB host server
+        host_out = self.ntb_host.send_expect("send {}".format(src_file), "ntb> ", 30)
+        host_reg = (
+            "send {}\r\r\nSending file, size is \d+\r\nDone sending file.".format(
+                src_file
+            )
+        )
+        host_info = re.findall(host_reg, host_out)
+        self.verify(len(host_info) == 1, "Send File FAILED!")
+
+        # check the print info after send file on NTB client server
+        client_out = self.ntb_client.get_session_output()
+        client_reg = " Received file \(size: \d+\) from peer to ntb_recv_file0.\r\n"
+        client_info = re.findall(client_reg, client_out)
+        self.verify(len(client_info) == 1, "Recieve File FAILED!")
 
         # Check file received on client.
-        cnt = self.ntb_client.alt_session.send_expect("cat %s" % dst_file, "# ")
-        self.verify(cnt == content, "the content can't match with the sent")
+        client_content = self.ntb_client.alt_session.send_expect(
+            "cat %s" % dst_file, "# "
+        )
+        self.verify(
+            client_content == host_content, "the content can't match with the sent"
+        )
 
     def send_pkg_and_verify(self):
         for frame_size in self.frame_sizes:
@@ -255,7 +274,9 @@  class TestNtb(TestCase):
         self.set_driver(driver)
         self.ntb_bind_driver(driver)
 
-        self.launch_ntb_fwd(**{"buf-size": 65407})
+        host_ports = [self.get_ntb_port(self.ntb_host).pci]
+        client_ports = [self.get_ntb_port(self.ntb_client).pci]
+        self.launch_ntb_fwd(host_ports, client_ports, **{"buf-size": 65407})
         self.start_ntb_fwd_on_dut(self.ntb_host, fwd_mode="file-trans")
         self.start_ntb_fwd_on_dut(self.ntb_client, fwd_mode="file-trans")
         self.send_file_and_verify()
@@ -265,7 +286,9 @@  class TestNtb(TestCase):
         self.set_driver(driver)
         self.ntb_bind_driver(driver)
 
-        self.launch_ntb_fwd(**{"buf-size": 65407})
+        host_ports = [self.get_ntb_port(self.ntb_host).pci]
+        client_ports = [self.get_ntb_port(self.ntb_client).pci]
+        self.launch_ntb_fwd(host_ports, client_ports, **{"buf-size": 65407})
         self.start_ntb_fwd_on_dut(self.ntb_host, fwd_mode="rxonly")
         self.start_ntb_fwd_on_dut(self.ntb_client, fwd_mode="txonly")
         time.sleep(1)
@@ -278,7 +301,15 @@  class TestNtb(TestCase):
         self.port_bind_driver(driver)
 
         self.create_table()
-        self.launch_ntb_fwd(**{"burst": 32})
+        host_ports = [
+            self.get_ntb_port(self.ntb_host).pci,
+            self.ntb_host.ports_info[0]["pci"],
+        ]
+        client_ports = [
+            self.get_ntb_port(self.ntb_client).pci,
+            self.ntb_client.ports_info[0]["pci"],
+        ]
+        self.launch_ntb_fwd(host_ports, client_ports, **{"burst": 32})
         self.start_ntb_fwd_on_dut(self.ntb_host, fwd_mode="iofwd")
         self.start_ntb_fwd_on_dut(self.ntb_client, fwd_mode="iofwd")
         self.send_pkg_and_verify()