Please refer to the main repository for how to use these tools here
CLI tool for using the CSA Test Harness
- Ubuntu Server OS
- Python >= 3.10
- Poetry installed (see: https://python-poetry.org/docs/#installation)
- Open terminal in the root folder and run the command
./scripts/th_cli_install.sh - Change the url in config.json if required:
"hostname" : "192.168.x.x" //Change this to your Raspberry Pi IP address/localhost for local development- Run
th-cli --helpto check available commands
Commands:
abort-testing Abort the current test execution
available-tests Get a list of available tests
project Manage the application projects
run-tests Create a new test run from selected tests
test-run-execution List test run executions and read logs
test-runner-status Get the current Matter test runner status
Run th-cli available-tests to get a list of tests available in Test Harness, printed in YAML. For JSON respond, use th-cli available-tests --json .
Run th-cli run-tests --tests-list <tests> [--title, -n <title>] [--config, -c <config>] [--pics-config-folder, -p <pics-config-folder>] [--project-id <ID>] [--no-color] to start a new test execution.
Required:
--tests-list: Comma-separated list of test case identifiers (e.g. --tests-list TC-ACE-1.1,TC_ACE_1_3)
Optional:
--title: Custom title for the test run. If not provided, the current timestamp will be used as the default.--config: Path to the property config file. If not specified, default_config.properties will be used.--pics-config-folder: Path to the folder that contains PICS files. If not specified, no PICS file will be used.--project-id: Project ID that this test run belongs to. If not provided, uses the default 'CLI Execution Project' in TH.--no-color: Disable all colors from the CLI's output text of this test run execution
Run th-cli test-run-execution-history to fetch the history of test runs. Use --skip and --limit for pagination
Run th-cli test-run-execution-history --id {id} with a test run execution id to fetch the information for that test run.
For JSON respond, add --json to the command.
Run th-cli create-project --name {project name} --config {config file} to create a new project. Project name is required.
Run th-cli list-projects to fetch projects. Use --skip and --limit for pagination. Use --archived to fetch archived projects only.
Run th-cli list-projects --id {id} with a project id to fetch the information for that specific project.
For JSON respond, add --json to the command.
Run th-cli delete-project --id {id} to delete a project.
Run th-cli update-project --id {id} --config {config file} to update a project. Both parameters are required. Config must be a full test environment config file.
By default, the CLI application presents colored texts for all the available commands, specially for the log of test run executions from the th-cli run-tests command.
If the users need to disable the colors from the tool's output, they may use one of the options presented below:
- Use the option flag
--no-colorfrom therun-testscommand to remove color for that execution (e.gth-cli run-tests --no-color -t TC-ACE-1.1) - Prepend the environment variable
TH_CLI_NO_COLORset to True to therun-testcommand (e.gTH_CLI_NO_COLOR=1 th-cli run-tests -t TC-ACE-1.1) - Export the environment variable and use the CLI normally on the same terminal instance (e.g Use
export TH_CLI_NO_COLOR=1before using the CLI commands)
For the item 3 above, it's possible to change permanently adding the TH_CLI_NO_COLOR=1 variable to the shell profile (e.g. ~/.bashrc).
After that, resetting that terminal or any new one will present no color for all the CLI commands.
The source files are organized in ./th_cli/.
The project uses click to declare commands.
To add a new command to the CLI:
- Add a new file in
./th_cli/commands - Import the new command in
./th_cli/commands/__init__.py - Import and add the new command to the
rootgroup in./th_cli/main.py
This project comes with a pre-configured dev-container for VS Code. This takes care of all dependencies and configuring type-checker, linters and auto-formatting.
A major component of the CLI is the calling the Test Harness API. We're auto-generating a python client for this API
using fastapi_client based on the openapi.json published by the
Test Harness backend.
To update our client:
- update
openapi.jsonin the root of this project - run
./scripts/generate_client(This requires Docker to be installed)
The project dependencies are managed with Poetry.
To add a new dependency, run poetry add <package-name>.
The project dependencies may be scanned to look for known vulnerabilities or conflicts for all the poetry packages configured. For that, run the following command after the tool installation to verify the current status of the required dependencies:
poetry run python ./scripts/check_deps.py
The GitHub Project will run linting with Black, Flake8 and mypy on PRs. But these are also available in convenient scripts:
./scripts/lint.sh./scripts/format.sh
The VS Code dev-container is also configured to do this automatically on file save.