parent
76489d30f7
commit
dfc5399cd7
|
@ -76,9 +76,6 @@ def pytest_addoption(parser):
|
||||||
'--log-file-date-format',
|
'--log-file-date-format',
|
||||||
dest='log_file_date_format', default=DEFAULT_LOG_DATE_FORMAT,
|
dest='log_file_date_format', default=DEFAULT_LOG_DATE_FORMAT,
|
||||||
help='log date format as used by the logging module.')
|
help='log date format as used by the logging module.')
|
||||||
add_option_ini(
|
|
||||||
'--capture-log', choices=['on-failure', 'off', 'live'],
|
|
||||||
dest='capture_log', default='on-failure')
|
|
||||||
|
|
||||||
|
|
||||||
@contextmanager
|
@contextmanager
|
||||||
|
@ -120,16 +117,6 @@ class LogCaptureHandler(logging.StreamHandler):
|
||||||
logging.StreamHandler.emit(self, record)
|
logging.StreamHandler.emit(self, record)
|
||||||
|
|
||||||
|
|
||||||
class TerminalWriterHandler(logging.Handler):
|
|
||||||
def __init__(self):
|
|
||||||
# TODO sys.stderr is captured by default ?!??!
|
|
||||||
self.tw = py.io.TerminalWriter(sys.stderr)
|
|
||||||
super(TerminalWriterHandler, self).__init__()
|
|
||||||
|
|
||||||
def emit(self, record):
|
|
||||||
self.tw.write(self.format(record))
|
|
||||||
|
|
||||||
|
|
||||||
class LogCaptureFixture(object):
|
class LogCaptureFixture(object):
|
||||||
"""Provides access and control of log capturing."""
|
"""Provides access and control of log capturing."""
|
||||||
|
|
||||||
|
@ -254,8 +241,6 @@ class LoggingPlugin(object):
|
||||||
The formatter can be safely shared across all handlers so
|
The formatter can be safely shared across all handlers so
|
||||||
create a single one for the entire test session here.
|
create a single one for the entire test session here.
|
||||||
"""
|
"""
|
||||||
self.capture_log = get_option_ini(config, 'capture_log')
|
|
||||||
|
|
||||||
self.log_cli_level = get_actual_log_level(
|
self.log_cli_level = get_actual_log_level(
|
||||||
config, 'log_cli_level', 'log_level') or logging.WARNING
|
config, 'log_cli_level', 'log_level') or logging.WARNING
|
||||||
|
|
||||||
|
@ -264,14 +249,18 @@ class LoggingPlugin(object):
|
||||||
get_option_ini(config, 'log_format'),
|
get_option_ini(config, 'log_format'),
|
||||||
get_option_ini(config, 'log_date_format'))
|
get_option_ini(config, 'log_date_format'))
|
||||||
|
|
||||||
|
log_cli_handler = logging.StreamHandler(sys.stderr)
|
||||||
log_cli_format = get_option_ini(
|
log_cli_format = get_option_ini(
|
||||||
config, 'log_cli_format', 'log_format')
|
config, 'log_cli_format', 'log_format')
|
||||||
log_cli_date_format = get_option_ini(
|
log_cli_date_format = get_option_ini(
|
||||||
config, 'log_cli_date_format', 'log_date_format')
|
config, 'log_cli_date_format', 'log_date_format')
|
||||||
self.log_cli_formatter = logging.Formatter(
|
log_cli_formatter = logging.Formatter(
|
||||||
log_cli_format,
|
log_cli_format,
|
||||||
datefmt=log_cli_date_format)
|
datefmt=log_cli_date_format)
|
||||||
|
self.log_cli_handler = log_cli_handler # needed for a single unittest
|
||||||
|
self.live_logs = catching_logs(log_cli_handler,
|
||||||
|
formatter=log_cli_formatter,
|
||||||
|
level=self.log_cli_level)
|
||||||
|
|
||||||
log_file = get_option_ini(config, 'log_file')
|
log_file = get_option_ini(config, 'log_file')
|
||||||
if log_file:
|
if log_file:
|
||||||
|
@ -327,20 +316,7 @@ class LoggingPlugin(object):
|
||||||
@pytest.hookimpl(hookwrapper=True)
|
@pytest.hookimpl(hookwrapper=True)
|
||||||
def pytest_runtestloop(self, session):
|
def pytest_runtestloop(self, session):
|
||||||
"""Runs all collected test items."""
|
"""Runs all collected test items."""
|
||||||
|
with self.live_logs:
|
||||||
# TODO what should happen at the end of the tests?
|
|
||||||
if self.capture_log == 'live':
|
|
||||||
with catching_logs(TerminalWriterHandler(),
|
|
||||||
formatter=self.log_cli_formatter,
|
|
||||||
level=self.log_cli_level):
|
|
||||||
if self.log_file_handler is not None:
|
|
||||||
with closing(self.log_file_handler):
|
|
||||||
with catching_logs(self.log_file_handler,
|
|
||||||
level=self.log_file_level):
|
|
||||||
yield # run all the tests
|
|
||||||
else:
|
|
||||||
yield # run all the tests
|
|
||||||
elif self.capture_log == 'on-failure':
|
|
||||||
if self.log_file_handler is not None:
|
if self.log_file_handler is not None:
|
||||||
with closing(self.log_file_handler):
|
with closing(self.log_file_handler):
|
||||||
with catching_logs(self.log_file_handler,
|
with catching_logs(self.log_file_handler,
|
||||||
|
@ -348,7 +324,3 @@ class LoggingPlugin(object):
|
||||||
yield # run all the tests
|
yield # run all the tests
|
||||||
else:
|
else:
|
||||||
yield # run all the tests
|
yield # run all the tests
|
||||||
elif self.capture_log == 'off':
|
|
||||||
yield
|
|
||||||
else:
|
|
||||||
raise ValueError('capture_log: %s' % capture_log)
|
|
||||||
|
|
Loading…
Reference in New Issue