summaryrefslogtreecommitdiff
path: root/test/unittest_logger.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/unittest_logger.py')
-rw-r--r--test/unittest_logger.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/test/unittest_logger.py b/test/unittest_logger.py
new file mode 100644
index 0000000..dc289db
--- /dev/null
+++ b/test/unittest_logger.py
@@ -0,0 +1,54 @@
+"""unittests for logilab.common.logger"""
+
+import unittest
+from tempfile import mktemp
+import os
+
+import sys
+from cStringIO import StringIO
+
+from logilab.common.logger import *
+
+
+def get_logged_messages(output):
+ """strip timestamps and extract effective logged text
+ (log lines look like: [timestamp] message)
+ """
+ return [line.split(']')[-1].strip() for line in output.splitlines()]
+
+
+class LoggerTC(unittest.TestCase):
+
+ def test_defaultlogging(self):
+ # redirect stdout so that we can test
+ stdout_backup = sys.stdout
+ sys.stdout = StringIO()
+ # make default logger
+ logger = make_logger()
+ logger.log(message='hello')
+ logger.log(message='world')
+ output = sys.stdout.getvalue()
+ msg = get_logged_messages(output)
+ # restore stdout
+ sys.stdout = stdout_backup
+ self.assertEquals(msg, ['hello', 'world'])
+
+ def test_filelogging(self):
+ filename = mktemp(dir='/tmp')
+ # make file logger
+ logger = make_logger(method='file', output=filename)
+ logger.log(message='hello')
+ logger.log(message='world')
+ # make sure everything gets flushed (testing purpose)
+ logger.output.flush()
+ output = open(filename).read() #os.read(descr, 300)
+ # close everything correcly
+ #os.close(descr)
+ logger.output.close()
+ # remove file
+ os.remove(filename)
+ self.assertEquals(get_logged_messages(output), ['hello', 'world'])
+
+if __name__ == '__main__':
+ unittest.main()
+