Projet

Général

Profil

0001-utils-add-ignore_loggers-context-manager-56881.patch

Benjamin Dauvergne, 13 septembre 2021 20:50

Télécharger (1,91 ko)

Voir les différences:

Subject: [PATCH 1/4] utils: add ignore_loggers context manager (#56881)

 passerelle/utils/logging.py | 38 +++++++++++++++++++++++++++++++++++++
 1 file changed, 38 insertions(+)
 create mode 100644 passerelle/utils/logging.py
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
-