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 itertools | 13 import itertools |
14 import logging | 14 import logging |
15 import multiprocessing | 15 import multiprocessing |
16 import os | 16 import os |
17 import re | 17 import re |
18 import subprocess | 18 import subprocess |
19 import sys | 19 import sys |
20 import optparse | 20 import optparse |
21 | 21 |
22 from pylib.device import adb_wrapper | 22 from pylib.device import adb_wrapper |
23 from pylib.device import device_errors | 23 from pylib.device import device_errors |
24 from pylib.device import device_filter | |
25 from pylib.device import device_utils | 24 from pylib.device import device_utils |
26 from pylib.utils import run_tests_helper | 25 from pylib.utils import run_tests_helper |
27 | 26 |
28 | 27 |
29 _TZ_UTC = {'TZ': 'UTC'} | 28 _TZ_UTC = {'TZ': 'UTC'} |
30 | 29 |
31 def _ListTombstones(device): | 30 def _ListTombstones(device): |
32 """List the tombstone files on the device. | 31 """List the tombstone files on the device. |
33 | 32 |
34 Args: | 33 Args: |
(...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
227 help='Also include symbols for stack data') | 226 help='Also include symbols for stack data') |
228 parser.add_option('-w', '--wipe-tombstones', action='store_true', | 227 parser.add_option('-w', '--wipe-tombstones', action='store_true', |
229 help='Erase all tombstones from device after processing') | 228 help='Erase all tombstones from device after processing') |
230 parser.add_option('-j', '--jobs', type='int', | 229 parser.add_option('-j', '--jobs', type='int', |
231 default=4, | 230 default=4, |
232 help='Number of jobs to use when processing multiple ' | 231 help='Number of jobs to use when processing multiple ' |
233 'crash stacks.') | 232 'crash stacks.') |
234 options, _ = parser.parse_args() | 233 options, _ = parser.parse_args() |
235 | 234 |
236 if options.device: | 235 if options.device: |
237 devices = [options.device] | 236 devices = [device_utils.DeviceUtils(options.device)] |
238 else: | 237 else: |
239 devices = adb_wrapper.AdbWrapper.Devices( | 238 devices = device_utils.DeviceUtils.HealthyDevices() |
240 filters=device_filter.DefaultFilters()) | |
241 | 239 |
242 # This must be done serially because strptime can hit a race condition if | 240 # This must be done serially because strptime can hit a race condition if |
243 # used for the first time in a multithreaded environment. | 241 # used for the first time in a multithreaded environment. |
244 # http://bugs.python.org/issue7980 | 242 # http://bugs.python.org/issue7980 |
245 tombstones = [] | 243 tombstones = [] |
246 for adb in devices: | 244 for device in devices: |
247 device = device_utils.DeviceUtils(adb) | |
248 tombstones += _GetTombstonesForDevice(device, options) | 245 tombstones += _GetTombstonesForDevice(device, options) |
249 | 246 |
250 _ResolveTombstones(options.jobs, tombstones) | 247 _ResolveTombstones(options.jobs, tombstones) |
251 | 248 |
| 249 |
252 if __name__ == '__main__': | 250 if __name__ == '__main__': |
253 sys.exit(main()) | 251 sys.exit(main()) |
OLD | NEW |