|
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(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(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.