kombu/t/unit/test_log.py

148 lines
4.7 KiB
Python
Raw Normal View History

from __future__ import annotations
2012-01-10 15:38:17 +00:00
import logging
import sys
2020-08-15 20:51:02 +00:00
from unittest.mock import ANY, Mock, patch
from kombu.log import (Log, LogMixin, get_logger, get_loglevel, safeify_format,
setup_logging)
2012-03-20 14:53:00 +00:00
2012-01-10 15:38:17 +00:00
class test_get_logger:
2012-01-10 15:38:17 +00:00
def test_when_string(self):
2017-12-17 10:15:42 +00:00
logger = get_logger('foo')
2012-01-10 15:38:17 +00:00
2017-12-17 10:15:42 +00:00
assert logger is logging.getLogger('foo')
h1 = logger.handlers[0]
assert isinstance(h1, logging.NullHandler)
2012-01-10 15:38:17 +00:00
def test_when_logger(self):
2017-12-17 10:15:42 +00:00
logger = get_logger(logging.getLogger('foo'))
h1 = logger.handlers[0]
assert isinstance(h1, logging.NullHandler)
2012-01-10 15:38:17 +00:00
def test_with_custom_handler(self):
2017-12-17 10:15:42 +00:00
logger = logging.getLogger('bar')
2016-01-13 01:10:12 +00:00
handler = logging.NullHandler()
2017-12-17 10:15:42 +00:00
logger.addHandler(handler)
2012-01-10 15:38:17 +00:00
2017-12-17 10:15:42 +00:00
logger = get_logger('bar')
assert logger.handlers[0] is handler
2012-01-10 15:38:17 +00:00
def test_get_loglevel(self):
assert get_loglevel('DEBUG') == logging.DEBUG
assert get_loglevel('ERROR') == logging.ERROR
assert get_loglevel(logging.INFO) == logging.INFO
2012-01-10 15:38:17 +00:00
def test_safe_format():
fmt = 'The %r jumped %x over the %s'
args = ['frog', 'foo', 'elephant']
2012-01-10 15:38:17 +00:00
res = list(safeify_format(fmt, args))
assert [x.strip('u') for x in res] == ["'frog'", 'foo', 'elephant']
2012-01-10 15:38:17 +00:00
class test_LogMixin:
2012-01-10 15:38:17 +00:00
def setup(self):
2013-06-18 12:09:02 +00:00
self.log = Log('Log', Mock())
2012-01-10 15:38:17 +00:00
self.logger = self.log.logger
def test_debug(self):
2012-06-15 17:32:40 +00:00
self.log.debug('debug')
self.logger.log.assert_called_with(logging.DEBUG, 'Log - debug')
2012-01-10 15:38:17 +00:00
def test_info(self):
2012-06-15 17:32:40 +00:00
self.log.info('info')
self.logger.log.assert_called_with(logging.INFO, 'Log - info')
2012-01-10 15:38:17 +00:00
def test_warning(self):
2012-06-15 17:32:40 +00:00
self.log.warn('warning')
self.logger.log.assert_called_with(logging.WARN, 'Log - warning')
2012-01-10 15:38:17 +00:00
def test_error(self):
2012-06-15 17:32:40 +00:00
self.log.error('error', exc_info='exc')
2013-01-17 12:02:00 +00:00
self.logger.log.assert_called_with(
logging.ERROR, 'Log - error', exc_info='exc',
)
2012-01-10 15:38:17 +00:00
def test_critical(self):
2012-06-15 17:32:40 +00:00
self.log.critical('crit', exc_info='exc')
2013-01-17 12:02:00 +00:00
self.logger.log.assert_called_with(
logging.CRITICAL, 'Log - crit', exc_info='exc',
)
2012-01-10 15:38:17 +00:00
def test_error_when_DISABLE_TRACEBACKS(self):
2013-06-18 12:09:02 +00:00
from kombu import log
2012-01-10 15:38:17 +00:00
log.DISABLE_TRACEBACKS = True
try:
2012-06-15 17:32:40 +00:00
self.log.error('error')
self.logger.log.assert_called_with(logging.ERROR, 'Log - error')
2012-01-10 15:38:17 +00:00
finally:
log.DISABLE_TRACEBACKS = False
def test_get_loglevel(self):
assert self.log.get_loglevel('DEBUG') == logging.DEBUG
assert self.log.get_loglevel('ERROR') == logging.ERROR
assert self.log.get_loglevel(logging.INFO) == logging.INFO
2012-01-10 15:38:17 +00:00
def test_is_enabled_for(self):
self.logger.isEnabledFor.return_value = True
assert self.log.is_enabled_for('DEBUG')
2012-01-10 15:38:17 +00:00
self.logger.isEnabledFor.assert_called_with(logging.DEBUG)
def test_LogMixin_get_logger(self):
assert LogMixin().get_logger() is logging.getLogger('LogMixin')
2012-01-10 15:38:17 +00:00
def test_Log_get_logger(self):
assert Log('test_Log').get_logger() is logging.getLogger('test_Log')
2012-01-10 15:38:17 +00:00
def test_log_when_not_enabled(self):
self.logger.isEnabledFor.return_value = False
2012-06-15 17:32:40 +00:00
self.log.debug('debug')
2016-04-09 04:10:31 +00:00
self.logger.log.assert_not_called()
2012-01-10 15:38:17 +00:00
def test_log_with_format(self):
2012-06-15 17:32:40 +00:00
self.log.debug('Host %r removed', 'example.com')
2013-01-17 12:02:00 +00:00
self.logger.log.assert_called_with(
logging.DEBUG, 'Log - Host %s removed', ANY,
)
assert self.logger.log.call_args[0][2].strip('u') == "'example.com'"
2012-01-10 15:38:17 +00:00
class test_setup_logging:
2012-01-10 15:38:17 +00:00
2012-06-15 17:32:40 +00:00
@patch('logging.getLogger')
2012-01-10 15:38:17 +00:00
def test_set_up_default_values(self, getLogger):
logger = logging.getLogger.return_value = Mock()
logger.handlers = []
2013-06-18 12:09:02 +00:00
setup_logging()
2012-01-10 15:38:17 +00:00
logger.setLevel.assert_called_with(logging.ERROR)
2016-04-09 04:10:31 +00:00
logger.addHandler.assert_called()
2012-01-10 15:38:17 +00:00
ah_args, _ = logger.addHandler.call_args
handler = ah_args[0]
assert isinstance(handler, logging.StreamHandler)
assert handler.stream is sys.__stderr__
2012-01-10 15:38:17 +00:00
2012-06-15 17:32:40 +00:00
@patch('logging.getLogger')
@patch('kombu.log.WatchedFileHandler')
2012-01-10 15:38:17 +00:00
def test_setup_custom_values(self, getLogger, WatchedFileHandler):
logger = logging.getLogger.return_value = Mock()
logger.handlers = []
2013-06-18 12:09:02 +00:00
setup_logging(loglevel=logging.DEBUG, logfile='/var/logfile')
2012-01-10 15:38:17 +00:00
logger.setLevel.assert_called_with(logging.DEBUG)
2016-04-09 04:10:31 +00:00
logger.addHandler.assert_called()
WatchedFileHandler.assert_called()
2012-01-10 15:38:17 +00:00
2012-06-15 17:32:40 +00:00
@patch('logging.getLogger')
2012-01-10 15:38:17 +00:00
def test_logger_already_setup(self, getLogger):
logger = logging.getLogger.return_value = Mock()
logger.handlers = [Mock()]
2013-06-18 12:09:02 +00:00
setup_logging()
2012-01-10 15:38:17 +00:00
2016-04-09 04:10:31 +00:00
logger.setLevel.assert_not_called()