Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / build / android / devil / utils / run_tests_helper.py
blob43f654ddcffb61750991cdedb6169defba5499bb
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.
5 """Helper functions common to native, java and host-driven test runners."""
7 import logging
8 import sys
9 import time
12 class CustomFormatter(logging.Formatter):
13 """Custom log formatter."""
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()
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)
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)