2012-03-02 36 views
11

ロギングが適切に機能するかどうかをテストする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() 

問題は、どのように私がうなぎをテストすべきか、私のロガーが動作しているかわからないことです。

+1

申し訳ありませんが、これはちょうど私を超えかもしれないが、あなただけの 'stream.getvalueを()'しないだろうか? – macduff

+0

related:[PyDev unittesting: "キャプチャされた出力"でlogging.Loggerに記録されたテキストをキャプチャする方法(http://stackoverflow.com/q/7472863/321973) –

答えて

18

ここでは動作する例を示します。ログのレベルを設定し、バッファをフラッシュしてください。

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.assertTrue(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の例があります。

あなたはまた、単にLogCaptureを使用することができ
関連する問題