summaryrefslogtreecommitdiff
path: root/test/unittest_logger.py
blob: 071893fc372fcea75f516c29fa396ace07d6e6be (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
"""unittests for logilab.common.logger"""

from tempfile import mktemp
import os
import sys
from cStringIO import StringIO

from logilab.common.testlib import TestCase, unittest_main
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(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()