DPDK patches and discussions
 help / color / mirror / Atom feed
* [PATCH v1 0/1] dts: add EAL sanity check suite
@ 2024-12-09 21:54 Dean Marx
  2024-12-09 21:54 ` [PATCH v1 1/1] " Dean Marx
  0 siblings, 1 reply; 15+ messages in thread
From: Dean Marx @ 2024-12-09 21:54 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Adds a test suite to DTS which the user can have as
a sanity check for their EAL configuration. This can
be used as a replacement for the hello_world suite.

Dean Marx (1):
  dts: add EAL sanity check suite

 dts/tests/TestSuite_eal.py | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)
 create mode 100644 dts/tests/TestSuite_eal.py

-- 
2.44.0


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

* [PATCH v1 1/1] dts: add EAL sanity check suite
  2024-12-09 21:54 [PATCH v1 0/1] dts: add EAL sanity check suite Dean Marx
@ 2024-12-09 21:54 ` Dean Marx
  2024-12-20 15:49   ` Paul Szczepanek
  2024-12-23 18:57   ` [PATCH v2 1/1] dts: add EAL confidence " Dean Marx
  0 siblings, 2 replies; 15+ messages in thread
From: Dean Marx @ 2024-12-09 21:54 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Add a test suite to replace hello_world which simply
starts and stops a testpmd session. The user can use
this as a sanity check to verify their configuration.

Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
---
 dts/tests/TestSuite_eal.py | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)
 create mode 100644 dts/tests/TestSuite_eal.py

diff --git a/dts/tests/TestSuite_eal.py b/dts/tests/TestSuite_eal.py
new file mode 100644
index 0000000000..35660178f0
--- /dev/null
+++ b/dts/tests/TestSuite_eal.py
@@ -0,0 +1,28 @@
+# SPDX-License-Identifier: BSD-3-Clause
+# Copyright(c) 2024 University of New Hampshire
+
+"""DPDK EAL sanity check suite.
+
+Starts and stops a testpmd session to verify EAL parameters
+are properly configured.
+"""
+
+from framework.remote_session.testpmd_shell import TestPmdShell
+from framework.test_suite import TestSuite, func_test
+
+
+class TestEal(TestSuite):
+    """EAL test suite. One test case, which starts and stops a testpmd session."""
+
+    @func_test
+    def test_verify_eal(self) -> None:
+        """EAL sanity test.
+
+        Steps:
+            Start testpmd session and check status.
+        Verify:
+            The testpmd session is alive after starting.
+        """
+        with TestPmdShell(node=self.sut_node) as testpmd:
+            testpmd.start()
+            self.verify(True, "True")
-- 
2.44.0


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

* Re: [PATCH v1 1/1] dts: add EAL sanity check suite
  2024-12-09 21:54 ` [PATCH v1 1/1] " Dean Marx
@ 2024-12-20 15:49   ` Paul Szczepanek
  2024-12-20 16:21     ` Stephen Hemminger
  2024-12-23 18:57   ` [PATCH v2 1/1] dts: add EAL confidence " Dean Marx
  1 sibling, 1 reply; 15+ messages in thread
From: Paul Szczepanek @ 2024-12-20 15:49 UTC (permalink / raw)
  To: Dean Marx, probb, npratte, luca.vizzarro, yoan.picchi,
	Honnappa.Nagarahalli
  Cc: nd, dev



On 09/12/2024 21:54, Dean Marx wrote:
> Add a test suite to replace hello_world which simply
> starts and stops a testpmd session. The user can use
> this as a sanity check to verify their configuration.
> 
> Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
> ---
>  dts/tests/TestSuite_eal.py | 28 ++++++++++++++++++++++++++++
>  1 file changed, 28 insertions(+)
>  create mode 100644 dts/tests/TestSuite_eal.py
> 
> diff --git a/dts/tests/TestSuite_eal.py b/dts/tests/TestSuite_eal.py
> new file mode 100644
> index 0000000000..35660178f0
> --- /dev/null
> +++ b/dts/tests/TestSuite_eal.py
> @@ -0,0 +1,28 @@
> +# SPDX-License-Identifier: BSD-3-Clause
> +# Copyright(c) 2024 University of New Hampshire
> +
> +"""DPDK EAL sanity check suite.
> +
> +Starts and stops a testpmd session to verify EAL parameters
> +are properly configured.
> +"""
> +
> +from framework.remote_session.testpmd_shell import TestPmdShell
> +from framework.test_suite import TestSuite, func_test
> +
> +
> +class TestEal(TestSuite):
> +    """EAL test suite. One test case, which starts and stops a testpmd session."""
> +
> +    @func_test
> +    def test_verify_eal(self) -> None:
> +        """EAL sanity test.
> +
> +        Steps:
> +            Start testpmd session and check status.
> +        Verify:
> +            The testpmd session is alive after starting.
> +        """
> +        with TestPmdShell(node=self.sut_node) as testpmd:
> +            testpmd.start()
> +            self.verify(True, "True")

Not sure the self.verify(True, "True") is needed.

Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>

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

* Re: [PATCH v1 1/1] dts: add EAL sanity check suite
  2024-12-20 15:49   ` Paul Szczepanek
@ 2024-12-20 16:21     ` Stephen Hemminger
  0 siblings, 0 replies; 15+ messages in thread
From: Stephen Hemminger @ 2024-12-20 16:21 UTC (permalink / raw)
  To: Paul Szczepanek
  Cc: Dean Marx, probb, npratte, luca.vizzarro, yoan.picchi,
	Honnappa.Nagarahalli, nd, dev

On Fri, 20 Dec 2024 15:49:10 +0000
Paul Szczepanek <paul.szczepanek@arm.com> wrote:

> On 09/12/2024 21:54, Dean Marx wrote:
> > Add a test suite to replace hello_world which simply
> > starts and stops a testpmd session. The user can use
> > this as a sanity check to verify their configuration.
> > 
> > Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
> > ---
> >  dts/tests/TestSuite_eal.py | 28 ++++++++++++++++++++++++++++
> >  1 file changed, 28 insertions(+)
> >  create mode 100644 dts/tests/TestSuite_eal.py
> > 
> > diff --git a/dts/tests/TestSuite_eal.py b/dts/tests/TestSuite_eal.py
> > new file mode 100644
> > index 0000000000..35660178f0
> > --- /dev/null
> > +++ b/dts/tests/TestSuite_eal.py
> > @@ -0,0 +1,28 @@
> > +# SPDX-License-Identifier: BSD-3-Clause
> > +# Copyright(c) 2024 University of New Hampshire
> > +
> > +"""DPDK EAL sanity check suite.

Do not use the term "sanity check".

https://inclusivenaming.org/word-lists/tier-2/sanity-check/

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

* Re: [PATCH v2 1/1] dts: add EAL confidence check suite
  2024-12-23 18:57   ` [PATCH v2 1/1] dts: add EAL confidence " Dean Marx
@ 2024-12-23 18:50     ` Patrick Robb
  2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
  1 sibling, 0 replies; 15+ messages in thread
From: Patrick Robb @ 2024-12-23 18:50 UTC (permalink / raw)
  To: Dean Marx
  Cc: npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek, dev

[-- Attachment #1: Type: text/plain, Size: 1863 bytes --]

Hey Dean,

I would retain the hello world name if I were you, in place of "eal" as you
use here. I don't want to give off the impression that we are testing EAL
in some intentional way, as opposed to providing a reference testsuite.

On Mon, Dec 23, 2024 at 12:56 PM Dean Marx <dmarx@iol.unh.edu> wrote:

> Add a test suite to replace hello_world which simply
> starts and stops a testpmd session. The user can use
> this as a confidence check to verify their configuration.
>
> Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
> ---
>  dts/tests/TestSuite_eal.py | 27 +++++++++++++++++++++++++++
>  1 file changed, 27 insertions(+)
>  create mode 100644 dts/tests/TestSuite_eal.py
>
> diff --git a/dts/tests/TestSuite_eal.py b/dts/tests/TestSuite_eal.py
> new file mode 100644
> index 0000000000..7cf96e61cd
> --- /dev/null
> +++ b/dts/tests/TestSuite_eal.py
> @@ -0,0 +1,27 @@
> +# SPDX-License-Identifier: BSD-3-Clause
> +# Copyright(c) 2024 University of New Hampshire
> +
> +"""DPDK EAL confidence check suite.
> +
> +Starts and stops a testpmd session to verify EAL parameters
> +are properly configured.
> +"""
> +
> +from framework.remote_session.testpmd_shell import TestPmdShell
> +from framework.test_suite import TestSuite, func_test
> +
> +
> +class TestEal(TestSuite):
> +    """EAL test suite. One test case, which starts and stops a testpmd
> session."""
> +
> +    @func_test
> +    def test_verify_eal(self) -> None:
> +        """EAL confidence test.
> +
> +        Steps:
> +            Start testpmd session and check status.
> +        Verify:
> +            The testpmd session is alive after starting.
> +        """
> +        with TestPmdShell(node=self.sut_node) as testpmd:
> +            testpmd.start()
> --
> 2.44.0
>
>

[-- Attachment #2: Type: text/html, Size: 2554 bytes --]

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

* [PATCH v2 1/1] dts: add EAL confidence check suite
  2024-12-09 21:54 ` [PATCH v1 1/1] " Dean Marx
  2024-12-20 15:49   ` Paul Szczepanek
@ 2024-12-23 18:57   ` Dean Marx
  2024-12-23 18:50     ` Patrick Robb
  2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
  1 sibling, 2 replies; 15+ messages in thread
From: Dean Marx @ 2024-12-23 18:57 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Add a test suite to replace hello_world which simply
starts and stops a testpmd session. The user can use
this as a confidence check to verify their configuration.

Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
---
 dts/tests/TestSuite_eal.py | 27 +++++++++++++++++++++++++++
 1 file changed, 27 insertions(+)
 create mode 100644 dts/tests/TestSuite_eal.py

diff --git a/dts/tests/TestSuite_eal.py b/dts/tests/TestSuite_eal.py
new file mode 100644
index 0000000000..7cf96e61cd
--- /dev/null
+++ b/dts/tests/TestSuite_eal.py
@@ -0,0 +1,27 @@
+# SPDX-License-Identifier: BSD-3-Clause
+# Copyright(c) 2024 University of New Hampshire
+
+"""DPDK EAL confidence check suite.
+
+Starts and stops a testpmd session to verify EAL parameters
+are properly configured.
+"""
+
+from framework.remote_session.testpmd_shell import TestPmdShell
+from framework.test_suite import TestSuite, func_test
+
+
+class TestEal(TestSuite):
+    """EAL test suite. One test case, which starts and stops a testpmd session."""
+
+    @func_test
+    def test_verify_eal(self) -> None:
+        """EAL confidence test.
+
+        Steps:
+            Start testpmd session and check status.
+        Verify:
+            The testpmd session is alive after starting.
+        """
+        with TestPmdShell(node=self.sut_node) as testpmd:
+            testpmd.start()
-- 
2.44.0


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

* [PATCH v3] dts: reform hello world test suite
  2024-12-23 18:57   ` [PATCH v2 1/1] dts: add EAL confidence " Dean Marx
  2024-12-23 18:50     ` Patrick Robb
@ 2025-01-06 17:58     ` Dean Marx
  2025-01-07 16:37       ` Luca Vizzarro
                         ` (2 more replies)
  1 sibling, 3 replies; 15+ messages in thread
From: Dean Marx @ 2025-01-06 17:58 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Add a test suite to replace hello_world which simply
starts and stops a testpmd session. The user can use
this as a confidence check to verify their configuration.

Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
---
 dts/tests/TestSuite_hello_world.py | 68 ++++++------------------------
 1 file changed, 12 insertions(+), 56 deletions(-)

diff --git a/dts/tests/TestSuite_hello_world.py b/dts/tests/TestSuite_hello_world.py
index 734f006026..75f168bc9f 100644
--- a/dts/tests/TestSuite_hello_world.py
+++ b/dts/tests/TestSuite_hello_world.py
@@ -1,71 +1,27 @@
 # SPDX-License-Identifier: BSD-3-Clause
-# Copyright(c) 2010-2014 Intel Corporation
+# Copyright(c) 2024 University of New Hampshire
 
-"""The DPDK hello world app test suite.
+"""DPDK Hello World test suite.
 
-Run the helloworld example app and verify it prints a message for each used core.
-No other EAL parameters apart from cores are used.
+Starts and stops a testpmd session to verify EAL parameters
+are properly configured.
 """
 
-from framework.remote_session.dpdk_shell import compute_eal_params
+from framework.remote_session.testpmd_shell import TestPmdShell
 from framework.test_suite import TestSuite, func_test
-from framework.testbed_model.capability import TopologyType, requires
-from framework.testbed_model.cpu import (
-    LogicalCoreCount,
-    LogicalCoreCountFilter,
-    LogicalCoreList,
-)
 
 
-@requires(topology_type=TopologyType.no_link)
 class TestHelloWorld(TestSuite):
-    """DPDK hello world app test suite."""
-
-    def set_up_suite(self) -> None:
-        """Set up the test suite.
-
-        Setup:
-            Build the app we're about to test - helloworld.
-        """
-        self.app_helloworld_path = self.sut_node.build_dpdk_app("helloworld")
-
-    @func_test
-    def hello_world_single_core(self) -> None:
-        """Single core test case.
-
-        Steps:
-            Run the helloworld app on the first usable logical core.
-        Verify:
-            The app prints a message from the used core:
-            "hello from core <core_id>"
-        """
-        # get the first usable core
-        lcore_amount = LogicalCoreCount(1, 1, 1)
-        lcores = LogicalCoreCountFilter(self.sut_node.lcores, lcore_amount).filter()
-        eal_para = compute_eal_params(self.sut_node, lcore_filter_specifier=lcore_amount)
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para)
-        self.verify(
-            f"hello from core {int(lcores[0])}" in result.stdout,
-            f"helloworld didn't start on lcore{lcores[0]}",
-        )
+    """Hello World test suite. One test case, which starts and stops a testpmd session."""
 
     @func_test
-    def hello_world_all_cores(self) -> None:
-        """All cores test case.
+    def test_hello_world(self) -> None:
+        """EAL confidence test.
 
         Steps:
-            Run the helloworld app on all usable logical cores.
+            Start testpmd session and check status.
         Verify:
-            The app prints a message from all used cores:
-            "hello from core <core_id>"
+            The testpmd session throws no errors.
         """
-        # get the maximum logical core number
-        eal_para = compute_eal_params(
-            self.sut_node, lcore_filter_specifier=LogicalCoreList(self.sut_node.lcores)
-        )
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para, 50)
-        for lcore in self.sut_node.lcores:
-            self.verify(
-                f"hello from core {int(lcore)}" in result.stdout,
-                f"helloworld didn't start on lcore{lcore}",
-            )
+        with TestPmdShell(node=self.sut_node) as testpmd:
+            testpmd.start()
-- 
2.44.0


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

* Re: [PATCH v3] dts: reform hello world test suite
  2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
@ 2025-01-07 16:37       ` Luca Vizzarro
  2025-01-07 16:49       ` Patrick Robb
  2025-01-07 21:34       ` [PATCH v4] " Dean Marx
  2 siblings, 0 replies; 15+ messages in thread
From: Luca Vizzarro @ 2025-01-07 16:37 UTC (permalink / raw)
  To: Dean Marx, probb, npratte, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev

Reviewed-by: Luca Vizzarro <luca.vizzarro@arm.com>

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

* Re: [PATCH v3] dts: reform hello world test suite
  2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
  2025-01-07 16:37       ` Luca Vizzarro
@ 2025-01-07 16:49       ` Patrick Robb
  2025-01-07 21:34       ` [PATCH v4] " Dean Marx
  2 siblings, 0 replies; 15+ messages in thread
From: Patrick Robb @ 2025-01-07 16:49 UTC (permalink / raw)
  To: Dean Marx
  Cc: npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek, dev

[-- Attachment #1: Type: text/plain, Size: 4317 bytes --]

Actually, would you want to use logger to print a "hello world" message. It
might make the testsuite name make more sense hah.

On Mon, Jan 6, 2025 at 11:57 AM Dean Marx <dmarx@iol.unh.edu> wrote:

> Add a test suite to replace hello_world which simply
> starts and stops a testpmd session. The user can use
> this as a confidence check to verify their configuration.
>
> Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
> ---
>  dts/tests/TestSuite_hello_world.py | 68 ++++++------------------------
>  1 file changed, 12 insertions(+), 56 deletions(-)
>
> diff --git a/dts/tests/TestSuite_hello_world.py
> b/dts/tests/TestSuite_hello_world.py
> index 734f006026..75f168bc9f 100644
> --- a/dts/tests/TestSuite_hello_world.py
> +++ b/dts/tests/TestSuite_hello_world.py
> @@ -1,71 +1,27 @@
>  # SPDX-License-Identifier: BSD-3-Clause
> -# Copyright(c) 2010-2014 Intel Corporation
> +# Copyright(c) 2024 University of New Hampshire
>
> -"""The DPDK hello world app test suite.
> +"""DPDK Hello World test suite.
>
> -Run the helloworld example app and verify it prints a message for each
> used core.
> -No other EAL parameters apart from cores are used.
> +Starts and stops a testpmd session to verify EAL parameters
> +are properly configured.
>  """
>
> -from framework.remote_session.dpdk_shell import compute_eal_params
> +from framework.remote_session.testpmd_shell import TestPmdShell
>  from framework.test_suite import TestSuite, func_test
> -from framework.testbed_model.capability import TopologyType, requires
> -from framework.testbed_model.cpu import (
> -    LogicalCoreCount,
> -    LogicalCoreCountFilter,
> -    LogicalCoreList,
> -)
>
>
> -@requires(topology_type=TopologyType.no_link)
>  class TestHelloWorld(TestSuite):
> -    """DPDK hello world app test suite."""
> -
> -    def set_up_suite(self) -> None:
> -        """Set up the test suite.
> -
> -        Setup:
> -            Build the app we're about to test - helloworld.
> -        """
> -        self.app_helloworld_path =
> self.sut_node.build_dpdk_app("helloworld")
> -
> -    @func_test
> -    def hello_world_single_core(self) -> None:
> -        """Single core test case.
> -
> -        Steps:
> -            Run the helloworld app on the first usable logical core.
> -        Verify:
> -            The app prints a message from the used core:
> -            "hello from core <core_id>"
> -        """
> -        # get the first usable core
> -        lcore_amount = LogicalCoreCount(1, 1, 1)
> -        lcores = LogicalCoreCountFilter(self.sut_node.lcores,
> lcore_amount).filter()
> -        eal_para = compute_eal_params(self.sut_node,
> lcore_filter_specifier=lcore_amount)
> -        result = self.sut_node.run_dpdk_app(self.app_helloworld_path,
> eal_para)
> -        self.verify(
> -            f"hello from core {int(lcores[0])}" in result.stdout,
> -            f"helloworld didn't start on lcore{lcores[0]}",
> -        )
> +    """Hello World test suite. One test case, which starts and stops a
> testpmd session."""
>
>      @func_test
> -    def hello_world_all_cores(self) -> None:
> -        """All cores test case.
> +    def test_hello_world(self) -> None:
> +        """EAL confidence test.
>
>          Steps:
> -            Run the helloworld app on all usable logical cores.
> +            Start testpmd session and check status.
>          Verify:
> -            The app prints a message from all used cores:
> -            "hello from core <core_id>"
> +            The testpmd session throws no errors.
>          """
> -        # get the maximum logical core number
> -        eal_para = compute_eal_params(
> -            self.sut_node,
> lcore_filter_specifier=LogicalCoreList(self.sut_node.lcores)
> -        )
> -        result = self.sut_node.run_dpdk_app(self.app_helloworld_path,
> eal_para, 50)
> -        for lcore in self.sut_node.lcores:
> -            self.verify(
> -                f"hello from core {int(lcore)}" in result.stdout,
> -                f"helloworld didn't start on lcore{lcore}",
> -            )
> +        with TestPmdShell(node=self.sut_node) as testpmd:
> +            testpmd.start()
> --
> 2.44.0
>
>

[-- Attachment #2: Type: text/html, Size: 5491 bytes --]

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

* [PATCH v4] dts: reform hello world test suite
  2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
  2025-01-07 16:37       ` Luca Vizzarro
  2025-01-07 16:49       ` Patrick Robb
@ 2025-01-07 21:34       ` Dean Marx
  2025-01-08  9:07         ` Paul Szczepanek
  2025-01-10 19:28         ` [PATCH v5] " Dean Marx
  2 siblings, 2 replies; 15+ messages in thread
From: Dean Marx @ 2025-01-07 21:34 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Add a test suite to replace hello_world which simply
starts and stops a testpmd session. The user can use
this as a confidence check to verify their configuration.

Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
Reviewed-by: Luca Vizzarro <luca.vizzarro@arm.com>
---
 dts/tests/TestSuite_hello_world.py | 70 ++++++------------------------
 1 file changed, 14 insertions(+), 56 deletions(-)

diff --git a/dts/tests/TestSuite_hello_world.py b/dts/tests/TestSuite_hello_world.py
index 734f006026..bad35f3267 100644
--- a/dts/tests/TestSuite_hello_world.py
+++ b/dts/tests/TestSuite_hello_world.py
@@ -1,71 +1,29 @@
 # SPDX-License-Identifier: BSD-3-Clause
-# Copyright(c) 2010-2014 Intel Corporation
+# Copyright(c) 2024 University of New Hampshire
 
-"""The DPDK hello world app test suite.
+"""DPDK Hello World test suite.
 
-Run the helloworld example app and verify it prints a message for each used core.
-No other EAL parameters apart from cores are used.
+Starts and stops a testpmd session to verify EAL parameters
+are properly configured.
 """
 
-from framework.remote_session.dpdk_shell import compute_eal_params
+from framework.remote_session.testpmd_shell import TestPmdShell
+from framework import logger
 from framework.test_suite import TestSuite, func_test
-from framework.testbed_model.capability import TopologyType, requires
-from framework.testbed_model.cpu import (
-    LogicalCoreCount,
-    LogicalCoreCountFilter,
-    LogicalCoreList,
-)
 
 
-@requires(topology_type=TopologyType.no_link)
 class TestHelloWorld(TestSuite):
-    """DPDK hello world app test suite."""
-
-    def set_up_suite(self) -> None:
-        """Set up the test suite.
-
-        Setup:
-            Build the app we're about to test - helloworld.
-        """
-        self.app_helloworld_path = self.sut_node.build_dpdk_app("helloworld")
-
-    @func_test
-    def hello_world_single_core(self) -> None:
-        """Single core test case.
-
-        Steps:
-            Run the helloworld app on the first usable logical core.
-        Verify:
-            The app prints a message from the used core:
-            "hello from core <core_id>"
-        """
-        # get the first usable core
-        lcore_amount = LogicalCoreCount(1, 1, 1)
-        lcores = LogicalCoreCountFilter(self.sut_node.lcores, lcore_amount).filter()
-        eal_para = compute_eal_params(self.sut_node, lcore_filter_specifier=lcore_amount)
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para)
-        self.verify(
-            f"hello from core {int(lcores[0])}" in result.stdout,
-            f"helloworld didn't start on lcore{lcores[0]}",
-        )
+    """Hello World test suite. One test case, which starts and stops a testpmd session."""
 
     @func_test
-    def hello_world_all_cores(self) -> None:
-        """All cores test case.
+    def test_hello_world(self) -> None:
+        """EAL confidence test.
 
         Steps:
-            Run the helloworld app on all usable logical cores.
+            Start testpmd session and check status.
         Verify:
-            The app prints a message from all used cores:
-            "hello from core <core_id>"
+            The testpmd session throws no errors.
         """
-        # get the maximum logical core number
-        eal_para = compute_eal_params(
-            self.sut_node, lcore_filter_specifier=LogicalCoreList(self.sut_node.lcores)
-        )
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para, 50)
-        for lcore in self.sut_node.lcores:
-            self.verify(
-                f"hello from core {int(lcore)}" in result.stdout,
-                f"helloworld didn't start on lcore{lcore}",
-            )
+        with TestPmdShell(node=self.sut_node) as testpmd:
+            testpmd.start()
+        self._logger.log(1, "Hello World!")
-- 
2.44.0


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

* Re: [PATCH v4] dts: reform hello world test suite
  2025-01-07 21:34       ` [PATCH v4] " Dean Marx
@ 2025-01-08  9:07         ` Paul Szczepanek
  2025-01-10 19:28         ` [PATCH v5] " Dean Marx
  1 sibling, 0 replies; 15+ messages in thread
From: Paul Szczepanek @ 2025-01-08  9:07 UTC (permalink / raw)
  To: Dean Marx, probb, npratte, luca.vizzarro, yoan.picchi,
	Honnappa.Nagarahalli
  Cc: nd, dev

On 07/01/2025 21:34, Dean Marx wrote:> +        with
TestPmdShell(node=self.sut_node) as testpmd:
> +            testpmd.start()
> +        self._logger.log(1, "Hello World!")

You should not be using private members like _logger
you can use get_dts_logger to get the logger but honestly I think we
should not encourage tests to use the logger directly.
Maybe we should add a TestSuite class method to log.

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

* [PATCH v5] dts: reform hello world test suite
  2025-01-07 21:34       ` [PATCH v4] " Dean Marx
  2025-01-08  9:07         ` Paul Szczepanek
@ 2025-01-10 19:28         ` Dean Marx
  2025-01-15 10:17           ` Luca Vizzarro
  1 sibling, 1 reply; 15+ messages in thread
From: Dean Marx @ 2025-01-10 19:28 UTC (permalink / raw)
  To: probb, npratte, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx

Add a test suite to replace hello_world which simply
starts and stops a testpmd session. The user can use
this as a confidence check to verify their configuration.

Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com>
Reviewed-by: Luca Vizzarro <luca.vizzarro@arm.com>
---
 dts/framework/test_suite.py        | 10 +++++
 dts/tests/TestSuite_hello_world.py | 69 ++++++------------------------
 2 files changed, 23 insertions(+), 56 deletions(-)

diff --git a/dts/framework/test_suite.py b/dts/framework/test_suite.py
index 16012bfc79..6de36b7242 100644
--- a/dts/framework/test_suite.py
+++ b/dts/framework/test_suite.py
@@ -300,6 +300,16 @@ def get_expected_packet(self, packet: Packet) -> Packet:
         """
         return self.get_expected_packets([packet])[0]
 
+    def testsuite_log(self, message: str) -> None:
+        """Call the private instance of logger within the TestSuite class.
+
+        Log the given message with the level 'INFO'.
+
+        Args:
+            message: String representing the message to log.
+        """
+        self._logger.info(message)
+
     def _adjust_addresses(self, packets: list[Packet], expected: bool = False) -> list[Packet]:
         """L2 and L3 address additions in both directions.
 
diff --git a/dts/tests/TestSuite_hello_world.py b/dts/tests/TestSuite_hello_world.py
index 734f006026..3789b027f9 100644
--- a/dts/tests/TestSuite_hello_world.py
+++ b/dts/tests/TestSuite_hello_world.py
@@ -1,71 +1,28 @@
 # SPDX-License-Identifier: BSD-3-Clause
-# Copyright(c) 2010-2014 Intel Corporation
+# Copyright(c) 2024 University of New Hampshire
 
-"""The DPDK hello world app test suite.
+"""DPDK Hello World test suite.
 
-Run the helloworld example app and verify it prints a message for each used core.
-No other EAL parameters apart from cores are used.
+Starts and stops a testpmd session to verify EAL parameters
+are properly configured.
 """
 
-from framework.remote_session.dpdk_shell import compute_eal_params
+from framework.remote_session.testpmd_shell import TestPmdShell
 from framework.test_suite import TestSuite, func_test
-from framework.testbed_model.capability import TopologyType, requires
-from framework.testbed_model.cpu import (
-    LogicalCoreCount,
-    LogicalCoreCountFilter,
-    LogicalCoreList,
-)
 
 
-@requires(topology_type=TopologyType.no_link)
 class TestHelloWorld(TestSuite):
-    """DPDK hello world app test suite."""
-
-    def set_up_suite(self) -> None:
-        """Set up the test suite.
-
-        Setup:
-            Build the app we're about to test - helloworld.
-        """
-        self.app_helloworld_path = self.sut_node.build_dpdk_app("helloworld")
-
-    @func_test
-    def hello_world_single_core(self) -> None:
-        """Single core test case.
-
-        Steps:
-            Run the helloworld app on the first usable logical core.
-        Verify:
-            The app prints a message from the used core:
-            "hello from core <core_id>"
-        """
-        # get the first usable core
-        lcore_amount = LogicalCoreCount(1, 1, 1)
-        lcores = LogicalCoreCountFilter(self.sut_node.lcores, lcore_amount).filter()
-        eal_para = compute_eal_params(self.sut_node, lcore_filter_specifier=lcore_amount)
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para)
-        self.verify(
-            f"hello from core {int(lcores[0])}" in result.stdout,
-            f"helloworld didn't start on lcore{lcores[0]}",
-        )
+    """Hello World test suite. One test case, which starts and stops a testpmd session."""
 
     @func_test
-    def hello_world_all_cores(self) -> None:
-        """All cores test case.
+    def test_hello_world(self) -> None:
+        """EAL confidence test.
 
         Steps:
-            Run the helloworld app on all usable logical cores.
+            Start testpmd session and check status.
         Verify:
-            The app prints a message from all used cores:
-            "hello from core <core_id>"
+            The testpmd session throws no errors.
         """
-        # get the maximum logical core number
-        eal_para = compute_eal_params(
-            self.sut_node, lcore_filter_specifier=LogicalCoreList(self.sut_node.lcores)
-        )
-        result = self.sut_node.run_dpdk_app(self.app_helloworld_path, eal_para, 50)
-        for lcore in self.sut_node.lcores:
-            self.verify(
-                f"hello from core {int(lcore)}" in result.stdout,
-                f"helloworld didn't start on lcore{lcore}",
-            )
+        with TestPmdShell(node=self.sut_node) as testpmd:
+            testpmd.start()
+        self.testsuite_log("Hello World!")
-- 
2.44.0


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

* Re: [PATCH v5] dts: reform hello world test suite
  2025-01-10 19:28         ` [PATCH v5] " Dean Marx
@ 2025-01-15 10:17           ` Luca Vizzarro
  2025-01-15 12:53             ` Paul Szczepanek
  0 siblings, 1 reply; 15+ messages in thread
From: Luca Vizzarro @ 2025-01-15 10:17 UTC (permalink / raw)
  To: Dean Marx, probb, npratte, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev

Sorry for the late reply Dean. This is a bit redundant in my opinion, 
there is no reason not to give full access to the test suite's own 
logger. I'd just change TestSuite._logger into TestSuite.logger to 
indicate that it's a public member, and do what you initially did.

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

* Re: [PATCH v5] dts: reform hello world test suite
  2025-01-15 10:17           ` Luca Vizzarro
@ 2025-01-15 12:53             ` Paul Szczepanek
  2025-01-15 14:42               ` Luca Vizzarro
  0 siblings, 1 reply; 15+ messages in thread
From: Paul Szczepanek @ 2025-01-15 12:53 UTC (permalink / raw)
  To: Luca Vizzarro, Dean Marx, probb, npratte, yoan.picchi,
	Honnappa.Nagarahalli
  Cc: nd, dev

I think it makes sense to keep logger private and separate. I can see
one reason - we can change the logger in the framework without affecting
the tests. We can also decide to not use the logger to print test suites
messages - for example save per test artifacts.

On 15/01/2025 10:17, Luca Vizzarro wrote:
> Sorry for the late reply Dean. This is a bit redundant in my opinion, 
> there is no reason not to give full access to the test suite's own 
> logger. I'd just change TestSuite._logger into TestSuite.logger to 
> indicate that it's a public member, and do what you initially did.

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

* Re: [PATCH v5] dts: reform hello world test suite
  2025-01-15 12:53             ` Paul Szczepanek
@ 2025-01-15 14:42               ` Luca Vizzarro
  0 siblings, 0 replies; 15+ messages in thread
From: Luca Vizzarro @ 2025-01-15 14:42 UTC (permalink / raw)
  To: Paul Szczepanek, Dean Marx, probb, npratte, yoan.picchi,
	Honnappa.Nagarahalli
  Cc: dev

Alright scratch that then. The only thing I'd change Dean is the name of 
the method. Saying testsuite is somewhat redundant, I think just log fine.

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

end of thread, other threads:[~2025-01-15 14:42 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-12-09 21:54 [PATCH v1 0/1] dts: add EAL sanity check suite Dean Marx
2024-12-09 21:54 ` [PATCH v1 1/1] " Dean Marx
2024-12-20 15:49   ` Paul Szczepanek
2024-12-20 16:21     ` Stephen Hemminger
2024-12-23 18:57   ` [PATCH v2 1/1] dts: add EAL confidence " Dean Marx
2024-12-23 18:50     ` Patrick Robb
2025-01-06 17:58     ` [PATCH v3] dts: reform hello world test suite Dean Marx
2025-01-07 16:37       ` Luca Vizzarro
2025-01-07 16:49       ` Patrick Robb
2025-01-07 21:34       ` [PATCH v4] " Dean Marx
2025-01-08  9:07         ` Paul Szczepanek
2025-01-10 19:28         ` [PATCH v5] " Dean Marx
2025-01-15 10:17           ` Luca Vizzarro
2025-01-15 12:53             ` Paul Szczepanek
2025-01-15 14:42               ` Luca Vizzarro

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).