1
|
|
|
import os |
|
|
|
|
2
|
|
|
import sys |
3
|
|
|
|
4
|
|
|
|
5
|
|
|
def _gw_logging_cfg(log_file): |
6
|
|
|
return { |
7
|
|
|
'version': 1, |
8
|
|
|
'disable_existing_loggers': False, |
9
|
|
|
'formatters': { |
10
|
|
|
'standard': { |
11
|
|
|
'format': "%(asctime)s - %(levelname)-5s - %(message)s" |
12
|
|
|
}, |
13
|
|
|
'debug': { |
14
|
|
|
'format': "%(asctime)s - %(levelname)-5s - %(name)-40s - %(message)-80s - %(module)s:%(" |
|
|
|
|
15
|
|
|
"funcName)s(%(lineno)s)" |
16
|
|
|
}, |
17
|
|
|
}, |
18
|
|
|
'handlers': { |
19
|
|
|
'console_stdout': { |
20
|
|
|
'formatter': 'standard', |
21
|
|
|
'class': 'logging.StreamHandler', |
22
|
|
|
'stream': sys.stdout, |
23
|
|
|
'level': 'INFO' |
24
|
|
|
}, |
25
|
|
|
'file': { |
26
|
|
|
"class": "logging.handlers.RotatingFileHandler", |
27
|
|
|
"formatter": "debug", |
28
|
|
|
"filename": log_file, |
29
|
|
|
"maxBytes": 1024000, |
30
|
|
|
"backupCount": 3, |
31
|
|
|
'level': 'INFO' |
32
|
|
|
}, |
33
|
|
|
}, |
34
|
|
|
'loggers': { |
35
|
|
|
'': { |
36
|
|
|
'handlers': ['console_stdout'], |
37
|
|
|
'level': 'INFO', |
38
|
|
|
'propagate': False |
39
|
|
|
}, |
40
|
|
|
'groundwork': { |
41
|
|
|
'handlers': ['console_stdout', 'file'], |
42
|
|
|
'level': 'INFO', |
43
|
|
|
'propagate': False |
44
|
|
|
}, |
45
|
|
|
} |
46
|
|
|
} |
47
|
|
|
|
48
|
|
|
|
49
|
|
View Code Duplication |
def test_logging_file(basicApp, tmpdir): |
|
|
|
|
50
|
|
|
log_file = os.path.join(str(tmpdir), "test.log") |
51
|
|
|
app = basicApp |
52
|
|
|
# set up logging in the config, with log level INFO |
53
|
|
|
app.config.set('GROUNDWORK_LOGGING', _gw_logging_cfg(log_file)) |
54
|
|
|
app._configure_logging(app.config.get("GROUNDWORK_LOGGING")) |
|
|
|
|
55
|
|
|
|
56
|
|
|
debug_message = "This is a test debug message." |
57
|
|
|
info_message = "This is a test info message." |
58
|
|
|
app.log.debug(debug_message) |
59
|
|
|
app.log.info(info_message) |
60
|
|
|
|
61
|
|
|
# verify the contents of the log file |
62
|
|
|
with open(log_file) as lf: |
|
|
|
|
63
|
|
|
log = lf.read() |
64
|
|
|
# at log level INFO, the DEBUG message should not be there |
65
|
|
|
assert log.find(debug_message) == -1 |
66
|
|
|
# the INFO message should be there |
67
|
|
|
assert log.find(info_message) > 0 |
68
|
|
|
|
69
|
|
|
|
70
|
|
View Code Duplication |
def test_logging_console(basicApp, tmpdir, capsys): |
|
|
|
|
71
|
|
|
log_file = os.path.join(str(tmpdir), "test.log") |
72
|
|
|
app = basicApp |
73
|
|
|
# set up logging in the config, with log level INFO |
74
|
|
|
app.config.set('GROUNDWORK_LOGGING', _gw_logging_cfg(log_file)) |
75
|
|
|
app._configure_logging(app.config.get("GROUNDWORK_LOGGING")) |
|
|
|
|
76
|
|
|
|
77
|
|
|
debug_message = "This is a test debug message." |
78
|
|
|
info_message = "This is a test info message." |
79
|
|
|
app.log.debug(debug_message) |
80
|
|
|
app.log.info(info_message) |
81
|
|
|
|
82
|
|
|
out, err = capsys.readouterr() |
|
|
|
|
83
|
|
|
# at log level INFO, the DEBUG message should not be there |
84
|
|
|
assert out.find(debug_message) == -1 |
85
|
|
|
# the INFO message should be there |
86
|
|
|
assert out.find(info_message) > 0 |
87
|
|
|
|
The coding style of this project requires that you add a docstring to this code element. Below, you find an example for methods:
If you would like to know more about docstrings, we recommend to read PEP-257: Docstring Conventions.