* [PATCH v1 1/3] dts: rewrite README
@ 2025-05-27 15:37 Dean Marx
  2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx
                   ` (3 more replies)
  0 siblings, 4 replies; 39+ messages in thread
From: Dean Marx @ 2025-05-27 15:37 UTC (permalink / raw)
  To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli,
	paul.szczepanek
  Cc: dev, Dean Marx
Remove unnecessary information from README.md, and add new sections to clarify
the purpose/use of DTS along with clear setup instructions.
Signed-off-by: Dean Marx <dmarx@iol.unh.edu>
---
 dts/README.md | 104 +++++++++++++++++++-------------------------------
 1 file changed, 39 insertions(+), 65 deletions(-)
diff --git a/dts/README.md b/dts/README.md
index 2b3a7f89c5..879cf65abc 100644
--- a/dts/README.md
+++ b/dts/README.md
@@ -1,81 +1,55 @@
-# DTS Environment
+# Description
 
-The execution and development environments for DTS are the same,
-a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile).
-Using a container for the development environment helps with a few things.
+DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK 
+enabled hardware. Unlike the DPDK unit test application, DTS is intended to be used to 
+evaluate real DPDK workloads run over supported hardware. For instance, DTS will control
+a traffic generator node which will send packets to a system under test node which is 
+running a DPDK application, and evaluate those results.
 
-1. It helps enforce the boundary between the DTS environment and the TG/SUT,
-   something which caused issues in the past.
-2. It makes creating containers to run DTS inside automated tooling much easier, since
-   they can be based off of a known-working environment that will be updated as DTS is.
-3. It abstracts DTS from the server it is running on. This means that the bare-metal OS
-   can be whatever corporate policy or your personal preferences dictate,
-   and DTS does not have to try to support all distros that are supported by DPDK CI.
-4. It makes automated testing for DTS easier,
-   since new dependencies can be sent in with the patches.
-5. It fixes the issue of undocumented dependencies,
-   where some test suites require Python libraries that are not installed.
-6. Allows everyone to use the same Python version easily,
-   even if they are using a distribution or Windows with out-of-date packages.
-7. Allows you to run the tester on Windows while developing via Docker for Windows.
+# Supported Test Node Topologies
 
-## Tips for setting up a development environment
+DTS is a python application which will control a traffic generator node (TG) and system 
+under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a 
+host. The devices/NICs can be located on two separate servers, or on the same server. If you use
+the same server for both NICs, install them on separate NUMA domains if possible (this is ideal
+for performance testing.)
 
-### Getting a docker shell
+1. 2 link: Represents a topology in which the TG node and SUT node both have two network interfaces
+which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the
+TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 
+on SUT, interface 1 on TG <-> interface 1 on SUT.
+2. 1 link: Works, but may result in skips for testsuites which are explicitly decorated with a
+2 link requirement. Represents a topology in which the TG node and SUT node are both located on one
+network interface. An example of this would be a dual interface NIC with a connection between
+its own ports.
 
-These commands will give you a bash shell inside the container
-with all the Python dependencies installed.
-This will place you inside a Python virtual environment.
-DTS is mounted via a volume, which is essentially a symlink from the host to the container.
-This enables you to edit and run inside the container
-and then delete the container when you are done, keeping your work.
-It is also strongly recommended that you mount your SSH keys into the container
-to allow you to connect to hosts without specifying a password.
+# Simple linux setup
 
-#### Start docker container with SSH keys
+1. On your TG and SUT nodes, add a dedicated user. In this example I will name the user "dts."
+2. Grant passwordless sudo to the dts user, like so:
+    2a: enter 'visudo' in your terminal
+    2b: In the visudo text editor, add:
+        dts   ALL=(ALL:ALL) NOPASSWD:ALL
+3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT:
+    ssh-copy-id dts@{your host}.
 
-```shell
-docker build --target dev -t dpdk-dts .
-docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash
-$ poetry install
-$ poetry shell
-```
+For additional detail, please refer to [dts.rst](doc/guides/tools/dts.rst)
+
+# DTS Configuration
 
-#### Start docker container without SSH keys
+DTS requires two yaml files to be filled out with information about your environment,
+test_run.yaml and nodes.yaml, which follow the format illustrated in the example files.
 
 ```shell
 docker build --target dev -t dpdk-dts .
-docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash
+docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash
 $ poetry install
-$ poetry shell
+$ poetry run ./main.py
 ```
 
-### Vim/Emacs
-
-Any editor in the Ubuntu repos should be easy to use,
-with Vim and Emacs already installed.
-You can add your normal config files as a volume,
-enabling you to use your preferred settings.
-
-```shell
-docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash
-```
-
-### Visual Studio Code
-
-VSCode has first-class support for developing with containers.
-You may need to run the non-Docker setup commands in the integrated terminal.
-DTS contains a .devcontainer config,
-so if you open the folder in VSCode it should prompt you to use the dev container
-assuming you have the plugin installed.
-Please refer to
-[VS Development Containers Docs](https://code.visualstudio.com/docs/remote/containers)
-to set it all up.
-Additionally, there is a line in `.devcontainer/devcontainer.json` that, when included,
-will mount the SSH keys of the user currently running VSCode into the container for you.
-The `source` on this line can be altered to mount any SSH keys
-on the local machine into the container at the correct location.
+These commands will give you a bash shell inside a docker container
+with all DTS Python dependencies installed.
 
-### Other
+## Other
 
-Searching for '$IDE dev containers' will probably lead you in the right direction.
+Searching for '$IDE dev containers' will probably lead you in the right direction.
\ No newline at end of file
-- 
2.49.0
^ permalink raw reply related	[flat|nested] 39+ messages in thread* [PATCH v1 2/3] dts: rewrite dts rst 2025-05-27 15:37 [PATCH v1 1/3] dts: rewrite README Dean Marx @ 2025-05-27 15:37 ` Dean Marx 2025-05-28 21:25 ` Patrick Robb 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx 2025-05-27 15:37 ` [PATCH v1 3/3] dts: fix doc generation bug Dean Marx ` (2 subsequent siblings) 3 siblings, 2 replies; 39+ messages in thread From: Dean Marx @ 2025-05-27 15:37 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Modify dts.rst to exclude redundant/outdated information about the project, and add new information regarding setup and framework design. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> --- doc/guides/tools/dts.rst | 310 +++++++++++++-------------------------- 1 file changed, 99 insertions(+), 211 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index fcc6d22036..0aa6663b9f 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,18 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + Node with DPDK and relevant hardware (NICs, crypto, etc.). System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic; can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -195,12 +183,28 @@ These need to be set up on a Traffic Generator Node: Running DTS ----------- -DTS needs to know which nodes to connect to and what hardware to use on those nodes. -Once that's configured, either a DPDK source code tarball or tree folder -need to be supplied whether these are on your DTS host machine or the SUT node. -DTS can accept a pre-compiled build placed in a subdirectory, -or it will compile DPDK on the SUT node, -and then run the tests with the newly built binaries. +To run DTS, use ``main.py`` with Poetry: + +.. code-block:: console + + ```shell + docker build --target dev -t dpdk-dts . + docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash + $ poetry install + $ poetry run ./main.py + ``` + +Common options include: + +- ``--output-dir``: Custom output location. +- ``--remote-source``: Use sources stored on the SUT. +- ``--tarball``: Specify the tarball to be tested. + +For a full list: + +.. code-block:: console + + poetry run ./main.py --help Configuring DTS @@ -220,71 +224,6 @@ The user must have :ref:`administrator privileges <sut_admin_user>` which don't require password authentication. -DTS Execution -~~~~~~~~~~~~~ - -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: - -.. code-block:: console - - (dts-py3.10) $ ./main.py --help - usage: main.py [-h] [--test-run-config-file FILE_PATH] [--nodes-config-file FILE_PATH] [--tests-config-file FILE_PATH] - [--output-dir DIR_PATH] [-t SECONDS] [-v] [--dpdk-tree DIR_PATH | --tarball FILE_PATH] [--remote-source] - [--precompiled-build-dir DIR_NAME] [--compile-timeout SECONDS] [--test-suite TEST_SUITE [TEST_CASES ...]] - [--re-run N_TIMES] [--random-seed NUMBER] - - Run DPDK test suites. All options may be specified with the environment variables provided in brackets. Command line arguments have higher - priority. - - options: - -h, --help show this help message and exit - --test-run-config-file FILE_PATH - [DTS_TEST_RUN_CFG_FILE] The configuration file that describes the test cases and DPDK build options. (default: test-run.conf.yaml) - --nodes-config-file FILE_PATH - [DTS_NODES_CFG_FILE] The configuration file that describes the SUT and TG nodes. (default: nodes.conf.yaml) - --tests-config-file FILE_PATH - [DTS_TESTS_CFG_FILE] Configuration file used to override variable values inside specific test suites. (default: None) - --output-dir DIR_PATH, --output DIR_PATH - [DTS_OUTPUT_DIR] Output directory where DTS logs and results are saved. (default: output) - -t SECONDS, --timeout SECONDS - [DTS_TIMEOUT] The default timeout for all DTS operations except for compiling DPDK. (default: 15) - -v, --verbose [DTS_VERBOSE] Specify to enable verbose output, logging all messages to the console. (default: False) - --compile-timeout SECONDS - [DTS_COMPILE_TIMEOUT] The timeout for compiling DPDK. (default: 1200) - --test-suite TEST_SUITE [TEST_CASES ...] - [DTS_TEST_SUITES] A list containing a test suite with test cases. The first parameter is the test suite name, and - the rest are test case names, which are optional. May be specified multiple times. To specify multiple test suites - in the environment variable, join the lists with a comma. Examples: --test-suite suite case case --test-suite - suite case ... | DTS_TEST_SUITES='suite case case, suite case, ...' | --test-suite suite --test-suite suite case - ... | DTS_TEST_SUITES='suite, suite case, ...' (default: []) - --re-run N_TIMES, --re_run N_TIMES - [DTS_RERUN] Re-run each test case the specified number of times if a test failure occurs. (default: 0) - --random-seed NUMBER [DTS_RANDOM_SEED] The seed to use with the pseudo-random generator. If not specified, the configuration value is - used instead. If that's also not specified, a random seed is generated. (default: None) - - DPDK Build Options: - Arguments in this group (and subgroup) will be applied to a DPDKLocation when the DPDK tree, tarball or revision will be provided, - other arguments like remote source and build dir are optional. A DPDKLocation from settings are used instead of from config if - construct successful. - - --dpdk-tree DIR_PATH [DTS_DPDK_TREE] The path to the DPDK source tree directory to test. Cannot be used in conjunction with --tarball. - (default: None) - --tarball FILE_PATH, --snapshot FILE_PATH - [DTS_DPDK_TARBALL] The path to the DPDK source tarball to test. DPDK must be contained in a folder with the same - name as the tarball file. Cannot be used in conjunction with --dpdk-tree. (default: None) - --remote-source [DTS_REMOTE_SOURCE] Set this option if either the DPDK source tree or tarball to be used are located on the SUT - node. Can only be used with --dpdk-tree or --tarball. (default: False) - --precompiled-build-dir DIR_NAME - [DTS_PRECOMPILED_BUILD_DIR] Define the subdirectory under the DPDK tree root directory or tarball where the pre- - compiled binaries are located. (default: None) - - -The brackets contain the names of environment variables that set the same thing. -The minimum DTS needs is a config file and a pre-built DPDK -or DPDK sources location which can be specified in said config file -or on the command line or environment variables. - - DTS Results ~~~~~~~~~~~ @@ -308,140 +247,89 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. - - -How To Write a Test Suite -------------------------- - -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: - -#. **Test cases** - - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. - -#. **Setup and Teardown methods** - - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. - -#. **Configuration, traffic and other logic** - - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. - - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. - - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. - -#. **Test case verification** - - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. - -#. **Other methods** - - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. -.. _dts_dev_tools: +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: -DTS Developer Tools -------------------- +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines -There are two tools used in DTS to help with code checking, style and formatting: +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks (e.g., `` `param` ``), + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks (````value````) for literal values. -* `ruff <https://astral.sh/ruff/>`_ +Example:: - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. + def foo(greet: bool) -> None: + """Demonstrates single vs. double backticks. -* `mypy <https://github.com/python/mypy>`_ + `greet` controls whether ``Hello World`` is printed. - Enables static typing for Python, exploiting the type hints in the source code. + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. + + +Creating a Test Suite +--------------------- + +All test suites inherit from ``TestSuite`` in ``dts/framework/test_suite.py``. A typical suite contains: + +- Test Cases + - Functional: start with ``test_``, e.g., ``test_basic_link`` + - Performance: start with ``test_perf_``, e.g., ``test_perf_throughput`` + - Import the ``func_test`` and/or ``perf_test`` decorators from ``TestSuite`` and add them above each test case method, + e.g., ``@func_test`` followed by ``test_basic_link`` + +- Setup/Teardown Hooks + - Suite-level: ``set_up_suite()``, ``tear_down_suite()`` + - Case-level: ``set_up_test_case()``, ``tear_down_test_case()`` + +- Verification + Use ``self.verify(condition, message)`` to record test results. + +- Support Methods + Helper logic (e.g., traffic handling, config) should be in private methods or delegated to ``sut_node``. + + +.. _dts_dev_tools: + +Developer Tools +--------------- + +- ruff + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black + +- mypy + - Performs static type checking + +Run checks using: + +.. code-block:: console -These two tools are all used in ``devtools/dts-check-format.sh``, -the DTS code check and format script. -Refer to the script for usage: ``devtools/dts-check-format.sh -h``. + devtools/dts-check-format.sh .. _building_api_docs: -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v1 2/3] dts: rewrite dts rst 2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx @ 2025-05-28 21:25 ` Patrick Robb 2025-05-29 12:27 ` Paul Szczepanek 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx 1 sibling, 1 reply; 39+ messages in thread From: Patrick Robb @ 2025-05-28 21:25 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 21899 bytes --] On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu> wrote: > Modify dts.rst to exclude redundant/outdated information about the project, > and add new information regarding setup and framework design. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > --- > doc/guides/tools/dts.rst | 310 +++++++++++++-------------------------- > 1 file changed, 99 insertions(+), 211 deletions(-) > > diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst > index fcc6d22036..0aa6663b9f 100644 > --- a/doc/guides/tools/dts.rst > +++ b/doc/guides/tools/dts.rst > @@ -1,6 +1,7 @@ > .. SPDX-License-Identifier: BSD-3-Clause > Copyright(c) 2022-2023 PANTHEON.tech s.r.o. > Copyright(c) 2024 Arm Limited > + Copyright(c) 2025 University of New Hampshire > > DPDK Test Suite > =============== > @@ -20,31 +21,18 @@ DTS runtime environment > > DTS runtime environment node > A node where at least one DTS runtime environment is present. > - This is the node where we run DTS and from which DTS connects to other > nodes. > Leave this in. > > System under test > - An SUT is the combination of DPDK and the hardware we're testing > - in conjunction with DPDK (NICs, crypto and other devices). > + Node with DPDK and relevant hardware (NICs, crypto, etc.). > Maybe change to "The system which runs a DPDK application on relevant hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is observed for tests." > > System under test node > A node where at least one SUT is present. > > Traffic generator > - A TG is either software or hardware capable of sending packets. > + Node that sends traffic; can be hardware or software-based. > "Node that sends traffic to the SUT;" Sorry for being so particular. :) > Traffic generator node > A node where at least one TG is present. > - In case of hardware traffic generators, the TG and the node are > literally the same. > - > - > -In most cases, interchangeably referring to a runtime environment, SUT, > TG or the node > -they're running on (e.g. using SUT and SUT node interchangeably) doesn't > cause confusion. > -There could theoretically be more than of these running on the same node > and in that case > -it's useful to have stricter definitions. > -An example would be two different traffic generators (such as Trex and > Scapy) > -running on the same node. > -A different example would be a node containing both a DTS runtime > environment > -and a traffic generator, in which case it's both a DTS runtime > environment node and a TG node. > > > DTS Environment > @@ -195,12 +183,28 @@ These need to be set up on a Traffic Generator Node: > Running DTS > ----------- > > -DTS needs to know which nodes to connect to and what hardware to use on > those nodes. > -Once that's configured, either a DPDK source code tarball or tree folder > -need to be supplied whether these are on your DTS host machine or the SUT > node. > -DTS can accept a pre-compiled build placed in a subdirectory, > -or it will compile DPDK on the SUT node, > -and then run the tests with the newly built binaries. > +To run DTS, use ``main.py`` with Poetry: > + > +.. code-block:: console > + > + ```shell > + docker build --target dev -t dpdk-dts . > + docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it > dpdk-dts bash > + $ poetry install > + $ poetry run ./main.py > + ``` > + > +Common options include: > + > +- ``--output-dir``: Custom output location. > +- ``--remote-source``: Use sources stored on the SUT. > +- ``--tarball``: Specify the tarball to be tested. > + > +For a full list: > + > +.. code-block:: console > + > + poetry run ./main.py --help > I think we should keep the full list of flags here instead of removing it for this subset. It's a bit of a maintenance burden and it make the file longer but it's important info. I think it's good to present it here even if it is only "a --help away." > > > Configuring DTS > @@ -220,71 +224,6 @@ The user must have :ref:`administrator privileges > <sut_admin_user>` > which don't require password authentication. > > > -DTS Execution > -~~~~~~~~~~~~~ > - > -DTS is run with ``main.py`` located in the ``dts`` directory after > entering Poetry shell: > - > -.. code-block:: console > - > - (dts-py3.10) $ ./main.py --help > - usage: main.py [-h] [--test-run-config-file FILE_PATH] > [--nodes-config-file FILE_PATH] [--tests-config-file FILE_PATH] > - [--output-dir DIR_PATH] [-t SECONDS] [-v] [--dpdk-tree > DIR_PATH | --tarball FILE_PATH] [--remote-source] > - [--precompiled-build-dir DIR_NAME] [--compile-timeout > SECONDS] [--test-suite TEST_SUITE [TEST_CASES ...]] > - [--re-run N_TIMES] [--random-seed NUMBER] > - > - Run DPDK test suites. All options may be specified with the > environment variables provided in brackets. Command line arguments have > higher > - priority. > - > - options: > - -h, --help show this help message and exit > - --test-run-config-file FILE_PATH > - [DTS_TEST_RUN_CFG_FILE] The configuration file > that describes the test cases and DPDK build options. (default: > test-run.conf.yaml) > - --nodes-config-file FILE_PATH > - [DTS_NODES_CFG_FILE] The configuration file > that describes the SUT and TG nodes. (default: nodes.conf.yaml) > - --tests-config-file FILE_PATH > - [DTS_TESTS_CFG_FILE] Configuration file used > to override variable values inside specific test suites. (default: None) > - --output-dir DIR_PATH, --output DIR_PATH > - [DTS_OUTPUT_DIR] Output directory where DTS > logs and results are saved. (default: output) > - -t SECONDS, --timeout SECONDS > - [DTS_TIMEOUT] The default timeout for all DTS > operations except for compiling DPDK. (default: 15) > - -v, --verbose [DTS_VERBOSE] Specify to enable verbose > output, logging all messages to the console. (default: False) > - --compile-timeout SECONDS > - [DTS_COMPILE_TIMEOUT] The timeout for > compiling DPDK. (default: 1200) > - --test-suite TEST_SUITE [TEST_CASES ...] > - [DTS_TEST_SUITES] A list containing a test > suite with test cases. The first parameter is the test suite name, and > - the rest are test case names, which are > optional. May be specified multiple times. To specify multiple test suites > - in the environment variable, join the lists > with a comma. Examples: --test-suite suite case case --test-suite > - suite case ... | DTS_TEST_SUITES='suite case > case, suite case, ...' | --test-suite suite --test-suite suite case > - ... | DTS_TEST_SUITES='suite, suite case, ...' > (default: []) > - --re-run N_TIMES, --re_run N_TIMES > - [DTS_RERUN] Re-run each test case the > specified number of times if a test failure occurs. (default: 0) > - --random-seed NUMBER [DTS_RANDOM_SEED] The seed to use with the > pseudo-random generator. If not specified, the configuration value is > - used instead. If that's also not specified, a > random seed is generated. (default: None) > - > - DPDK Build Options: > - Arguments in this group (and subgroup) will be applied to a > DPDKLocation when the DPDK tree, tarball or revision will be provided, > - other arguments like remote source and build dir are optional. A > DPDKLocation from settings are used instead of from config if > - construct successful. > - > - --dpdk-tree DIR_PATH [DTS_DPDK_TREE] The path to the DPDK source > tree directory to test. Cannot be used in conjunction with --tarball. > - (default: None) > - --tarball FILE_PATH, --snapshot FILE_PATH > - [DTS_DPDK_TARBALL] The path to the DPDK source > tarball to test. DPDK must be contained in a folder with the same > - name as the tarball file. Cannot be used in > conjunction with --dpdk-tree. (default: None) > - --remote-source [DTS_REMOTE_SOURCE] Set this option if either > the DPDK source tree or tarball to be used are located on the SUT > - node. Can only be used with --dpdk-tree or > --tarball. (default: False) > - --precompiled-build-dir DIR_NAME > - [DTS_PRECOMPILED_BUILD_DIR] Define the > subdirectory under the DPDK tree root directory or tarball where the pre- > - compiled binaries are located. (default: None) > - > - > -The brackets contain the names of environment variables that set the same > thing. > -The minimum DTS needs is a config file and a pre-built DPDK > -or DPDK sources location which can be specified in said config file > -or on the command line or environment variables. > - > - > DTS Results > ~~~~~~~~~~~ > > @@ -308,140 +247,89 @@ Adding test cases may require adding code to the > framework as well. > Framework Coding Guidelines > ~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > -When adding code to the DTS framework, pay attention to the rest of the > code > -and try not to divert much from it. > -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings > -when some of the basics are not met. > -You should also build the :ref:`API documentation <building_api_docs>` > -to address any issues found during the build. > - > -The API documentation, which is a helpful reference when developing, may > be accessed > -in the code directly or generated with the :ref:`API docs build steps > <building_api_docs>`. > -When adding new files or modifying the directory structure, > -the corresponding changes must be made to DTS API doc sources in > ``doc/api/dts``. > - > -Speaking of which, the code must be properly documented with docstrings. > -The style must conform to the `Google style > -< > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > -See an example of the style `here > -< > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_. > -For cases which are not covered by the Google style, refer to `PEP 257 > -<https://peps.python.org/pep-0257/>`_. > -There are some cases which are not covered by the two style guides, > -where we deviate or where some additional clarification is helpful: > - > - * The ``__init__()`` methods of classes are documented separately > - from the docstring of the class itself. > - * The docstrings of implemented abstract methods should refer to the > superclass's definition > - if there's no deviation. > - * Instance variables/attributes should be documented in the docstring > of the class > - in the ``Attributes:`` section. > - * The ``dataclass.dataclass`` decorator changes how the attributes are > processed. > - The dataclass attributes which result in instance > variables/attributes > - should also be recorded in the ``Attributes:`` section. > - * Class variables/attributes and Pydantic model fields, on the other > hand, > - should be documented with ``#:`` above the type annotated line. > - The description may be omitted if the meaning is obvious. > - * The ``Enum`` and ``TypedDict`` also process the attributes in > particular ways > - and should be documented with ``#:`` as well. > - This is mainly so that the autogenerated documentation contains the > assigned value. > - * When referencing a parameter of a function or a method in their > docstring, > - don't use any articles and put the parameter into single backticks. > - This mimics the style of `Python's documentation < > https://docs.python.org/3/index.html>`_. > - * When specifying a value, use double backticks:: > - > - def foo(greet: bool) -> None: > - """Demonstration of single and double backticks. > - > - `greet` controls whether ``Hello World`` is printed. > - > - Args: > - greet: Whether to print the ``Hello World`` message. > - """ > - if greet: > - print(f"Hello World") > - > - * The docstring maximum line length is the same as the code maximum > line length. > - > - > -How To Write a Test Suite > -------------------------- > - > -All test suites inherit from ``TestSuite`` defined in > ``dts/framework/test_suite.py``. > "All test suites are a class which inherits from" > -There are four types of methods that comprise a test suite: > - > -#. **Test cases** > - > - | Test cases are methods that start with a particular prefix. > - | Functional test cases start with ``test_``, e.g. > ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. > ``test_perf_nic_single_core``. > Now decorator based. > - | A test suite may have any number of functional and/or performance > test cases. > - However, these test cases must test the same feature, > - following the rule of one feature = one test suite. > - Test cases for one feature don't need to be grouped in just one test > suite, though. > - If the feature requires many testing scenarios to cover, > - the test cases would be better off spread over multiple test suites > - so that each test suite doesn't take too long to execute. > - > -#. **Setup and Teardown methods** > - > - | There are setup and teardown methods for the whole test suite and > each individual test case. > - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed > - before any and after all test cases have been executed, respectively. > - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be > executed > - before and after each test case, respectively. > - | These methods don't need to be implemented if there's no need for > them in a test suite. > - In that case, nothing will happen when they are executed. > - > -#. **Configuration, traffic and other logic** > - > - The ``TestSuite`` class contains a variety of methods for anything that > - a test suite setup, a teardown, or a test case may need to do. > - > - The test suites also frequently use a DPDK app, such as testpmd, in > interactive mode > - and use the interactive shell instances directly. > - > - These are the two main ways to call the framework logic in test suites. > - If there's any functionality or logic missing from the framework, > - it should be implemented so that the test suites can use one of these > two ways. > - > -#. **Test case verification** > - > - Test case verification should be done with the ``verify`` method, > which records the result. > - The method should be called at the end of each test case. > - > -#. **Other methods** > I see that some of the content under "Other methods" is now false and should be removed - thanks for doing so. However, I do think there was a lot of good within the original "Test Cases," "Setup and Teardown Methods," and "Configuration, traffic and other logic" which has been removed. For this one I prefer if we just sit down and hash it out in person when you're in next week. > - > - Of course, all test suite code should adhere to coding standards. > - Only the above methods will be treated specially and any other methods > may be defined > - (which should be mostly private methods needed by each particular test > suite). > - Any specific features (such as NIC configuration) required by a test > suite > - should be implemented in the ``SutNode`` class (and the underlying > classes that ``SutNode`` uses) > - and used by the test suite via the ``sut_node`` field. > +When contributing code to the DTS framework, follow existing conventions > to ensure consistency. > +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. > +Also, be sure to :ref:`build the API documentation <building_api_docs>` > to catch any problems during the build. > > +The API documentation is a helpful reference during development. > +It can be viewed in the code directly or generated using the :ref:`API > docs build steps <building_api_docs>`. > +If you add new files or change the directory structure, update the > corresponding sources in ``doc/api/dts``. > > -.. _dts_dev_tools: > +Code must be documented with docstrings that follow the > +`Google style < > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > +Additional references: > > -DTS Developer Tools > -------------------- > +* `Sphinx Google style example < > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_ > +* `PEP 257 <https://peps.python.org/pep-0257/>`_ > + > +Docstring and Attribute Guidelines > > -There are two tools used in DTS to help with code checking, style and > formatting: > +* Document ``__init__()`` separately from the class docstring. > +* If an abstract method simply implements a superclass definition without > changes, refer to that superclass in the docstring. > +* Document instance variables in the class docstring under an > ``Attributes:`` section. > +* For ``@dataclass`` classes, document instance-level attributes in > ``Attributes:``, as they are generated from the class fields. > +* Document class variables and Pydantic fields using ``#:``, > + placed above the type-annotated line. Descriptions may be omitted if > the meaning is clear. > +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that > autogenerated documentation includes their values. > +* When referring to a parameter in a docstring, omit articles and enclose > the parameter in single backticks (e.g., `` `param` ``), > + consistent with the `Python documentation style < > https://docs.python.org/3/index.html>`_. > +* Use double backticks (````value````) for literal values. > > -* `ruff <https://astral.sh/ruff/>`_ > +Example:: > > - An extremely fast all-in-one linting and formatting solution, > - which covers most if not all the major rules such as: > - pylama, flake8, pylint etc. > - Its built-in formatter is also Black-compatible > - and is able to sort imports automatically like isort would. > + def foo(greet: bool) -> None: > + """Demonstrates single vs. double backticks. > > -* `mypy <https://github.com/python/mypy>`_ > + `greet` controls whether ``Hello World`` is printed. > > - Enables static typing for Python, exploiting the type hints in the > source code. > + Args: > + greet: Whether to print the ``Hello World`` message. > + """ > + if greet: > + print("Hello World") > + > +The maximum line length for docstrings must match that of the code. > + > + > +Creating a Test Suite > +--------------------- > + > +All test suites inherit from ``TestSuite`` in > ``dts/framework/test_suite.py``. A typical suite contains: > + > +- Test Cases > + - Functional: start with ``test_``, e.g., ``test_basic_link`` > + - Performance: start with ``test_perf_``, e.g., > ``test_perf_throughput`` I realize you go on to describe the decorators after this, but I think the test_func and test_perf naming convention is no longer required. Example: @requires(NicCapability.FLOW_CTRL) @func_test def flow_ctrl_port_configuration_persistence(self) -> None: """Flow control port configuration persistency test. Steps: For each port enable flow control for RX and TX individually. Verify: The configuration persists after the port is restarted. """ > + - Import the ``func_test`` and/or ``perf_test`` decorators from > ``TestSuite`` and add them above each test case method, > + e.g., ``@func_test`` followed by ``test_basic_link`` > + > +- Setup/Teardown Hooks > + - Suite-level: ``set_up_suite()``, ``tear_down_suite()`` > + - Case-level: ``set_up_test_case()``, ``tear_down_test_case()`` > + > +- Verification > + Use ``self.verify(condition, message)`` to record test results. > I think the important part of "verify" to explain to people is that you are setting the testcase assertion condition, not the recording aspect. > + > +- Support Methods > + Helper logic (e.g., traffic handling, config) should be in private > methods or delegated to ``sut_node``. > I realize this is just a rewording that crept in, but this is wrong for a couple reasons: 1. We no longer import node/sutnode when writing testsuites. Node is purely framework code now, and is not exposed to testsuites. 2. sut_node (and tg_node) no longer exists. > + > + > +.. _dts_dev_tools: > + > +Developer Tools > +--------------- > + > +- ruff > + - Linter and formatter (replaces flake8, pylint, isort, etc.) > + - Compatible with Black > + > +- mypy > + - Performs static type checking > + > +Run checks using: > + > +.. code-block:: console > > -These two tools are all used in ``devtools/dts-check-format.sh``, > -the DTS code check and format script. > -Refer to the script for usage: ``devtools/dts-check-format.sh -h``. > + devtools/dts-check-format.sh > > > .. _building_api_docs: > -- > 2.49.0 > > Lots of improvements overall - keep up the good work! A productive Summer ahead. Reviewed-by: Patrick Robb <probb@iol.unh.edu> [-- Attachment #2: Type: text/html, Size: 26837 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v1 2/3] dts: rewrite dts rst 2025-05-28 21:25 ` Patrick Robb @ 2025-05-29 12:27 ` Paul Szczepanek 0 siblings, 0 replies; 39+ messages in thread From: Paul Szczepanek @ 2025-05-29 12:27 UTC (permalink / raw) To: Patrick Robb, Dean Marx Cc: nd, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, dev I think shortening it is great, less maintenance overhead and avoids going out of sync with code which is already plenty documented. Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> On 28/05/2025 22:25, Patrick Robb wrote: > > > On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu > <mailto:dmarx@iol.unh.edu>> wrote: > > Modify dts.rst to exclude redundant/outdated information about the > project, > and add new information regarding setup and framework design. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu <mailto:dmarx@iol.unh.edu>> > --- > doc/guides/tools/dts.rst | 310 +++++++++++++-------------------------- > 1 file changed, 99 insertions(+), 211 deletions(-) > > diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst > index fcc6d22036..0aa6663b9f 100644 > --- a/doc/guides/tools/dts.rst > +++ b/doc/guides/tools/dts.rst > @@ -1,6 +1,7 @@ > .. SPDX-License-Identifier: BSD-3-Clause > Copyright(c) 2022-2023 PANTHEON.tech s.r.o. > Copyright(c) 2024 Arm Limited > + Copyright(c) 2025 University of New Hampshire > > DPDK Test Suite > =============== > @@ -20,31 +21,18 @@ DTS runtime environment > > DTS runtime environment node > A node where at least one DTS runtime environment is present. > - This is the node where we run DTS and from which DTS connects to > other nodes. > > > Leave this in. > > > > System under test > - An SUT is the combination of DPDK and the hardware we're testing > - in conjunction with DPDK (NICs, crypto and other devices). > + Node with DPDK and relevant hardware (NICs, crypto, etc.). > > > Maybe change to "The system which runs a DPDK application on relevant > hardware (NIC, accelerator cards, etc) and from which the DPDK behavior > is observed for tests." > > > > System under test node > A node where at least one SUT is present. > > Traffic generator > - A TG is either software or hardware capable of sending packets. > + Node that sends traffic; can be hardware or software-based. > > > "Node that sends traffic to the SUT;" > > Sorry for being so particular. :) > > > Traffic generator node > A node where at least one TG is present. > - In case of hardware traffic generators, the TG and the node are > literally the same. > - > - > -In most cases, interchangeably referring to a runtime environment, > SUT, TG or the node > -they're running on (e.g. using SUT and SUT node interchangeably) > doesn't cause confusion. > -There could theoretically be more than of these running on the same > node and in that case > -it's useful to have stricter definitions. > -An example would be two different traffic generators (such as Trex > and Scapy) > -running on the same node. > -A different example would be a node containing both a DTS runtime > environment > -and a traffic generator, in which case it's both a DTS runtime > environment node and a TG node. > > > DTS Environment > @@ -195,12 +183,28 @@ These need to be set up on a Traffic Generator > Node: > Running DTS > ----------- > > -DTS needs to know which nodes to connect to and what hardware to > use on those nodes. > -Once that's configured, either a DPDK source code tarball or tree > folder > -need to be supplied whether these are on your DTS host machine or > the SUT node. > -DTS can accept a pre-compiled build placed in a subdirectory, > -or it will compile DPDK on the SUT node, > -and then run the tests with the newly built binaries. > +To run DTS, use ``main.py`` with Poetry: > + > +.. code-block:: console > + > + ```shell > + docker build --target dev -t dpdk-dts . > + docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/ > root/.ssh:ro -it dpdk-dts bash > + $ poetry install > + $ poetry run ./main.py > + ``` > + > +Common options include: > + > +- ``--output-dir``: Custom output location. > +- ``--remote-source``: Use sources stored on the SUT. > +- ``--tarball``: Specify the tarball to be tested. > + > +For a full list: > + > +.. code-block:: console > + > + poetry run ./main.py --help > > > I think we should keep the full list of flags here instead of removing > it for this subset. It's a bit of a maintenance burden and it make the > file longer but it's important info. I think it's good to present it > here even if it is only "a --help away." > > > > > Configuring DTS > @@ -220,71 +224,6 @@ The user must have :ref:`administrator > privileges <sut_admin_user>` > which don't require password authentication. > > > -DTS Execution > -~~~~~~~~~~~~~ > - > -DTS is run with ``main.py`` located in the ``dts`` directory after > entering Poetry shell: > - > -.. code-block:: console > - > - (dts-py3.10) $ ./main.py --help > - usage: main.py [-h] [--test-run-config-file FILE_PATH] [--nodes- > config-file FILE_PATH] [--tests-config-file FILE_PATH] > - [--output-dir DIR_PATH] [-t SECONDS] [-v] [-- > dpdk-tree DIR_PATH | --tarball FILE_PATH] [--remote-source] > - [--precompiled-build-dir DIR_NAME] [--compile- > timeout SECONDS] [--test-suite TEST_SUITE [TEST_CASES ...]] > - [--re-run N_TIMES] [--random-seed NUMBER] > - > - Run DPDK test suites. All options may be specified with the > environment variables provided in brackets. Command line arguments > have higher > - priority. > - > - options: > - -h, --help show this help message and exit > - --test-run-config-file FILE_PATH > - [DTS_TEST_RUN_CFG_FILE] The > configuration file that describes the test cases and DPDK build > options. (default: test-run.conf.yaml) > - --nodes-config-file FILE_PATH > - [DTS_NODES_CFG_FILE] The configuration > file that describes the SUT and TG nodes. (default: nodes.conf.yaml) > - --tests-config-file FILE_PATH > - [DTS_TESTS_CFG_FILE] Configuration file > used to override variable values inside specific test suites. > (default: None) > - --output-dir DIR_PATH, --output DIR_PATH > - [DTS_OUTPUT_DIR] Output directory where > DTS logs and results are saved. (default: output) > - -t SECONDS, --timeout SECONDS > - [DTS_TIMEOUT] The default timeout for > all DTS operations except for compiling DPDK. (default: 15) > - -v, --verbose [DTS_VERBOSE] Specify to enable verbose > output, logging all messages to the console. (default: False) > - --compile-timeout SECONDS > - [DTS_COMPILE_TIMEOUT] The timeout for > compiling DPDK. (default: 1200) > - --test-suite TEST_SUITE [TEST_CASES ...] > - [DTS_TEST_SUITES] A list containing a > test suite with test cases. The first parameter is the test suite > name, and > - the rest are test case names, which are > optional. May be specified multiple times. To specify multiple test > suites > - in the environment variable, join the > lists with a comma. Examples: --test-suite suite case case --test-suite > - suite case ... | DTS_TEST_SUITES='suite > case case, suite case, ...' | --test-suite suite --test-suite suite case > - ... | DTS_TEST_SUITES='suite, suite > case, ...' (default: []) > - --re-run N_TIMES, --re_run N_TIMES > - [DTS_RERUN] Re-run each test case the > specified number of times if a test failure occurs. (default: 0) > - --random-seed NUMBER [DTS_RANDOM_SEED] The seed to use with > the pseudo-random generator. If not specified, the configuration > value is > - used instead. If that's also not > specified, a random seed is generated. (default: None) > - > - DPDK Build Options: > - Arguments in this group (and subgroup) will be applied to a > DPDKLocation when the DPDK tree, tarball or revision will be provided, > - other arguments like remote source and build dir are optional. > A DPDKLocation from settings are used instead of from config if > - construct successful. > - > - --dpdk-tree DIR_PATH [DTS_DPDK_TREE] The path to the DPDK > source tree directory to test. Cannot be used in conjunction with -- > tarball. > - (default: None) > - --tarball FILE_PATH, --snapshot FILE_PATH > - [DTS_DPDK_TARBALL] The path to the DPDK > source tarball to test. DPDK must be contained in a folder with the same > - name as the tarball file. Cannot be used > in conjunction with --dpdk-tree. (default: None) > - --remote-source [DTS_REMOTE_SOURCE] Set this option if > either the DPDK source tree or tarball to be used are located on the SUT > - node. Can only be used with --dpdk-tree > or --tarball. (default: False) > - --precompiled-build-dir DIR_NAME > - [DTS_PRECOMPILED_BUILD_DIR] Define the > subdirectory under the DPDK tree root directory or tarball where the > pre- > - compiled binaries are located. (default: > None) > - > - > -The brackets contain the names of environment variables that set > the same thing. > -The minimum DTS needs is a config file and a pre-built DPDK > -or DPDK sources location which can be specified in said config file > -or on the command line or environment variables. > - > - > DTS Results > ~~~~~~~~~~~ > > @@ -308,140 +247,89 @@ Adding test cases may require adding code to > the framework as well. > Framework Coding Guidelines > ~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > -When adding code to the DTS framework, pay attention to the rest of > the code > -and try not to divert much from it. > -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings > -when some of the basics are not met. > -You should also build the :ref:`API documentation <building_api_docs>` > -to address any issues found during the build. > - > -The API documentation, which is a helpful reference when > developing, may be accessed > -in the code directly or generated with the :ref:`API docs build > steps <building_api_docs>`. > -When adding new files or modifying the directory structure, > -the corresponding changes must be made to DTS API doc sources in > ``doc/api/dts``. > - > -Speaking of which, the code must be properly documented with > docstrings. > -The style must conform to the `Google style > -<https://google.github.io/styleguide/pyguide.html#38-comments-and- > docstrings <https://google.github.io/styleguide/pyguide.html#38- > comments-and-docstrings>>`_. > -See an example of the style `here > -<https://www.sphinx-doc.org/en/master/usage/extensions/ > example_google.html <https://www.sphinx-doc.org/en/master/usage/ > extensions/example_google.html>>`_. > -For cases which are not covered by the Google style, refer to `PEP 257 > -<https://peps.python.org/pep-0257/ <https://peps.python.org/ > pep-0257/>>`_. > -There are some cases which are not covered by the two style guides, > -where we deviate or where some additional clarification is helpful: > - > - * The ``__init__()`` methods of classes are documented separately > - from the docstring of the class itself. > - * The docstrings of implemented abstract methods should refer to > the superclass's definition > - if there's no deviation. > - * Instance variables/attributes should be documented in the > docstring of the class > - in the ``Attributes:`` section. > - * The ``dataclass.dataclass`` decorator changes how the > attributes are processed. > - The dataclass attributes which result in instance variables/ > attributes > - should also be recorded in the ``Attributes:`` section. > - * Class variables/attributes and Pydantic model fields, on the > other hand, > - should be documented with ``#:`` above the type annotated line. > - The description may be omitted if the meaning is obvious. > - * The ``Enum`` and ``TypedDict`` also process the attributes in > particular ways > - and should be documented with ``#:`` as well. > - This is mainly so that the autogenerated documentation > contains the assigned value. > - * When referencing a parameter of a function or a method in > their docstring, > - don't use any articles and put the parameter into single > backticks. > - This mimics the style of `Python's documentation <https:// > docs.python.org/3/index.html <https://docs.python.org/3/index.html>>`_. > - * When specifying a value, use double backticks:: > - > - def foo(greet: bool) -> None: > - """Demonstration of single and double backticks. > - > - `greet` controls whether ``Hello World`` is printed. > - > - Args: > - greet: Whether to print the ``Hello World`` message. > - """ > - if greet: > - print(f"Hello World") > - > - * The docstring maximum line length is the same as the code > maximum line length. > - > - > -How To Write a Test Suite > -------------------------- > - > -All test suites inherit from ``TestSuite`` defined in ``dts/ > framework/test_suite.py``. > > > "All test suites are a class which inherits from" > > > -There are four types of methods that comprise a test suite: > - > -#. **Test cases** > - > - | Test cases are methods that start with a particular prefix. > - | Functional test cases start with ``test_``, e.g. > ``test_hello_world_single_core``. > > - | Performance test cases start with ``test_perf_``, e.g. > ``test_perf_nic_single_core``. > > > Now decorator based. > > > - | A test suite may have any number of functional and/or > performance test cases. > - However, these test cases must test the same feature, > - following the rule of one feature = one test suite. > - Test cases for one feature don't need to be grouped in just > one test suite, though. > - If the feature requires many testing scenarios to cover, > - the test cases would be better off spread over multiple test > suites > - so that each test suite doesn't take too long to execute. > - > -#. **Setup and Teardown methods** > - > - | There are setup and teardown methods for the whole test suite > and each individual test case. > - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed > - before any and after all test cases have been executed, > respectively. > - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will > be executed > - before and after each test case, respectively. > - | These methods don't need to be implemented if there's no need > for them in a test suite. > - In that case, nothing will happen when they are executed. > - > -#. **Configuration, traffic and other logic** > - > - The ``TestSuite`` class contains a variety of methods for > anything that > - a test suite setup, a teardown, or a test case may need to do. > - > - The test suites also frequently use a DPDK app, such as testpmd, > in interactive mode > - and use the interactive shell instances directly. > - > - These are the two main ways to call the framework logic in test > suites. > - If there's any functionality or logic missing from the framework, > - it should be implemented so that the test suites can use one of > these two ways. > - > -#. **Test case verification** > - > - Test case verification should be done with the ``verify`` > method, which records the result. > - The method should be called at the end of each test case. > - > -#. **Other methods** > > > I see that some of the content under "Other methods" is now false and > should be removed - thanks for doing so. However, I do think there was a > lot of good within the original "Test Cases," "Setup and Teardown > Methods," and "Configuration, traffic and other logic" which has been > removed. For this one I prefer if we just sit down and hash it out in > person when you're in next week. > > > - > - Of course, all test suite code should adhere to coding standards. > - Only the above methods will be treated specially and any other > methods may be defined > - (which should be mostly private methods needed by each > particular test suite). > - Any specific features (such as NIC configuration) required by a > test suite > - should be implemented in the ``SutNode`` class (and the > underlying classes that ``SutNode`` uses) > - and used by the test suite via the ``sut_node`` field. > +When contributing code to the DTS framework, follow existing > conventions to ensure consistency. > +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. > +Also, be sure to :ref:`build the API documentation > <building_api_docs>` to catch any problems during the build. > > +The API documentation is a helpful reference during development. > +It can be viewed in the code directly or generated using > the :ref:`API docs build steps <building_api_docs>`. > +If you add new files or change the directory structure, update the > corresponding sources in ``doc/api/dts``. > > -.. _dts_dev_tools: > +Code must be documented with docstrings that follow the > +`Google style <https://google.github.io/styleguide/pyguide.html#38- > comments-and-docstrings <https://google.github.io/styleguide/ > pyguide.html#38-comments-and-docstrings>>`_. > +Additional references: > > -DTS Developer Tools > -------------------- > +* `Sphinx Google style example <https://www.sphinx-doc.org/en/ > master/usage/extensions/example_google.html <https://www.sphinx- > doc.org/en/master/usage/extensions/example_google.html>>`_ > +* `PEP 257 <https://peps.python.org/pep-0257/ <https:// > peps.python.org/pep-0257/>>`_ > + > +Docstring and Attribute Guidelines > > -There are two tools used in DTS to help with code checking, style > and formatting: > +* Document ``__init__()`` separately from the class docstring. > +* If an abstract method simply implements a superclass definition > without changes, refer to that superclass in the docstring. > +* Document instance variables in the class docstring under an > ``Attributes:`` section. > +* For ``@dataclass`` classes, document instance-level attributes in > ``Attributes:``, as they are generated from the class fields. > +* Document class variables and Pydantic fields using ``#:``, > + placed above the type-annotated line. Descriptions may be > omitted if the meaning is clear. > +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so > that autogenerated documentation includes their values. > +* When referring to a parameter in a docstring, omit articles and > enclose the parameter in single backticks (e.g., `` `param` ``), > + consistent with the `Python documentation style <https:// > docs.python.org/3/index.html <https://docs.python.org/3/index.html>>`_. > +* Use double backticks (````value````) for literal values. > > -* `ruff <https://astral.sh/ruff/ <https://astral.sh/ruff/>>`_ > +Example:: > > - An extremely fast all-in-one linting and formatting solution, > - which covers most if not all the major rules such as: > - pylama, flake8, pylint etc. > - Its built-in formatter is also Black-compatible > - and is able to sort imports automatically like isort would. > + def foo(greet: bool) -> None: > + """Demonstrates single vs. double backticks. > > -* `mypy <https://github.com/python/mypy <https://github.com/python/ > mypy>>`_ > + `greet` controls whether ``Hello World`` is printed. > > - Enables static typing for Python, exploiting the type hints in > the source code. > + Args: > + greet: Whether to print the ``Hello World`` message. > + """ > + if greet: > + print("Hello World") > + > +The maximum line length for docstrings must match that of the code. > + > + > +Creating a Test Suite > +--------------------- > + > +All test suites inherit from ``TestSuite`` in ``dts/framework/ > test_suite.py``. A typical suite contains: > + > +- Test Cases > + - Functional: start with ``test_``, e.g., ``test_basic_link`` > + - Performance: start with ``test_perf_``, e.g., > ``test_perf_throughput`` > > > I realize you go on to describe the decorators after this, but I think > the test_func and test_perf naming convention is no longer required. > Example: > > @requires(NicCapability.FLOW_CTRL) > @func_test > def flow_ctrl_port_configuration_persistence(self) -> None: > """Flow control port configuration persistency test. > > Steps: > For each port enable flow control for RX and TX individually. > Verify: > The configuration persists after the port is restarted. > """ > > > > + - Import the ``func_test`` and/or ``perf_test`` decorators from > ``TestSuite`` and add them above each test case method, > + e.g., ``@func_test`` followed by ``test_basic_link`` > + > +- Setup/Teardown Hooks > + - Suite-level: ``set_up_suite()``, ``tear_down_suite()`` > + - Case-level: ``set_up_test_case()``, ``tear_down_test_case()`` > + > +- Verification > + Use ``self.verify(condition, message)`` to record test results. > > > I think the important part of "verify" to explain to people is that you > are setting the testcase assertion condition, not the recording aspect. > > > + > +- Support Methods > + Helper logic (e.g., traffic handling, config) should be in > private methods or delegated to ``sut_node``. > > > I realize this is just a rewording that crept in, but this is wrong for > a couple reasons: > > 1. We no longer import node/sutnode when writing testsuites. Node > is purely framework code now, and is not exposed to testsuites. > 2. sut_node (and tg_node) no longer exists. > > > + > + > +.. _dts_dev_tools: > + > +Developer Tools > +--------------- > + > +- ruff > + - Linter and formatter (replaces flake8, pylint, isort, etc.) > + - Compatible with Black > + > +- mypy > + - Performs static type checking > + > +Run checks using: > + > +.. code-block:: console > > -These two tools are all used in ``devtools/dts-check-format.sh``, > -the DTS code check and format script. > -Refer to the script for usage: ``devtools/dts-check-format.sh -h``. > + devtools/dts-check-format.sh > > > .. _building_api_docs: > -- > 2.49.0 > > > Lots of improvements overall - keep up the good work! A productive > Summer ahead. > > Reviewed-by: Patrick Robb <probb@iol.unh.edu <mailto:probb@iol.unh.edu>> > ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v2 1/2] dts: rewrite README 2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx 2025-05-28 21:25 ` Patrick Robb @ 2025-06-03 17:28 ` Dean Marx 2025-06-03 17:28 ` [PATCH v2 2/2] dts: rewrite dts rst Dean Marx ` (2 more replies) 1 sibling, 3 replies; 39+ messages in thread From: Dean Marx @ 2025-06-03 17:28 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Remove unnecessary information from README.md, and add new sections to clarify the purpose/use of DTS along with clear setup instructions. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 115 +++++++++++++++++++++++++------------------------- 1 file changed, 57 insertions(+), 58 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..224a7aa20b 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,66 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +1. 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +2. 1 links topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are both located on one +network interface. An example of this would be a dual interface NIC with a connection between +its own ports. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user. In this example I will name the user "dts." +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Download Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -76,6 +75,6 @@ will mount the SSH keys of the user currently running VSCode into the container The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. -### Other +## Other -Searching for '$IDE dev containers' will probably lead you in the right direction. +Searching for '$IDE dev containers' will probably lead you in the right direction. \ No newline at end of file -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v2 2/2] dts: rewrite dts rst 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx @ 2025-06-03 17:28 ` Dean Marx 2025-06-25 4:07 ` Patrick Robb 2025-06-25 4:06 ` [PATCH v2 1/2] dts: rewrite README Patrick Robb 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx 2 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-06-03 17:28 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Modify dts.rst to exclude redundant/outdated information about the project, and add new information regarding setup and framework design. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- doc/guides/tools/dts.rst | 372 +++++++++++++++++---------------------- 1 file changed, 162 insertions(+), 210 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index fcc6d22036..b08041f28d 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT; can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -55,6 +47,70 @@ DTS uses Poetry as its Python dependency management. Python build/development and runtime environments are the same and DTS development environment, DTS runtime environment or just plain DTS environment are used interchangeably. +DTS Execution +------------- + +DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: + +.. code-block:: console + + (dts-py3.10) $ ./main.py --help + usage: main.py [-h] [--test-run-config-file FILE_PATH] [--nodes-config-file FILE_PATH] [--tests-config-file FILE_PATH] + [--output-dir DIR_PATH] [-t SECONDS] [-v] [--dpdk-tree DIR_PATH | --tarball FILE_PATH] [--remote-source] + [--precompiled-build-dir DIR_NAME] [--compile-timeout SECONDS] [--test-suite TEST_SUITE [TEST_CASES ...]] + [--re-run N_TIMES] [--random-seed NUMBER] + + Run DPDK test suites. All options may be specified with the environment variables provided in brackets. Command line arguments have higher + priority. + + options: + -h, --help show this help message and exit + --test-run-config-file FILE_PATH + [DTS_TEST_RUN_CFG_FILE] The configuration file that describes the test cases and DPDK build options. (default: test-run.conf.yaml) + --nodes-config-file FILE_PATH + [DTS_NODES_CFG_FILE] The configuration file that describes the SUT and TG nodes. (default: nodes.conf.yaml) + --tests-config-file FILE_PATH + [DTS_TESTS_CFG_FILE] Configuration file used to override variable values inside specific test suites. (default: None) + --output-dir DIR_PATH, --output DIR_PATH + [DTS_OUTPUT_DIR] Output directory where DTS logs and results are saved. (default: output) + -t SECONDS, --timeout SECONDS + [DTS_TIMEOUT] The default timeout for all DTS operations except for compiling DPDK. (default: 15) + -v, --verbose [DTS_VERBOSE] Specify to enable verbose output, logging all messages to the console. (default: False) + --compile-timeout SECONDS + [DTS_COMPILE_TIMEOUT] The timeout for compiling DPDK. (default: 1200) + --test-suite TEST_SUITE [TEST_CASES ...] + [DTS_TEST_SUITES] A list containing a test suite with test cases. The first parameter is the test suite name, and + the rest are test case names, which are optional. May be specified multiple times. To specify multiple test suites + in the environment variable, join the lists with a comma. Examples: --test-suite suite case --test-suite + suite case ... | DTS_TEST_SUITES='suite case, suite case, ...' | --test-suite suite --test-suite suite case + ... | DTS_TEST_SUITES='suite, suite case, ...' (default: []) + --re-run N_TIMES, --re_run N_TIMES + [DTS_RERUN] Re-run each test case the specified number of times if a test failure occurs. (default: 0) + --random-seed NUMBER [DTS_RANDOM_SEED] The seed to use with the pseudo-random generator. If not specified, the configuration value is + used instead. If that's also not specified, a random seed is generated. (default: None) + + DPDK Build Options: + Arguments in this group (and subgroup) will be applied to a DPDKLocation when the DPDK tree, tarball or revision will be provided, + other arguments like remote source and build dir are optional. A DPDKLocation from settings are used instead of from config if + construct successful. + + --dpdk-tree DIR_PATH [DTS_DPDK_TREE] The path to the DPDK source tree directory to test. Cannot be used in conjunction with --tarball. + (default: None) + --tarball FILE_PATH, --snapshot FILE_PATH + [DTS_DPDK_TARBALL] The path to the DPDK source tarball to test. DPDK must be contained in a folder with the same + name as the tarball file. Cannot be used in conjunction with --dpdk-tree. (default: None) + --remote-source [DTS_REMOTE_SOURCE] Set this option if either the DPDK source tree or tarball to be used are located on the SUT + node. Can only be used with --dpdk-tree or --tarball. (default: False) + --precompiled-build-dir DIR_NAME + [DTS_PRECOMPILED_BUILD_DIR] Define the subdirectory under the DPDK tree root directory or tarball where the pre- + compiled binaries are located. (default: None) + + +The brackets contain the names of environment variables that set the same thing. +The minimum DTS needs is a config file and a pre-built DPDK +or DPDK sources location which can be specified in said config file +or on the command line or environment variables. + .. _dts_deps: Setting up DTS environment @@ -195,12 +251,28 @@ These need to be set up on a Traffic Generator Node: Running DTS ----------- -DTS needs to know which nodes to connect to and what hardware to use on those nodes. -Once that's configured, either a DPDK source code tarball or tree folder -need to be supplied whether these are on your DTS host machine or the SUT node. -DTS can accept a pre-compiled build placed in a subdirectory, -or it will compile DPDK on the SUT node, -and then run the tests with the newly built binaries. +To run DTS, use ``main.py`` with Poetry: + +.. code-block:: console + + ```shell + docker build --target dev -t dpdk-dts . + docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash + $ poetry install + $ poetry run ./main.py + ``` + +Common options include: + +- ``--output-dir``: Custom output location. +- ``--remote-source``: Use sources stored on the SUT. +- ``--tarball``: Specify the tarball to be tested. + +For a full list: + +.. code-block:: console + + poetry run ./main.py --help Configuring DTS @@ -220,71 +292,6 @@ The user must have :ref:`administrator privileges <sut_admin_user>` which don't require password authentication. -DTS Execution -~~~~~~~~~~~~~ - -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: - -.. code-block:: console - - (dts-py3.10) $ ./main.py --help - usage: main.py [-h] [--test-run-config-file FILE_PATH] [--nodes-config-file FILE_PATH] [--tests-config-file FILE_PATH] - [--output-dir DIR_PATH] [-t SECONDS] [-v] [--dpdk-tree DIR_PATH | --tarball FILE_PATH] [--remote-source] - [--precompiled-build-dir DIR_NAME] [--compile-timeout SECONDS] [--test-suite TEST_SUITE [TEST_CASES ...]] - [--re-run N_TIMES] [--random-seed NUMBER] - - Run DPDK test suites. All options may be specified with the environment variables provided in brackets. Command line arguments have higher - priority. - - options: - -h, --help show this help message and exit - --test-run-config-file FILE_PATH - [DTS_TEST_RUN_CFG_FILE] The configuration file that describes the test cases and DPDK build options. (default: test-run.conf.yaml) - --nodes-config-file FILE_PATH - [DTS_NODES_CFG_FILE] The configuration file that describes the SUT and TG nodes. (default: nodes.conf.yaml) - --tests-config-file FILE_PATH - [DTS_TESTS_CFG_FILE] Configuration file used to override variable values inside specific test suites. (default: None) - --output-dir DIR_PATH, --output DIR_PATH - [DTS_OUTPUT_DIR] Output directory where DTS logs and results are saved. (default: output) - -t SECONDS, --timeout SECONDS - [DTS_TIMEOUT] The default timeout for all DTS operations except for compiling DPDK. (default: 15) - -v, --verbose [DTS_VERBOSE] Specify to enable verbose output, logging all messages to the console. (default: False) - --compile-timeout SECONDS - [DTS_COMPILE_TIMEOUT] The timeout for compiling DPDK. (default: 1200) - --test-suite TEST_SUITE [TEST_CASES ...] - [DTS_TEST_SUITES] A list containing a test suite with test cases. The first parameter is the test suite name, and - the rest are test case names, which are optional. May be specified multiple times. To specify multiple test suites - in the environment variable, join the lists with a comma. Examples: --test-suite suite case case --test-suite - suite case ... | DTS_TEST_SUITES='suite case case, suite case, ...' | --test-suite suite --test-suite suite case - ... | DTS_TEST_SUITES='suite, suite case, ...' (default: []) - --re-run N_TIMES, --re_run N_TIMES - [DTS_RERUN] Re-run each test case the specified number of times if a test failure occurs. (default: 0) - --random-seed NUMBER [DTS_RANDOM_SEED] The seed to use with the pseudo-random generator. If not specified, the configuration value is - used instead. If that's also not specified, a random seed is generated. (default: None) - - DPDK Build Options: - Arguments in this group (and subgroup) will be applied to a DPDKLocation when the DPDK tree, tarball or revision will be provided, - other arguments like remote source and build dir are optional. A DPDKLocation from settings are used instead of from config if - construct successful. - - --dpdk-tree DIR_PATH [DTS_DPDK_TREE] The path to the DPDK source tree directory to test. Cannot be used in conjunction with --tarball. - (default: None) - --tarball FILE_PATH, --snapshot FILE_PATH - [DTS_DPDK_TARBALL] The path to the DPDK source tarball to test. DPDK must be contained in a folder with the same - name as the tarball file. Cannot be used in conjunction with --dpdk-tree. (default: None) - --remote-source [DTS_REMOTE_SOURCE] Set this option if either the DPDK source tree or tarball to be used are located on the SUT - node. Can only be used with --dpdk-tree or --tarball. (default: False) - --precompiled-build-dir DIR_NAME - [DTS_PRECOMPILED_BUILD_DIR] Define the subdirectory under the DPDK tree root directory or tarball where the pre- - compiled binaries are located. (default: None) - - -The brackets contain the names of environment variables that set the same thing. -The minimum DTS needs is a config file and a pre-built DPDK -or DPDK sources location which can be specified in said config file -or on the command line or environment variables. - - DTS Results ~~~~~~~~~~~ @@ -308,140 +315,85 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. - - -How To Write a Test Suite -------------------------- - -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: - -#. **Test cases** - - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. - -#. **Setup and Teardown methods** - - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. - -#. **Configuration, traffic and other logic** - - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. - - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. - - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. - -#. **Test case verification** - - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. - -#. **Other methods** - - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks (e.g., `` `param` ``), + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks (````value````) for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single vs. double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. + + +Creating a Test Suite +--------------------- + +All test suites are a class which inherits from ``TestSuite`` in ``dts/framework/test_suite.py``. A typical suite contains: + +- Test Cases + - Import the ``func_test`` and/or ``perf_test`` decorators from ``TestSuite`` and add them above each test case method, + e.g., ``@func_test`` followed by ``test_basic_link`` + +- Setup/Teardown Hooks + - Suite-level: ``set_up_suite()``, ``tear_down_suite()`` + - Case-level: ``set_up_test_case()``, ``tear_down_test_case()`` + +- Verification + - Use ``self.verify(condition, message)`` to set the testcase assertion condition. .. _dts_dev_tools: -DTS Developer Tools -------------------- -There are two tools used in DTS to help with code checking, style and formatting: +Developer Tools +--------------- -* `ruff <https://astral.sh/ruff/>`_ +- ruff + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. +- mypy + - Performs static type checking -* `mypy <https://github.com/python/mypy>`_ +Run checks using: - Enables static typing for Python, exploiting the type hints in the source code. +.. code-block:: console -These two tools are all used in ``devtools/dts-check-format.sh``, -the DTS code check and format script. -Refer to the script for usage: ``devtools/dts-check-format.sh -h``. + devtools/dts-check-format.sh .. _building_api_docs: -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v2 2/2] dts: rewrite dts rst 2025-06-03 17:28 ` [PATCH v2 2/2] dts: rewrite dts rst Dean Marx @ 2025-06-25 4:07 ` Patrick Robb 2025-07-09 19:57 ` Thomas Monjalon 0 siblings, 1 reply; 39+ messages in thread From: Patrick Robb @ 2025-06-25 4:07 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 34 bytes --] Applied to next-dts, thanks Dean. [-- Attachment #2: Type: text/html, Size: 55 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v2 2/2] dts: rewrite dts rst 2025-06-25 4:07 ` Patrick Robb @ 2025-07-09 19:57 ` Thomas Monjalon 2025-07-11 14:58 ` Patrick Robb 0 siblings, 1 reply; 39+ messages in thread From: Thomas Monjalon @ 2025-07-09 19:57 UTC (permalink / raw) To: Dean Marx, Patrick Robb Cc: dev, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev 25/06/2025 06:07, Patrick Robb: > Applied to next-dts, thanks Dean. I'm almost sure it has overriden some doc added recently by Nicholas Pratte. Anyway it is too difficult to understand what is changed in this series, because there are too many unrelated changes. I prefer not pulling this series in the main branch for now. Please split the patches with clear explanation of what is changed and why. Thanks ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v2 2/2] dts: rewrite dts rst 2025-07-09 19:57 ` Thomas Monjalon @ 2025-07-11 14:58 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-11 14:58 UTC (permalink / raw) To: Thomas Monjalon Cc: Dean Marx, dev, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek [-- Attachment #1: Type: text/plain, Size: 853 bytes --] On Wed, Jul 9, 2025 at 3:57 PM Thomas Monjalon <thomas@monjalon.net> wrote: > 25/06/2025 06:07, Patrick Robb: > > Applied to next-dts, thanks Dean. > > I'm almost sure it has overriden some doc added recently by Nicholas > Pratte. > Good catch. It removed some sentences explaining usage of tests_config.yaml (where you can provide testsuites specific config values). Sorry about that. Dean is writing a new patch which adds that back in, along with a couple other parts of the "How to write a testsuite" section which were dropped. > > Anyway it is too difficult to understand what is changed in this series, > because there are too many unrelated changes. > > I prefer not pulling this series in the main branch for now. > Please split the patches with clear explanation of what is changed and why. > > Thanks > > > [-- Attachment #2: Type: text/html, Size: 1408 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v2 1/2] dts: rewrite README 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx 2025-06-03 17:28 ` [PATCH v2 2/2] dts: rewrite dts rst Dean Marx @ 2025-06-25 4:06 ` Patrick Robb 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx 2 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-06-25 4:06 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 34 bytes --] Applied to next-dts, thanks Dean. [-- Attachment #2: Type: text/html, Size: 55 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v3 1/3] dts: rewrite README 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx 2025-06-03 17:28 ` [PATCH v2 2/2] dts: rewrite dts rst Dean Marx 2025-06-25 4:06 ` [PATCH v2 1/2] dts: rewrite README Patrick Robb @ 2025-07-11 17:24 ` Dean Marx 2025-07-11 17:24 ` [PATCH v3 2/3] doc: rephrase terminology in dts.rst Dean Marx ` (3 more replies) 2 siblings, 4 replies; 39+ messages in thread From: Dean Marx @ 2025-07-11 17:24 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Remove unnecessary information from README.md, and add new sections to clarify the purpose/use of DTS along with clear setup instructions. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 115 +++++++++++++++++++++++++------------------------- 1 file changed, 57 insertions(+), 58 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..1345f03df0 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,66 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +1. 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +2. 1 links topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are both located on one +network interface. An example of this would be a dual interface NIC with a connection between +its own ports. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user. In this example I will name the user "dts." +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](../doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Download Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -76,6 +75,6 @@ will mount the SSH keys of the user currently running VSCode into the container The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. -### Other +## Other -Searching for '$IDE dev containers' will probably lead you in the right direction. +Searching for '$IDE dev containers' will probably lead you in the right direction. \ No newline at end of file -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v3 2/3] doc: rephrase terminology in dts.rst 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx @ 2025-07-11 17:24 ` Dean Marx 2025-07-14 14:10 ` Patrick Robb 2025-07-11 17:24 ` [PATCH v3 3/3] doc: revise coding guidelines section Dean Marx ` (2 subsequent siblings) 3 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-07-11 17:24 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Rephrase some of the DTS tool/term definitions to be more concise. These sections were unnecessarily verbose and can be conveyed in a clearer way. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> --- doc/guides/tools/dts.rst | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 016dc5e374..7f6f7c1db5 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT; can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -481,17 +473,12 @@ DTS Developer Tools There are two tools used in DTS to help with code checking, style and formatting: -* `ruff <https://astral.sh/ruff/>`_ - - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. - -* `mypy <https://github.com/python/mypy>`_ +ruff: + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - Enables static typing for Python, exploiting the type hints in the source code. +mypy: + - Performs static type checking These two tools are all used in ``devtools/dts-check-format.sh``, the DTS code check and format script. -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v3 2/3] doc: rephrase terminology in dts.rst 2025-07-11 17:24 ` [PATCH v3 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-14 14:10 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-14 14:10 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 590 bytes --] On Fri, Jul 11, 2025 at 1:25 PM Dean Marx <dmarx@iol.unh.edu> wrote: > > System under test node > A node where at least one SUT is present. > > Traffic generator > - A TG is either software or hardware capable of sending packets. > + Node that sends traffic to the SUT; can be hardware or software-based. Not to be a grammar nitpicker but I believe semicolons separate independent clauses. Maybe just change to: Node that sends traffic to the SUT, which can be hardware or software-based. > > > 2.49.0 > > Reviewed-by: Patrick Robb <probb@iol.unh.edu> [-- Attachment #2: Type: text/html, Size: 1197 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v3 3/3] doc: revise coding guidelines section 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx 2025-07-11 17:24 ` [PATCH v3 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-11 17:24 ` Dean Marx 2025-07-14 16:22 ` Patrick Robb 2025-07-11 21:22 ` [PATCH v3 1/3] dts: rewrite README Patrick Robb 2025-07-14 17:13 ` [PATCH v4 " Dean Marx 3 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-07-11 17:24 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx The Framework Coding Guidelines section includes outdated information about DTS and how to write a test suite. Updated these points to include the new test case decorators and setup/teardown hooks. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> --- doc/guides/tools/dts.rst | 181 ++++++++++++++++++--------------------- 1 file changed, 84 insertions(+), 97 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 7f6f7c1db5..6af9f8b75c 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -348,122 +348,109 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks (e.g., `` `param` ``), + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks (````value````) for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single vs. double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. How To Write a Test Suite ------------------------- -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: +All test suites are classes that inherit from TestSuite, defined in dts/framework/test_suite.py. A typical suite contains: + +Test Cases + + Test cases are defined as methods and must be decorated appropriately. + Use the @func_test and/or @perf_test decorators from TestSuite above each test case method. + For example: @func_test followed by def test_basic_link(self): + + Functional test cases should use the @func_test decorator, and performance test cases should use @perf_test. + A test suite may include any number of functional and/or performance test cases. + Each suite should focus on testing a single feature (one feature = one test suite). + If a feature requires extensive testing scenarios, it's better to split the test cases across multiple test suites to reduce execution time. + +Setup and Teardown Hooks + + Setup and teardown methods can be defined at both the suite and test case levels. + + Suite-level: + + * set_up_suite() — runs once before any test cases in the suite + + * tear_down_suite() — runs once after all test cases have completed -#. **Test cases** + Case-level: - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. + * set_up_test_case() — runs before each individual test case -#. **Setup and Teardown methods** + * tear_down_test_case() — runs after each individual test case - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. + These methods are optional. If not implemented, the framework will simply skip them. -#. **Configuration, traffic and other logic** +Configuration, Traffic, and Other Logic - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. + The TestSuite class provides a variety of methods for setup, teardown, and test logic. + Test suites often use DPDK applications (e.g., testpmd) in interactive mode and interact with them via shell instances. - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. +Framework logic should be used in one of two ways: - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. +* Using built-in methods provided by TestSuite or its base classes - Test suites may also be configured individually using a file provided at the command line. - The file is a simple mapping of test suite names to their corresponding configurations. +* Interacting directly with tools or shell interfaces - Any test suite can be designed to require custom configuration attributes or optional ones. - Any optional attributes should supply a default value for the test suite to use. +If any required functionality is missing, it should be implemented in a way that supports one of these two approaches. -#. **Test case verification** +Test Case Verification - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. + Use the verify method to assert conditions and record test results. + This should typically be called at the end of each test case. + Example: self.verify(link_up, "Link should be up after configuration.") -#. **Other methods** +Other Methods - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. + All test suite code should follow the project's coding standards. + Only test cases, setup/teardown hooks, and verification methods are treated specially by the framework. + Additional methods may be defined as needed (ideally private). + Any specific features (such as NIC configuration) should be implemented in the SutNode class or its supporting classes, and accessed using the sut_node field. .. _dts_dev_tools: -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v3 3/3] doc: revise coding guidelines section 2025-07-11 17:24 ` [PATCH v3 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-14 16:22 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-14 16:22 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 13967 bytes --] On Fri, Jul 11, 2025 at 1:25 PM Dean Marx <dmarx@iol.unh.edu> wrote: > The Framework Coding Guidelines section includes outdated information > about DTS and how to write a test suite. Updated these points to include > the new test case decorators and setup/teardown hooks. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > --- > doc/guides/tools/dts.rst | 181 ++++++++++++++++++--------------------- > 1 file changed, 84 insertions(+), 97 deletions(-) > > diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst > index 7f6f7c1db5..6af9f8b75c 100644 > --- a/doc/guides/tools/dts.rst > +++ b/doc/guides/tools/dts.rst > @@ -348,122 +348,109 @@ Adding test cases may require adding code to the > framework as well. > Framework Coding Guidelines > ~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > -When adding code to the DTS framework, pay attention to the rest of the > code > -and try not to divert much from it. > -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings > -when some of the basics are not met. > -You should also build the :ref:`API documentation <building_api_docs>` > -to address any issues found during the build. > - > -The API documentation, which is a helpful reference when developing, may > be accessed > -in the code directly or generated with the :ref:`API docs build steps > <building_api_docs>`. > -When adding new files or modifying the directory structure, > -the corresponding changes must be made to DTS API doc sources in > ``doc/api/dts``. > - > -Speaking of which, the code must be properly documented with docstrings. > -The style must conform to the `Google style > -< > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > -See an example of the style `here > -< > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_. > -For cases which are not covered by the Google style, refer to `PEP 257 > -<https://peps.python.org/pep-0257/>`_. > -There are some cases which are not covered by the two style guides, > -where we deviate or where some additional clarification is helpful: > - > - * The ``__init__()`` methods of classes are documented separately > - from the docstring of the class itself. > - * The docstrings of implemented abstract methods should refer to the > superclass's definition > - if there's no deviation. > - * Instance variables/attributes should be documented in the docstring > of the class > - in the ``Attributes:`` section. > - * The ``dataclass.dataclass`` decorator changes how the attributes are > processed. > - The dataclass attributes which result in instance > variables/attributes > - should also be recorded in the ``Attributes:`` section. > - * Class variables/attributes and Pydantic model fields, on the other > hand, > - should be documented with ``#:`` above the type annotated line. > - The description may be omitted if the meaning is obvious. > - * The ``Enum`` and ``TypedDict`` also process the attributes in > particular ways > - and should be documented with ``#:`` as well. > - This is mainly so that the autogenerated documentation contains the > assigned value. > - * When referencing a parameter of a function or a method in their > docstring, > - don't use any articles and put the parameter into single backticks. > - This mimics the style of `Python's documentation < > https://docs.python.org/3/index.html>`_. > - * When specifying a value, use double backticks:: > - > - def foo(greet: bool) -> None: > - """Demonstration of single and double backticks. > - > - `greet` controls whether ``Hello World`` is printed. > - > - Args: > - greet: Whether to print the ``Hello World`` message. > - """ > - if greet: > - print(f"Hello World") > - > - * The docstring maximum line length is the same as the code maximum > line length. > +When contributing code to the DTS framework, follow existing conventions > to ensure consistency. > +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. > +Also, be sure to :ref:`build the API documentation <building_api_docs>` > to catch any problems during the build. > + > +The API documentation is a helpful reference during development. > +It can be viewed in the code directly or generated using the :ref:`API > docs build steps <building_api_docs>`. > +If you add new files or change the directory structure, update the > corresponding sources in ``doc/api/dts``. > + > +Code must be documented with docstrings that follow the > +`Google style < > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > +Additional references: > + > +* `Sphinx Google style example < > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_ > +* `PEP 257 <https://peps.python.org/pep-0257/>`_ > + > +Docstring and Attribute Guidelines > + > +* Document ``__init__()`` separately from the class docstring. > +* If an abstract method simply implements a superclass definition without > changes, refer to that superclass in the docstring. > +* Document instance variables in the class docstring under an > ``Attributes:`` section. > +* For ``@dataclass`` classes, document instance-level attributes in > ``Attributes:``, as they are generated from the class fields. > +* Document class variables and Pydantic fields using ``#:``, > + placed above the type-annotated line. Descriptions may be omitted if > the meaning is clear. > +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that > autogenerated documentation includes their values. > +* When referring to a parameter in a docstring, omit articles and enclose > the parameter in single backticks (e.g., `` `param` ``), > + consistent with the `Python documentation style < > https://docs.python.org/3/index.html>`_. > +* Use double backticks (````value````) for literal values. > + > +Example:: > + > + def foo(greet: bool) -> None: > + """Demonstrates single vs. double backticks. > single AND double > + > + `greet` controls whether ``Hello World`` is printed. > + > + Args: > + greet: Whether to print the ``Hello World`` message. > + """ > + if greet: > + print("Hello World") > + > +The maximum line length for docstrings must match that of the code. > > > How To Write a Test Suite > ------------------------- > > -All test suites inherit from ``TestSuite`` defined in > ``dts/framework/test_suite.py``. > -There are four types of methods that comprise a test suite: > +All test suites are classes that inherit from TestSuite, defined in > dts/framework/test_suite.py. A typical suite contains: > + > +Test Cases > + > + Test cases are defined as methods and must be decorated appropriately. > + Use the @func_test and/or @perf_test decorators from TestSuite above > each test case method. > + For example: @func_test followed by def test_basic_link(self): > I think you should either not attempt to provide a literal example, or, if you are going to do so, then show it in normal syntax i.e.: @func_test def test_basic_link(self): """your testcase docstring here""" #your testcase code here > + > + Functional test cases should use the @func_test decorator, and > performance test cases should use @perf_test. > + A test suite may include any number of functional and/or performance > test cases. > + Each suite should focus on testing a single feature (one feature = one > test suite). > + If a feature requires extensive testing scenarios, it's better to > split the test cases across multiple test suites to reduce execution time. > Can you remove this last line about execution time? It doesn't sound true to me (the execution time will be the same). > + > +Setup and Teardown Hooks > + > + Setup and teardown methods can be defined at both the suite and test > case levels. > + > + Suite-level: > + > + * set_up_suite() — runs once before any test cases in the suite > + > + * tear_down_suite() — runs once after all test cases have completed > > -#. **Test cases** > + Case-level: > > - | Test cases are methods that start with a particular prefix. > - | Functional test cases start with ``test_``, e.g. > ``test_hello_world_single_core``. > - | Performance test cases start with ``test_perf_``, e.g. > ``test_perf_nic_single_core``. > - | A test suite may have any number of functional and/or performance > test cases. > - However, these test cases must test the same feature, > - following the rule of one feature = one test suite. > - Test cases for one feature don't need to be grouped in just one test > suite, though. > - If the feature requires many testing scenarios to cover, > - the test cases would be better off spread over multiple test suites > - so that each test suite doesn't take too long to execute. > + * set_up_test_case() — runs before each individual test case > > -#. **Setup and Teardown methods** > + * tear_down_test_case() — runs after each individual test case > > - | There are setup and teardown methods for the whole test suite and > each individual test case. > - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed > - before any and after all test cases have been executed, respectively. > - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be > executed > - before and after each test case, respectively. > - | These methods don't need to be implemented if there's no need for > them in a test suite. > - In that case, nothing will happen when they are executed. > + These methods are optional. If not implemented, the framework will > simply skip them. > > -#. **Configuration, traffic and other logic** > +Configuration, Traffic, and Other Logic > Your section below does not say anything about configuration, so remove configuration from the header above. Also, it's unclear (to people who dont write/read lots of DTS) that "Traffic" is encompassed by the TestSuite class methods (like send_packet_and_capture). > > - The ``TestSuite`` class contains a variety of methods for anything that > - a test suite setup, a teardown, or a test case may need to do. > + The TestSuite class provides a variety of methods for setup, teardown, > and test logic. > + Test suites often use DPDK applications (e.g., testpmd) in interactive > mode and interact with them via shell instances. > > - The test suites also frequently use a DPDK app, such as testpmd, in > interactive mode > - and use the interactive shell instances directly. > +Framework logic should be used in one of two ways: > I think what this section is trying to say is that there is an API surface for the testsuite writer, and that is the TestSuite classes and DPDK apps. > > - These are the two main ways to call the framework logic in test suites. > - If there's any functionality or logic missing from the framework, > - it should be implemented so that the test suites can use one of these > two ways. > +* Using built-in methods provided by TestSuite or its base classes > > - Test suites may also be configured individually using a file provided > at the command line. > - The file is a simple mapping of test suite names to their > corresponding configurations. > +* Interacting directly with tools or shell interfaces > > - Any test suite can be designed to require custom configuration > attributes or optional ones. > - Any optional attributes should supply a default value for the test > suite to use. > +If any required functionality is missing, it should be implemented in a > way that supports one of these two approaches. > > Should this be indented since it is under the section "Framework logic should be used in one of two ways:" (although that section name should be renamed per the earlier comment). > -#. **Test case verification** > +Test Case Verification > > - Test case verification should be done with the ``verify`` method, > which records the result. > - The method should be called at the end of each test case. > + Use the verify method to assert conditions and record test results. > + This should typically be called at the end of each test case. > + Example: self.verify(link_up, "Link should be up after configuration.") > > -#. **Other methods** > +Other Methods > > - Of course, all test suite code should adhere to coding standards. > - Only the above methods will be treated specially and any other methods > may be defined > - (which should be mostly private methods needed by each particular test > suite). > - Any specific features (such as NIC configuration) required by a test > suite > - should be implemented in the ``SutNode`` class (and the underlying > classes that ``SutNode`` uses) > - and used by the test suite via the ``sut_node`` field. > + All test suite code should follow the project's coding standards. > + Only test cases, setup/teardown hooks, and verification methods are > treated specially by the framework. > + Additional methods may be defined as needed (ideally private). > + Any specific features (such as NIC configuration) should be > implemented in the SutNode class or its supporting classes, and accessed > using the sut_node field. > There's no such class as SutNode anymore. > > > .. _dts_dev_tools: > -- > 2.49.0 > > Also, this series should adjust the poetry section to explain that "poetry shell" is deprecated now and one must use "poetry run" instead. Reviewed-by: Patrick Robb <probb@iol.unh.edu> [-- Attachment #2: Type: text/html, Size: 17279 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v3 1/3] dts: rewrite README 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx 2025-07-11 17:24 ` [PATCH v3 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-11 17:24 ` [PATCH v3 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-11 21:22 ` Patrick Robb 2025-07-14 14:47 ` Dean Marx 2025-07-14 17:13 ` [PATCH v4 " Dean Marx 3 siblings, 1 reply; 39+ messages in thread From: Patrick Robb @ 2025-07-11 21:22 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 7106 bytes --] On Fri, Jul 11, 2025 at 1:25 PM Dean Marx <dmarx@iol.unh.edu> wrote: > Remove unnecessary information from README.md, > I would call the dropped information "extraneous". > and add new sections to clarify the purpose/use > of DTS along with clear setup instructions. > Maybe say that the goal of the commit is refactoring the README to be a document which contains only a high level description of the relevant concepts in DTS and a simple getting started guide. > > + > +1. 2 links topology: Represents a topology in which the TG node and SUT > node both have two network interfaces > +which form the TG <-> SUT connection. An example of this would be a dual > interface NIC which is the > +TG node connected to a dual interface NIC which is the SUT node. > Interface 0 on TG <-> interface 0 > +on SUT, interface 1 on TG <-> interface 1 on SUT. > +2. 1 links topology: Works, but may result in skips for testsuites which > are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT > node are both located on one > +network interface. An example of this would be a dual interface NIC with > a connection between > +its own ports. > 1 links -> 1 link And the phrasing seems slightly off. Can you reword the 1 link topology to: "Represents a topology in which the TG node and SUT node are connected over a single networking link. An example of this would be two single interface NICs directly connected to each other." or similar to this phrasing. And, maybe make this an unordered list? the "1. 2" and "2. 1" thing looks a touch weird. Not a big deal but probably worth doing: https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax#lists Also, I never did get a response from you about whether it would be good to include some ascii art to depict these topologies :) You don't have to be a fan, but it would be good to get your opinion. If you think it's a good idea, can you add a bugzilla ticket so we can do this during 25.11? If you're opposed I'm okay with it - ultimately the wording should make the valid topologies clear enough to people. It's not something we can add during RC4 in any case. 2 link topology: +------------------------------+ +------------------------------+ | | | | | | --------------- | | | | | | | Tester (Traffic Generator) | | System Under Test | | | | | | | --------------- | | | | | | +------------------------------+ +------------------------------+ 1 link topology: +------------------------------+ +------------------------------+ | | | | | | --------------- | | | | | | | Tester (Traffic Generator) | | System Under Test | | | | | | | | | | | | | +------------------------------+ +------------------------------+ 2 link topology on a single host: ----------------------------------- | | | ------------------------- | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | +--------------------------------------------------+ | | | | | | | | | Combined Tester & SUT system | | | | | - | | | | +--------------------------------------------------+ > + > +# Simple Linux Setup > + > +1. On your TG and SUT nodes, add a dedicated user. In this example I will > name the user "dts." > "add a dedicated user for DTS" > +2. Grant passwordless sudo to the dts user, like so: > + 2a: enter 'visudo' in your terminal > + 2b: In the visudo text editor, add: > + dts ALL=(ALL:ALL) NOPASSWD:ALL > +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the > TG and SUT: > + ssh-copy-id dts@{your host}. > + > +For additional detail, please refer to > [dts.rst](../doc/guides/tools/dts.rst) > + > +# DTS Configuration > + > +DTS requires two yaml files to be filled out with information about your > environment, > +test_run.yaml and nodes.yaml, which follow the format illustrated in the > example files. > + > +1. Download Docker on the SUT, and Scapy on the TG. > It's semantics but let's say Install instead of download. > -### Visual Studio Code > +Usage of VScode devcontainers is NOT required for developing on DTS and > running DTS, > +but provide some small quality of life improvements for the developer. If > you > +want to develop from a devcontainer, see the instructions below: > > VSCode has first-class support for developing with containers. > You may need to run the non-Docker setup commands in the integrated > terminal. > @@ -76,6 +75,6 @@ will mount the SSH keys of the user currently running > VSCode into the container > The `source` on this line can be altered to mount any SSH keys > on the local machine into the container at the correct location. > > -### Other > +## Other > -Searching for '$IDE dev containers' will probably lead you in the right > direction. > +Searching for '$IDE dev containers' will probably lead you in the right > direction. > I would just drop this whole "Other" section with the comment about searching for dev containers - it's not needed. > \ No newline at end of file > -- > 2.49.0 > > [-- Attachment #2: Type: text/html, Size: 12757 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v3 1/3] dts: rewrite README 2025-07-11 21:22 ` [PATCH v3 1/3] dts: rewrite README Patrick Robb @ 2025-07-14 14:47 ` Dean Marx 0 siblings, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-14 14:47 UTC (permalink / raw) To: Patrick Robb Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev > Also, I never did get a response from you about whether it would be good to include some ascii art to depict these topologies :) > > You don't have to be a fan, but it would be good to get your opinion. If you think it's a good idea, can you add a bugzilla ticket so we can do this during 25.11? If you're opposed I'm okay with it - ultimately the wording should make the valid topologies clear enough to people. It's not something we can add during RC4 in any case. I like the idea of some ASCII art to illustrate the documentation better, I'll make that Bugzilla ticket so we can add it in the next release. ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v4 1/3] dts: rewrite README 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx ` (2 preceding siblings ...) 2025-07-11 21:22 ` [PATCH v3 1/3] dts: rewrite README Patrick Robb @ 2025-07-14 17:13 ` Dean Marx 2025-07-14 17:13 ` [PATCH v4 2/3] doc: rephrase terminology in dts.rst Dean Marx ` (3 more replies) 3 siblings, 4 replies; 39+ messages in thread From: Dean Marx @ 2025-07-14 17:13 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Refactor README to contain only a high level description of relevant DTS concepts and a simple getting started guide. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 115 ++++++++++++++++++++++++-------------------------- 1 file changed, 55 insertions(+), 60 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..20b09a4b7e 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,66 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +- 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +- 1 link topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are connected over +a single networking link. An example of this would be two single interface +NICs directly connected to each other. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user. In this example I will add a dedicated user for DTS. +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](../doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Install Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -75,7 +74,3 @@ Additionally, there is a line in `.devcontainer/devcontainer.json` that, when in will mount the SSH keys of the user currently running VSCode into the container for you. The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. - -### Other - -Searching for '$IDE dev containers' will probably lead you in the right direction. -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v4 2/3] doc: rephrase terminology in dts.rst 2025-07-14 17:13 ` [PATCH v4 " Dean Marx @ 2025-07-14 17:13 ` Dean Marx 2025-07-14 17:13 ` [PATCH v4 3/3] doc: revise coding guidelines section Dean Marx ` (2 subsequent siblings) 3 siblings, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-14 17:13 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Rephrase some of the DTS tool/term definitions to be more concise. These sections were unnecessarily verbose and can be conveyed in a clearer way. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 016dc5e374..8ba855c6fc 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT, which can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -481,17 +473,12 @@ DTS Developer Tools There are two tools used in DTS to help with code checking, style and formatting: -* `ruff <https://astral.sh/ruff/>`_ - - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. - -* `mypy <https://github.com/python/mypy>`_ +ruff: + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - Enables static typing for Python, exploiting the type hints in the source code. +mypy: + - Performs static type checking These two tools are all used in ``devtools/dts-check-format.sh``, the DTS code check and format script. -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v4 3/3] doc: revise coding guidelines section 2025-07-14 17:13 ` [PATCH v4 " Dean Marx 2025-07-14 17:13 ` [PATCH v4 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-14 17:13 ` Dean Marx 2025-07-15 22:25 ` Patrick Robb 2025-07-15 21:52 ` [PATCH v4 1/3] dts: rewrite README Patrick Robb 2025-07-16 13:57 ` [PATCH v5 " Dean Marx 3 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-07-14 17:13 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx The Framework Coding Guidelines section includes outdated information about DTS and how to write a test suite. Updated these points to include the new test case decorators and setup/teardown hooks. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 194 ++++++++++++++++++--------------------- 1 file changed, 90 insertions(+), 104 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 8ba855c6fc..4da55e00ef 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -78,15 +78,15 @@ Setting up DTS environment To install Poetry, visit their `doc pages <https://python-poetry.org/docs/>`_. The recommended Poetry version is at least 1.8.2. -#. **Getting a Poetry shell** +#. **Running DTS with Poetry** Once you have Poetry along with the proper Python version all set up, it's just a matter - of installing dependencies via Poetry and using the virtual environment Poetry provides: + of installing dependencies via Poetry and running main.py: .. code-block:: console poetry install - poetry shell + poetry run ./main.py #. **SSH Connection** @@ -263,7 +263,7 @@ which don't require password authentication. DTS Execution ~~~~~~~~~~~~~ -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: +DTS is run with ``main.py`` located in the ``dts`` directory using the ``poetry run`` command: .. code-block:: console @@ -348,122 +348,111 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks (e.g., `` `param` ``), + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks (````value````) for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single and double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. How To Write a Test Suite ------------------------- -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: +All test suites are classes that inherit from TestSuite, defined in dts/framework/test_suite.py. A typical suite contains: -#. **Test cases** +Test Cases - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. + Test cases are defined as methods and must be decorated appropriately. + Use the @func_test and/or @perf_test decorators from TestSuite above each test case method. + For example: -#. **Setup and Teardown methods** + @func_test + def test_basic_link(self): + """your testcase docstring here""" + #your testcase code here - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. + Functional test cases should use the @func_test decorator, and performance test cases should use @perf_test. + A test suite may include any number of functional and/or performance test cases. + Each suite should focus on testing a single feature (one feature = one test suite). -#. **Configuration, traffic and other logic** +Setup and Teardown Hooks - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. + Setup and teardown methods can be defined at both the suite and test case levels. - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. + Suite-level: - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. + * set_up_suite() — runs once before any test cases in the suite - Test suites may also be configured individually using a file provided at the command line. - The file is a simple mapping of test suite names to their corresponding configurations. + * tear_down_suite() — runs once after all test cases have completed - Any test suite can be designed to require custom configuration attributes or optional ones. - Any optional attributes should supply a default value for the test suite to use. + Case-level: -#. **Test case verification** + * set_up_test_case() — runs before each individual test case - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. + * tear_down_test_case() — runs after each individual test case -#. **Other methods** + These methods are optional. If not implemented, the framework will simply skip them. - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. + The TestSuite class provides a variety of methods for setup, teardown, and test logic. + Test suites often use DPDK applications (e.g., testpmd) in interactive mode and interact with them via shell instances. + +Using the DTS Framework Within TestSuites: + + There are two ways to call the framework logic in test suites: + + - Using built-in methods provided by TestSuite or its base classes + - Interacting directly with tools or shell interfaces + + If any required functionality is missing, it should be implemented in a way that supports one of these two approaches. + +Test Case Verification + + Use the verify method to assert conditions and record test results. + This should typically be called at the end of each test case. + Example: self.verify(link_up, "Link should be up after configuration.") + +Other Methods + + All test suite code should follow the project's coding standards. + Only test cases, setup/teardown hooks, and verification methods are treated specially by the framework. + Additional methods may be defined as needed (ideally private). .. _dts_dev_tools: @@ -493,13 +482,10 @@ Building DTS API docs The documentation is built using the standard DPDK build system. See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK with meson. -The :ref:`doc build dependencies <doc_dependencies>` may be installed with Poetry: - .. code-block:: console poetry install --only docs poetry install --with docs # an alternative that will also install DTS dependencies - poetry shell After executing the meson command, build the documentation with: -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v4 3/3] doc: revise coding guidelines section 2025-07-14 17:13 ` [PATCH v4 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-15 22:25 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-15 22:25 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 15681 bytes --] On Mon, Jul 14, 2025 at 1:13 PM Dean Marx <dmarx@iol.unh.edu> wrote: > The Framework Coding Guidelines section includes outdated information > about DTS and how to write a test suite. Updated these points to include > the new test case decorators and setup/teardown hooks. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > Reviewed-by: Patrick Robb <probb@iol.unh.edu> > --- > doc/guides/tools/dts.rst | 194 ++++++++++++++++++--------------------- > 1 file changed, 90 insertions(+), 104 deletions(-) > > diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst > index 8ba855c6fc..4da55e00ef 100644 > --- a/doc/guides/tools/dts.rst > +++ b/doc/guides/tools/dts.rst > @@ -78,15 +78,15 @@ Setting up DTS environment > To install Poetry, visit their `doc pages < > https://python-poetry.org/docs/>`_. > The recommended Poetry version is at least 1.8.2. > > -#. **Getting a Poetry shell** > +#. **Running DTS with Poetry** > > Once you have Poetry along with the proper Python version all set up, > it's just a matter > - of installing dependencies via Poetry and using the virtual > environment Poetry provides: > + of installing dependencies via Poetry and running main.py: > > .. code-block:: console > > poetry install > - poetry shell > + poetry run ./main.py > > #. **SSH Connection** > > @@ -263,7 +263,7 @@ which don't require password authentication. > DTS Execution > ~~~~~~~~~~~~~ > > -DTS is run with ``main.py`` located in the ``dts`` directory after > entering Poetry shell: > +DTS is run with ``main.py`` located in the ``dts`` directory using the > ``poetry run`` command: > > .. code-block:: console > > @@ -348,122 +348,111 @@ Adding test cases may require adding code to the > framework as well. > Framework Coding Guidelines > ~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > -When adding code to the DTS framework, pay attention to the rest of the > code > -and try not to divert much from it. > -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings > -when some of the basics are not met. > -You should also build the :ref:`API documentation <building_api_docs>` > -to address any issues found during the build. > - > -The API documentation, which is a helpful reference when developing, may > be accessed > -in the code directly or generated with the :ref:`API docs build steps > <building_api_docs>`. > -When adding new files or modifying the directory structure, > -the corresponding changes must be made to DTS API doc sources in > ``doc/api/dts``. > - > -Speaking of which, the code must be properly documented with docstrings. > -The style must conform to the `Google style > -< > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > -See an example of the style `here > -< > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_. > -For cases which are not covered by the Google style, refer to `PEP 257 > -<https://peps.python.org/pep-0257/>`_. > -There are some cases which are not covered by the two style guides, > -where we deviate or where some additional clarification is helpful: > - > - * The ``__init__()`` methods of classes are documented separately > - from the docstring of the class itself. > - * The docstrings of implemented abstract methods should refer to the > superclass's definition > - if there's no deviation. > - * Instance variables/attributes should be documented in the docstring > of the class > - in the ``Attributes:`` section. > - * The ``dataclass.dataclass`` decorator changes how the attributes are > processed. > - The dataclass attributes which result in instance > variables/attributes > - should also be recorded in the ``Attributes:`` section. > - * Class variables/attributes and Pydantic model fields, on the other > hand, > - should be documented with ``#:`` above the type annotated line. > - The description may be omitted if the meaning is obvious. > - * The ``Enum`` and ``TypedDict`` also process the attributes in > particular ways > - and should be documented with ``#:`` as well. > - This is mainly so that the autogenerated documentation contains the > assigned value. > - * When referencing a parameter of a function or a method in their > docstring, > - don't use any articles and put the parameter into single backticks. > - This mimics the style of `Python's documentation < > https://docs.python.org/3/index.html>`_. > - * When specifying a value, use double backticks:: > - > - def foo(greet: bool) -> None: > - """Demonstration of single and double backticks. > - > - `greet` controls whether ``Hello World`` is printed. > - > - Args: > - greet: Whether to print the ``Hello World`` message. > - """ > - if greet: > - print(f"Hello World") > - > - * The docstring maximum line length is the same as the code maximum > line length. > +When contributing code to the DTS framework, follow existing conventions > to ensure consistency. > +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. > +Also, be sure to :ref:`build the API documentation <building_api_docs>` > to catch any problems during the build. > + > +The API documentation is a helpful reference during development. > +It can be viewed in the code directly or generated using the :ref:`API > docs build steps <building_api_docs>`. > +If you add new files or change the directory structure, update the > corresponding sources in ``doc/api/dts``. > + > +Code must be documented with docstrings that follow the > +`Google style < > https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings > >`_. > +Additional references: > + > +* `Sphinx Google style example < > https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html > >`_ > +* `PEP 257 <https://peps.python.org/pep-0257/>`_ > + > +Docstring and Attribute Guidelines > + > +* Document ``__init__()`` separately from the class docstring. > +* If an abstract method simply implements a superclass definition without > changes, refer to that superclass in the docstring. > +* Document instance variables in the class docstring under an > ``Attributes:`` section. > +* For ``@dataclass`` classes, document instance-level attributes in > ``Attributes:``, as they are generated from the class fields. > +* Document class variables and Pydantic fields using ``#:``, > + placed above the type-annotated line. Descriptions may be omitted if > the meaning is clear. > +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that > autogenerated documentation includes their values. > +* When referring to a parameter in a docstring, omit articles and enclose > the parameter in single backticks (e.g., `` `param` ``), > + consistent with the `Python documentation style < > https://docs.python.org/3/index.html>`_. > +* Use double backticks (````value````) for literal values. > + > +Example:: > + > + def foo(greet: bool) -> None: > + """Demonstrates single and double backticks. > + > + `greet` controls whether ``Hello World`` is printed. > + > + Args: > + greet: Whether to print the ``Hello World`` message. > + """ > + if greet: > + print("Hello World") > + > +The maximum line length for docstrings must match that of the code. > > > How To Write a Test Suite > ------------------------- > > -All test suites inherit from ``TestSuite`` defined in > ``dts/framework/test_suite.py``. > -There are four types of methods that comprise a test suite: > +All test suites are classes that inherit from TestSuite, defined in > dts/framework/test_suite.py. A typical suite contains: > > -#. **Test cases** > +Test Cases > > - | Test cases are methods that start with a particular prefix. > - | Functional test cases start with ``test_``, e.g. > ``test_hello_world_single_core``. > - | Performance test cases start with ``test_perf_``, e.g. > ``test_perf_nic_single_core``. > - | A test suite may have any number of functional and/or performance > test cases. > - However, these test cases must test the same feature, > - following the rule of one feature = one test suite. > - Test cases for one feature don't need to be grouped in just one test > suite, though. > - If the feature requires many testing scenarios to cover, > - the test cases would be better off spread over multiple test suites > - so that each test suite doesn't take too long to execute. > + Test cases are defined as methods and must be decorated appropriately. > + Use the @func_test and/or @perf_test decorators from TestSuite above > each test case method. > + For example: > > -#. **Setup and Teardown methods** > + @func_test > + def test_basic_link(self): > + """your testcase docstring here""" > + #your testcase code here > > - | There are setup and teardown methods for the whole test suite and > each individual test case. > - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed > - before any and after all test cases have been executed, respectively. > - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be > executed > - before and after each test case, respectively. > - | These methods don't need to be implemented if there's no need for > them in a test suite. > - In that case, nothing will happen when they are executed. > + Functional test cases should use the @func_test decorator, and > performance test cases should use @perf_test. > + A test suite may include any number of functional and/or performance > test cases. > + Each suite should focus on testing a single feature (one feature = one > test suite). > > -#. **Configuration, traffic and other logic** > +Setup and Teardown Hooks > > - The ``TestSuite`` class contains a variety of methods for anything that > - a test suite setup, a teardown, or a test case may need to do. > + Setup and teardown methods can be defined at both the suite and test > case levels. > > - The test suites also frequently use a DPDK app, such as testpmd, in > interactive mode > - and use the interactive shell instances directly. > + Suite-level: > > - These are the two main ways to call the framework logic in test suites. > - If there's any functionality or logic missing from the framework, > - it should be implemented so that the test suites can use one of these > two ways. > + * set_up_suite() — runs once before any test cases in the suite > > - Test suites may also be configured individually using a file provided > at the command line. > - The file is a simple mapping of test suite names to their > corresponding configurations. > + * tear_down_suite() — runs once after all test cases have completed > > - Any test suite can be designed to require custom configuration > attributes or optional ones. > - Any optional attributes should supply a default value for the test > suite to use. > + Case-level: > > -#. **Test case verification** > + * set_up_test_case() — runs before each individual test case > > - Test case verification should be done with the ``verify`` method, > which records the result. > - The method should be called at the end of each test case. > + * tear_down_test_case() — runs after each individual test case > > -#. **Other methods** > + These methods are optional. If not implemented, the framework will > simply skip them. > > - Of course, all test suite code should adhere to coding standards. > - Only the above methods will be treated specially and any other methods > may be defined > - (which should be mostly private methods needed by each particular test > suite). > - Any specific features (such as NIC configuration) required by a test > suite > - should be implemented in the ``SutNode`` class (and the underlying > classes that ``SutNode`` uses) > - and used by the test suite via the ``sut_node`` field. > + The TestSuite class provides a variety of methods for setup, teardown, > and test logic. > + Test suites often use DPDK applications (e.g., testpmd) in interactive > mode and interact with them via shell instances. > + > +Using the DTS Framework Within TestSuites: > + > + There are two ways to call the framework logic in test suites: > + > + - Using built-in methods provided by TestSuite or its base classes > + - Interacting directly with tools or shell interfaces > + > + If any required functionality is missing, it should be implemented in > a way that supports one of these two approaches. > I still don't think we're driving the point home, which is that the testsuite class is essentially an API responsible for calls made to framework code, and it should provide methods for common processes required in DPDK testsuites (like sending and sniffing traffic). Maybe we should use more direct language Here is a proposal which you can feel free to modify. ------------------------------- Leveraging the DTS framework in writing testsuites: One should avoid directly importing DTS framework code to their testsuites where possible. Instead, for performing common processes required in testsuites, one should use (or add to) the list of methods provided in the Testsuite class (the base class of all testsuites). For instance, for sending a list of packets, one should work through the packet transmitting function already made available in the TestSuite class, instead of directly importing the DTS traffic generator class and using that class in one's testsuite implementation. It is also acceptable to import and instantiate classes for various DPDK applications. For instance, writing a testsuite for a simple packet forwarding operation would involve importing the DTS TestPmdShell class, instantiating TestPmdShell, calling TestPmdShell's .start() method, and then sending traffic via one of the traffic transmitting functions exposed in the Testsuite class. ------------------------------- + > +Test Case Verification > + > + Use the verify method to assert conditions and record test results. > + This should typically be called at the end of each test case. > + Example: self.verify(link_up, "Link should be up after configuration.") > + > +Other Methods > + > + All test suite code should follow the project's coding standards. > + Only test cases, setup/teardown hooks, and verification methods are > treated specially by the framework. > + Additional methods may be defined as needed (ideally private). > Not a big deal but why dont you change to: Additional private methods may be added as needed in your testsuite implementation. > > > .. _dts_dev_tools: > @@ -493,13 +482,10 @@ Building DTS API docs > The documentation is built using the standard DPDK build system. > See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK > with meson. > > -The :ref:`doc build dependencies <doc_dependencies>` may be installed > with Poetry: > - > .. code-block:: console > > poetry install --only docs > poetry install --with docs # an alternative that will also install > DTS dependencies > - poetry shell > > After executing the meson command, build the documentation with: > > -- > 2.49.0 > > [-- Attachment #2: Type: text/html, Size: 18408 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v4 1/3] dts: rewrite README 2025-07-14 17:13 ` [PATCH v4 " Dean Marx 2025-07-14 17:13 ` [PATCH v4 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-14 17:13 ` [PATCH v4 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-15 21:52 ` Patrick Robb 2025-07-16 13:57 ` [PATCH v5 " Dean Marx 3 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-15 21:52 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 830 bytes --] On Mon, Jul 14, 2025 at 1:13 PM Dean Marx <dmarx@iol.unh.edu> wrote: > > + > +# Simple Linux Setup > + > +1. On your TG and SUT nodes, add a dedicated user. In this example I will > add a dedicated user for DTS. > This is getting away from what I was suggesting. The original version was: On your TG and SUT nodes, add a dedicated user. In this example I will name the user "dts." And it's English semantics but what I was getting at is if you are going to call a user "dedicated" you have to say what for. I don't like that you have now removed the "In this example I will name the user "dts." line because that's really important info. So in my opinion the final version should be like: On your TG and SUT nodes, add a dedicated user for DTS. In this example I will name the user "dts." > > > [-- Attachment #2: Type: text/html, Size: 1531 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v5 1/3] dts: rewrite README 2025-07-14 17:13 ` [PATCH v4 " Dean Marx ` (2 preceding siblings ...) 2025-07-15 21:52 ` [PATCH v4 1/3] dts: rewrite README Patrick Robb @ 2025-07-16 13:57 ` Dean Marx 2025-07-16 13:57 ` [PATCH v5 2/3] doc: rephrase terminology in dts.rst Dean Marx ` (2 more replies) 3 siblings, 3 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 13:57 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Refactor README to contain only a high level description of relevant DTS concepts and a simple getting started guide. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 116 ++++++++++++++++++++++++-------------------------- 1 file changed, 56 insertions(+), 60 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..106afdfbdb 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,67 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +- 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +- 1 link topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are connected over +a single networking link. An example of this would be two single interface +NICs directly connected to each other. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user for DTS. In this example I + will name the user "dts." +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](../doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Install Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -75,7 +75,3 @@ Additionally, there is a line in `.devcontainer/devcontainer.json` that, when in will mount the SSH keys of the user currently running VSCode into the container for you. The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. - -### Other - -Searching for '$IDE dev containers' will probably lead you in the right direction. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v5 2/3] doc: rephrase terminology in dts.rst 2025-07-16 13:57 ` [PATCH v5 " Dean Marx @ 2025-07-16 13:57 ` Dean Marx 2025-07-16 13:57 ` [PATCH v5 3/3] doc: revise coding guidelines section Dean Marx 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx 2 siblings, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 13:57 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Rephrase some of the DTS tool/term definitions to be more concise. These sections were unnecessarily verbose and can be conveyed in a clearer way. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 016dc5e374..8ba855c6fc 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT, which can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -481,17 +473,12 @@ DTS Developer Tools There are two tools used in DTS to help with code checking, style and formatting: -* `ruff <https://astral.sh/ruff/>`_ - - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. - -* `mypy <https://github.com/python/mypy>`_ +ruff: + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - Enables static typing for Python, exploiting the type hints in the source code. +mypy: + - Performs static type checking These two tools are all used in ``devtools/dts-check-format.sh``, the DTS code check and format script. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v5 3/3] doc: revise coding guidelines section 2025-07-16 13:57 ` [PATCH v5 " Dean Marx 2025-07-16 13:57 ` [PATCH v5 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-16 13:57 ` Dean Marx 2025-07-16 18:19 ` Patrick Robb 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx 2 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-07-16 13:57 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx The Framework Coding Guidelines section includes outdated information about DTS and how to write a test suite. Updated these points to include the new test case decorators and setup/teardown hooks. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 201 +++++++++++++++++++-------------------- 1 file changed, 97 insertions(+), 104 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 8ba855c6fc..735c0a2f12 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -78,15 +78,15 @@ Setting up DTS environment To install Poetry, visit their `doc pages <https://python-poetry.org/docs/>`_. The recommended Poetry version is at least 1.8.2. -#. **Getting a Poetry shell** +#. **Running DTS with Poetry** Once you have Poetry along with the proper Python version all set up, it's just a matter - of installing dependencies via Poetry and using the virtual environment Poetry provides: + of installing dependencies via Poetry and running main.py: .. code-block:: console poetry install - poetry shell + poetry run ./main.py #. **SSH Connection** @@ -263,7 +263,7 @@ which don't require password authentication. DTS Execution ~~~~~~~~~~~~~ -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: +DTS is run with ``main.py`` located in the ``dts`` directory using the ``poetry run`` command: .. code-block:: console @@ -348,122 +348,118 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks (e.g., `` `param` ``), + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks (````value````) for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single and double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. How To Write a Test Suite ------------------------- -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: +All test suites are classes that inherit from TestSuite, defined in dts/framework/test_suite.py. A typical suite contains: + +Test Cases + + Test cases are defined as methods and must be decorated appropriately. + Use the @func_test and/or @perf_test decorators from TestSuite above each test case method. + For example: + + @func_test + def test_basic_link(self): + """your testcase docstring here""" + #your testcase code here -#. **Test cases** + Functional test cases should use the @func_test decorator, and performance test cases should use @perf_test. + A test suite may include any number of functional and/or performance test cases. + Each suite should focus on testing a single feature (one feature = one test suite). - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. +Setup and Teardown Hooks -#. **Setup and Teardown methods** + Setup and teardown methods can be defined at both the suite and test case levels. - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. + Suite-level: -#. **Configuration, traffic and other logic** + * set_up_suite() — runs once before any test cases in the suite - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. + * tear_down_suite() — runs once after all test cases have completed - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. + Case-level: - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. + * set_up_test_case() — runs before each individual test case - Test suites may also be configured individually using a file provided at the command line. - The file is a simple mapping of test suite names to their corresponding configurations. + * tear_down_test_case() — runs after each individual test case - Any test suite can be designed to require custom configuration attributes or optional ones. - Any optional attributes should supply a default value for the test suite to use. + These methods are optional. If not implemented, the framework will simply skip them. -#. **Test case verification** + The TestSuite class provides a variety of methods for setup, teardown, and test logic. + Test suites often use DPDK applications (e.g., testpmd) in interactive mode and interact with them via shell instances. - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. +Leveraging the DTS framework in writing testsuites: -#. **Other methods** + One should avoid directly importing DTS framework code to their + testsuites where possible. Instead, for performing common processes + required in testsuites, one should use (or add to) the list of methods + provided in the Testsuite class (the base class of all testsuites). For + instance, for sending a list of packets, one should work through the packet + transmitting function already made available in the TestSuite class, + instead of directly importing the DTS traffic generator class and using + that class in one's testsuite implementation. It is also acceptable to + import and instantiate classes for various DPDK applications. For instance, + writing a testsuite for a simple packet forwarding operation would involve + importing the DTS TestPmdShell class, instantiating TestPmdShell, calling + TestPmdShell's start() method, and then sending traffic via one of the + traffic transmitting functions exposed in the Testsuite class. - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. +Test Case Verification + + Use the verify method to assert conditions and record test results. + This should typically be called at the end of each test case. + Example: self.verify(link_up, "Link should be up after configuration.") + +Other Methods + + All test suite code should follow the project's coding standards. + Only test cases, setup/teardown hooks, and verification methods are treated specially by the framework. + Additional private methods may be added as needed in your testsuite implementation. .. _dts_dev_tools: @@ -493,13 +489,10 @@ Building DTS API docs The documentation is built using the standard DPDK build system. See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK with meson. -The :ref:`doc build dependencies <doc_dependencies>` may be installed with Poetry: - .. code-block:: console poetry install --only docs poetry install --with docs # an alternative that will also install DTS dependencies - poetry shell After executing the meson command, build the documentation with: -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v5 3/3] doc: revise coding guidelines section 2025-07-16 13:57 ` [PATCH v5 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-16 18:19 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-16 18:19 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 2030 bytes --] On Wed, Jul 16, 2025 at 9:57 AM Dean Marx <dmarx@iol.unh.edu> wrote: > > + > +* Document ``__init__()`` separately from the class docstring. > +* If an abstract method simply implements a superclass definition without > changes, refer to that superclass in the docstring. > +* Document instance variables in the class docstring under an > ``Attributes:`` section. > +* For ``@dataclass`` classes, document instance-level attributes in > ``Attributes:``, as they are generated from the class fields. > +* Document class variables and Pydantic fields using ``#:``, > + placed above the type-annotated line. Descriptions may be omitted if > the meaning is clear. > +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that > autogenerated documentation includes their values. > +* When referring to a parameter in a docstring, omit articles and enclose > the parameter in single backticks (e.g., `` `param` ``), > There is actually a docs build failure on GHA from this line: https://mails.dpdk.org/archives/test-report/2025-July/894788.html One option would be to escape the backticks like \`. But, it's even better to just drop the inline single and double backtick examples given that you have an example block below which shows both. So, keep the bulleted descriptions, but remove the examples in parenthesis. > + consistent with the `Python documentation style < > https://docs.python.org/3/index.html>`_. > +* Use double backticks (````value````) for literal values. > + > +Example:: > + > + def foo(greet: bool) -> None: > + """Demonstrates single and double backticks. > + > + `greet` controls whether ``Hello World`` is printed. > + > + Args: > + greet: Whether to print the ``Hello World`` message. > + """ > + if greet: > + print("Hello World") > + > +The maximum line length for docstrings must match that of the code. > > > How To Write a Test Suite > ------------------------- > > > > [-- Attachment #2: Type: text/html, Size: 2852 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v6 1/3] dts: rewrite README 2025-07-16 13:57 ` [PATCH v5 " Dean Marx 2025-07-16 13:57 ` [PATCH v5 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 13:57 ` [PATCH v5 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-16 18:25 ` Dean Marx 2025-07-16 18:25 ` [PATCH v6 2/3] doc: rephrase terminology in dts.rst Dean Marx ` (2 more replies) 2 siblings, 3 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 18:25 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Refactor README to contain only a high level description of relevant DTS concepts and a simple getting started guide. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 116 ++++++++++++++++++++++++-------------------------- 1 file changed, 56 insertions(+), 60 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..106afdfbdb 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,67 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +- 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +- 1 link topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are connected over +a single networking link. An example of this would be two single interface +NICs directly connected to each other. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user for DTS. In this example I + will name the user "dts." +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](../doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Install Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -75,7 +75,3 @@ Additionally, there is a line in `.devcontainer/devcontainer.json` that, when in will mount the SSH keys of the user currently running VSCode into the container for you. The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. - -### Other - -Searching for '$IDE dev containers' will probably lead you in the right direction. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v6 2/3] doc: rephrase terminology in dts.rst 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx @ 2025-07-16 18:25 ` Dean Marx 2025-07-16 18:25 ` [PATCH v6 3/3] doc: revise coding guidelines section Dean Marx 2025-07-16 20:53 ` [PATCH v7 1/3] dts: rewrite README Dean Marx 2 siblings, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 18:25 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Rephrase some of the DTS tool/term definitions to be more concise. These sections were unnecessarily verbose and can be conveyed in a clearer way. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 016dc5e374..8ba855c6fc 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT, which can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -481,17 +473,12 @@ DTS Developer Tools There are two tools used in DTS to help with code checking, style and formatting: -* `ruff <https://astral.sh/ruff/>`_ - - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. - -* `mypy <https://github.com/python/mypy>`_ +ruff: + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - Enables static typing for Python, exploiting the type hints in the source code. +mypy: + - Performs static type checking These two tools are all used in ``devtools/dts-check-format.sh``, the DTS code check and format script. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v6 3/3] doc: revise coding guidelines section 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx 2025-07-16 18:25 ` [PATCH v6 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-16 18:25 ` Dean Marx 2025-07-16 20:53 ` [PATCH v7 1/3] dts: rewrite README Dean Marx 2 siblings, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 18:25 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx The Framework Coding Guidelines section includes outdated information about DTS and how to write a test suite. Updated these points to include the new test case decorators and setup/teardown hooks. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 201 +++++++++++++++++++-------------------- 1 file changed, 97 insertions(+), 104 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 8ba855c6fc..dab0d02a0a 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -78,15 +78,15 @@ Setting up DTS environment To install Poetry, visit their `doc pages <https://python-poetry.org/docs/>`_. The recommended Poetry version is at least 1.8.2. -#. **Getting a Poetry shell** +#. **Running DTS with Poetry** Once you have Poetry along with the proper Python version all set up, it's just a matter - of installing dependencies via Poetry and using the virtual environment Poetry provides: + of installing dependencies via Poetry and running main.py: .. code-block:: console poetry install - poetry shell + poetry run ./main.py #. **SSH Connection** @@ -263,7 +263,7 @@ which don't require password authentication. DTS Execution ~~~~~~~~~~~~~ -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: +DTS is run with ``main.py`` located in the ``dts`` directory using the ``poetry run`` command: .. code-block:: console @@ -348,122 +348,118 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks, + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single and double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. How To Write a Test Suite ------------------------- -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: +All test suites are classes that inherit from TestSuite, defined in dts/framework/test_suite.py. A typical suite contains: + +Test Cases + + Test cases are defined as methods and must be decorated appropriately. + Use the @func_test and/or @perf_test decorators from TestSuite above each test case method. + For example: + + @func_test + def test_basic_link(self): + """your testcase docstring here""" + #your testcase code here -#. **Test cases** + Functional test cases should use the @func_test decorator, and performance test cases should use @perf_test. + A test suite may include any number of functional and/or performance test cases. + Each suite should focus on testing a single feature (one feature = one test suite). - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. +Setup and Teardown Hooks -#. **Setup and Teardown methods** + Setup and teardown methods can be defined at both the suite and test case levels. - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. + Suite-level: -#. **Configuration, traffic and other logic** + * set_up_suite() — runs once before any test cases in the suite - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. + * tear_down_suite() — runs once after all test cases have completed - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. + Case-level: - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. + * set_up_test_case() — runs before each individual test case - Test suites may also be configured individually using a file provided at the command line. - The file is a simple mapping of test suite names to their corresponding configurations. + * tear_down_test_case() — runs after each individual test case - Any test suite can be designed to require custom configuration attributes or optional ones. - Any optional attributes should supply a default value for the test suite to use. + These methods are optional. If not implemented, the framework will simply skip them. -#. **Test case verification** + The TestSuite class provides a variety of methods for setup, teardown, and test logic. + Test suites often use DPDK applications (e.g., testpmd) in interactive mode and interact with them via shell instances. - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. +Leveraging the DTS framework in writing testsuites: -#. **Other methods** + One should avoid directly importing DTS framework code to their + testsuites where possible. Instead, for performing common processes + required in testsuites, one should use (or add to) the list of methods + provided in the Testsuite class (the base class of all testsuites). For + instance, for sending a list of packets, one should work through the packet + transmitting function already made available in the TestSuite class, + instead of directly importing the DTS traffic generator class and using + that class in one's testsuite implementation. It is also acceptable to + import and instantiate classes for various DPDK applications. For instance, + writing a testsuite for a simple packet forwarding operation would involve + importing the DTS TestPmdShell class, instantiating TestPmdShell, calling + TestPmdShell's start() method, and then sending traffic via one of the + traffic transmitting functions exposed in the Testsuite class. - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. +Test Case Verification + + Use the verify method to assert conditions and record test results. + This should typically be called at the end of each test case. + Example: self.verify(link_up, "Link should be up after configuration.") + +Other Methods + + All test suite code should follow the project's coding standards. + Only test cases, setup/teardown hooks, and verification methods are treated specially by the framework. + Additional private methods may be added as needed in your testsuite implementation. .. _dts_dev_tools: @@ -493,13 +489,10 @@ Building DTS API docs The documentation is built using the standard DPDK build system. See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK with meson. -The :ref:`doc build dependencies <doc_dependencies>` may be installed with Poetry: - .. code-block:: console poetry install --only docs poetry install --with docs # an alternative that will also install DTS dependencies - poetry shell After executing the meson command, build the documentation with: -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v7 1/3] dts: rewrite README 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx 2025-07-16 18:25 ` [PATCH v6 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 18:25 ` [PATCH v6 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-16 20:53 ` Dean Marx 2025-07-16 20:53 ` [PATCH v7 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 20:54 ` [PATCH v7 3/3] doc: revise coding guidelines section Dean Marx 2 siblings, 2 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 20:53 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Refactor README to contain only a high level description of relevant DTS concepts and a simple getting started guide. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> --- dts/README.md | 116 ++++++++++++++++++++++++-------------------------- 1 file changed, 56 insertions(+), 60 deletions(-) diff --git a/dts/README.md b/dts/README.md index 2b3a7f89c5..106afdfbdb 100644 --- a/dts/README.md +++ b/dts/README.md @@ -1,67 +1,67 @@ -# DTS Environment - -The execution and development environments for DTS are the same, -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). -Using a container for the development environment helps with a few things. - -1. It helps enforce the boundary between the DTS environment and the TG/SUT, - something which caused issues in the past. -2. It makes creating containers to run DTS inside automated tooling much easier, since - they can be based off of a known-working environment that will be updated as DTS is. -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS - can be whatever corporate policy or your personal preferences dictate, - and DTS does not have to try to support all distros that are supported by DPDK CI. -4. It makes automated testing for DTS easier, - since new dependencies can be sent in with the patches. -5. It fixes the issue of undocumented dependencies, - where some test suites require Python libraries that are not installed. -6. Allows everyone to use the same Python version easily, - even if they are using a distribution or Windows with out-of-date packages. -7. Allows you to run the tester on Windows while developing via Docker for Windows. - -## Tips for setting up a development environment - -### Getting a docker shell - -These commands will give you a bash shell inside the container -with all the Python dependencies installed. -This will place you inside a Python virtual environment. -DTS is mounted via a volume, which is essentially a symlink from the host to the container. -This enables you to edit and run inside the container -and then delete the container when you are done, keeping your work. -It is also strongly recommended that you mount your SSH keys into the container -to allow you to connect to hosts without specifying a password. - -#### Start docker container with SSH keys +# Description + +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK +enabled hardware. Unlike DPDK's dpdk-test application, which is used for running unit tests, +DTS is intended to be used to evaluate real DPDK workloads run over supported hardware. For instance, +DTS will control a traffic generator node which will send packets to a system under test node which +is running a DPDK application, and evaluate the resulting DPDK application behavior. + +# Supported Test Node Topologies + +DTS is a python application which will control a traffic generator node (TG) and system +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a +host. The devices/NICs can be located on two separate servers, or on the same server. If you use +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal +for performance testing.) + +- 2 links topology: Represents a topology in which the TG node and SUT node both have two network interfaces +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 +on SUT, interface 1 on TG <-> interface 1 on SUT. +- 1 link topology: Works, but may result in skips for testsuites which are explicitly decorated with a +2 link requirement. Represents a topology in which the TG node and SUT node are connected over +a single networking link. An example of this would be two single interface +NICs directly connected to each other. + +# Simple Linux Setup + +1. On your TG and SUT nodes, add a dedicated user for DTS. In this example I + will name the user "dts." +2. Grant passwordless sudo to the dts user, like so: + 2a: enter 'visudo' in your terminal + 2b: In the visudo text editor, add: + dts ALL=(ALL:ALL) NOPASSWD:ALL +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: + ssh-copy-id dts@{your host}. + +For additional detail, please refer to [dts.rst](../doc/guides/tools/dts.rst) + +# DTS Configuration + +DTS requires two yaml files to be filled out with information about your environment, +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. + +1. Install Docker on the SUT, and Scapy on the TG. +2. Create and fill out a test_run.yaml and nodes.yaml file within your dts + directory, based on the structure from the example config files. +3. Run the bash terminal commands below in order to run the DTS container + and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash +docker run -v $(pwd)/..:/dpdk -v /home/{name of dts user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install -$ poetry shell +$ poetry run ./main.py ``` -#### Start docker container without SSH keys +These commands will give you a bash shell inside a docker container +with all DTS Python dependencies installed. -```shell -docker build --target dev -t dpdk-dts . -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash -$ poetry install -$ poetry shell -``` - -### Vim/Emacs - -Any editor in the Ubuntu repos should be easy to use, -with Vim and Emacs already installed. -You can add your normal config files as a volume, -enabling you to use your preferred settings. - -```shell -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash -``` +## Visual Studio Code -### Visual Studio Code +Usage of VScode devcontainers is NOT required for developing on DTS and running DTS, +but provide some small quality of life improvements for the developer. If you +want to develop from a devcontainer, see the instructions below: VSCode has first-class support for developing with containers. You may need to run the non-Docker setup commands in the integrated terminal. @@ -75,7 +75,3 @@ Additionally, there is a line in `.devcontainer/devcontainer.json` that, when in will mount the SSH keys of the user currently running VSCode into the container for you. The `source` on this line can be altered to mount any SSH keys on the local machine into the container at the correct location. - -### Other - -Searching for '$IDE dev containers' will probably lead you in the right direction. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v7 2/3] doc: rephrase terminology in dts.rst 2025-07-16 20:53 ` [PATCH v7 1/3] dts: rewrite README Dean Marx @ 2025-07-16 20:53 ` Dean Marx 2025-07-16 20:54 ` [PATCH v7 3/3] doc: revise coding guidelines section Dean Marx 1 sibling, 0 replies; 39+ messages in thread From: Dean Marx @ 2025-07-16 20:53 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Rephrase some of the DTS tool/term definitions to be more concise. These sections were unnecessarily verbose and can be conveyed in a clearer way. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 016dc5e374..8ba855c6fc 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -1,6 +1,7 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2022-2023 PANTHEON.tech s.r.o. Copyright(c) 2024 Arm Limited + Copyright(c) 2025 University of New Hampshire DPDK Test Suite =============== @@ -20,31 +21,22 @@ DTS runtime environment DTS runtime environment node A node where at least one DTS runtime environment is present. - This is the node where we run DTS and from which DTS connects to other nodes. + This is the node where we run DTS and from which DTS connects to other + nodes. System under test - An SUT is the combination of DPDK and the hardware we're testing - in conjunction with DPDK (NICs, crypto and other devices). + The system which runs a DPDK application on relevant + hardware (NIC, accelerator cards, etc) and from which the DPDK behavior is + observed for tests. System under test node A node where at least one SUT is present. Traffic generator - A TG is either software or hardware capable of sending packets. + Node that sends traffic to the SUT, which can be hardware or software-based. Traffic generator node A node where at least one TG is present. - In case of hardware traffic generators, the TG and the node are literally the same. - - -In most cases, interchangeably referring to a runtime environment, SUT, TG or the node -they're running on (e.g. using SUT and SUT node interchangeably) doesn't cause confusion. -There could theoretically be more than of these running on the same node and in that case -it's useful to have stricter definitions. -An example would be two different traffic generators (such as Trex and Scapy) -running on the same node. -A different example would be a node containing both a DTS runtime environment -and a traffic generator, in which case it's both a DTS runtime environment node and a TG node. DTS Environment @@ -481,17 +473,12 @@ DTS Developer Tools There are two tools used in DTS to help with code checking, style and formatting: -* `ruff <https://astral.sh/ruff/>`_ - - An extremely fast all-in-one linting and formatting solution, - which covers most if not all the major rules such as: - pylama, flake8, pylint etc. - Its built-in formatter is also Black-compatible - and is able to sort imports automatically like isort would. - -* `mypy <https://github.com/python/mypy>`_ +ruff: + - Linter and formatter (replaces flake8, pylint, isort, etc.) + - Compatible with Black - Enables static typing for Python, exploiting the type hints in the source code. +mypy: + - Performs static type checking These two tools are all used in ``devtools/dts-check-format.sh``, the DTS code check and format script. -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* [PATCH v7 3/3] doc: revise coding guidelines section 2025-07-16 20:53 ` [PATCH v7 1/3] dts: rewrite README Dean Marx 2025-07-16 20:53 ` [PATCH v7 2/3] doc: rephrase terminology in dts.rst Dean Marx @ 2025-07-16 20:54 ` Dean Marx 2025-07-16 21:58 ` Patrick Robb 1 sibling, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-07-16 20:54 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx The Framework Coding Guidelines section includes outdated information about DTS and how to write a test suite. Updated these points to include the new test case decorators and setup/teardown hooks. Signed-off-by: Dean Marx <dmarx@iol.unh.edu> Reviewed-by: Patrick Robb <probb@iol.unh.edu> --- doc/guides/tools/dts.rst | 203 +++++++++++++++++++-------------------- 1 file changed, 99 insertions(+), 104 deletions(-) diff --git a/doc/guides/tools/dts.rst b/doc/guides/tools/dts.rst index 8ba855c6fc..cc1f1a9270 100644 --- a/doc/guides/tools/dts.rst +++ b/doc/guides/tools/dts.rst @@ -78,15 +78,15 @@ Setting up DTS environment To install Poetry, visit their `doc pages <https://python-poetry.org/docs/>`_. The recommended Poetry version is at least 1.8.2. -#. **Getting a Poetry shell** +#. **Running DTS with Poetry** Once you have Poetry along with the proper Python version all set up, it's just a matter - of installing dependencies via Poetry and using the virtual environment Poetry provides: + of installing dependencies via Poetry and running main.py: .. code-block:: console poetry install - poetry shell + poetry run ./main.py #. **SSH Connection** @@ -263,7 +263,7 @@ which don't require password authentication. DTS Execution ~~~~~~~~~~~~~ -DTS is run with ``main.py`` located in the ``dts`` directory after entering Poetry shell: +DTS is run with ``main.py`` located in the ``dts`` directory using the ``poetry run`` command: .. code-block:: console @@ -348,122 +348,120 @@ Adding test cases may require adding code to the framework as well. Framework Coding Guidelines ~~~~~~~~~~~~~~~~~~~~~~~~~~~ -When adding code to the DTS framework, pay attention to the rest of the code -and try not to divert much from it. -The :ref:`DTS developer tools <dts_dev_tools>` will issue warnings -when some of the basics are not met. -You should also build the :ref:`API documentation <building_api_docs>` -to address any issues found during the build. - -The API documentation, which is a helpful reference when developing, may be accessed -in the code directly or generated with the :ref:`API docs build steps <building_api_docs>`. -When adding new files or modifying the directory structure, -the corresponding changes must be made to DTS API doc sources in ``doc/api/dts``. - -Speaking of which, the code must be properly documented with docstrings. -The style must conform to the `Google style -<https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. -See an example of the style `here -<https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_. -For cases which are not covered by the Google style, refer to `PEP 257 -<https://peps.python.org/pep-0257/>`_. -There are some cases which are not covered by the two style guides, -where we deviate or where some additional clarification is helpful: - - * The ``__init__()`` methods of classes are documented separately - from the docstring of the class itself. - * The docstrings of implemented abstract methods should refer to the superclass's definition - if there's no deviation. - * Instance variables/attributes should be documented in the docstring of the class - in the ``Attributes:`` section. - * The ``dataclass.dataclass`` decorator changes how the attributes are processed. - The dataclass attributes which result in instance variables/attributes - should also be recorded in the ``Attributes:`` section. - * Class variables/attributes and Pydantic model fields, on the other hand, - should be documented with ``#:`` above the type annotated line. - The description may be omitted if the meaning is obvious. - * The ``Enum`` and ``TypedDict`` also process the attributes in particular ways - and should be documented with ``#:`` as well. - This is mainly so that the autogenerated documentation contains the assigned value. - * When referencing a parameter of a function or a method in their docstring, - don't use any articles and put the parameter into single backticks. - This mimics the style of `Python's documentation <https://docs.python.org/3/index.html>`_. - * When specifying a value, use double backticks:: - - def foo(greet: bool) -> None: - """Demonstration of single and double backticks. - - `greet` controls whether ``Hello World`` is printed. - - Args: - greet: Whether to print the ``Hello World`` message. - """ - if greet: - print(f"Hello World") - - * The docstring maximum line length is the same as the code maximum line length. +When contributing code to the DTS framework, follow existing conventions to ensure consistency. +The :ref:`DTS developer tools <dts_dev_tools>` will flag basic issues. +Also, be sure to :ref:`build the API documentation <building_api_docs>` to catch any problems during the build. + +The API documentation is a helpful reference during development. +It can be viewed in the code directly or generated using the :ref:`API docs build steps <building_api_docs>`. +If you add new files or change the directory structure, update the corresponding sources in ``doc/api/dts``. + +Code must be documented with docstrings that follow the +`Google style <https://google.github.io/styleguide/pyguide.html#38-comments-and-docstrings>`_. +Additional references: + +* `Sphinx Google style example <https://www.sphinx-doc.org/en/master/usage/extensions/example_google.html>`_ +* `PEP 257 <https://peps.python.org/pep-0257/>`_ + +Docstring and Attribute Guidelines + +* Document ``__init__()`` separately from the class docstring. +* If an abstract method simply implements a superclass definition without changes, refer to that superclass in the docstring. +* Document instance variables in the class docstring under an ``Attributes:`` section. +* For ``@dataclass`` classes, document instance-level attributes in ``Attributes:``, as they are generated from the class fields. +* Document class variables and Pydantic fields using ``#:``, + placed above the type-annotated line. Descriptions may be omitted if the meaning is clear. +* Apply ``#:`` to ``Enum`` and ``TypedDict`` fields as well, so that autogenerated documentation includes their values. +* When referring to a parameter in a docstring, omit articles and enclose the parameter in single backticks, + consistent with the `Python documentation style <https://docs.python.org/3/index.html>`_. +* Use double backticks for literal values. + +Example:: + + def foo(greet: bool) -> None: + """Demonstrates single and double backticks. + + `greet` controls whether ``Hello World`` is printed. + + Args: + greet: Whether to print the ``Hello World`` message. + """ + if greet: + print("Hello World") + +The maximum line length for docstrings must match that of the code. How To Write a Test Suite ------------------------- -All test suites inherit from ``TestSuite`` defined in ``dts/framework/test_suite.py``. -There are four types of methods that comprise a test suite: +All test suites are classes that inherit from TestSuite, defined in dts/framework/test_suite.py. A typical suite contains: + +Test Cases + + Test cases are defined as methods and must be decorated appropriately. + Use the @func_test and/or @perf_test decorators from TestSuite above each test case method. + For example: + +Example:: + + @func_test + def test_basic_link(self): + """your testcase docstring here""" + # your testcase code here -#. **Test cases** + Functional test cases should use the @func_test decorator, and performance test cases should use @perf_test. + A test suite may include any number of functional and/or performance test cases. + Each suite should focus on testing a single feature (one feature = one test suite). - | Test cases are methods that start with a particular prefix. - | Functional test cases start with ``test_``, e.g. ``test_hello_world_single_core``. - | Performance test cases start with ``test_perf_``, e.g. ``test_perf_nic_single_core``. - | A test suite may have any number of functional and/or performance test cases. - However, these test cases must test the same feature, - following the rule of one feature = one test suite. - Test cases for one feature don't need to be grouped in just one test suite, though. - If the feature requires many testing scenarios to cover, - the test cases would be better off spread over multiple test suites - so that each test suite doesn't take too long to execute. +Setup and Teardown Hooks -#. **Setup and Teardown methods** + Setup and teardown methods can be defined at both the suite and test case levels. - | There are setup and teardown methods for the whole test suite and each individual test case. - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed - before any and after all test cases have been executed, respectively. - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be executed - before and after each test case, respectively. - | These methods don't need to be implemented if there's no need for them in a test suite. - In that case, nothing will happen when they are executed. + Suite-level: -#. **Configuration, traffic and other logic** + * set_up_suite() — runs once before any test cases in the suite - The ``TestSuite`` class contains a variety of methods for anything that - a test suite setup, a teardown, or a test case may need to do. + * tear_down_suite() — runs once after all test cases have completed - The test suites also frequently use a DPDK app, such as testpmd, in interactive mode - and use the interactive shell instances directly. + Case-level: - These are the two main ways to call the framework logic in test suites. - If there's any functionality or logic missing from the framework, - it should be implemented so that the test suites can use one of these two ways. + * set_up_test_case() — runs before each individual test case - Test suites may also be configured individually using a file provided at the command line. - The file is a simple mapping of test suite names to their corresponding configurations. + * tear_down_test_case() — runs after each individual test case - Any test suite can be designed to require custom configuration attributes or optional ones. - Any optional attributes should supply a default value for the test suite to use. + These methods are optional. If not implemented, the framework will simply skip them. -#. **Test case verification** + The TestSuite class provides a variety of methods for setup, teardown, and test logic. + Test suites often use DPDK applications (e.g., testpmd) in interactive mode and interact with them via shell instances. - Test case verification should be done with the ``verify`` method, which records the result. - The method should be called at the end of each test case. +Leveraging the DTS framework in writing testsuites: -#. **Other methods** + One should avoid directly importing DTS framework code to their + testsuites where possible. Instead, for performing common processes + required in testsuites, one should use (or add to) the list of methods + provided in the Testsuite class (the base class of all testsuites). For + instance, for sending a list of packets, one should work through the packet + transmitting function already made available in the TestSuite class, + instead of directly importing the DTS traffic generator class and using + that class in one's testsuite implementation. It is also acceptable to + import and instantiate classes for various DPDK applications. For instance, + writing a testsuite for a simple packet forwarding operation would involve + importing the DTS TestPmdShell class, instantiating TestPmdShell, calling + TestPmdShell's start() method, and then sending traffic via one of the + traffic transmitting functions exposed in the Testsuite class. - Of course, all test suite code should adhere to coding standards. - Only the above methods will be treated specially and any other methods may be defined - (which should be mostly private methods needed by each particular test suite). - Any specific features (such as NIC configuration) required by a test suite - should be implemented in the ``SutNode`` class (and the underlying classes that ``SutNode`` uses) - and used by the test suite via the ``sut_node`` field. +Test Case Verification + + Use the verify method to assert conditions and record test results. + This should typically be called at the end of each test case. + Example: self.verify(link_up, "Link should be up after configuration.") + +Other Methods + + All test suite code should follow the project's coding standards. + Only test cases, setup/teardown hooks, and verification methods are treated specially by the framework. + Additional private methods may be added as needed in your testsuite implementation. .. _dts_dev_tools: @@ -493,13 +491,10 @@ Building DTS API docs The documentation is built using the standard DPDK build system. See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK with meson. -The :ref:`doc build dependencies <doc_dependencies>` may be installed with Poetry: - .. code-block:: console poetry install --only docs poetry install --with docs # an alternative that will also install DTS dependencies - poetry shell After executing the meson command, build the documentation with: -- 2.50.1 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v7 3/3] doc: revise coding guidelines section 2025-07-16 20:54 ` [PATCH v7 3/3] doc: revise coding guidelines section Dean Marx @ 2025-07-16 21:58 ` Patrick Robb 0 siblings, 0 replies; 39+ messages in thread From: Patrick Robb @ 2025-07-16 21:58 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 7816 bytes --] On Wed, Jul 16, 2025 at 4:54 PM Dean Marx <dmarx@iol.unh.edu> wrote: > code. > > > How To Write a Test Suite > ------------------------- > > -All test suites inherit from ``TestSuite`` defined in > ``dts/framework/test_suite.py``. > -There are four types of methods that comprise a test suite: > +All test suites are classes that inherit from TestSuite, defined in > dts/framework/test_suite.py. A typical suite contains: > + > +Test Cases > + > + Test cases are defined as methods and must be decorated appropriately. > + Use the @func_test and/or @perf_test decorators from TestSuite above > each test case method. > + For example: > + > +Example:: > + > + @func_test > + def test_basic_link(self): > + """your testcase docstring here""" > + # your testcase code here > This looks good except for the fact that the whole example block should be indented once. Otherwise it's not actually under "Test Cases," and also it consumes the text blurb immediately following the example. I just did a git fixup which indents it and that looks good after reviewing the guides docs build output file. I'm pushing to my GHA robot fork to make sure it still passes the checks but unless there are any fails I will just push to next-dts with my fixup. > > -#. **Test cases** > + Functional test cases should use the @func_test decorator, and > performance test cases should use @perf_test. > + A test suite may include any number of functional and/or performance > test cases. > + Each suite should focus on testing a single feature (one feature = one > test suite). > > - | Test cases are methods that start with a particular prefix. > - | Functional test cases start with ``test_``, e.g. > ``test_hello_world_single_core``. > - | Performance test cases start with ``test_perf_``, e.g. > ``test_perf_nic_single_core``. > - | A test suite may have any number of functional and/or performance > test cases. > - However, these test cases must test the same feature, > - following the rule of one feature = one test suite. > - Test cases for one feature don't need to be grouped in just one test > suite, though. > - If the feature requires many testing scenarios to cover, > - the test cases would be better off spread over multiple test suites > - so that each test suite doesn't take too long to execute. > +Setup and Teardown Hooks > > -#. **Setup and Teardown methods** > + Setup and teardown methods can be defined at both the suite and test > case levels. > > - | There are setup and teardown methods for the whole test suite and > each individual test case. > - | Methods ``set_up_suite`` and ``tear_down_suite`` will be executed > - before any and after all test cases have been executed, respectively. > - | Methods ``set_up_test_case`` and ``tear_down_test_case`` will be > executed > - before and after each test case, respectively. > - | These methods don't need to be implemented if there's no need for > them in a test suite. > - In that case, nothing will happen when they are executed. > + Suite-level: > > -#. **Configuration, traffic and other logic** > + * set_up_suite() — runs once before any test cases in the suite > > - The ``TestSuite`` class contains a variety of methods for anything that > - a test suite setup, a teardown, or a test case may need to do. > + * tear_down_suite() — runs once after all test cases have completed > > - The test suites also frequently use a DPDK app, such as testpmd, in > interactive mode > - and use the interactive shell instances directly. > + Case-level: > > - These are the two main ways to call the framework logic in test suites. > - If there's any functionality or logic missing from the framework, > - it should be implemented so that the test suites can use one of these > two ways. > + * set_up_test_case() — runs before each individual test case > > - Test suites may also be configured individually using a file provided > at the command line. > - The file is a simple mapping of test suite names to their > corresponding configurations. > + * tear_down_test_case() — runs after each individual test case > > - Any test suite can be designed to require custom configuration > attributes or optional ones. > - Any optional attributes should supply a default value for the test > suite to use. > + These methods are optional. If not implemented, the framework will > simply skip them. > > -#. **Test case verification** > + The TestSuite class provides a variety of methods for setup, teardown, > and test logic. > + Test suites often use DPDK applications (e.g., testpmd) in interactive > mode and interact with them via shell instances. > > - Test case verification should be done with the ``verify`` method, > which records the result. > - The method should be called at the end of each test case. > +Leveraging the DTS framework in writing testsuites: > > -#. **Other methods** > + One should avoid directly importing DTS framework code to their > + testsuites where possible. Instead, for performing common processes > + required in testsuites, one should use (or add to) the list of methods > + provided in the Testsuite class (the base class of all testsuites). For > + instance, for sending a list of packets, one should work through the > packet > + transmitting function already made available in the TestSuite class, > + instead of directly importing the DTS traffic generator class and using > + that class in one's testsuite implementation. It is also acceptable to > + import and instantiate classes for various DPDK applications. For > instance, > + writing a testsuite for a simple packet forwarding operation would > involve > + importing the DTS TestPmdShell class, instantiating TestPmdShell, > calling > + TestPmdShell's start() method, and then sending traffic via one of the > + traffic transmitting functions exposed in the Testsuite class. > > - Of course, all test suite code should adhere to coding standards. > - Only the above methods will be treated specially and any other methods > may be defined > - (which should be mostly private methods needed by each particular test > suite). > - Any specific features (such as NIC configuration) required by a test > suite > - should be implemented in the ``SutNode`` class (and the underlying > classes that ``SutNode`` uses) > - and used by the test suite via the ``sut_node`` field. > +Test Case Verification > + > + Use the verify method to assert conditions and record test results. > + This should typically be called at the end of each test case. > + Example: self.verify(link_up, "Link should be up after configuration.") > + > +Other Methods > + > + All test suite code should follow the project's coding standards. > + Only test cases, setup/teardown hooks, and verification methods are > treated specially by the framework. > + Additional private methods may be added as needed in your testsuite > implementation. > > > .. _dts_dev_tools: > @@ -493,13 +491,10 @@ Building DTS API docs > The documentation is built using the standard DPDK build system. > See :doc:`../linux_gsg/build_dpdk` for more details on compiling DPDK > with meson. > > -The :ref:`doc build dependencies <doc_dependencies>` may be installed > with Poetry: > - > .. code-block:: console > > poetry install --only docs > poetry install --with docs # an alternative that will also install > DTS dependencies > - poetry shell > > After executing the meson command, build the documentation with: > > -- > 2.50.1 > > [-- Attachment #2: Type: text/html, Size: 8773 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* [PATCH v1 3/3] dts: fix doc generation bug 2025-05-27 15:37 [PATCH v1 1/3] dts: rewrite README Dean Marx 2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx @ 2025-05-27 15:37 ` Dean Marx 2025-05-28 20:28 ` Patrick Robb 2025-05-28 20:40 ` [PATCH v1 1/3] dts: rewrite README Patrick Robb 2025-05-29 12:40 ` Paul Szczepanek 3 siblings, 1 reply; 39+ messages in thread From: Dean Marx @ 2025-05-27 15:37 UTC (permalink / raw) To: probb, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek Cc: dev, Dean Marx Fix a bug in the port stats check test suite that was causing the DTS doc generation to fail. Fixes: 8f21210b1d50 ("dts: add port stats check test suite") Signed-off-by: Dean Marx <dmarx@iol.unh.edu> --- dts/tests/TestSuite_port_stats_checks.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/dts/tests/TestSuite_port_stats_checks.py b/dts/tests/TestSuite_port_stats_checks.py index 2a3fb06946..491c2263b6 100644 --- a/dts/tests/TestSuite_port_stats_checks.py +++ b/dts/tests/TestSuite_port_stats_checks.py @@ -51,10 +51,15 @@ class TestPortStatsChecks(TestSuite): #: Length of the packet being sent including the IP and frame headers. total_packet_len: ClassVar[int] = 100 - #: Packet to send during testing. - send_pkt: ClassVar[Packet] = ( - Ether() / IP() / Raw(b"X" * (total_packet_len - ip_header_len - ether_header_len)) - ) + + @property + def send_pkt(self) -> Packet: + """Packet to send during testing.""" + return ( + Ether() + / IP() + / Raw(b"X" * (self.total_packet_len - self.ip_header_len - self.ether_header_len)) + ) def extract_noise_information( self, verbose_out: list[TestPmdVerbosePacket] -- 2.49.0 ^ permalink raw reply related [flat|nested] 39+ messages in thread
* Re: [PATCH v1 3/3] dts: fix doc generation bug 2025-05-27 15:37 ` [PATCH v1 3/3] dts: fix doc generation bug Dean Marx @ 2025-05-28 20:28 ` Patrick Robb 2025-05-29 12:28 ` Paul Szczepanek 0 siblings, 1 reply; 39+ messages in thread From: Patrick Robb @ 2025-05-28 20:28 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 1809 bytes --] On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu> wrote: > Fix a bug in the port stats check test suite that was causing > the DTS doc generation to fail. > > Fixes: 8f21210b1d50 ("dts: add port stats check test suite") > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > --- > dts/tests/TestSuite_port_stats_checks.py | 13 +++++++++---- > 1 file changed, 9 insertions(+), 4 deletions(-) > > diff --git a/dts/tests/TestSuite_port_stats_checks.py > b/dts/tests/TestSuite_port_stats_checks.py > index 2a3fb06946..491c2263b6 100644 > --- a/dts/tests/TestSuite_port_stats_checks.py > +++ b/dts/tests/TestSuite_port_stats_checks.py > @@ -51,10 +51,15 @@ class TestPortStatsChecks(TestSuite): > > #: Length of the packet being sent including the IP and frame headers. > total_packet_len: ClassVar[int] = 100 > - #: Packet to send during testing. > - send_pkt: ClassVar[Packet] = ( > - Ether() / IP() / Raw(b"X" * (total_packet_len - ip_header_len - > ether_header_len)) > - ) > + > + @property > + def send_pkt(self) -> Packet: > + """Packet to send during testing.""" > + return ( > + Ether() > + / IP() > + / Raw(b"X" * (self.total_packet_len - self.ip_header_len - > self.ether_header_len)) > + ) > Looks good. In my opinion this should be a standalone patch, since it's unrelated to patch 1 and 2, but it's not functionally relevant since there is no such thing as a series in git, so you don't need to resubmit. Keep in mind for future series though that they should be logically grouped. Reviewed-by: Patrick Robb <probb@iol.unh.edu> > > def extract_noise_information( > self, verbose_out: list[TestPmdVerbosePacket] > -- > 2.49.0 > > [-- Attachment #2: Type: text/html, Size: 2643 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v1 3/3] dts: fix doc generation bug 2025-05-28 20:28 ` Patrick Robb @ 2025-05-29 12:28 ` Paul Szczepanek 0 siblings, 0 replies; 39+ messages in thread From: Paul Szczepanek @ 2025-05-29 12:28 UTC (permalink / raw) To: Patrick Robb, Dean Marx Cc: nd, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, dev Patrick is right but it's OK, I'll merge as part of the series - in the end it's a separate commit. Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> On 28/05/2025 21:28, Patrick Robb wrote: > > > On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu > <mailto:dmarx@iol.unh.edu>> wrote: > > Fix a bug in the port stats check test suite that was causing > the DTS doc generation to fail. > > Fixes: 8f21210b1d50 ("dts: add port stats check test suite") > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu <mailto:dmarx@iol.unh.edu>> > --- > dts/tests/TestSuite_port_stats_checks.py | 13 +++++++++---- > 1 file changed, 9 insertions(+), 4 deletions(-) > > diff --git a/dts/tests/TestSuite_port_stats_checks.py b/dts/tests/ > TestSuite_port_stats_checks.py > index 2a3fb06946..491c2263b6 100644 > --- a/dts/tests/TestSuite_port_stats_checks.py > +++ b/dts/tests/TestSuite_port_stats_checks.py > @@ -51,10 +51,15 @@ class TestPortStatsChecks(TestSuite): > > #: Length of the packet being sent including the IP and frame > headers. > total_packet_len: ClassVar[int] = 100 > - #: Packet to send during testing. > - send_pkt: ClassVar[Packet] = ( > - Ether() / IP() / Raw(b"X" * (total_packet_len - > ip_header_len - ether_header_len)) > - ) > + > + @property > + def send_pkt(self) -> Packet: > + """Packet to send during testing.""" > + return ( > + Ether() > + / IP() > + / Raw(b"X" * (self.total_packet_len - > self.ip_header_len - self.ether_header_len)) > + ) > > > Looks good. In my opinion this should be a standalone patch, since it's > unrelated to patch 1 and 2, but it's not functionally relevant since > there is no such thing as a series in git, so you don't need to > resubmit. Keep in mind for future series though that they should be > logically grouped. > > Reviewed-by: Patrick Robb <probb@iol.unh.edu <mailto:probb@iol.unh.edu>> > > > > def extract_noise_information( > self, verbose_out: list[TestPmdVerbosePacket] > -- > 2.49.0 > ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v1 1/3] dts: rewrite README 2025-05-27 15:37 [PATCH v1 1/3] dts: rewrite README Dean Marx 2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx 2025-05-27 15:37 ` [PATCH v1 3/3] dts: fix doc generation bug Dean Marx @ 2025-05-28 20:40 ` Patrick Robb 2025-05-29 12:27 ` Paul Szczepanek 2025-05-29 12:40 ` Paul Szczepanek 3 siblings, 1 reply; 39+ messages in thread From: Patrick Robb @ 2025-05-28 20:40 UTC (permalink / raw) To: Dean Marx Cc: luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, paul.szczepanek, dev [-- Attachment #1: Type: text/plain, Size: 11507 bytes --] On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu> wrote: > Remove unnecessary information from README.md, and add new sections to > clarify > the purpose/use of DTS along with clear setup instructions. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > --- > dts/README.md | 104 +++++++++++++++++++------------------------------- > 1 file changed, 39 insertions(+), 65 deletions(-) > > diff --git a/dts/README.md b/dts/README.md > index 2b3a7f89c5..879cf65abc 100644 > --- a/dts/README.md > +++ b/dts/README.md > @@ -1,81 +1,55 @@ > -# DTS Environment > +# Description > > -The execution and development environments for DTS are the same, > -a [Docker](https://docs.docker.com/) container defined by our > [Dockerfile](./Dockerfile). > -Using a container for the development environment helps with a few things. > +DTS is a testing framework and set of testsuites for end to end testing > of DPDK and DPDK > +enabled hardware. Unlike the DPDK unit test application, DTS is intended > to be used to Maybe change to "unlike DPDK's dpdk-test application, which is used for running unit tests, DTS is intended to be used to evaluate real DPDK workloads run over supported hardware." > > +evaluate real DPDK workloads run over supported hardware. For instance, > DTS will control > +a traffic generator node which will send packets to a system under test > node which is > +running a DPDK application, and evaluate those results. > > Change to "evaluate the resulting DPDK application behavior." > -1. It helps enforce the boundary between the DTS environment and the > TG/SUT, > - something which caused issues in the past. > -2. It makes creating containers to run DTS inside automated tooling much > easier, since > - they can be based off of a known-working environment that will be > updated as DTS is. > -3. It abstracts DTS from the server it is running on. This means that the > bare-metal OS > - can be whatever corporate policy or your personal preferences dictate, > - and DTS does not have to try to support all distros that are supported > by DPDK CI. > -4. It makes automated testing for DTS easier, > - since new dependencies can be sent in with the patches. > -5. It fixes the issue of undocumented dependencies, > - where some test suites require Python libraries that are not installed. > -6. Allows everyone to use the same Python version easily, > - even if they are using a distribution or Windows with out-of-date > packages. > -7. Allows you to run the tester on Windows while developing via Docker > for Windows. > +# Supported Test Node Topologies > > -## Tips for setting up a development environment > +DTS is a python application which will control a traffic generator node > (TG) and system > +under test node (SUT). The nodes represent a DPDK device (usually a NIC) > located on a > +host. The devices/NICs can be located on two separate servers, or on the > same server. If you use > +the same server for both NICs, install them on separate NUMA domains if > possible (this is ideal > +for performance testing.) > > -### Getting a docker shell > +1. 2 link: Represents a topology in which the TG node and SUT node both > have two network interfaces > 2 links topology > +which form the TG <-> SUT connection. An example of this would be a dual > interface NIC which is the > +TG node connected to a dual interface NIC which is the SUT node. > Interface 0 on TG <-> interface 0 > +on SUT, interface 1 on TG <-> interface 1 on SUT. > +2. 1 link: Works, but may result in skips for testsuites which are > explicitly decorated with a > 1 links topology > +2 link requirement. Represents a topology in which the TG node and SUT > node are both located on one > +network interface. An example of this would be a dual interface NIC with > a connection between > +its own ports. > I wonder whether it makes sense to provide an ascii drawing of the various topologies? I google an online ascii art tool and got these 2 showing the 2 links topology for 2 servers and 1 server: +------------------------------+ +------------------------------+ | | | | | | --------------- | | | | | | | Tester (Traffic Generator) | | System Under Test | | | | | | | --------------- | | | | | | +------------------------------+ +------------------------------+ ----------------------------------- | | | ------------------------- | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | +--------------------------------------------------+ | | | | | | | | | Combined Tester & SUT system | | | | | - | | | | +--------------------------------------------------+ If you wanted to do this you might have to use triple tilde to put it in a code block so it renders with a monospaced font for readers. > -These commands will give you a bash shell inside the container > -with all the Python dependencies installed. > -This will place you inside a Python virtual environment. > -DTS is mounted via a volume, which is essentially a symlink from the host > to the container. > -This enables you to edit and run inside the container > -and then delete the container when you are done, keeping your work. > -It is also strongly recommended that you mount your SSH keys into the > container > -to allow you to connect to hosts without specifying a password. > +# Simple linux setup > capitalize linux and setup > > -#### Start docker container with SSH keys > +1. On your TG and SUT nodes, add a dedicated user. In this example I will > name the user "dts." > +2. Grant passwordless sudo to the dts user, like so: > + 2a: enter 'visudo' in your terminal > + 2b: In the visudo text editor, add: > + dts ALL=(ALL:ALL) NOPASSWD:ALL > +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the > TG and SUT: > + ssh-copy-id dts@{your host}. > > -```shell > -docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it > dpdk-dts bash > -$ poetry install > -$ poetry shell > -``` > +For additional detail, please refer to [dts.rst](doc/guides/tools/dts.rst) > + > +# DTS Configuration > > -#### Start docker container without SSH keys > +DTS requires two yaml files to be filled out with information about your > environment, > +test_run.yaml and nodes.yaml, which follow the format illustrated in the > example files. > > ```shell > docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash > +docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it > dpdk-dts bash > Instead of dtsuser maybe we can more explicitly say {insert your dts ssh user}/ or similar. > $ poetry install > -$ poetry shell > +$ poetry run ./main.py > ``` > This information looks good, but I think it needs to be tied together more cohesively. I would make a step 4 like: 4. Create and fill out a test_run.yaml and nodes.yaml file within your dts directory, based on the structure from the example config files. And a step 5 like: 5. Run the bash terminal commands below in order to run the DTS container and start the DTS execution. ```shell docker build --target dev -t dpdk-dts . docker run -v $(pwd)/..:/dpdk -v /home/{insert your dts ssh user}/.ssh:/root/.ssh:ro -it dpdk-dts bash $ poetry install $ poetry run ./main.py ``` I also think we may have to call out some of the project dependencies (this is outside of the python dependencies that poetry handles for the DTS execution). So that would include Docker on the execution host, Scapy on the TG host. > -### Vim/Emacs > - > -Any editor in the Ubuntu repos should be easy to use, > -with Vim and Emacs already installed. > -You can add your normal config files as a volume, > -enabling you to use your preferred settings. > - > -```shell > -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts > bash > -``` > I agree we can remove this. > - > -### Visual Studio Code > - > -VSCode has first-class support for developing with containers. > -You may need to run the non-Docker setup commands in the integrated > terminal. > -DTS contains a .devcontainer config, > -so if you open the folder in VSCode it should prompt you to use the dev > container > -assuming you have the plugin installed. > -Please refer to > -[VS Development Containers Docs]( > https://code.visualstudio.com/docs/remote/containers) > -to set it all up. > -Additionally, there is a line in `.devcontainer/devcontainer.json` that, > when included, > -will mount the SSH keys of the user currently running VSCode into the > container for you. > -The `source` on this line can be altered to mount any SSH keys > -on the local machine into the container at the correct location. > +These commands will give you a bash shell inside a docker container > +with all DTS Python dependencies installed. > > Well... I know I was saying the devcontainers aren't so useful, but upon reflection, it's kind of nice to not have to manage the 2nd terminal for driving the container, and of course it means python intellisense will work without having to poetry install on your base system. I would leave this part in, but stick a sentence in at the start saying "usage of vscode devcontainers is NOT required for developing on DTS and running DTS, but provide some small quality of life improvements for the developer. If you want to develop from a devcontainer, see the instructions here" or somethign like that. > -### Other > +## Other > > -Searching for '$IDE dev containers' will probably lead you in the right > direction. > +Searching for '$IDE dev containers' will probably lead you in the right > direction. > \ No newline at end of file > -- > 2.49.0 > > Reviewed-by: Patrick Robb <probb@iol.unh.edu> [-- Attachment #2: Type: text/html, Size: 16138 bytes --] ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v1 1/3] dts: rewrite README 2025-05-28 20:40 ` [PATCH v1 1/3] dts: rewrite README Patrick Robb @ 2025-05-29 12:27 ` Paul Szczepanek 0 siblings, 0 replies; 39+ messages in thread From: Paul Szczepanek @ 2025-05-29 12:27 UTC (permalink / raw) To: Patrick Robb, Dean Marx Cc: nd, luca.vizzarro, yoan.picchi, Honnappa.Nagarahalli, dev Reviewed-by: Paul Szczepanek <paul.szczepanek@arm.com> On 28/05/2025 21:40, Patrick Robb wrote: > > > On Tue, May 27, 2025 at 11:37 AM Dean Marx <dmarx@iol.unh.edu > <mailto:dmarx@iol.unh.edu>> wrote: > > Remove unnecessary information from README.md, and add new sections > to clarify > the purpose/use of DTS along with clear setup instructions. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu <mailto:dmarx@iol.unh.edu>> > --- > dts/README.md | 104 +++++++++++++++++++------------------------------- > 1 file changed, 39 insertions(+), 65 deletions(-) > > diff --git a/dts/README.md b/dts/README.md > index 2b3a7f89c5..879cf65abc 100644 > --- a/dts/README.md > +++ b/dts/README.md > @@ -1,81 +1,55 @@ > -# DTS Environment > +# Description > > -The execution and development environments for DTS are the same, > -a [Docker](https://docs.docker.com/ <https://docs.docker.com/>) > container defined by our [Dockerfile](./Dockerfile). > -Using a container for the development environment helps with a few > things. > +DTS is a testing framework and set of testsuites for end to end > testing of DPDK and DPDK > +enabled hardware. Unlike the DPDK unit test application, DTS is > intended to be used to > > > Maybe change to "unlike DPDK's dpdk-test application, which is used for > running unit tests, DTS is intended to be used to evaluate real DPDK > workloads run over supported hardware." > > > > +evaluate real DPDK workloads run over supported hardware. For > instance, DTS will control > +a traffic generator node which will send packets to a system under > test node which is > +running a DPDK application, and evaluate those results. > > > Change to "evaluate the resulting DPDK application behavior." > > > -1. It helps enforce the boundary between the DTS environment and > the TG/SUT, > - something which caused issues in the past. > -2. It makes creating containers to run DTS inside automated tooling > much easier, since > - they can be based off of a known-working environment that will > be updated as DTS is. > -3. It abstracts DTS from the server it is running on. This means > that the bare-metal OS > - can be whatever corporate policy or your personal preferences > dictate, > - and DTS does not have to try to support all distros that are > supported by DPDK CI. > -4. It makes automated testing for DTS easier, > - since new dependencies can be sent in with the patches. > -5. It fixes the issue of undocumented dependencies, > - where some test suites require Python libraries that are not > installed. > -6. Allows everyone to use the same Python version easily, > - even if they are using a distribution or Windows with out-of- > date packages. > -7. Allows you to run the tester on Windows while developing via > Docker for Windows. > +# Supported Test Node Topologies > > -## Tips for setting up a development environment > +DTS is a python application which will control a traffic generator > node (TG) and system > +under test node (SUT). The nodes represent a DPDK device (usually a > NIC) located on a > +host. The devices/NICs can be located on two separate servers, or > on the same server. If you use > +the same server for both NICs, install them on separate NUMA > domains if possible (this is ideal > +for performance testing.) > > -### Getting a docker shell > +1. 2 link: Represents a topology in which the TG node and SUT node > both have two network interfaces > > > 2 links topology > > > +which form the TG <-> SUT connection. An example of this would be a > dual interface NIC which is the > +TG node connected to a dual interface NIC which is the SUT node. > Interface 0 on TG <-> interface 0 > +on SUT, interface 1 on TG <-> interface 1 on SUT. > +2. 1 link: Works, but may result in skips for testsuites which are > explicitly decorated with a > > > 1 links topology > > > +2 link requirement. Represents a topology in which the TG node and > SUT node are both located on one > +network interface. An example of this would be a dual interface NIC > with a connection between > +its own ports. > > > I wonder whether it makes sense to provide an ascii drawing of the > various topologies? > > I google an online ascii art tool and got these 2 showing the 2 links > topology for 2 servers and 1 server: > > +------------------------------+ +------------------------------+ > | | | | > | | --------------- | | > | | | | > | Tester (Traffic Generator) | | System Under Test | > | | | | > | | --------------- | | > | | | | > +------------------------------+ +------------------------------+ > > > > > > ----------------------------------- > | | > | ------------------------- | > | | | | > | | | | > | | | | > | | | | > | | | | > | | | | > | | | | > | | | | > +--------------------------------------------------+ > | | > | | > | | > | | > | Combined Tester & SUT system | > | | > | | - > | | > | | > +--------------------------------------------------+ > > > > If you wanted to do this you might have to use triple tilde to put it in > a code block so it renders with a monospaced font for readers. > > > > -These commands will give you a bash shell inside the container > -with all the Python dependencies installed. > -This will place you inside a Python virtual environment. > -DTS is mounted via a volume, which is essentially a symlink from > the host to the container. > -This enables you to edit and run inside the container > -and then delete the container when you are done, keeping your work. > -It is also strongly recommended that you mount your SSH keys into > the container > -to allow you to connect to hosts without specifying a password. > +# Simple linux setup > > > capitalize linux and setup > > > > -#### Start docker container with SSH keys > +1. On your TG and SUT nodes, add a dedicated user. In this example > I will name the user "dts." > +2. Grant passwordless sudo to the dts user, like so: > + 2a: enter 'visudo' in your terminal > + 2b: In the visudo text editor, add: > + dts ALL=(ALL:ALL) NOPASSWD:ALL > +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys > to the TG and SUT: > + ssh-copy-id dts@{your host}. > > -```shell > -docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro - > it dpdk-dts bash > -$ poetry install > -$ poetry shell > -``` > +For additional detail, please refer to [dts.rst](doc/guides/tools/ > dts.rst) > + > +# DTS Configuration > > -#### Start docker container without SSH keys > +DTS requires two yaml files to be filled out with information about > your environment, > +test_run.yaml and nodes.yaml, which follow the format illustrated > in the example files. > > ```shell > docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash > +docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro - > it dpdk-dts bash > > > Instead of dtsuser maybe we can more explicitly say {insert your dts ssh > user}/ or similar. > > > $ poetry install > -$ poetry shell > +$ poetry run ./main.py > ``` > > > This information looks good, but I think it needs to be tied together > more cohesively. I would make a step 4 like: > > 4. Create and fill out a test_run.yaml and nodes.yaml file within your > dts directory, based on the structure from the example config files. > > And a step 5 like: > > 5. Run the bash terminal commands below in order to run the DTS > container and start the DTS execution. > > ```shell > docker build --target dev -t dpdk-dts . > docker run -v $(pwd)/..:/dpdk -v /home/{insert your dts ssh user}/.ssh:/ > root/.ssh:ro -it dpdk-dts bash > $ poetry install > $ poetry run ./main.py > ``` > > > I also think we may have to call out some of the project dependencies > (this is outside of the python dependencies that poetry handles for the > DTS execution). So that would include Docker on the execution host, > Scapy on the TG host. > > > -### Vim/Emacs > - > -Any editor in the Ubuntu repos should be easy to use, > -with Vim and Emacs already installed. > -You can add your normal config files as a volume, > -enabling you to use your preferred settings. > - > -```shell > -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it > dpdk-dts bash > -``` > > > I agree we can remove this. > > > - > -### Visual Studio Code > - > -VSCode has first-class support for developing with containers. > -You may need to run the non-Docker setup commands in the integrated > terminal. > -DTS contains a .devcontainer config, > -so if you open the folder in VSCode it should prompt you to use the > dev container > -assuming you have the plugin installed. > -Please refer to > -[VS Development Containers Docs](https://code.visualstudio.com/ > docs/remote/containers <https://code.visualstudio.com/docs/remote/ > containers>) > -to set it all up. > -Additionally, there is a line in `.devcontainer/devcontainer.json` > that, when included, > -will mount the SSH keys of the user currently running VSCode into > the container for you. > -The `source` on this line can be altered to mount any SSH keys > -on the local machine into the container at the correct location. > +These commands will give you a bash shell inside a docker container > +with all DTS Python dependencies installed. > > > Well... I know I was saying the devcontainers aren't so useful, but upon > reflection, it's kind of nice to not have to manage the 2nd terminal for > driving the container, and of course it means python intellisense will > work without having to poetry install on your base system. I would leave > this part in, but stick a sentence in at the start saying "usage of > vscode devcontainers is NOT required for developing on DTS and running > DTS, but provide some small quality of life improvements for the > developer. If you want to develop from a devcontainer, see the > instructions here" or somethign like that. > > > -### Other > +## Other > > -Searching for '$IDE dev containers' will probably lead you in the > right direction. > +Searching for '$IDE dev containers' will probably lead you in the > right direction. > \ No newline at end of file > -- > 2.49.0 > > > Reviewed-by: Patrick Robb <probb@iol.unh.edu <mailto:probb@iol.unh.edu>> ^ permalink raw reply [flat|nested] 39+ messages in thread
* Re: [PATCH v1 1/3] dts: rewrite README 2025-05-27 15:37 [PATCH v1 1/3] dts: rewrite README Dean Marx ` (2 preceding siblings ...) 2025-05-28 20:40 ` [PATCH v1 1/3] dts: rewrite README Patrick Robb @ 2025-05-29 12:40 ` Paul Szczepanek 3 siblings, 0 replies; 39+ messages in thread From: Paul Szczepanek @ 2025-05-29 12:40 UTC (permalink / raw) To: Dean Marx, probb; +Cc: nd, dev Pls fix warning and I will merge On 27/05/2025 16:37, Dean Marx wrote: > Remove unnecessary information from README.md, and add new sections to clarify > the purpose/use of DTS along with clear setup instructions. > > Signed-off-by: Dean Marx <dmarx@iol.unh.edu> > --- > dts/README.md | 104 +++++++++++++++++++------------------------------- > 1 file changed, 39 insertions(+), 65 deletions(-) > > diff --git a/dts/README.md b/dts/README.md > index 2b3a7f89c5..879cf65abc 100644 > --- a/dts/README.md > +++ b/dts/README.md > @@ -1,81 +1,55 @@ > -# DTS Environment > +# Description > > -The execution and development environments for DTS are the same, > -a [Docker](https://docs.docker.com/) container defined by our [Dockerfile](./Dockerfile). > -Using a container for the development environment helps with a few things. > +DTS is a testing framework and set of testsuites for end to end testing of DPDK and DPDK > +enabled hardware. Unlike the DPDK unit test application, DTS is intended to be used to > +evaluate real DPDK workloads run over supported hardware. For instance, DTS will control > +a traffic generator node which will send packets to a system under test node which is > +running a DPDK application, and evaluate those results. > > -1. It helps enforce the boundary between the DTS environment and the TG/SUT, > - something which caused issues in the past. > -2. It makes creating containers to run DTS inside automated tooling much easier, since > - they can be based off of a known-working environment that will be updated as DTS is. > -3. It abstracts DTS from the server it is running on. This means that the bare-metal OS > - can be whatever corporate policy or your personal preferences dictate, > - and DTS does not have to try to support all distros that are supported by DPDK CI. > -4. It makes automated testing for DTS easier, > - since new dependencies can be sent in with the patches. > -5. It fixes the issue of undocumented dependencies, > - where some test suites require Python libraries that are not installed. > -6. Allows everyone to use the same Python version easily, > - even if they are using a distribution or Windows with out-of-date packages. > -7. Allows you to run the tester on Windows while developing via Docker for Windows. > +# Supported Test Node Topologies > > -## Tips for setting up a development environment > +DTS is a python application which will control a traffic generator node (TG) and system > +under test node (SUT). The nodes represent a DPDK device (usually a NIC) located on a > +host. The devices/NICs can be located on two separate servers, or on the same server. If you use > +the same server for both NICs, install them on separate NUMA domains if possible (this is ideal > +for performance testing.) > > -### Getting a docker shell > +1. 2 link: Represents a topology in which the TG node and SUT node both have two network interfaces > +which form the TG <-> SUT connection. An example of this would be a dual interface NIC which is the > +TG node connected to a dual interface NIC which is the SUT node. Interface 0 on TG <-> interface 0 > +on SUT, interface 1 on TG <-> interface 1 on SUT. > +2. 1 link: Works, but may result in skips for testsuites which are explicitly decorated with a > +2 link requirement. Represents a topology in which the TG node and SUT node are both located on one > +network interface. An example of this would be a dual interface NIC with a connection between > +its own ports. > > -These commands will give you a bash shell inside the container > -with all the Python dependencies installed. > -This will place you inside a Python virtual environment. > -DTS is mounted via a volume, which is essentially a symlink from the host to the container. > -This enables you to edit and run inside the container > -and then delete the container when you are done, keeping your work. > -It is also strongly recommended that you mount your SSH keys into the container > -to allow you to connect to hosts without specifying a password. > +# Simple linux setup > > -#### Start docker container with SSH keys > +1. On your TG and SUT nodes, add a dedicated user. In this example I will name the user "dts." > +2. Grant passwordless sudo to the dts user, like so: > + 2a: enter 'visudo' in your terminal > + 2b: In the visudo text editor, add: > + dts ALL=(ALL:ALL) NOPASSWD:ALL > +3. DTS uses ssh key auth to control the nodes. Copy your ssh keys to the TG and SUT: > + ssh-copy-id dts@{your host}. > > -```shell > -docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash > -$ poetry install > -$ poetry shell > -``` > +For additional detail, please refer to [dts.rst](doc/guides/tools/dts.rst) > + > +# DTS Configuration > > -#### Start docker container without SSH keys > +DTS requires two yaml files to be filled out with information about your environment, > +test_run.yaml and nodes.yaml, which follow the format illustrated in the example files. > > ```shell > docker build --target dev -t dpdk-dts . > -docker run -v $(pwd)/..:/dpdk -it dpdk-dts bash > +docker run -v $(pwd)/..:/dpdk -v /home/dtsuser/.ssh:/root/.ssh:ro -it dpdk-dts bash > $ poetry install > -$ poetry shell > +$ poetry run ./main.py > ``` > > -### Vim/Emacs > - > -Any editor in the Ubuntu repos should be easy to use, > -with Vim and Emacs already installed. > -You can add your normal config files as a volume, > -enabling you to use your preferred settings. > - > -```shell > -docker run -v ${HOME}/.vimrc:/root/.vimrc -v $(pwd)/..:/dpdk -it dpdk-dts bash > -``` > - > -### Visual Studio Code > - > -VSCode has first-class support for developing with containers. > -You may need to run the non-Docker setup commands in the integrated terminal. > -DTS contains a .devcontainer config, > -so if you open the folder in VSCode it should prompt you to use the dev container > -assuming you have the plugin installed. > -Please refer to > -[VS Development Containers Docs](https://code.visualstudio.com/docs/remote/containers) > -to set it all up. > -Additionally, there is a line in `.devcontainer/devcontainer.json` that, when included, > -will mount the SSH keys of the user currently running VSCode into the container for you. > -The `source` on this line can be altered to mount any SSH keys > -on the local machine into the container at the correct location. > +These commands will give you a bash shell inside a docker container > +with all DTS Python dependencies installed. > > -### Other > +## Other > > -Searching for '$IDE dev containers' will probably lead you in the right direction. > +Searching for '$IDE dev containers' will probably lead you in the right direction. > \ No newline at end of file ^ permalink raw reply [flat|nested] 39+ messages in thread
end of thread, other threads:[~2025-07-16 22:04 UTC | newest] Thread overview: 39+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-05-27 15:37 [PATCH v1 1/3] dts: rewrite README Dean Marx 2025-05-27 15:37 ` [PATCH v1 2/3] dts: rewrite dts rst Dean Marx 2025-05-28 21:25 ` Patrick Robb 2025-05-29 12:27 ` Paul Szczepanek 2025-06-03 17:28 ` [PATCH v2 1/2] dts: rewrite README Dean Marx 2025-06-03 17:28 ` [PATCH v2 2/2] dts: rewrite dts rst Dean Marx 2025-06-25 4:07 ` Patrick Robb 2025-07-09 19:57 ` Thomas Monjalon 2025-07-11 14:58 ` Patrick Robb 2025-06-25 4:06 ` [PATCH v2 1/2] dts: rewrite README Patrick Robb 2025-07-11 17:24 ` [PATCH v3 1/3] " Dean Marx 2025-07-11 17:24 ` [PATCH v3 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-14 14:10 ` Patrick Robb 2025-07-11 17:24 ` [PATCH v3 3/3] doc: revise coding guidelines section Dean Marx 2025-07-14 16:22 ` Patrick Robb 2025-07-11 21:22 ` [PATCH v3 1/3] dts: rewrite README Patrick Robb 2025-07-14 14:47 ` Dean Marx 2025-07-14 17:13 ` [PATCH v4 " Dean Marx 2025-07-14 17:13 ` [PATCH v4 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-14 17:13 ` [PATCH v4 3/3] doc: revise coding guidelines section Dean Marx 2025-07-15 22:25 ` Patrick Robb 2025-07-15 21:52 ` [PATCH v4 1/3] dts: rewrite README Patrick Robb 2025-07-16 13:57 ` [PATCH v5 " Dean Marx 2025-07-16 13:57 ` [PATCH v5 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 13:57 ` [PATCH v5 3/3] doc: revise coding guidelines section Dean Marx 2025-07-16 18:19 ` Patrick Robb 2025-07-16 18:25 ` [PATCH v6 1/3] dts: rewrite README Dean Marx 2025-07-16 18:25 ` [PATCH v6 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 18:25 ` [PATCH v6 3/3] doc: revise coding guidelines section Dean Marx 2025-07-16 20:53 ` [PATCH v7 1/3] dts: rewrite README Dean Marx 2025-07-16 20:53 ` [PATCH v7 2/3] doc: rephrase terminology in dts.rst Dean Marx 2025-07-16 20:54 ` [PATCH v7 3/3] doc: revise coding guidelines section Dean Marx 2025-07-16 21:58 ` Patrick Robb 2025-05-27 15:37 ` [PATCH v1 3/3] dts: fix doc generation bug Dean Marx 2025-05-28 20:28 ` Patrick Robb 2025-05-29 12:28 ` Paul Szczepanek 2025-05-28 20:40 ` [PATCH v1 1/3] dts: rewrite README Patrick Robb 2025-05-29 12:27 ` Paul Szczepanek 2025-05-29 12:40 ` Paul Szczepanek
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).