zephyr/scripts/tests/sanitycheck
Anas Nashif e8e367ada4 sanitycheck: support only_tags for boards
Support running/building only specific tags and ignoring everything
else.

Adding this to a platform yaml file will enable tests with one of of
tags listed to be executed on the platform.

This is useful for special platform configurations used for testing
specific features for example.

Signed-off-by: Anas Nashif <anas.nashif@intel.com>
2020-07-20 17:44:16 -04:00
..
test_data
conftest.py sanitycheck: Testcases for report functions of TestSuite Class 2020-07-03 12:20:35 -04:00
README.md sanitycheck: Updating README file 2020-07-09 16:03:57 -05:00
test_reporting_testsuite.py sanitycheck: Testcases for report functions of TestSuite Class 2020-07-03 12:20:35 -04:00
test_sanitycheck.py
test_testinstance.py sanitycheck: native: Add option to enable UBSAN 2020-07-09 07:49:57 -04:00
test_testsuite_class.py sanitycheck: support only_tags for boards 2020-07-20 17:44:16 -04:00

Sanitycheck Testing

Running the tests require the environment variable ZEPHYR_BASE to be set.

Sanitycheck 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/tests/sanitycheck/requirements.txt

Executing testsuite

The testcases can be executed from the root directory using

pytest $ZEPHYR_BASE/scripts/tests/sanitycheck

Sanitycheck 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/sanitycheck/

Then we can generate the coverage report for just sanitylib script using

coverage report -m $ZEPHYR_BASE/scripts/sanity_chk/sanitylib.py

To generate the coverage report for sanitycheck script use below command

coverage report -m $ZEPHYR_BASE/scripts/sanitycheck

The html coverage report for sanitycheck can be generated using

coverage html sanitycheck

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 sanitycheck tool.
  • test_sanitycheck.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 sanitylib.py.
  • test_testinstance.py : Contains testcases for Testinstance and Testcase class.
  • test_reporting_testsuite.py : Contains testcases for reporting fucntionality of Testsuite class of sanitycheck.