#!/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"