OLD | NEW |
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # | 2 # |
3 # Copyright 2013 The Chromium Authors. All rights reserved. | 3 # Copyright 2013 The Chromium Authors. All rights reserved. |
4 # Use of this source code is governed by a BSD-style license that can be | 4 # Use of this source code is governed by a BSD-style license that can be |
5 # found in the LICENSE file. | 5 # found in the LICENSE file. |
6 # | 6 # |
7 # Find the most recent tombstone file(s) on all connected devices | 7 # Find the most recent tombstone file(s) on all connected devices |
8 # and prints their stacks. | 8 # and prints their stacks. |
9 # | 9 # |
10 # Assumes tombstone file was created with current symbols. | 10 # Assumes tombstone file was created with current symbols. |
11 | 11 |
12 import datetime | 12 import datetime |
13 import logging | 13 import logging |
14 import multiprocessing | 14 import multiprocessing |
15 import os | 15 import os |
16 import re | 16 import re |
17 import subprocess | 17 import subprocess |
18 import sys | 18 import sys |
19 import optparse | 19 import optparse |
20 | 20 |
21 import devil_chromium | |
22 | |
23 from devil.android import device_blacklist | 21 from devil.android import device_blacklist |
24 from devil.android import device_errors | 22 from devil.android import device_errors |
25 from devil.android import device_utils | 23 from devil.android import device_utils |
26 from devil.utils import run_tests_helper | 24 from devil.utils import run_tests_helper |
27 | 25 |
28 _TZ_UTC = {'TZ': 'UTC'} | 26 _TZ_UTC = {'TZ': 'UTC'} |
29 | 27 |
30 def _ListTombstones(device): | 28 def _ListTombstones(device): |
31 """List the tombstone files on the device. | 29 """List the tombstone files on the device. |
32 | 30 |
(...skipping 203 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
236 parser.add_option('-j', '--jobs', type='int', | 234 parser.add_option('-j', '--jobs', type='int', |
237 default=4, | 235 default=4, |
238 help='Number of jobs to use when processing multiple ' | 236 help='Number of jobs to use when processing multiple ' |
239 'crash stacks.') | 237 'crash stacks.') |
240 options, _ = parser.parse_args() | 238 options, _ = parser.parse_args() |
241 | 239 |
242 blacklist = (device_blacklist.Blacklist(options.blacklist_file) | 240 blacklist = (device_blacklist.Blacklist(options.blacklist_file) |
243 if options.blacklist_file | 241 if options.blacklist_file |
244 else None) | 242 else None) |
245 | 243 |
246 devil_chromium.Initialize() | |
247 | |
248 if options.device: | 244 if options.device: |
249 devices = [device_utils.DeviceUtils(options.device)] | 245 devices = [device_utils.DeviceUtils(options.device)] |
250 else: | 246 else: |
251 devices = device_utils.DeviceUtils.HealthyDevices(blacklist) | 247 devices = device_utils.DeviceUtils.HealthyDevices(blacklist) |
252 | 248 |
253 # This must be done serially because strptime can hit a race condition if | 249 # This must be done serially because strptime can hit a race condition if |
254 # used for the first time in a multithreaded environment. | 250 # used for the first time in a multithreaded environment. |
255 # http://bugs.python.org/issue7980 | 251 # http://bugs.python.org/issue7980 |
256 tombstones = [] | 252 tombstones = [] |
257 for device in devices: | 253 for device in devices: |
258 tombstones += _GetTombstonesForDevice(device, options) | 254 tombstones += _GetTombstonesForDevice(device, options) |
259 | 255 |
260 _ResolveTombstones(options.jobs, tombstones) | 256 _ResolveTombstones(options.jobs, tombstones) |
261 | 257 |
262 | 258 |
263 if __name__ == '__main__': | 259 if __name__ == '__main__': |
264 sys.exit(main()) | 260 sys.exit(main()) |
OLD | NEW |