Files
Jonathan Hui 523f5015bc [docs] update GEMINI.md with Nexus test instructions (#12542)
This commit updates GEMINI.md to include instructions for building and
running Nexus tests. Nexus is a test framework that enables faster and
more scalable network simulations within a single process.

The updated documentation provides:
- A brief overview of the Nexus test framework.
- The command to build Nexus tests using 'tests/nexus/build.sh'.
- Commands to run all Nexus tests or a specific test using
  'tests/nexus/run_nexus_tests.sh'.
- A reference to 'tests/nexus/README.md' for further details.
2026-02-24 15:38:44 -06:00

62 lines
2.3 KiB
Markdown

# Nexus test framework
Nexus is a test framework for OpenThread testing.
### Design Goals
- **Faster and more scalable network simulation**: Enable faster and more efficient simulations of OpenThread networks involving a large number of nodes over extended durations.
- **Enhanced control**: Achieve greater control and scalability over simulated tests.
### Features
- Includes the Nexus platform implementation that emulates platform behavior, allowing multiple nodes running the OpenThread core stack to be simulated and interact with each other within the same process.
- Unlike the simulation platform (under `examples/platforms/simulation`), where nodes run in separate processes and interact via POSIX sockets, Nexus nodes are simulated within a single process.
- Nexus tests can interact directly with the C++ or C OT core APIs, providing more control than the simulation platform's CLI-based interactions.
- The flow of time in Nexus tests is directly controlled by the test itself, allowing for quick time interval advancement.
### How to build and run tests
To build Nexus test cases, the `tests/nexus/build.sh` script can be used:
```bash
top_builddir=nexus_test ./tests/nexus/build.sh
```
By default, the script builds for IEEE 802.15.4. To build for TREL tests, use the `trel` argument:
```bash
top_builddir=nexus_test ./tests/nexus/build.sh trel
```
#### Automated testing and packet verification
The `tests/nexus/run_nexus_tests.sh` script automates the process of running tests and performing packet verification using corresponding Python scripts.
To run all default tests:
```bash
top_builddir=nexus_test ./tests/nexus/run_nexus_tests.sh
```
To run a specific test:
```bash
top_builddir=nexus_test ./tests/nexus/run_nexus_tests.sh 5_1_1
```
The script runs the Nexus C++ test (which generates a JSON file and optionally a PCAP file) and then executes the Python verification script (e.g., `verify_5_1_1.py`) if it exists. Artifacts for each test are preserved in a temporary directory if the test fails.
#### Manual execution
Each test can be run directly from the build directory. C++ tests typically take a topology name (if applicable) and a JSON output filename as arguments.
```bash
./nexus_test/tests/nexus/nexus_6_1_1 A test_6_1_1.json
```
The verification script can then be run manually:
```bash
python3 ./tests/nexus/verify_6_1_1.py test_6_1_1.json
```