| #!/bin/sh |
| # |
| # Usage |
| # |
| # COVERAGE_CPUS=32 tools/coverage.sh [/path/to/report-directory/] |
| # |
| # COVERAGE_CPUS defaults to 2, and the default destination is a temp |
| # dir. |
| |
| genhtml=$(which genhtml) |
| if [[ -z "${genhtml}" ]]; then |
| echo "Install 'genhtml' (contained in the 'lcov' package)" |
| exit 1 |
| fi |
| |
| destdir="$1" |
| if [[ -z "${destdir}" ]]; then |
| destdir=$(mktemp -d /tmp/gerritcov.XXXXXX) |
| fi |
| |
| echo "Running 'bazel coverage'; this may take a while" |
| |
| # coverage is expensive to run; use --jobs=2 to avoid overloading the |
| # machine. |
| bazel coverage -k --jobs=${COVERAGE_CPUS:-2} -- ... -//javatests/com/google/gerrit/common:auto_value_tests |
| |
| # The coverage data contains filenames relative to the Java root, and |
| # genhtml has no logic to search these elsewhere. Workaround this |
| # limitation by running genhtml in a directory with the files in the |
| # right place. Also -inexplicably- genhtml wants to have the source |
| # files relative to the output directory. |
| mkdir -p ${destdir}/ |
| cp -a */src/{main,test}/java/* ${destdir}/ |
| |
| base=$(bazel info bazel-testlogs) |
| for f in $(find ${base} -name 'coverage.dat') ; do |
| cp $f ${destdir}/$(echo $f| sed "s|${base}/||" | sed "s|/|_|g") |
| done |
| |
| cd ${destdir} |
| find -name '*coverage.dat' -size 0 -delete |
| |
| genhtml -o . --ignore-errors source *coverage.dat |
| |
| echo "coverage report at file://${destdir}/index.html" |