summaryrefslogtreecommitdiff
path: root/src/samples/logsample.py
blob: 0436c4f4f8558750c1572748e1f2a1ede4fd1518 (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
54
55
#!/usr/bin/env python
# -*- coding: utf-8 -*-

import logging

from libavg import avg, app

# Setup Python Logger
hdlr = logging.StreamHandler()
# category is added as an extra formatting key by libavg
formatter = logging.Formatter('[%(asctime)s][%(levelname)s][%(category)s] : %(message)s')
hdlr.setFormatter(formatter)
pyLogger = logging.getLogger(__name__)
pyLogger.addHandler(hdlr)
pyLogger.propagate = False
pyLogger.level = logging.DEBUG


class LoggingTest(app.MainDiv):
    def onInit(self):
        # Add the python logger to libavgs logger as a message sink
        avg.logger.removeStdLogSink()
        avg.logger.addSink(pyLogger)

        avg.logger.debug("Hidden, unless AVG_LOG_CATEGORIES configured with APP:DEBUG")

        avg.logger.configureCategory(avg.logger.Category.APP, avg.logger.Severity.INFO)
        avg.logger.log("Custom Info level message", avg.logger.Category.APP,
                avg.logger.Severity.INFO)

        avg.logger.info("Info level message, with APP Category")
        avg.logger.warning("Warn level message, with APP Category")

        #Remove the logSink, no message should be logged now, if run with
        #AVG_LOG_OMIT_STDERR=1
        #avg.logger.removeSink(logging.getLogger("MY_APP"))

        avg.logger.error("std::err - Error")
        avg.logger.critical("std::err - Critical")
        avg.logger.log("std::err - Log")

        #Register custom log category
        CUSTOM_LOG_CAT = avg.logger.configureCategory("My Custom Category",
                avg.logger.Severity.INFO)

        #Log with custom log category
        avg.logger.log("Message with custom category", CUSTOM_LOG_CAT)
        avg.logger.debug("Hidden message", CUSTOM_LOG_CAT)
        avg.logger.configureCategory(CUSTOM_LOG_CAT, avg.logger.Severity.DBG)
        avg.logger.debug("This will show up", CUSTOM_LOG_CAT)


if __name__ == '__main__':
    app.App().run(LoggingTest(), app_resolution='140x140')