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