Coverage for src/logging.py: 100%
21 statements
« prev ^ index » next coverage.py v7.3.0, created at 2025-01-21 12:25 +0000
« prev ^ index » next coverage.py v7.3.0, created at 2025-01-21 12:25 +0000
1import logging
2import pathlib
3import sys
6def load_logger(verbose=False, logfile='./www/build.txt', truncate_logfile=True) -> logging.Logger: # noqa: E501
7 """
8 Load a logger with some sensible defaults.
10 ```python
11 logger = src.load_logger()
12 logger.info('starting program')
13 ```
15 Those defaults being:
17 1. Log to stderr with a simple formatter
18 2. Write last build log to a file in the webroot.
20 Extra options:
22 - `logfile` path to the logfile
23 - `truncate_logfile` whether to truncate the logfile or not
24 """
26 logger = logging.getLogger('blog')
28 # formatter
29 formatter = logging.Formatter(fmt='blog: %(message)s')
31 # level
32 if verbose:
33 level = logging.DEBUG
34 else:
35 level = logging.INFO
36 logger.setLevel(level)
38 # add stderr handler
39 stderr_handler = logging.StreamHandler(stream=sys.stderr)
40 stderr_handler.setFormatter(formatter)
41 stderr_handler.setLevel(level)
42 logger.addHandler(stderr_handler)
44 # add logfile handler
45 file_handler = logging.FileHandler(str(logfile))
46 file_handler.setFormatter(formatter)
47 file_handler.setLevel(level)
48 logger.addHandler(file_handler)
50 # truncate log file
51 with pathlib.Path(logfile).open('w') as f:
52 f.write('')
54 return logger