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