mirror of
https://github.com/nasa/trick.git
synced 2025-01-10 23:12:44 +00:00
62 lines
2.9 KiB
Markdown
62 lines
2.9 KiB
Markdown
|
| [Home](/trick) → [Developer Docs](Developer-Docs-Home) → Testing |
|
||
|
|------------------------------------------------------------------|
|
||
|
|
||
|
|
||
|
# Testing
|
||
|
|
||
|
Currently, Trick has a suite of unit and integration tests that run through a hodgepodge of GTest, Trick's internal unit test framework, Makefiles, and TrickOps.
|
||
|
|
||
|
Unit tests can be found in their respective `trick_source/[sim_services|utils]/*/test` directories, and primarily use the Gtest framework. These are run primarily through test targets in their Makefiles. See `trick_source/sim_services/MemoryManager/test` for an example of organization.
|
||
|
|
||
|
Integration tests take the form of Sims with some embedded tests. They live under `trick_sims/` and `test/`. A full list of sims that are used as part of the test suite are in [test_sims.yml](). These are run with TrickOps.
|
||
|
|
||
|
## Test suite dependencies
|
||
|
|
||
|
Gtest is required for the unit tests and some integration tests. See the [install guide](../documentation/install_guide/Install-Guide.md) for gtest installation.
|
||
|
|
||
|
TrickOps requires python3 and the packages `PyYAML` and `psutil` (updated list in [Trickops requirements.txt](https://github.com/nasa/trick/blob/master/share/trick/trickops/requirements.txt)). Install these in your python environment, or create a virtual environment as follows:
|
||
|
```
|
||
|
cd share/trick/trickops/
|
||
|
python3 -m venv .venv && . .venv/bin/activate && pip3 install -r requirements.txt
|
||
|
cd ../../../
|
||
|
```
|
||
|
|
||
|
|
||
|
## Running the test suite
|
||
|
From trick home:
|
||
|
```
|
||
|
# Run everything
|
||
|
make test
|
||
|
|
||
|
# Run only integration tests
|
||
|
make sim_test
|
||
|
|
||
|
# Run only unit tests
|
||
|
make unit_test
|
||
|
```
|
||
|
|
||
|
Currently, TrickOps will redirect all console output from tests into logs under {TRICK_HOME}/trickops_logs/, and will also dump the output of failing logs to console after the test suite is finished.
|
||
|
|
||
|
## Coverage
|
||
|
Trick uses [Coveralls](https://coveralls.io/github/nasa/trick?branch=master) to host code coverage. Coverage is generated by running the test suite with gcov in CI, and then those files are uploaded to Coveralls.
|
||
|
|
||
|
To enable gcov in Trick, it must be cleaned and compiled with the following:
|
||
|
```
|
||
|
export CFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export CXXFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export LDFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export TRICK_CFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export TRICK_CXXFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export TRICK_SYSTEM_LDFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export TRICK_SYSTEM_CFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
export TRICK_SYSTEM_CXXFLAGS="-fprofile-arcs -ftest-coverage -O0"
|
||
|
```
|
||
|
|
||
|
After Trick has been rebuild with the instrumentation, run:
|
||
|
```
|
||
|
make code-coverage
|
||
|
```
|
||
|
This will generate, collect, and filter all the various coverage data collection files into `coverage.info`. This is the file that is uploaded to Coveralls in the [code_coverage.yml](https://github.com/nasa/trick/blob/master/.github/workflows/code_coverage.yml) Github Actions workflow.
|
||
|
|
||
|
|