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

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

Issue 738413002: [Android] Extract MD5sum logic. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 1 month 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
« no previous file with comments | « build/android/pylib/instrumentation/test_jar.py ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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
3 # found in the LICENSE file.
4
5 import collections
6 import logging
7 import os
8 import tempfile
9 import types
10
11 from pylib import cmd_helper
12 from pylib import constants
13 from pylib.utils import device_temp_file
14
15 HashAndPath = collections.namedtuple('HashAndPath', ['hash', 'path'])
16
17 MD5SUM_DEVICE_LIB_PATH = '/data/local/tmp/md5sum/'
18 MD5SUM_DEVICE_BIN_PATH = MD5SUM_DEVICE_LIB_PATH + 'md5sum_bin'
19
20 MD5SUM_DEVICE_SCRIPT_FORMAT = (
21 'test -f {path} -o -d {path} '
perezju 2014/11/20 17:04:53 why not just 'test -e {path}' ?
jbudorick 2014/11/20 19:38:07 This avoids file types we don't want to md5sum, e.
perezju 2014/11/20 20:38:41 Ok!
22 '&& LD_LIBRARY_PATH={md5sum_lib} {md5sum_bin} {path}')
perezju 2014/11/20 17:04:53 could we send the LD_LIBRARY_PATH using the RunShe
jbudorick 2014/11/20 19:38:08 No, not with the way this script is rolled.
23
24
25 def CalculateHostMd5Sums(paths):
26 """Calculates the MD5 sum value for all items in |paths|.
27
28 Args:
29 paths: A list of host paths to md5sum.
30 Returns:
31 A list of named tuples with 'hash' and 'path' attributes.
32 """
33 if not isinstance(paths, list):
34 paths = [paths]
perezju 2014/11/20 17:04:53 I would check 'if isinstance(paths, basestr)' so t
jbudorick 2014/11/20 19:38:07 With the list addition below, we actually do want
perezju 2014/11/20 20:38:42 But what if I want to pass a tuple? or some other
jbudorick 2014/11/20 20:58:13 Good point.
35 out = cmd_helper.GetCmdOutput(
36 [os.path.join(constants.GetOutDirectory(), 'md5sum_bin_host')] + paths)
perezju 2014/11/20 17:04:53 if GetOutDirectory() is a constant, can we move th
jbudorick 2014/11/20 19:38:07 It's one of the not-quite-constant constants. I wa
perezju 2014/11/20 20:38:42 Ok!
37 return [HashAndPath(*l.split(None, 1)) for l in out.splitlines()]
38
39
40 def CalculateDeviceMd5Sums(paths, device):
41 """Calculates the MD5 sum value for all items in |paths|.
42
43 Args:
44 paths: A list of device paths to md5sum.
45 Returns:
46 A list of named tuples with 'hash' and 'path' attributes.
47 """
48 if isinstance(paths, types.GeneratorType):
49 paths = list(paths)
50 elif not isinstance(paths, list):
51 paths = [paths]
perezju 2014/11/20 17:04:53 Same here, we could just write: if isinstance(pat
jbudorick 2014/11/20 19:38:07 Sticking with this for consistency with the above,
jbudorick 2014/11/20 20:58:13 (also switched)
52
53 if not device.FileExists(MD5SUM_DEVICE_BIN_PATH):
perezju 2014/11/20 17:04:53 Probably not something to do now, but maybe Device
jbudorick 2014/11/20 19:38:07 Definitely not something to do now, but not a bad
54 device.adb.Push(
55 os.path.join(constants.GetOutDirectory(), 'md5sum_dist'),
perezju 2014/11/20 17:04:53 Same thing about the constant, though.
jbudorick 2014/11/20 19:38:07 same response.
56 MD5SUM_DEVICE_LIB_PATH)
57
58 out = []
59 with tempfile.NamedTemporaryFile() as md5sum_script_file:
60 with device_temp_file.DeviceTempFile(device) as md5sum_device_script_file:
61 md5sum_script = (
62 MD5SUM_DEVICE_SCRIPT_FORMAT.format(
63 path=p, md5sum_lib=MD5SUM_DEVICE_LIB_PATH,
64 md5sum_bin=MD5SUM_DEVICE_BIN_PATH)
65 for p in paths)
66 md5sum_script_file.write('; '.join(md5sum_script))
67 md5sum_script_file.flush()
68 device.adb.Push(md5sum_script_file.name, md5sum_device_script_file.name)
69 out = device.RunShellCommand(['sh', md5sum_device_script_file.name])
perezju 2014/11/20 17:04:53 Why don't we just run the script on the device rat
perezju 2014/11/20 17:16:13 Another btw: looking at md5sum.cc, it also seems t
jbudorick 2014/11/20 19:38:07 Because the script is pretty likely to be longer t
jbudorick 2014/11/20 19:38:08 We can. I tried doing so (https://codereview.chrom
perezju 2014/11/20 20:38:42 Yeah, I thought about all those problems just afte
70
71 return [HashAndPath(*l.split(None, 1)) for l in out]
72
OLDNEW
« no previous file with comments | « build/android/pylib/instrumentation/test_jar.py ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698