@@ -198,7 +198,7 @@ and then run the tests with the newly built binaries.
Configuring DTS
~~~~~~~~~~~~~~~
-DTS configuration is split into nodes and executions and build targets within executions,
+DTS configuration is split into nodes and test runs and build targets within test runs,
and follows a defined schema as described in `Configuration Schema`_.
By default, DTS will try to use the ``dts/conf.yaml`` :ref:`config file <configuration_schema_example>`,
which is a template that illustrates what can be configured in DTS.
@@ -505,12 +505,12 @@ _`Test target`
Properties
~~~~~~~~~~
-The configuration requires listing all the execution environments and nodes
+The configuration requires listing all the test run environments and nodes
involved in the testing. These can be defined with the following mappings:
-``executions``
+``test runs``
`sequence <https://docs.python.org/3/library/stdtypes.html#sequence-types-list-tuple-range>`_ listing
- the execution environments. Each entry is described as per the following
+ the test run environments. Each entry is described as per the following
`mapping <https://docs.python.org/3/library/stdtypes.html#mapping-types-dict>`_:
+----------------------------+-------------------------------------------------------------------+
@@ -605,4 +605,4 @@ And they both have two network ports which are physically connected to each othe
.. literalinclude:: ../../../dts/conf.yaml
:language: yaml
- :start-at: executions:
+ :start-at: test_runs:
@@ -2,8 +2,8 @@
# Copyright 2022-2023 The DPDK contributors
# Copyright 2023 Arm Limited
-executions:
- # define one execution environment
+test_runs:
+ # define one test run environment
- build_targets:
- arch: x86_64
os: linux
@@ -20,9 +20,9 @@ executions:
# The machine running the DPDK test executable
system_under_test_node:
node_name: "SUT 1"
- vdevs: # optional; if removed, vdevs won't be used in the execution
+ vdevs: # optional; if removed, vdevs won't be used in the test run
- "crypto_openssl"
- # Traffic generator node to use for this execution environment
+ # Traffic generator node to use for this test run
traffic_generator_node: "TG 1"
nodes:
# Define a system under test node, having two network ports physically
@@ -16,7 +16,7 @@
The test run configuration has two main sections:
- * The :class:`ExecutionConfiguration` which defines what tests are going to be run
+ * The :class:`TestRunConfiguration` which defines what tests are going to be run
and how DPDK will be built. It also references the testbed where these tests and DPDK
are going to be run,
* The nodes of the testbed are defined in the other section,
@@ -47,9 +47,9 @@
from framework.config.types import (
BuildTargetConfigDict,
ConfigurationDict,
- ExecutionConfigDict,
NodeConfigDict,
PortConfigDict,
+ TestRunConfigDict,
TestSuiteConfigDict,
TrafficGeneratorConfigDict,
)
@@ -430,8 +430,8 @@ def from_dict(
@dataclass(slots=True, frozen=True)
-class ExecutionConfiguration:
- """The configuration of an execution.
+class TestRunConfiguration:
+ """The configuration of a test run.
The configuration contains testbed information, what tests to execute
and with what DPDK build.
@@ -442,8 +442,8 @@ class ExecutionConfiguration:
func: Whether to run functional tests.
skip_smoke_tests: Whether to skip smoke tests.
test_suites: The names of test suites and/or test cases to execute.
- system_under_test_node: The SUT node to use in this execution.
- traffic_generator_node: The TG node to use in this execution.
+ system_under_test_node: The SUT node to use in this test run.
+ traffic_generator_node: The TG node to use in this test run.
vdevs: The names of virtual devices to test.
"""
@@ -459,7 +459,7 @@ class ExecutionConfiguration:
@classmethod
def from_dict(
cls,
- d: ExecutionConfigDict,
+ d: TestRunConfigDict,
node_map: dict[str, SutNodeConfiguration | TGNodeConfiguration],
) -> Self:
"""A convenience method that processes the inputs before creating an instance.
@@ -469,11 +469,11 @@ def from_dict(
are just stored.
Args:
- d: The configuration dictionary.
+ d: The test run configuration dictionary.
node_map: A dictionary mapping node names to their config objects.
Returns:
- The execution configuration instance.
+ The test run configuration instance.
"""
build_targets: list[BuildTargetConfiguration] = list(
map(BuildTargetConfiguration.from_dict, d["build_targets"])
@@ -481,14 +481,14 @@ def from_dict(
test_suites: list[TestSuiteConfig] = list(map(TestSuiteConfig.from_dict, d["test_suites"]))
sut_name = d["system_under_test_node"]["node_name"]
skip_smoke_tests = d.get("skip_smoke_tests", False)
- assert sut_name in node_map, f"Unknown SUT {sut_name} in execution {d}"
+ assert sut_name in node_map, f"Unknown SUT {sut_name} in test run {d}"
system_under_test_node = node_map[sut_name]
assert isinstance(
system_under_test_node, SutNodeConfiguration
), f"Invalid SUT configuration {system_under_test_node}"
tg_name = d["traffic_generator_node"]
- assert tg_name in node_map, f"Unknown TG {tg_name} in execution {d}"
+ assert tg_name in node_map, f"Unknown TG {tg_name} in test run {d}"
traffic_generator_node = node_map[tg_name]
assert isinstance(
traffic_generator_node, TGNodeConfiguration
@@ -516,10 +516,10 @@ def copy_and_modify(self, **kwargs) -> Self:
Args:
**kwargs: The names and types of keyword arguments are defined
- by the fields of the :class:`ExecutionConfiguration` class.
+ by the fields of the :class:`TestRunConfiguration` class.
Returns:
- The copied and modified execution configuration.
+ The copied and modified test run configuration.
"""
new_config = {}
for field in fields(self):
@@ -536,13 +536,13 @@ class Configuration:
"""DTS testbed and test configuration.
The node configuration is not stored in this object. Rather, all used node configurations
- are stored inside the execution configuration where the nodes are actually used.
+ are stored inside the test run configuration where the nodes are actually used.
Attributes:
- executions: Execution configurations.
+ test_runs: Test run configurations.
"""
- executions: list[ExecutionConfiguration]
+ test_runs: list[TestRunConfiguration]
@classmethod
def from_dict(cls, d: ConfigurationDict) -> Self:
@@ -566,11 +566,11 @@ def from_dict(cls, d: ConfigurationDict) -> Self:
node_map = {node.name: node for node in nodes}
assert len(nodes) == len(node_map), "Duplicate node names are not allowed"
- executions: list[ExecutionConfiguration] = list(
- map(ExecutionConfiguration.from_dict, d["executions"], [node_map for _ in d])
+ test_runs: list[TestRunConfiguration] = list(
+ map(TestRunConfiguration.from_dict, d["test_runs"], [node_map for _ in d])
)
- return cls(executions=executions)
+ return cls(test_runs=test_runs)
def load_config(config_file_path: Path) -> Configuration:
@@ -322,7 +322,7 @@
},
"minimum": 1
},
- "executions": {
+ "test_runs": {
"type": "array",
"items": {
"type": "object",
@@ -366,7 +366,7 @@
"$ref": "#/definitions/node_name"
},
"vdevs": {
- "description": "Optional list of names of vdevs to be used in execution",
+ "description": "Optional list of names of vdevs to be used in the test run",
"type": "array",
"items": {
"type": "string"
@@ -395,7 +395,7 @@
}
},
"required": [
- "executions",
+ "test_runs",
"nodes"
],
"additionalProperties": false
@@ -95,7 +95,7 @@ class TestSuiteConfigDict(TypedDict):
cases: list[str]
-class ExecutionSUTConfigDict(TypedDict):
+class TestRunSUTConfigDict(TypedDict):
"""Allowed keys and values."""
#:
@@ -104,7 +104,7 @@ class ExecutionSUTConfigDict(TypedDict):
vdevs: list[str]
-class ExecutionConfigDict(TypedDict):
+class TestRunConfigDict(TypedDict):
"""Allowed keys and values."""
#:
@@ -118,7 +118,7 @@ class ExecutionConfigDict(TypedDict):
#:
test_suites: TestSuiteConfigDict
#:
- system_under_test_node: ExecutionSUTConfigDict
+ system_under_test_node: TestRunSUTConfigDict
#:
traffic_generator_node: str
@@ -129,4 +129,4 @@ class ConfigurationDict(TypedDict):
#:
nodes: list[NodeConfigDict]
#:
- executions: list[ExecutionConfigDict]
+ test_runs: list[TestRunConfigDict]
@@ -29,23 +29,23 @@ class DtsStage(StrEnum):
"""The DTS execution stage."""
#:
- pre_execution = auto()
+ pre_run = auto()
#:
- execution_setup = auto()
- #:
- execution_teardown = auto()
+ test_run_setup = auto()
#:
build_target_setup = auto()
#:
- build_target_teardown = auto()
- #:
test_suite_setup = auto()
#:
test_suite = auto()
#:
test_suite_teardown = auto()
#:
- post_execution = auto()
+ build_target_teardown = auto()
+ #:
+ test_run_teardown = auto()
+ #:
+ post_run = auto()
class DTSLogger(logging.Logger):
@@ -59,7 +59,7 @@ class DTSLogger(logging.Logger):
a new stage switch occurs. This is useful mainly for logging per test suite.
"""
- _stage: ClassVar[DtsStage] = DtsStage.pre_execution
+ _stage: ClassVar[DtsStage] = DtsStage.pre_run
_extra_file_handlers: list[FileHandler] = []
def __init__(self, *args, **kwargs):
@@ -7,12 +7,12 @@
The module is responsible for running DTS in a series of stages:
- #. Execution stage,
+ #. Test run stage,
#. Build target stage,
#. Test suite stage,
#. Test case stage.
-The execution and build target stages set up the environment before running test suites.
+The test run and build target stages set up the environment before running test suites.
The test suite stage sets up steps common to all test cases
and the test case stage runs test cases individually.
"""
@@ -29,7 +29,7 @@
from .config import (
BuildTargetConfiguration,
Configuration,
- ExecutionConfiguration,
+ TestRunConfiguration,
TestSuiteConfig,
load_config,
)
@@ -44,9 +44,9 @@
from .test_result import (
BuildTargetResult,
DTSResult,
- ExecutionResult,
Result,
TestCaseResult,
+ TestRunResult,
TestSuiteResult,
TestSuiteWithCases,
)
@@ -70,7 +70,7 @@ class DTSRunner:
An error occurs in a build target setup. The current build target is aborted,
all test suites and their test cases are marked as blocked and the run continues
with the next build target. If the errored build target was the last one in the
- given execution, the next execution begins.
+ given test run, the next test run begins.
"""
_configuration: Configuration
@@ -95,24 +95,24 @@ def __init__(self):
self._perf_test_case_regex = r"test_perf_"
def run(self) -> None:
- """Run all build targets in all executions from the test run configuration.
+ """Run all build targets in all test runs from the test run configuration.
- Before running test suites, executions and build targets are first set up.
- The executions and build targets defined in the test run configuration are iterated over.
- The executions define which tests to run and where to run them and build targets define
+ Before running test suites, test runs and build targets are first set up.
+ The test runs and build targets defined in the test run configuration are iterated over.
+ The test runs define which tests to run and where to run them and build targets define
the DPDK build setup.
- The tests suites are set up for each execution/build target tuple and each discovered
+ The tests suites are set up for each test run/build target tuple and each discovered
test case within the test suite is set up, executed and torn down. After all test cases
have been executed, the test suite is torn down and the next build target will be tested.
In order to properly mark test suites and test cases as blocked in case of a failure,
we need to have discovered which test suites and test cases to run before any failures
- happen. The discovery happens at the earliest point at the start of each execution.
+ happen. The discovery happens at the earliest point at the start of each test run.
All the nested steps look like this:
- #. Execution setup
+ #. Test run setup
#. Build target setup
@@ -126,7 +126,7 @@ def run(self) -> None:
#. Build target teardown
- #. Execution teardown
+ #. Test run teardown
The test cases are filtered according to the specification in the test run configuration and
the :option:`--test-suite` command line argument or
@@ -139,33 +139,37 @@ def run(self) -> None:
self._check_dts_python_version()
self._result.update_setup(Result.PASS)
- # for all Execution sections
- for execution in self._configuration.executions:
- self._logger.set_stage(DtsStage.execution_setup)
+ # for all test run sections
+ for test_run_config in self._configuration.test_runs:
+ self._logger.set_stage(DtsStage.test_run_setup)
self._logger.info(
- f"Running execution with SUT '{execution.system_under_test_node.name}'."
+ f"Running test run with SUT '{test_run_config.system_under_test_node.name}'."
)
- execution_result = self._result.add_execution(execution)
+ test_run_result = self._result.add_test_run(test_run_config)
# we don't want to modify the original config, so create a copy
- execution_test_suites = list(
- SETTINGS.test_suites if SETTINGS.test_suites else execution.test_suites
+ test_run_test_suites = list(
+ SETTINGS.test_suites if SETTINGS.test_suites else test_run_config.test_suites
)
- if not execution.skip_smoke_tests:
- execution_test_suites[:0] = [TestSuiteConfig.from_dict("smoke_tests")]
+ if not test_run_config.skip_smoke_tests:
+ test_run_test_suites[:0] = [TestSuiteConfig.from_dict("smoke_tests")]
try:
test_suites_with_cases = self._get_test_suites_with_cases(
- execution_test_suites, execution.func, execution.perf
+ test_run_test_suites, test_run_config.func, test_run_config.perf
)
- execution_result.test_suites_with_cases = test_suites_with_cases
+ test_run_result.test_suites_with_cases = test_suites_with_cases
except Exception as e:
self._logger.exception(
- f"Invalid test suite configuration found: " f"{execution_test_suites}."
+ f"Invalid test suite configuration found: " f"{test_run_test_suites}."
)
- execution_result.update_setup(Result.FAIL, e)
+ test_run_result.update_setup(Result.FAIL, e)
else:
- self._connect_nodes_and_run_execution(
- sut_nodes, tg_nodes, execution, execution_result, test_suites_with_cases
+ self._connect_nodes_and_run_test_run(
+ sut_nodes,
+ tg_nodes,
+ test_run_config,
+ test_run_result,
+ test_suites_with_cases,
)
except Exception as e:
@@ -175,7 +179,7 @@ def run(self) -> None:
finally:
try:
- self._logger.set_stage(DtsStage.post_execution)
+ self._logger.set_stage(DtsStage.post_run)
for node in (sut_nodes | tg_nodes).values():
node.close()
self._result.update_teardown(Result.PASS)
@@ -354,17 +358,17 @@ def _filter_test_cases(
return func_test_cases, perf_test_cases
- def _connect_nodes_and_run_execution(
+ def _connect_nodes_and_run_test_run(
self,
sut_nodes: dict[str, SutNode],
tg_nodes: dict[str, TGNode],
- execution: ExecutionConfiguration,
- execution_result: ExecutionResult,
+ test_run_config: TestRunConfiguration,
+ test_run_result: TestRunResult,
test_suites_with_cases: Iterable[TestSuiteWithCases],
) -> None:
- """Connect nodes, then continue to run the given execution.
+ """Connect nodes, then continue to run the given test run.
- Connect the :class:`SutNode` and the :class:`TGNode` of this `execution`.
+ Connect the :class:`SutNode` and the :class:`TGNode` of this `test_run_config`.
If either has already been connected, it's going to be in either `sut_nodes` or `tg_nodes`,
respectively.
If not, connect and add the node to the respective `sut_nodes` or `tg_nodes` :class:`dict`.
@@ -372,104 +376,110 @@ def _connect_nodes_and_run_execution(
Args:
sut_nodes: A dictionary storing connected/to be connected SUT nodes.
tg_nodes: A dictionary storing connected/to be connected TG nodes.
- execution: An execution's test run configuration.
- execution_result: The execution's result.
+ test_run_config: A test run configuration.
+ test_run_result: The test run's result.
test_suites_with_cases: The test suites with test cases to run.
"""
- sut_node = sut_nodes.get(execution.system_under_test_node.name)
- tg_node = tg_nodes.get(execution.traffic_generator_node.name)
+ sut_node = sut_nodes.get(test_run_config.system_under_test_node.name)
+ tg_node = tg_nodes.get(test_run_config.traffic_generator_node.name)
try:
if not sut_node:
- sut_node = SutNode(execution.system_under_test_node)
+ sut_node = SutNode(test_run_config.system_under_test_node)
sut_nodes[sut_node.name] = sut_node
if not tg_node:
- tg_node = TGNode(execution.traffic_generator_node)
+ tg_node = TGNode(test_run_config.traffic_generator_node)
tg_nodes[tg_node.name] = tg_node
except Exception as e:
- failed_node = execution.system_under_test_node.name
+ failed_node = test_run_config.system_under_test_node.name
if sut_node:
- failed_node = execution.traffic_generator_node.name
+ failed_node = test_run_config.traffic_generator_node.name
self._logger.exception(f"The Creation of node {failed_node} failed.")
- execution_result.update_setup(Result.FAIL, e)
+ test_run_result.update_setup(Result.FAIL, e)
else:
- self._run_execution(
- sut_node, tg_node, execution, execution_result, test_suites_with_cases
+ self._run_test_run(
+ sut_node, tg_node, test_run_config, test_run_result, test_suites_with_cases
)
- def _run_execution(
+ def _run_test_run(
self,
sut_node: SutNode,
tg_node: TGNode,
- execution: ExecutionConfiguration,
- execution_result: ExecutionResult,
+ test_run_config: TestRunConfiguration,
+ test_run_result: TestRunResult,
test_suites_with_cases: Iterable[TestSuiteWithCases],
) -> None:
- """Run the given execution.
+ """Run the given test run.
- This involves running the execution setup as well as running all build targets
- in the given execution. After that, execution teardown is run.
+ This involves running the test run setup as well as running all build targets
+ in the given test run. After that, the test run teardown is run.
Args:
- sut_node: The execution's SUT node.
- tg_node: The execution's TG node.
- execution: An execution's test run configuration.
- execution_result: The execution's result.
+ sut_node: The test run's SUT node.
+ tg_node: The test run's TG node.
+ test_run_config: A test run configuration.
+ test_run_result: The test run's result.
test_suites_with_cases: The test suites with test cases to run.
"""
- self._logger.info(f"Running execution with SUT '{execution.system_under_test_node.name}'.")
- execution_result.add_sut_info(sut_node.node_info)
+ self._logger.info(
+ f"Running test run with SUT '{test_run_config.system_under_test_node.name}'."
+ )
+ test_run_result.add_sut_info(sut_node.node_info)
try:
- sut_node.set_up_execution(execution)
- execution_result.update_setup(Result.PASS)
+ sut_node.set_up_test_run(test_run_config)
+ test_run_result.update_setup(Result.PASS)
except Exception as e:
- self._logger.exception("Execution setup failed.")
- execution_result.update_setup(Result.FAIL, e)
+ self._logger.exception("Test run setup failed.")
+ test_run_result.update_setup(Result.FAIL, e)
else:
- for build_target in execution.build_targets:
- build_target_result = execution_result.add_build_target(build_target)
+ for build_target_config in test_run_config.build_targets:
+ build_target_result = test_run_result.add_build_target(build_target_config)
self._run_build_target(
- sut_node, tg_node, build_target, build_target_result, test_suites_with_cases
+ sut_node,
+ tg_node,
+ build_target_config,
+ build_target_result,
+ test_suites_with_cases,
)
finally:
try:
- self._logger.set_stage(DtsStage.execution_teardown)
- sut_node.tear_down_execution()
- execution_result.update_teardown(Result.PASS)
+ self._logger.set_stage(DtsStage.test_run_teardown)
+ sut_node.tear_down_test_run()
+ test_run_result.update_teardown(Result.PASS)
except Exception as e:
- self._logger.exception("Execution teardown failed.")
- execution_result.update_teardown(Result.FAIL, e)
+ self._logger.exception("Test run teardown failed.")
+ test_run_result.update_teardown(Result.FAIL, e)
def _run_build_target(
self,
sut_node: SutNode,
tg_node: TGNode,
- build_target: BuildTargetConfiguration,
+ build_target_config: BuildTargetConfiguration,
build_target_result: BuildTargetResult,
test_suites_with_cases: Iterable[TestSuiteWithCases],
) -> None:
"""Run the given build target.
This involves running the build target setup as well as running all test suites
- of the build target's execution.
+ of the build target's test run.
After that, build target teardown is run.
Args:
- sut_node: The execution's sut node.
- tg_node: The execution's tg node.
- build_target: A build target's test run configuration.
+ sut_node: The test run's sut node.
+ tg_node: The test run's tg node.
+ build_target_config: A build target's test run configuration.
build_target_result: The build target level result object associated
with the current build target.
test_suites_with_cases: The test suites with test cases to run.
"""
self._logger.set_stage(DtsStage.build_target_setup)
- self._logger.info(f"Running build target '{build_target.name}'.")
+ self._logger.info(f"Running build target '{build_target_config.name}'.")
try:
- sut_node.set_up_build_target(build_target)
+ sut_node.set_up_build_target(build_target_config)
self._result.dpdk_version = sut_node.dpdk_version
build_target_result.add_build_target_info(sut_node.get_build_target_info())
build_target_result.update_setup(Result.PASS)
@@ -505,8 +515,8 @@ def _run_test_suites(
in the current build target won't be executed.
Args:
- sut_node: The execution's SUT node.
- tg_node: The execution's TG node.
+ sut_node: The test run's SUT node.
+ tg_node: The test run's TG node.
build_target_result: The build target level result object associated
with the current build target.
test_suites_with_cases: The test suites with test cases to run.
@@ -545,8 +555,8 @@ def _run_test_suite(
Record the setup and the teardown and handle failures.
Args:
- sut_node: The execution's SUT node.
- tg_node: The execution's TG node.
+ sut_node: The test run's SUT node.
+ tg_node: The test run's TG node.
test_suite_result: The test suite level result object associated
with the current test suite.
test_suite_with_cases: The test suite with test cases to run.
@@ -7,7 +7,7 @@
The results are recorded in a hierarchical manner:
* :class:`DTSResult` contains
- * :class:`ExecutionResult` contains
+ * :class:`TestRunResult` contains
* :class:`BuildTargetResult` contains
* :class:`TestSuiteResult` contains
* :class:`TestCaseResult`
@@ -37,8 +37,8 @@
BuildTargetInfo,
Compiler,
CPUType,
- ExecutionConfiguration,
NodeInfo,
+ TestRunConfiguration,
TestSuiteConfig,
)
from .exception import DTSError, ErrorSeverity
@@ -137,8 +137,8 @@ class BaseResult(object):
Stores the results of the setup and teardown portions of the corresponding stage.
The hierarchical nature of DTS results is captured recursively in an internal list.
- A stage is each level in this particular hierarchy (pre-execution or the top-most level,
- execution, build target, test suite and test case.)
+ A stage is each level in this particular hierarchy (pre-run or the top-most level,
+ test run, build target, test suite and test case.)
Attributes:
setup_result: The result of the setup of the particular stage.
@@ -222,7 +222,7 @@ def add_stats(self, statistics: "Statistics") -> None:
class DTSResult(BaseResult):
"""Stores environment information and test results from a DTS run.
- * Execution level information, such as testbed and the test suite list,
+ * Test run level information, such as testbed and the test suite list,
* Build target level information, such as compiler, target OS and cpu,
* Test suite and test case results,
* All errors that are caught and recorded during DTS execution.
@@ -230,7 +230,7 @@ class DTSResult(BaseResult):
The information is stored hierarchically. This is the first level of the hierarchy
and as such is where the data form the whole hierarchy is collated or processed.
- The internal list stores the results of all executions.
+ The internal list stores the results of all test runs.
Attributes:
dpdk_version: The DPDK version to record.
@@ -257,21 +257,21 @@ def __init__(self, logger: DTSLogger):
self._stats_result = None
self._stats_filename = os.path.join(SETTINGS.output_dir, "statistics.txt")
- def add_execution(self, execution: ExecutionConfiguration) -> "ExecutionResult":
- """Add and return the child result (execution).
+ def add_test_run(self, test_run_config: TestRunConfiguration) -> "TestRunResult":
+ """Add and return the child result (test run).
Args:
- execution: The execution's test run configuration.
+ test_run_config: A test run configuration.
Returns:
- The execution's result.
+ The test run's result.
"""
- result = ExecutionResult(execution)
+ result = TestRunResult(test_run_config)
self.child_results.append(result)
return result
def add_error(self, error: Exception) -> None:
- """Record an error that occurred outside any execution.
+ """Record an error that occurred outside any test run.
Args:
error: The exception to record.
@@ -314,10 +314,10 @@ def get_return_code(self) -> int:
return int(self._return_code)
-class ExecutionResult(BaseResult):
- """The execution specific result.
+class TestRunResult(BaseResult):
+ """The test run specific result.
- The internal list stores the results of all build targets in a given execution.
+ The internal list stores the results of all build targets in a given test run.
Attributes:
sut_os_name: The operating system of the SUT node.
@@ -328,45 +328,47 @@ class ExecutionResult(BaseResult):
sut_os_name: str
sut_os_version: str
sut_kernel_version: str
- _config: ExecutionConfiguration
+ _config: TestRunConfiguration
_parent_result: DTSResult
_test_suites_with_cases: list[TestSuiteWithCases]
- def __init__(self, execution: ExecutionConfiguration):
- """Extend the constructor with the execution's config and DTSResult.
+ def __init__(self, test_run_config: TestRunConfiguration):
+ """Extend the constructor with the test run's config and DTSResult.
Args:
- execution: The execution's test run configuration.
+ test_run_config: A test run configuration.
"""
- super(ExecutionResult, self).__init__()
- self._config = execution
+ super(TestRunResult, self).__init__()
+ self._config = test_run_config
self._test_suites_with_cases = []
- def add_build_target(self, build_target: BuildTargetConfiguration) -> "BuildTargetResult":
+ def add_build_target(
+ self, build_target_config: BuildTargetConfiguration
+ ) -> "BuildTargetResult":
"""Add and return the child result (build target).
Args:
- build_target: The build target's test run configuration.
+ build_target_config: The build target's test run configuration.
Returns:
The build target's result.
"""
result = BuildTargetResult(
self._test_suites_with_cases,
- build_target,
+ build_target_config,
)
self.child_results.append(result)
return result
@property
def test_suites_with_cases(self) -> list[TestSuiteWithCases]:
- """The test suites with test cases to be executed in this execution.
+ """The test suites with test cases to be executed in this test run.
The test suites can only be assigned once.
Returns:
The list of test suites with test cases. If an error occurs between
- the initialization of :class:`ExecutionResult` and assigning test cases to the instance,
+ the initialization of :class:`TestRunResult` and assigning test cases to the instance,
return an empty list, representing that we don't know what to execute.
"""
return self._test_suites_with_cases
@@ -375,7 +377,7 @@ def test_suites_with_cases(self) -> list[TestSuiteWithCases]:
def test_suites_with_cases(self, test_suites_with_cases: list[TestSuiteWithCases]) -> None:
if self._test_suites_with_cases:
raise ValueError(
- "Attempted to assign test suites to an execution result "
+ "Attempted to assign test suites to a test run result "
"which already has test suites."
)
self._test_suites_with_cases = test_suites_with_cases
@@ -422,19 +424,19 @@ class BuildTargetResult(BaseResult):
def __init__(
self,
test_suites_with_cases: list[TestSuiteWithCases],
- build_target: BuildTargetConfiguration,
+ build_target_config: BuildTargetConfiguration,
):
- """Extend the constructor with the build target's config and ExecutionResult.
+ """Extend the constructor with the build target's config and test suites with cases.
Args:
test_suites_with_cases: The test suites with test cases to be run in this build target.
- build_target: The build target's test run configuration.
+ build_target_config: The build target's test run configuration.
"""
super(BuildTargetResult, self).__init__()
- self.arch = build_target.arch
- self.os = build_target.os
- self.cpu = build_target.cpu
- self.compiler = build_target.compiler
+ self.arch = build_target_config.arch
+ self.os = build_target_config.os
+ self.cpu = build_target_config.cpu
+ self.compiler = build_target_config.compiler
self.compiler_version = None
self.dpdk_version = None
self._test_suites_with_cases = test_suites_with_cases
@@ -19,8 +19,8 @@
from framework.config import (
OS,
BuildTargetConfiguration,
- ExecutionConfiguration,
NodeConfiguration,
+ TestRunConfiguration,
)
from framework.exception import ConfigurationError
from framework.logger import DTSLogger, get_dts_logger
@@ -65,7 +65,7 @@ class Node(ABC):
ports: list[Port]
_logger: DTSLogger
_other_sessions: list[OSSession]
- _execution_config: ExecutionConfiguration
+ _test_run_config: TestRunConfiguration
virtual_devices: list[VirtualDevice]
def __init__(self, node_config: NodeConfiguration):
@@ -103,40 +103,40 @@ def _init_ports(self) -> None:
for port in self.ports:
self.configure_port_state(port)
- def set_up_execution(self, execution_config: ExecutionConfiguration) -> None:
- """Execution setup steps.
+ def set_up_test_run(self, test_run_config: TestRunConfiguration) -> None:
+ """Test run setup steps.
- Configure hugepages and call :meth:`_set_up_execution` where
+ Configure hugepages and call :meth:`_set_up_test_run` where
the rest of the configuration steps (if any) are implemented.
Args:
- execution_config: The execution test run configuration according to which
+ test_run_config: A test run configuration according to which
the setup steps will be taken.
"""
self._setup_hugepages()
- self._set_up_execution(execution_config)
- self._execution_config = execution_config
- for vdev in execution_config.vdevs:
+ self._set_up_test_run(test_run_config)
+ self._test_run_config = test_run_config
+ for vdev in test_run_config.vdevs:
self.virtual_devices.append(VirtualDevice(vdev))
- def _set_up_execution(self, execution_config: ExecutionConfiguration) -> None:
- """Optional additional execution setup steps for subclasses.
+ def _set_up_test_run(self, test_run_config: TestRunConfiguration) -> None:
+ """Optional additional test run setup steps for subclasses.
- Subclasses should override this if they need to add additional execution setup steps.
+ Subclasses should override this if they need to add additional test run setup steps.
"""
- def tear_down_execution(self) -> None:
- """Execution teardown steps.
+ def tear_down_test_run(self) -> None:
+ """Test run teardown steps.
- There are currently no common execution teardown steps common to all DTS node types.
+ There are currently no common test run teardown steps common to all DTS node types.
"""
self.virtual_devices = []
- self._tear_down_execution()
+ self._tear_down_test_run()
- def _tear_down_execution(self) -> None:
- """Optional additional execution teardown steps for subclasses.
+ def _tear_down_test_run(self) -> None:
+ """Optional additional test run teardown steps for subclasses.
- Subclasses should override this if they need to add additional execution teardown steps.
+ Subclasses should override this if they need to add additional test run teardown steps.
"""
def set_up_build_target(self, build_target_config: BuildTargetConfiguration) -> None:
@@ -52,7 +52,7 @@ def set_up_suite(self) -> None:
"""Set up the test suite.
Setup:
- Verify that we have at least 2 port links in the current execution
+ Verify that we have at least 2 port links in the current test run
and increase the MTU of both ports on the traffic generator to 9000
to support larger packet sizes.
"""