ロギングが適切に機能するかどうかをテストするPythonテストがあります。たとえば、私はユーザーを作成する関数を持っており、最後にログはログファイルに応答を書き込みます。PythonがStringIOハンドラにロギングする
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を()'しないだろうか? – macduff
related:[PyDev unittesting: "キャプチャされた出力"でlogging.Loggerに記録されたテキストをキャプチャする方法(http://stackoverflow.com/q/7472863/321973) –