Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(440)

Unified Diff: build/android/gyp/apk_install.py

Issue 14254005: [Android] Make gyp/apk_install.py resilient to user actions (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | build/android/gyp/util/md5_check.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/android/gyp/apk_install.py
diff --git a/build/android/gyp/apk_install.py b/build/android/gyp/apk_install.py
index 8cd1a604fe671b53e9e0ea736b0bec6b85637a10..714be081ca14c1084284e57c66336dcd5f7e842a 100755
--- a/build/android/gyp/apk_install.py
+++ b/build/android/gyp/apk_install.py
@@ -10,6 +10,7 @@
import optparse
import os
+import re
import subprocess
import sys
@@ -20,6 +21,39 @@ BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), '..')
sys.path.append(BUILD_ANDROID_DIR)
from pylib import android_commands
+from pylib.utils import apk_helper
+
+
+def GetMetadata(apk_package):
+ """Gets the metadata on the device for the apk_package apk."""
+ adb = android_commands.AndroidCommands()
+ output = adb.RunShellCommand('ls -l /data/app/')
+ # Matches lines like:
+ # -rw-r--r-- system system 7376582 2013-04-19 16:34 org.chromium.chrome.testshell.apk
+ # -rw-r--r-- system system 7376582 2013-04-19 16:34 org.chromium.chrome.testshell-1.apk
+ apk_matcher = lambda s: re.match('.*%s(-[0-9]*)?.apk$' % apk_package, s)
+ matches = filter(apk_matcher, output)
+ return matches[0] if matches else None
+
+
+def HasInstallMetadataChanged(apk_package, metadata_path):
+ """Checks if the metadata on the device for apk_package has changed."""
+ if not os.path.exists(metadata_path):
+ return True
+
+ with open(metadata_path, 'r') as expected_file:
+ return expected_file.read() != GetMetadata(apk_package)
+
+
+def RecordInstallMetadata(apk_package, metadata_path):
+ """Records the metadata from the device for apk_package."""
+ metadata = GetMetadata(apk_package)
+ if not metadata:
+ raise 'APK install failed unexpectedly.'
+
+ with open(metadata_path, 'w') as outfile:
+ outfile.write(metadata)
+
def main(argv):
parser = optparse.OptionParser()
@@ -39,17 +73,28 @@ def main(argv):
'install', '-r',
options.apk_path]
+ serial_number = android_commands.AndroidCommands().Adb().GetSerialNumber()
+ apk_package = apk_helper.GetPackageName(options.apk_path)
+
+ metadata_path = '%s.%s.device.time.stamp' % (options.apk_path, serial_number)
+
+ # If the APK on the device does not match the one that was last installed by
+ # the build, then the APK has to be installed (regardless of the md5 record).
+ force_install = HasInstallMetadataChanged(apk_package, metadata_path)
+
def Install():
- build_utils.CheckCallDie(install_cmd)
- build_utils.Touch(options.install_record)
+ build_utils.CheckCallDie(install_cmd)
+ RecordInstallMetadata(apk_package, metadata_path)
+ build_utils.Touch(options.install_record)
+
- serial_number = android_commands.AndroidCommands().Adb().GetSerialNumber()
record_path = '%s.%s.md5.stamp' % (options.apk_path, serial_number)
md5_check.CallAndRecordIfStale(
Install,
record_path=record_path,
input_paths=[options.apk_path],
- input_strings=install_cmd)
+ input_strings=install_cmd,
+ force=force_install)
if options.stamp:
build_utils.Touch(options.stamp)
« no previous file with comments | « no previous file | build/android/gyp/util/md5_check.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698