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 |