* [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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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; 17+ 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] 17+ 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
2025-01-15 15:51 ` [PATCH v6] " Dean Marx
1 sibling, 2 replies; 17+ 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] 17+ 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
2025-01-15 15:51 ` [PATCH v6] " Dean Marx
1 sibling, 1 reply; 17+ 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] 17+ 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; 17+ 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] 17+ 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
2025-01-15 15:19 ` Dean Marx
0 siblings, 1 reply; 17+ 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] 17+ messages in thread
* Re: [PATCH v5] dts: reform hello world test suite
2025-01-15 14:42 ` Luca Vizzarro
@ 2025-01-15 15:19 ` Dean Marx
0 siblings, 0 replies; 17+ messages in thread
From: Dean Marx @ 2025-01-15 15:19 UTC (permalink / raw)
To: Luca Vizzarro
Cc: Paul Szczepanek, probb, npratte, yoan.picchi, Honnappa.Nagarahalli, dev
Makes sense, I'll send out a new version soon
^ permalink raw reply [flat|nested] 17+ messages in thread
* [PATCH v6] 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 15:51 ` Dean Marx
1 sibling, 0 replies; 17+ messages in thread
From: Dean Marx @ 2025-01-15 15:51 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..de9f871b3f 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 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..031b94de4d 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.log("Hello World!")
--
2.44.0
^ permalink raw reply [flat|nested] 17+ messages in thread
end of thread, other threads:[~2025-01-15 15:51 UTC | newest]
Thread overview: 17+ 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
2025-01-15 15:19 ` Dean Marx
2025-01-15 15:51 ` [PATCH v6] " Dean Marx
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).