From 0cfeb25707c87af285cc993967be486d9c95a176 Mon Sep 17 00:00:00 2001 From: Omari Stephens Date: Tue, 11 Aug 2009 21:44:21 -0700 Subject: The triumphant return of the shell scripts, with bugreports, less code dup, and enhanced readability. --- tests/backup/test_restore.sh | 80 +++++++++++++++++++++++++++----------------- 1 file changed, 50 insertions(+), 30 deletions(-) (limited to 'tests/backup/test_restore.sh') diff --git a/tests/backup/test_restore.sh b/tests/backup/test_restore.sh index 44b3a28..4506c16 100755 --- a/tests/backup/test_restore.sh +++ b/tests/backup/test_restore.sh @@ -14,76 +14,96 @@ # See the License for the specific language governing permissions and # limitations under the License. +# uncomment for debugging +#export DRY_RUN="echo" +source test_backup_common.sh -ADB_OPTS="$@" +BUGREPORT_DIR="$HOME/backup/bugreports" function check_file { - data=$(adb $ADB_OPTS shell cat /data/data/com.android.backuptest/$1) + data=$(a shell cat /data/data/com.android.backuptest/$1) if [ "$data" = "$2" ] ; then echo "$1 has correct value [$2]" + return 0 else echo $1 is INCORRECT echo " value: [$data]" echo " expected: [$2]" + return 1 + fi +} + +function check_exists +{ + # return 0 if file exists, 1 otherwise + data=$(a shell "ls $@ 2> /dev/null >/dev/null && echo -n exists") + if [ "$data" = "exists" ]; then + return 0 + else + return 1 fi } # run adb as root so we can poke at com.android.backuptest's data -root_status=$(adb $ADB_OPTS root) -if [ "x$root_status" != "xadbd is already running as root" ]; then - echo -n "Restarting adb as root..." - sleep 2 - adb $ADB_OPTS 'wait-for-device' - echo done. -fi +adb_root # delete the old data echo --- Previous files -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/files" -adb $ADB_OPTS shell "rm /data/data/com.android.backuptest/files/*" +a shell "ls -l /data/data/com.android.backuptest/files" +a shell "rm /data/data/com.android.backuptest/files/*" echo --- Previous shared_prefs -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/shared_prefs" -adb $ADB_OPTS shell "rm /data/data/com.android.backuptest/shared_prefs/*" +a shell "ls -l /data/data/com.android.backuptest/shared_prefs" +a shell "rm /data/data/com.android.backuptest/shared_prefs/*" echo --- Erased files and shared_prefs -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/files" -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/shared_prefs" +a shell "ls -l /data/data/com.android.backuptest/files" +a shell "ls -l /data/data/com.android.backuptest/shared_prefs" echo --- echo echo -echo # FIXME: there's probably a smarter way to do this # FIXME: if we can get the android ID, that's probably the safest thing to do # pick the most recent set and restore from it -restore_set=$(adb $ADB_OPTS shell bmgr list sets | head -n1 | awk '{print $1}') +restore_set=$(a shell bmgr list sets | head -n1 | awk '{print $1}') # run the restore -printf "Restoring from set %d (hex: 0x%x)\n" $restore_set $restore_set -adb $ADB_OPTS shell bmgr restore $restore_set +echo "Restoring from set [$restore_set]" +a shell bmgr restore "$restore_set" echo echo -echo # check the results -check_file files/file.txt "first file" -check_file files/another_file.txt "asdf" -#check_file files/3.txt "3" -check_file files/empty.txt "" -check_file shared_prefs/raw.xml '' +export need_bug=0 + +# make sure files have the expected contents +check_file files/file.txt "first file" || need_bug=1 +check_file files/another_file.txt "asdf" || need_bug=1 +#check_file files/3.txt "3" || need_bug=1 +check_file files/empty.txt "" || need_bug=1 +check_file shared_prefs/raw.xml '' || need_bug=1 + +# make sure that missing files weren't somehow created +check_exists files/file_doesnt_exist.txt && need_bug=1 +check_exists files/no_files_here.txt && need_bug=1 + +if [ \( "$need_bug" -ne 0 \) -a -d "$BUGREPORT_DIR" ]; then + dev_id=$(a get-serialno) + filename="${dev_id}_`date +%s`" + echo "Grabbing bugreport; filename is $filename" + a bugreport > "$BUGREPORT_DIR/$filename.txt" +fi -echo -echo echo echo --- Restored files -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/files" +a shell "ls -l /data/data/com.android.backuptest/files" echo --- Restored shared_prefs -adb $ADB_OPTS shell "ls -l /data/data/com.android.backuptest/shared_prefs" +a shell "ls -l /data/data/com.android.backuptest/shared_prefs" echo --- echo echo "Last 3 timestamps in 3.txt:" -adb $ADB_OPTS shell cat /data/data/com.android.backuptest/files/3.txt | tail -n 3 +a shell cat /data/data/com.android.backuptest/files/3.txt | tail -n 3 -- cgit v1.1