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

Side by Side Diff: build/android/pylib/utils/md5sum.py

Issue 1106573002: [Android] Fix checksum handling when md5sum generates unexpected output. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 8 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 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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698