d9fe63b188
While the code already includes some provisions to allow running outside of a git checkout, attempting that right now causes a failure to generate the XML report, as the JSON report creates a null `zephyr_version` field. The reason for that is that the original code doesn't set `self.version` when the subprocess returns a non-zero status (and also doesn't log.) Instead of having to set `self.version` for all failure cases, initialize it to the failure state, and log if it hasn't changed from that. Signed-off-by: Diego Elio Pettenò <flameeyes@meta.com> |
||
---|---|---|
.. | ||
pytest_integration | ||
test_data | ||
conftest.py | ||
README.md | ||
test_cmakecache.py | ||
test_environment.py | ||
test_harness.py | ||
test_quarantine.py | ||
test_runner.py | ||
test_testinstance.py | ||
test_testplan_class.py | ||
test_testsuite.py | ||
test_twister.py |
Twister Testing
Running the tests require the environment variable ZEPHYR_BASE to be set.
Twister Testsuite are located in $ZEPHYR_BASE/scripts/tests directory with all the data files in $ZEPHYR_BASE/scripts/test_data directory.
Dependencies
Install all the dependencies using
pip install -r $ZEPHYR_BASE/scripts/requirements-build-test.txt
Executing testsuite
The testcases can be executed from the root directory using
pytest $ZEPHYR_BASE/scripts/tests/twister
Twister Coverage
The coverage for all the tests can be run using the command below. This will collect all the tests available.
coverage run -m pytest $ZEPHYR_BASE/scripts/tests/twister/
Then we can generate the coverage report for just twister script using
coverage report -m $ZEPHYR_BASE/scripts/pylib/twister/
To generate the coverage report for twister script use below command
coverage report -m $ZEPHYR_BASE/scripts/twister
The html coverage report for twister can be generated using
coverage html twister
If needed,the full coverage html report can be generated in every run of "pytest" in the tests directory using configuration file (setup.cfg).
Organization of tests
- conftest.py: Contains common fixtures for use in testing the twister tool.
- test_twister.py : Contains basic testcases for environment variables, verifying testcase & platform schema's.
- test_testsuite_class.py : Contains testcases for Testsuite class (except reporting functionality) in twisterlib.py.
- test_testinstance.py : Contains testcases for Testinstance and Testcase class.
- test_reporting_testsuite.py : Contains testcases for reporting functionality of Testsuite class of twister.