OLD | NEW |
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2012 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 """Helper functions common to native, java and python test runners.""" | 5 """Helper functions common to native, java and host-driven test runners.""" |
6 | 6 |
7 import logging | 7 import logging |
8 import os | |
9 import sys | 8 import sys |
10 import time | 9 import time |
11 | 10 |
12 | 11 |
13 class CustomFormatter(logging.Formatter): | 12 class CustomFormatter(logging.Formatter): |
14 """Custom log formatter.""" | 13 """Custom log formatter.""" |
15 | 14 |
16 #override | 15 # override |
17 def __init__(self, fmt='%(threadName)-4s %(message)s'): | 16 def __init__(self, fmt='%(threadName)-4s %(message)s'): |
18 # Can't use super() because in older Python versions logging.Formatter does | 17 # Can't use super() because in older Python versions logging.Formatter does |
19 # not inherit from object. | 18 # not inherit from object. |
20 logging.Formatter.__init__(self, fmt=fmt) | 19 logging.Formatter.__init__(self, fmt=fmt) |
21 self._creation_time = time.time() | 20 self._creation_time = time.time() |
22 | 21 |
23 #override | 22 # override |
24 def format(self, record): | 23 def format(self, record): |
25 # Can't use super() because in older Python versions logging.Formatter does | 24 # Can't use super() because in older Python versions logging.Formatter does |
26 # not inherit from object. | 25 # not inherit from object. |
27 msg = logging.Formatter.format(self, record) | 26 msg = logging.Formatter.format(self, record) |
28 if 'MainThread' in msg[:19]: | 27 if 'MainThread' in msg[:19]: |
29 msg = msg.replace('MainThread', 'Main', 1) | 28 msg = msg.replace('MainThread', 'Main', 1) |
30 timediff = str(int(time.time() - self._creation_time)) | 29 timediff = str(int(time.time() - self._creation_time)) |
31 return '%s %ss %s' % (record.levelname[0], timediff.rjust(4), msg) | 30 return '%s %ss %s' % (record.levelname[0], timediff.rjust(4), msg) |
32 | 31 |
33 | 32 |
34 def SetLogLevel(verbose_count): | 33 def SetLogLevel(verbose_count): |
35 """Sets log level as |verbose_count|.""" | 34 """Sets log level as |verbose_count|.""" |
36 log_level = logging.WARNING # Default. | 35 log_level = logging.WARNING # Default. |
37 if verbose_count == 1: | 36 if verbose_count == 1: |
38 log_level = logging.INFO | 37 log_level = logging.INFO |
39 elif verbose_count >= 2: | 38 elif verbose_count >= 2: |
40 log_level = logging.DEBUG | 39 log_level = logging.DEBUG |
41 logger = logging.getLogger() | 40 logger = logging.getLogger() |
42 logger.setLevel(log_level) | 41 logger.setLevel(log_level) |
43 custom_handler = logging.StreamHandler(sys.stdout) | 42 custom_handler = logging.StreamHandler(sys.stdout) |
44 custom_handler.setFormatter(CustomFormatter()) | 43 custom_handler.setFormatter(CustomFormatter()) |
45 logging.getLogger().addHandler(custom_handler) | 44 logging.getLogger().addHandler(custom_handler) |
OLD | NEW |