0001-utils-add-ignore_loggers-context-manager-56881.patch
passerelle/utils/logging.py | ||
---|---|---|
1 |
# passerelle - uniform access to multiple data sources and services |
|
2 |
# Copyright (C) 2021 Entr'ouvert |
|
3 |
# |
|
4 |
# This program is free software: you can redistribute it and/or modify it |
|
5 |
# under the terms of the GNU Affero General Public License as published |
|
6 |
# by the Free Software Foundation, either version 3 of the License, or |
|
7 |
# (at your option) any later version. |
|
8 |
# |
|
9 |
# This program is distributed in the hope that it will be useful, |
|
10 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
11 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
12 |
# GNU Affero General Public License for more details. |
|
13 |
# |
|
14 |
# You should have received a copy of the GNU Affero General Public License |
|
15 |
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
16 | ||
17 |
import logging |
|
18 |
from contextlib import contextmanager |
|
19 | ||
20 | ||
21 |
@contextmanager |
|
22 |
def ignore_loggers(*loggers_names): |
|
23 |
propagate = {} |
|
24 |
disabled = {} |
|
25 | ||
26 |
for logger_name in loggers_names: |
|
27 |
logger = logging.getLogger(logger_name) |
|
28 |
propagate[logger] = logger.propagate |
|
29 |
disabled[logger] = logger.disabled |
|
30 |
logger.propagate = False |
|
31 |
logger.disabled = True |
|
32 | ||
33 |
yield |
|
34 | ||
35 |
for logger_name in loggers_names: |
|
36 |
logger = logging.getLogger(logger_name) |
|
37 |
logger.propagate = propagate[logger] |
|
38 |
logger.disabled = disabled[logger] |
|
0 |
- |