Add LcovMerger.
(series 2/4 of open-sourcing coverage command for java test)
--
PiperOrigin-RevId: 141044216
MOS_MIGRATED_REVID=141044216
diff --git a/tools/test/collect_coverage.sh b/tools/test/collect_coverage.sh
new file mode 100755
index 0000000..33aa2e3
--- /dev/null
+++ b/tools/test/collect_coverage.sh
@@ -0,0 +1,113 @@
+#!/bin/bash
+
+# Copyright 2016 The Bazel Authors. All rights reserved.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+# Wrapper script for collecting code coverage during test execution.
+#
+# Expected environment:
+# COVERAGE_MANIFEST - mandatory, location of the instrumented file manifest
+# LCOV_MERGER - mandatory, location of the LcovMerger
+# COVERAGE_DIR - optional, location of the coverage temp directory
+# COVERAGE_OUTPUT_FILE - optional, location of the final lcov file
+#
+# Script expects that it will be started in the execution root directory and
+# not in the test's runfiles directory.
+
+if [[ -z "$COVERAGE_MANIFEST" ]]; then
+ echo --
+ echo Coverage runner: \$COVERAGE_MANIFEST is not set
+ echo Current environment:
+ env | sort
+ exit 1
+fi
+
+# When collect_coverage.sh is used, test runner must be instructed not to cd
+# to the test's runfiles directory.
+ROOT="$PWD"
+
+if [[ "$COVERAGE_MANIFEST" != /* ]]; then
+ # Canonicalize the path to coverage manifest so that tests can find it.
+ export COVERAGE_MANIFEST="$ROOT/$COVERAGE_MANIFEST"
+fi
+
+# write coverage data outside of the runfiles tree
+export COVERAGE_DIR=${COVERAGE_DIR:-"$ROOT/coverage"}
+# make COVERAGE_DIR an absolute path
+if ! [[ $COVERAGE_DIR == $ROOT* ]]; then
+ COVERAGE_DIR=$ROOT/$COVERAGE_DIR
+fi
+
+mkdir -p "$COVERAGE_DIR"
+COVERAGE_OUTPUT_FILE=${COVERAGE_OUTPUT_FILE:-"$COVERAGE_DIR/_coverage.dat"}
+# make COVERAGE_OUTPUT_FILE an absolute path
+if ! [[ $COVERAGE_OUTPUT_FILE == $ROOT* ]]; then
+ COVERAGE_OUTPUT_FILE=$ROOT/$COVERAGE_OUTPUT_FILE
+fi
+
+
+# Java
+# --------------------------------------
+export JAVA_COVERAGE_FILE=$COVERAGE_DIR/jvcov.dat
+# Let tests know that it is a coverage run
+export COVERAGE=1
+export BULK_COVERAGE_RUN=1
+
+
+# Only check if file exists when LCOV_MERGER is set
+if [[ ! -z "$LCOV_MERGER" ]]; then
+ for name in "$LCOV_MERGER"; do
+ if [[ ! -e $name ]]; then
+ echo --
+ echo Coverage runner: cannot locate file $name
+ exit 1
+ fi
+ done
+fi
+
+
+cd "$TEST_SRCDIR"
+"$@"
+TEST_STATUS=$?
+
+# If LCOV_MERGER is not set, coverage is not supported.
+if [[ -z "$LCOV_MERGER" ]]; then
+ exit $TEST_STATUS
+fi
+
+
+# always create output files
+touch $COVERAGE_OUTPUT_FILE
+
+if [[ $TEST_STATUS -ne 0 ]]; then
+ echo --
+ echo Coverage runner: Not collecting coverage for failed test.
+ echo The following commands failed with status $TEST_STATUS
+ echo "$@"
+ exit $TEST_STATUS
+fi
+
+cd $ROOT
+
+export LCOV_MERGER_CMD="java -jar ${LCOV_MERGER} --coverage_dir=${COVERAGE_DIR} \
+--output_file=${COVERAGE_OUTPUT_FILE}"
+
+
+if [[ $DISPLAY_LCOV_CMD ]] ; then
+ echo "Running lcov_merger"
+ echo $LCOV_MERGER_CMD
+ echo "-----------------"
+fi
+
+exec $LCOV_MERGER_CMD