Python 记录到 StringIO 处理程序

标签 python unit-testing logging stringio

我有一个 python 测试,我想在其中测试日志记录是否正常工作。例如,我有一个创建用户的函数,最后日志记录将响应写入日志文件。

logger = logging.getLogger('mylogger')
logger.setLevel(logging.DEBUG)
handler = logging.handlers.WatchedFileHandler('mylogfile.log')
formatter = logging.Formatter('%(asctime)s: %(message)s',
                              '%d/%b/%Y:%H:%M:%S %z')
handler.setFormatter(formatter)
logger.addHandler(handler)
logger.info('Some log text')

在我的测试用例中,我想将日志输出发送到 StringIO。

class MyTest(unittest.TestCase):
    def setUp(self):
        stream = StringIO()
        self.handler = logging.StreamHandler(stream)
        log = logging.getLogger('mylogger')
        log.removeHandler(log.handlers[0])
        log.addHandler(self.handler)

    def tearDown(self):
        log = logging.getLogger('mylogger')
        log.removeHandler(self.handler)
        self.handler.close()

问题是我不确定我应该如何测试我的记录器是否正常工作。

最佳答案

这是一个有效的示例,请确保设置日志级别并刷新缓冲区。

class MyTest(unittest.TestCase):
    def setUp(self):
        self.stream = StringIO()
        self.handler = logging.StreamHandler(self.stream)
        self.log = logging.getLogger('mylogger')
        self.log.setLevel(logging.INFO)
        for handler in self.log.handlers: 
            self.log.removeHandler(handler)
        self.log.addHandler(self.handler)
    def testLog(self):
        self.log.info("test")
        self.handler.flush()
        print '[', self.stream.getvalue(), ']'
        self.assertEqual(self.stream.getvalue(), 'test')

    def tearDown(self):
        self.log.removeHandler(self.handler)
        self.handler.close()

if __name__=='__main__':
    unittest.main()

进一步阅读,这里有一个例子Temporily Capturing Python Logging to a string buffer展示了您还可以如何进行格式化。

关于Python 记录到 StringIO 处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9534245/

相关文章:

Android - 设置 logcat 消息的最大长度

java - 如何在 JUnit 测试中从 log4j.properties 访问属性?

python - Numpy vectorize 作为带参数的装饰器

python - 如何传播默认值

python子类化multiprocessing.Process

java - Junit 测试无法使用 LocalServiceTestHelper 访问文件系统

javascript - 如何使用 Jest 测试对象的一部分?

python - 如果元组中的第一个值 = 1,则从字典值列表中删除元组

php - 使用 MongoDB 和对象数组进行 Laravel 单元测试

java - 套接字服务器 - 如何获取 Log4j2.xml 中客户端的名称?