summaryrefslogtreecommitdiffstats
path: root/tests/backup/test_restore.sh
diff options
context:
space:
mode:
authorOmari Stephens <xsdg@android.com>2009-08-11 21:44:21 -0700
committerOmari Stephens <xsdg@android.com>2009-08-11 21:51:03 -0700
commit0cfeb25707c87af285cc993967be486d9c95a176 (patch)
tree61ae212b6b8c424e0b4c39d13b5f9699431a810a /tests/backup/test_restore.sh
parentc5ea43920919eeaec4ec0686de9fa3d034d82337 (diff)
downloadframeworks_base-0cfeb25707c87af285cc993967be486d9c95a176.zip
frameworks_base-0cfeb25707c87af285cc993967be486d9c95a176.tar.gz
frameworks_base-0cfeb25707c87af285cc993967be486d9c95a176.tar.bz2
The triumphant return of the shell scripts, with bugreports, less code dup, and
enhanced readability.
Diffstat (limited to 'tests/backup/test_restore.sh')
-rwxr-xr-xtests/backup/test_restore.sh80
1 files changed, 50 insertions, 30 deletions
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 '<map><int name="pref" value="1" /></map>'
+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 '<map><int name="pref" value="1" /></map>' || 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