ログが適切に機能するかどうかをテストする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()
問題は、ロガーが機能しているかどうかをテストする方法がわからないことです。