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

Side by Side Diff: build/android/gyp/util/build_device.py

Issue 285143002: [Android] Convert to DeviceUtils versions of IsOnline, HasRoot, and EnableRoot. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 7 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 unified diff | Download patch
OLDNEW
1 # Copyright 2013 The Chromium Authors. All rights reserved. 1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """ A simple device interface for build steps. 5 """ A simple device interface for build steps.
6 6
7 """ 7 """
8 8
9 import logging 9 import logging
10 import os 10 import os
11 import re 11 import re
12 import sys 12 import sys
13 13
14 from util import build_utils 14 from util import build_utils
15 15
16 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), '..', '..') 16 BUILD_ANDROID_DIR = os.path.join(os.path.dirname(__file__), '..', '..')
17 sys.path.append(BUILD_ANDROID_DIR) 17 sys.path.append(BUILD_ANDROID_DIR)
18 18
19 from pylib import android_commands 19 from pylib import android_commands
20 from pylib.device import device_errors
20 from pylib.device import device_utils 21 from pylib.device import device_utils
21 22
22 GetAttachedDevices = android_commands.GetAttachedDevices 23 GetAttachedDevices = android_commands.GetAttachedDevices
23 24
24 25
25 class BuildDevice(object): 26 class BuildDevice(object):
26 def __init__(self, configuration): 27 def __init__(self, configuration):
27 self.id = configuration['id'] 28 self.id = configuration['id']
28 self.description = configuration['description'] 29 self.description = configuration['description']
29 self.install_metadata = configuration['install_metadata'] 30 self.install_metadata = configuration['install_metadata']
(...skipping 20 matching lines...) Expand all
50 # org.chromium.chrome.shell-1.apk 51 # org.chromium.chrome.shell-1.apk
51 apk_matcher = lambda s: re.match('.*%s(-[0-9]*)?.apk$' % apk_package, s) 52 apk_matcher = lambda s: re.match('.*%s(-[0-9]*)?.apk$' % apk_package, s)
52 matches = filter(apk_matcher, self.install_metadata) 53 matches = filter(apk_matcher, self.install_metadata)
53 return matches[0] if matches else None 54 return matches[0] if matches else None
54 55
55 56
56 def GetConfigurationForDevice(device_id): 57 def GetConfigurationForDevice(device_id):
57 device = device_utils.DeviceUtils(device_id) 58 device = device_utils.DeviceUtils(device_id)
58 configuration = None 59 configuration = None
59 has_root = False 60 has_root = False
60 is_online = device.old_interface.IsOnline() 61 is_online = device.IsOnline()
61 if is_online: 62 if is_online:
62 cmd = 'ls -l /data/app; getprop ro.build.description' 63 cmd = 'ls -l /data/app; getprop ro.build.description'
63 cmd_output = device.old_interface.RunShellCommand(cmd) 64 cmd_output = device.old_interface.RunShellCommand(cmd)
64 has_root = not 'Permission denied' in cmd_output[0] 65 has_root = not 'Permission denied' in cmd_output[0]
65 if not has_root: 66 if not has_root:
66 # Disable warning log messages from EnableAdbRoot() 67 # Disable warning log messages from EnableRoot()
67 logging.getLogger().disabled = True 68 class LoggingDisabled(object):
Primiano Tucci (use gerrit) 2014/05/15 12:39:09 Is there a specific reason for having all this boi
jbudorick 2014/05/15 14:10:20 No, not really. The context manager would make mor
Primiano Tucci (use gerrit) 2014/05/15 15:21:34 I don't want to interfere with anybody's work (als
68 has_root = device.old_interface.EnableAdbRoot() 69 def __enter__(self):
69 logging.getLogger().disabled = False 70 logging.getLogger().disabled = True
71 def __exit__(self, _a, _b, _c):
72 logging.getLogger().disabled = False
73
74 with LoggingDisabled():
75 try:
76 device.EnableRoot()
77 has_root = True
78 except device_errors.CommandFailedError:
79 has_root = False
70 cmd_output = device.old_interface.RunShellCommand(cmd) 80 cmd_output = device.old_interface.RunShellCommand(cmd)
71 81
72 configuration = { 82 configuration = {
73 'id': device_id, 83 'id': device_id,
74 'description': cmd_output[-1], 84 'description': cmd_output[-1],
75 'install_metadata': cmd_output[:-1], 85 'install_metadata': cmd_output[:-1],
76 } 86 }
77 return configuration, is_online, has_root 87 return configuration, is_online, has_root
78 88
79 89
(...skipping 10 matching lines...) Expand all
90 assert len(configurations) == 1 100 assert len(configurations) == 1
91 return BuildDevice(configurations[0]) 101 return BuildDevice(configurations[0])
92 102
93 103
94 def GetBuildDeviceFromPath(path): 104 def GetBuildDeviceFromPath(path):
95 configurations = ReadConfigurations(path) 105 configurations = ReadConfigurations(path)
96 if len(configurations) > 0: 106 if len(configurations) > 0:
97 return GetBuildDevice(ReadConfigurations(path)) 107 return GetBuildDevice(ReadConfigurations(path))
98 return None 108 return None
99 109
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698