diff options
author | Doug Zongker <dougz@android.com> | 2009-12-10 02:01:45 +0100 |
---|---|---|
committer | Doug Zongker <dougz@android.com> | 2009-12-10 02:01:45 +0100 |
commit | 73ae31ce0ac09c0e45924d817644261c87ab1a60 (patch) | |
tree | 532c9d372ba61216f1e8b2f6673db11e44174935 /verifier_test.sh | |
parent | am c652e41d: fix cut-and-paste error in verifier (diff) | |
download | android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar.gz android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar.bz2 android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar.lz android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar.xz android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.tar.zst android_bootable_recovery-73ae31ce0ac09c0e45924d817644261c87ab1a60.zip |
Diffstat (limited to 'verifier_test.sh')
-rwxr-xr-x | verifier_test.sh | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/verifier_test.sh b/verifier_test.sh new file mode 100755 index 000000000..6350e80d3 --- /dev/null +++ b/verifier_test.sh @@ -0,0 +1,94 @@ +#!/bin/bash +# +# A test suite for applypatch. Run in a client where you have done +# envsetup, choosecombo, etc. +# +# DO NOT RUN THIS ON A DEVICE YOU CARE ABOUT. It will mess up your +# system partition. +# +# +# TODO: find some way to get this run regularly along with the rest of +# the tests. + +EMULATOR_PORT=5580 +DATA_DIR=$ANDROID_BUILD_TOP/bootable/recovery/testdata + +WORK_DIR=/data/local/tmp + +# set to 0 to use a device instead +USE_EMULATOR=0 + +# ------------------------ + +if [ "$USE_EMULATOR" == 1 ]; then + emulator -wipe-data -noaudio -no-window -port $EMULATOR_PORT & + pid_emulator=$! + ADB="adb -s emulator-$EMULATOR_PORT " +else + ADB="adb -d " +fi + +echo "waiting to connect to device" +$ADB wait-for-device + +# run a command on the device; exit with the exit status of the device +# command. +run_command() { + $ADB shell "$@" \; echo \$? | awk '{if (b) {print a}; a=$0; b=1} END {exit a}' +} + +testname() { + echo + echo "::: testing $1 :::" + testname="$1" +} + +fail() { + echo + echo FAIL: $testname + echo + [ "$open_pid" == "" ] || kill $open_pid + [ "$pid_emulator" == "" ] || kill $pid_emulator + exit 1 +} + + +cleanup() { + # not necessary if we're about to kill the emulator, but nice for + # running on real devices or already-running emulators. + run_command rm $WORK_DIR/verifier_test + run_command rm $WORK_DIR/package.zip + + [ "$pid_emulator" == "" ] || kill $pid_emulator +} + +$ADB push $ANDROID_PRODUCT_OUT/system/bin/verifier_test \ + $WORK_DIR/verifier_test + +expect_succeed() { + testname "$1 (should succeed)" + $ADB push $DATA_DIR/$1 $WORK_DIR/package.zip + run_command $WORK_DIR/verifier_test $WORK_DIR/package.zip || fail +} + +expect_fail() { + testname "$1 (should fail)" + $ADB push $DATA_DIR/$1 $WORK_DIR/package.zip + run_command $WORK_DIR/verifier_test $WORK_DIR/package.zip && fail +} + +expect_fail unsigned.zip +expect_fail jarsigned.zip +expect_succeed otasigned.zip +expect_fail random.zip +expect_fail fake-eocd.zip +expect_fail alter-metadata.zip +expect_fail alter-footer.zip + +# --------------- cleanup ---------------------- + +cleanup + +echo +echo PASS +echo |