This is a guide aimed towards contributors of ChainerX which is mostly implemented in C++. It describes how to build the project and how to run the test suite so that you can get started contributing.
Please refer to the Chainer Contribution Guide for the more general contribution guideline that is not specific to ChainerX. E.g. how to download the source code, manage git branches, send pull requests or contribute to Chainer’s Python code base.
Running the test suite¶
The test suite can be built by passing
It is not built by default.
Once built, run the suite with the following command from within the
$ ctest -V
The ChainerX C++ coding standard is mostly based on the Google C++ Style Guide and principles.
ChainerX is formatted using clang-format. To fix the formatting in-place, run the following command from the repository root:
$ scripts/run-clang-format.sh --in-place
The thread sanitizer can be used to detect thread-related bugs, such as data races.
To enable the thread sanitizer, pass
You can run the test with
ctest -V as usual and you will get warnings if the thread sanitizer detects any issues.
CUDA runtime is known to cause a thread leak error as a false alarm.
In such case, disable the thread leak detection using environment variable
Python contributions and unit tests¶
To test the Python binding, run the following command at the repository root:
Run tests with coverage:
$ pytest --cov --no-cov-on-fail --cov-fail-under=80
Run tests without CUDA GPU:
$ pytest -m 'not cuda'
We use gcov to the measure C++ code coverage.
Build the Python package in
Debug mode, and build C++ test suite as:
$ python setup.py build --debug --build-temp ./build --build-lib ./build develop $ mkdir -p build $ cd build $ cmake -DCMAKE_BUILD_TYPE=Debug -DCHAINERX_BUILD_PYTHON=1 -DCHAINERX_ENABLE_COVERAGE .. $ make
Run both the Python and the C++ test suite:
$ pytest $ cd build $ ctest -V
Then find the
$ find build -name '*.gcda'
gcov command to get coverage:
$ gcov ./build/chainerx/CMakeFiles/chainerx.dir/chainerx.gcda
You can also generate HTML coverage reports with lcov. After running tests:
$ lcov -c -b chainerx -d build/chainerx/ --no-external -o build/coverage.info $ genhtml build/coverage.info -o build/coverage
build/coverage/index.html with any browsers.