Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright 2014 The Chromium Authors. All rights reserved. | 1 # Copyright 2014 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 import collections | 5 import collections |
| 6 import logging | 6 import logging |
| 7 import os | 7 import os |
| 8 import re | |
| 8 import tempfile | 9 import tempfile |
| 9 import types | 10 import types |
| 10 | 11 |
| 11 from pylib import cmd_helper | 12 from pylib import cmd_helper |
| 12 from pylib import constants | 13 from pylib import constants |
| 13 from pylib.utils import device_temp_file | 14 from pylib.utils import device_temp_file |
| 14 | 15 |
| 15 HashAndPath = collections.namedtuple('HashAndPath', ['hash', 'path']) | 16 HashAndPath = collections.namedtuple('HashAndPath', ['hash', 'path']) |
|
perezju
2015/04/24 08:06:33
this is not needed any more
jbudorick
2015/04/24 13:56:36
Removed.
| |
| 16 | 17 |
| 17 MD5SUM_DEVICE_LIB_PATH = '/data/local/tmp/md5sum/' | 18 MD5SUM_DEVICE_LIB_PATH = '/data/local/tmp/md5sum/' |
| 18 MD5SUM_DEVICE_BIN_PATH = MD5SUM_DEVICE_LIB_PATH + 'md5sum_bin' | 19 MD5SUM_DEVICE_BIN_PATH = MD5SUM_DEVICE_LIB_PATH + 'md5sum_bin' |
| 19 | 20 |
| 20 MD5SUM_DEVICE_SCRIPT_FORMAT = ( | 21 MD5SUM_DEVICE_SCRIPT_FORMAT = ( |
| 21 'test -f {path} -o -d {path} ' | 22 'test -f {path} -o -d {path} ' |
| 22 '&& LD_LIBRARY_PATH={md5sum_lib} {device_pie_wrapper} {md5sum_bin} {path}') | 23 '&& LD_LIBRARY_PATH={md5sum_lib} {device_pie_wrapper} {md5sum_bin} {path}') |
| 23 | 24 |
| 25 _STARTS_WITH_CHECKSUM_RE = re.compile(r'^\s*[0-9a-fA-f]{32}\s+') | |
| 26 | |
| 24 | 27 |
| 25 def CalculateHostMd5Sums(paths): | 28 def CalculateHostMd5Sums(paths): |
| 26 """Calculates the MD5 sum value for all items in |paths|. | 29 """Calculates the MD5 sum value for all items in |paths|. |
| 27 | 30 |
| 28 Args: | 31 Args: |
| 29 paths: A list of host paths to md5sum. | 32 paths: A list of host paths to md5sum. |
| 30 Returns: | 33 Returns: |
| 31 A list of named tuples with 'hash' and 'path' attributes. | 34 A dict mapping paths to their respective md5sum checksums. |
| 32 """ | 35 """ |
| 33 if isinstance(paths, basestring): | 36 if isinstance(paths, basestring): |
| 34 paths = [paths] | 37 paths = [paths] |
| 35 | 38 |
| 36 out = cmd_helper.GetCmdOutput( | 39 out = cmd_helper.GetCmdOutput( |
| 37 [os.path.join(constants.GetOutDirectory(), 'md5sum_bin_host')] + | 40 [os.path.join(constants.GetOutDirectory(), 'md5sum_bin_host')] + |
| 38 [p for p in paths]) | 41 [p for p in paths]) |
| 39 return [HashAndPath(*l.split(None, 1)) for l in out.splitlines()] | 42 |
| 43 return _ParseMd5SumOutput(out.splitlines()) | |
| 40 | 44 |
| 41 | 45 |
| 42 def CalculateDeviceMd5Sums(paths, device): | 46 def CalculateDeviceMd5Sums(paths, device): |
| 43 """Calculates the MD5 sum value for all items in |paths|. | 47 """Calculates the MD5 sum value for all items in |paths|. |
| 44 | 48 |
| 45 Args: | 49 Args: |
| 46 paths: A list of device paths to md5sum. | 50 paths: A list of device paths to md5sum. |
| 47 Returns: | 51 Returns: |
| 48 A list of named tuples with 'hash' and 'path' attributes. | 52 A dict mapping paths to their respective md5sum checksums. |
| 49 """ | 53 """ |
| 50 if isinstance(paths, basestring): | 54 if isinstance(paths, basestring): |
| 51 paths = [paths] | 55 paths = [paths] |
| 52 | 56 |
| 53 if not device.FileExists(MD5SUM_DEVICE_BIN_PATH): | 57 if not device.FileExists(MD5SUM_DEVICE_BIN_PATH): |
| 54 device.adb.Push( | 58 device.adb.Push( |
| 55 os.path.join(constants.GetOutDirectory(), 'md5sum_dist'), | 59 os.path.join(constants.GetOutDirectory(), 'md5sum_dist'), |
| 56 MD5SUM_DEVICE_LIB_PATH) | 60 MD5SUM_DEVICE_LIB_PATH) |
| 57 | 61 |
| 58 out = [] | 62 out = [] |
| 59 | 63 |
| 60 with tempfile.NamedTemporaryFile() as md5sum_script_file: | 64 with tempfile.NamedTemporaryFile() as md5sum_script_file: |
| 61 with device_temp_file.DeviceTempFile( | 65 with device_temp_file.DeviceTempFile( |
| 62 device.adb) as md5sum_device_script_file: | 66 device.adb) as md5sum_device_script_file: |
| 63 device_pie_wrapper = device.GetDevicePieWrapper() | 67 device_pie_wrapper = device.GetDevicePieWrapper() |
| 64 md5sum_script = ( | 68 md5sum_script = ( |
| 65 MD5SUM_DEVICE_SCRIPT_FORMAT.format( | 69 MD5SUM_DEVICE_SCRIPT_FORMAT.format( |
| 66 path=p, md5sum_lib=MD5SUM_DEVICE_LIB_PATH, | 70 path=p, md5sum_lib=MD5SUM_DEVICE_LIB_PATH, |
| 67 device_pie_wrapper=device_pie_wrapper, | 71 device_pie_wrapper=device_pie_wrapper, |
| 68 md5sum_bin=MD5SUM_DEVICE_BIN_PATH) | 72 md5sum_bin=MD5SUM_DEVICE_BIN_PATH) |
| 69 for p in paths) | 73 for p in paths) |
| 70 md5sum_script_file.write('; '.join(md5sum_script)) | 74 md5sum_script_file.write('; '.join(md5sum_script)) |
| 71 md5sum_script_file.flush() | 75 md5sum_script_file.flush() |
| 72 device.adb.Push(md5sum_script_file.name, md5sum_device_script_file.name) | 76 device.adb.Push(md5sum_script_file.name, md5sum_device_script_file.name) |
| 73 out = device.RunShellCommand(['sh', md5sum_device_script_file.name]) | 77 out = device.RunShellCommand(['sh', md5sum_device_script_file.name]) |
| 74 | 78 |
| 75 return [HashAndPath(*l.split(None, 1)) for l in out if l] | 79 return _ParseMd5SumOutput(out) |
| 76 | 80 |
| 81 | |
| 82 def _ParseMd5SumOutput(out): | |
| 83 hash_and_path = (l.split(None, 1) for l in out | |
| 84 if l and _STARTS_WITH_CHECKSUM_RE.match(l)) | |
| 85 return dict((p, h) for h, p in hash_and_path) | |
|
perezju
2015/04/24 08:06:32
nit: can be written as:
return {p: h for h, p i
jbudorick
2015/04/24 13:56:36
We have generally avoided dictionary comprehension
perezju
2015/04/24 14:13:25
hmmm, strange, but ok.
| |
| 86 | |
| OLD | NEW |