| #!/bin/sh |
| # Copyright (C) 2014 The Android Open Source Project |
| # |
| # 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. |
| |
| # |
| # acov is a tool for gathering coverage information from a device and generating |
| # a report from that information. To use: |
| # |
| # 1. sudo apt-get install lcov |
| # 2. Build application/library with coverage information. |
| # * make NATIVE_COVERAGE=true NATIVE_COVERAGE_PATHS='*' |
| # 3. Push the new binaries to the device with adb sync. |
| # (Optional): Run `acov --clean-device`. This will reset coverage for everything |
| # on the device. |
| # 4. Run tests. |
| # (Optional): Run `acov --flush`. This will dump coverage from all processes |
| # running on the device. |
| # 5. Run `acov`. |
| # |
| # acov will pull all coverage information from the device, push it to the right |
| # directories, run lcov, and display the coverage report (currently by opening |
| # it in your browser). |
| # |
| |
| if [ "$CLANG_COVERAGE" == "true" ]; then |
| echo "CLANG_COVERAGE is set. Use development/scripts/acov-llvm.py instead." |
| exit 0 |
| fi |
| |
| ANDROID_OUT=${OUT_DIR:-out} |
| FLUSH_SLEEP=${FLUSH_SLEEP:-60} |
| |
| function clearGcdaFiles() { |
| if [ -d "$ANDROID_OUT" ]; then |
| find $ANDROID_OUT -name '*.gcda' -delete |
| fi |
| } |
| |
| function clearGcnoFiles() { |
| if [ -d "$ANDROID_OUT" ]; then |
| find $ANDROID_OUT -name '*.gcno' -delete |
| fi |
| } |
| |
| if [ "$1" = "--clean" ]; then |
| echo "Clearing gcda and gcno files from the local build." |
| clearGcdaFiles |
| clearGcnoFiles |
| exit 0 |
| fi |
| |
| if [ "$1" = "--prep" ]; then |
| echo "Clearing gcda files from the local build." |
| clearGcdaFiles |
| exit 0 |
| fi |
| |
| adb root |
| |
| if [ "$1" = "--clean-device" ]; then |
| echo "Resetting coverage on the device..." |
| adb shell kill -37 -1 |
| echo "Waiting $FLUSH_SLEEP seconds for coverage to be written..." |
| sleep $FLUSH_SLEEP |
| adb shell rm -rf /data/misc/trace/* |
| exit 0 |
| fi |
| |
| if [ "$1" = "--flush" ]; then |
| shift |
| if [ -z $@ ]; then |
| echo "Flushing coverage for all processes on the device..." |
| adb shell kill -37 -1 |
| else |
| echo "Flushing coverage for [$@] on the device..." |
| adb shell kill -37 $(adb shell pidof $@) |
| fi |
| echo "Waiting $FLUSH_SLEEP seconds for coverage to be written..." |
| sleep $FLUSH_SLEEP |
| exit 0 |
| fi |
| |
| which lcov >/dev/null 2>/dev/null |
| if [ $? -ne 0 ]; then |
| echo 'lcov not found: running `sudo apt-get install lcov`' |
| sudo apt-get install lcov |
| fi |
| |
| cd $ANDROID_BUILD_TOP |
| DIR=$(mktemp -d covreport-XXXXXX) |
| |
| # Build a coverage report for each euid that has reported coverage. |
| COVERAGE_REPORTS= |
| for USER_ID in $(adb shell ls /data/misc/trace) |
| do |
| FILE=cov-$USER_ID.info |
| adb shell tar -czf - -C /data/misc/trace/$USER_ID/proc/self/cwd $ANDROID_OUT | tar zxvf - |
| |
| lcov -c -d $ANDROID_OUT -o $DIR/$FILE --gcov-tool=llvm-gcov $@ |
| COVERAGE_REPORTS="-a $DIR/$FILE $COVERAGE_REPORTS" |
| |
| clearGcdaFiles |
| done |
| |
| FILE=merged.info |
| lcov $COVERAGE_REPORTS -o $DIR/$FILE |
| echo "Generating coverage report at $DIR" |
| genhtml -q -o $DIR $DIR/$FILE |
| xdg-open $DIR/index.html >/dev/null |