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) |