【发布时间】:2023-04-11 02:41:01
【问题描述】:
我有一个 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()
问题是我不确定我应该如何测试我的记录器是否正常工作。
【问题讨论】:
-
对不起,这可能超出了我的能力范围,但你不会只是做
stream.getvalue()吗?
标签: python unit-testing logging stringio