diff options
author | Baligh Uddin <baligh@google.com> | 2020-10-20 15:05:35 +0000 |
---|---|---|
committer | Baligh Uddin <baligh@google.com> | 2020-10-22 04:34:57 +0000 |
commit | c77f2d507e9091daebf8f3fe45c1d3fffc41622c (patch) | |
tree | e60b8bab2919567c9f9d6020e95fedf87b0cf979 /adb/coverage/gen_coverage.sh | |
parent | 1670666252914c640359693a55f1dad4e21b4b65 (diff) |
Migrate system/core/adb to packages/modules/adb
BUG: 167963357
Test: TH
Change-Id: Ie1f82db2fb14e1bdd183bf8d3d93d5e9f974be5d
Ignore-AOSP-First: Unable to Merge into aosp/master due to downstream conflicts, so working from bottom up.
Diffstat (limited to 'adb/coverage/gen_coverage.sh')
-rwxr-xr-x | adb/coverage/gen_coverage.sh | 119 |
1 files changed, 0 insertions, 119 deletions
diff --git a/adb/coverage/gen_coverage.sh b/adb/coverage/gen_coverage.sh deleted file mode 100755 index 43d45f0d8e..0000000000 --- a/adb/coverage/gen_coverage.sh +++ /dev/null @@ -1,119 +0,0 @@ -#!/bin/bash - -set -euxo pipefail - -OUTPUT_DIR=$(dirname "$0") -. "$OUTPUT_DIR"/include.sh - -TRACEDIR=`mktemp -d` - -### Make sure we can connect to the device. - -# Get the device's wlan0 address. -IP_ADDR=$(adb shell ip route get 0.0.0.0 oif wlan0 | sed -En -e 's/.*src (\S+)\s.*/\1/p') -REMOTE_PORT=5555 -REMOTE=$IP_ADDR:$REMOTE_PORT -LOCAL_SERIAL=$(adb shell getprop ro.serialno) - -# Check that we can connect to it. -adb disconnect - -TRANSPORT_ID=$(adb transport-id) -adb tcpip $REMOTE_PORT -adb -t $TRANSPORT_ID wait-for-disconnect - -adb connect $REMOTE - -REMOTE_FETCHED_SERIAL=$(adb -s $REMOTE shell getprop ro.serialno) - -if [[ "$LOCAL_SERIAL" != "$REMOTE_FETCHED_SERIAL" ]]; then - echo "Mismatch: local serial = $LOCAL_SERIAL, remote serial = $REMOTE_FETCHED_SERIAL" - exit 1 -fi - -# Back to USB, and make sure adbd is root. -adb -s $REMOTE usb -adb disconnect $REMOTE - -adb wait-for-device root -adb root -adb wait-for-device - -TRANSPORT_ID=$(adb transport-id) -adb usb -adb -t $TRANSPORT_ID wait-for-disconnect - -adb wait-for-device - -### Run the adb unit tests and fetch traces from them. -mkdir "$TRACEDIR"/test_traces -adb shell rm -rf /data/local/tmp/adb_coverage -adb shell mkdir /data/local/tmp/adb_coverage - -for TEST in $ADB_TESTS; do - adb shell LLVM_PROFILE_FILE=/data/local/tmp/adb_coverage/$TEST.profraw /data/nativetest64/$TEST/$TEST - adb pull /data/local/tmp/adb_coverage/$TEST.profraw "$TRACEDIR"/test_traces/ -done - -adb pull /data/local/tmp/adb_coverage "$TRACEDIR"/test_traces - -# Clear logcat and increase the buffer to something ridiculous so we can fetch the pids of adbd later. -adb shell logcat -c -G128M - -# Turn on extremely verbose logging so as to not count debug logging against us. -adb shell setprop persist.adb.trace_mask 1 - -### Run test_device.py over USB. -TRANSPORT_ID=$(adb transport-id) -adb shell killall adbd -adb -t $TRANSPORT_ID wait-for-disconnect - -adb wait-for-device shell rm -rf "/data/misc/trace/*" /data/local/tmp/adb_coverage/ -"$OUTPUT_DIR"/../test_device.py - -# Do a usb reset to exercise the disconnect code. -adb_usbreset -adb wait-for-device - -# Dump traces from the currently running adbd. -adb shell killall -37 adbd - -echo Waiting for adbd to finish dumping traces -sleep 5 - -# Restart adbd in tcp mode. -TRANSPORT_ID=$(adb transport-id) -adb tcpip $REMOTE_PORT -adb -t $TRANSPORT_ID wait-for-disconnect - -adb connect $REMOTE -adb -s $REMOTE wait-for-device - -# Instead of running test_device.py again, which takes forever, do some I/O back and forth instead. -dd if=/dev/zero bs=1024 count=10240 | adb -s $REMOTE raw sink:10485760 -adb -s $REMOTE raw source:10485760 | dd of=/dev/null bs=1024 count=10240 - -# Dump traces again. -adb disconnect $REMOTE -adb shell killall -37 adbd - -echo Waiting for adbd to finish dumping traces -sleep 5 - -adb pull /data/misc/trace "$TRACEDIR"/ -echo Pulled traces to $TRACEDIR - -# Identify which of the trace files are actually adbd, in case something else exited simultaneously. -ADBD_PIDS=$(adb shell "logcat -d -s adbd --format=process | grep 'adbd started' | cut -c 3-7 | tr -d ' ' | sort | uniq") -mkdir "$TRACEDIR"/adbd_traces - -adb shell 'setprop persist.adb.trace_mask 0; killall adbd' - -IFS=$'\n' -for PID in $ADBD_PIDS; do - cp "$TRACEDIR"/trace/clang-$PID-*.profraw "$TRACEDIR"/adbd_traces 2>/dev/null || true -done -unset IFS - -### Merge the traces. -llvm-profdata merge --output="$OUTPUT_DIR"/adbd.profdata "$TRACEDIR"/adbd_traces/* "$TRACEDIR"/test_traces/* |