1
0
mirror of https://github.com/ARM-software/devlib.git synced 2025-10-25 12:03:19 +01:00

Add support for arbitrary ADB servers

This commit is contained in:
Anthony Barbier
2017-07-25 13:48:33 +01:00
parent fb58e47cf5
commit 7919a5643c

View File

@@ -163,7 +163,7 @@ class AdbConnection(object):
@memoized @memoized
def newline_separator(self): def newline_separator(self):
output = adb_command(self.device, output = adb_command(self.device,
"shell '({}); echo \"\n$?\"'".format(self.ls_command)) "shell '({}); echo \"\n$?\"'".format(self.ls_command), adb_server=self.adb_server)
if output.endswith('\r\n'): if output.endswith('\r\n'):
return '\r\n' return '\r\n'
elif output.endswith('\n'): elif output.endswith('\n'):
@@ -178,7 +178,7 @@ class AdbConnection(object):
def _setup_ls(self): def _setup_ls(self):
command = "shell '(ls -1); echo \"\n$?\"'" command = "shell '(ls -1); echo \"\n$?\"'"
try: try:
output = adb_command(self.device, command, timeout=self.timeout) output = adb_command(self.device, command, timeout=self.timeout, adb_server=self.adb_server)
except subprocess.CalledProcessError as e: except subprocess.CalledProcessError as e:
raise HostError( raise HostError(
'Failed to set up ls command on Android device. Output:\n' 'Failed to set up ls command on Android device. Output:\n'
@@ -191,11 +191,12 @@ class AdbConnection(object):
self.ls_command = 'ls' self.ls_command = 'ls'
logger.debug("ls command is set to {}".format(self.ls_command)) logger.debug("ls command is set to {}".format(self.ls_command))
def __init__(self, device=None, timeout=None, platform=None): def __init__(self, device=None, timeout=None, platform=None, adb_server=None):
self.timeout = timeout if timeout is not None else self.default_timeout self.timeout = timeout if timeout is not None else self.default_timeout
if device is None: if device is None:
device = adb_get_device(timeout=timeout) device = adb_get_device(timeout=timeout, adb_server=adb_server)
self.device = device self.device = device
self.adb_server = adb_server
adb_connect(self.device) adb_connect(self.device)
AdbConnection.active_connections[self.device] += 1 AdbConnection.active_connections[self.device] += 1
self._setup_ls() self._setup_ls()
@@ -206,7 +207,7 @@ class AdbConnection(object):
command = "push '{}' '{}'".format(source, dest) command = "push '{}' '{}'".format(source, dest)
if not os.path.exists(source): if not os.path.exists(source):
raise HostError('No such file "{}"'.format(source)) raise HostError('No such file "{}"'.format(source))
return adb_command(self.device, command, timeout=timeout) return adb_command(self.device, command, timeout=timeout, adb_server=self.adb_server)
def pull(self, source, dest, timeout=None): def pull(self, source, dest, timeout=None):
if timeout is None: if timeout is None:
@@ -215,18 +216,18 @@ class AdbConnection(object):
if os.path.isdir(dest) and \ if os.path.isdir(dest) and \
('*' in source or '?' in source): ('*' in source or '?' in source):
command = 'shell {} {}'.format(self.ls_command, source) command = 'shell {} {}'.format(self.ls_command, source)
output = adb_command(self.device, command, timeout=timeout) output = adb_command(self.device, command, timeout=timeout, adb_server=self.adb_server)
for line in output.splitlines(): for line in output.splitlines():
command = "pull '{}' '{}'".format(line.strip(), dest) command = "pull '{}' '{}'".format(line.strip(), dest)
adb_command(self.device, command, timeout=timeout) adb_command(self.device, command, timeout=timeout, adb_server=self.adb_server)
return return
command = "pull '{}' '{}'".format(source, dest) command = "pull '{}' '{}'".format(source, dest)
return adb_command(self.device, command, timeout=timeout) return adb_command(self.device, command, timeout=timeout, adb_server=self.adb_server)
def execute(self, command, timeout=None, check_exit_code=False, def execute(self, command, timeout=None, check_exit_code=False,
as_root=False, strip_colors=True): as_root=False, strip_colors=True):
return adb_shell(self.device, command, timeout, check_exit_code, return adb_shell(self.device, command, timeout, check_exit_code,
as_root, self.newline_separator) as_root, self.newline_separator,adb_server=self.adb_server)
def background(self, command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, as_root=False): def background(self, command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, as_root=False):
return adb_background_shell(self.device, command, stdout, stderr, as_root) return adb_background_shell(self.device, command, stdout, stderr, as_root)
@@ -258,7 +259,7 @@ def fastboot_flash_partition(partition, path_to_image):
fastboot_command(command) fastboot_command(command)
def adb_get_device(timeout=None): def adb_get_device(timeout=None, adb_server=None):
""" """
Returns the serial number of a connected android device. Returns the serial number of a connected android device.
@@ -273,7 +274,7 @@ def adb_get_device(timeout=None):
# then the output length is 2 + (1 for each device) # then the output length is 2 + (1 for each device)
start = time.time() start = time.time()
while True: while True:
output = adb_command(None, "devices").splitlines() # pylint: disable=E1103 output = adb_command(None, "devices", adb_server=adb_server).splitlines() # pylint: disable=E1103
output_length = len(output) output_length = len(output)
if output_length == 3: if output_length == 3:
# output[1] is the 2nd line in the output which has the device name # output[1] is the 2nd line in the output which has the device name
@@ -339,11 +340,14 @@ def _ping(device):
def adb_shell(device, command, timeout=None, check_exit_code=False, def adb_shell(device, command, timeout=None, check_exit_code=False,
as_root=False, newline_separator='\r\n'): # NOQA as_root=False, newline_separator='\r\n', adb_server=None): # NOQA
_check_env() _check_env()
if as_root: if as_root:
command = 'echo \'{}\' | su'.format(escape_single_quotes(command)) command = 'echo \'{}\' | su'.format(escape_single_quotes(command))
device_part = ['-s', device] if device else [] device_part = []
if adb_server:
device_part = ['-H', adb_server]
device_part += ['-s', device] if device else []
# On older combinations of ADB/Android versions, the adb host command always # On older combinations of ADB/Android versions, the adb host command always
# exits with 0 if it was able to run the command on the target, even if the # exits with 0 if it was able to run the command on the target, even if the
@@ -401,8 +405,8 @@ def adb_background_shell(device, command,
return subprocess.Popen(full_command, stdout=stdout, stderr=stderr, shell=True) return subprocess.Popen(full_command, stdout=stdout, stderr=stderr, shell=True)
def adb_list_devices(): def adb_list_devices(adb_server=None):
output = adb_command(None, 'devices') output = adb_command(None, 'devices',adb_server=adb_server)
devices = [] devices = []
for line in output.splitlines(): for line in output.splitlines():
parts = [p.strip() for p in line.split()] parts = [p.strip() for p in line.split()]
@@ -411,9 +415,12 @@ def adb_list_devices():
return devices return devices
def adb_command(device, command, timeout=None): def adb_command(device, command, timeout=None,adb_server=None):
_check_env() _check_env()
device_string = ' -s {}'.format(device) if device else '' device_string = ""
if adb_server != None:
device_string = ' -H {}'.format(adb_server)
device_string += ' -s {}'.format(device) if device else ''
full_command = "adb{} {}".format(device_string, command) full_command = "adb{} {}".format(device_string, command)
logger.debug(full_command) logger.debug(full_command)
output, _ = check_output(full_command, timeout, shell=True) output, _ = check_output(full_command, timeout, shell=True)