From dcdc999ee9c0a7842b8dd94463c6f526550afe40 Mon Sep 17 00:00:00 2001 From: Elzbieta Kotulska Date: Thu, 21 Nov 2024 14:09:32 +0100 Subject: [PATCH] Fix ConfigLoggingUpdater not changing root logging level Setting log level with method `logging.basicConfig` during runtime is not working. Instead logging.getLogger() is used. Signed-off-by: Elzbieta Kotulska --- RELEASE_NOTES.md | 2 +- .../sdk/config/_logging_config_updater.py | 20 +++++++++++++------ 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/RELEASE_NOTES.md b/RELEASE_NOTES.md index 3175d54d4..069129ec6 100644 --- a/RELEASE_NOTES.md +++ b/RELEASE_NOTES.md @@ -14,4 +14,4 @@ ## Bug Fixes - +* Fix bug with LoggingConfigUpdater not updating root logger level. diff --git a/src/frequenz/sdk/config/_logging_config_updater.py b/src/frequenz/sdk/config/_logging_config_updater.py index a9d9e88c5..a4f624e01 100644 --- a/src/frequenz/sdk/config/_logging_config_updater.py +++ b/src/frequenz/sdk/config/_logging_config_updater.py @@ -141,16 +141,25 @@ def __init__( config_recv: The receiver to listen for configuration changes. log_format: Use the specified format string in logs. log_datefmt: Use the specified date/time format in logs. + + Note: + The `log_format` and `log_datefmt` parameters are used in a call to + `logging.basicConfig()`. If logging has already been configured elsewhere + in the application (through a previous `basicConfig()` call), then the format + settings specified here will be ignored. """ super().__init__() self._config_recv = config_recv - self._format = log_format - self._datefmt = log_datefmt # Setup default configuration. # This ensures logging is configured even if actor fails to start or # if the configuration cannot be loaded. self._current_config: LoggingConfig = LoggingConfig() + + logging.basicConfig( + format=log_format, + datefmt=log_datefmt, + ) self._update_logging(self._current_config) async def _run(self) -> None: @@ -176,11 +185,10 @@ def _update_logging(self, config: LoggingConfig) -> None: logging.getLogger(logger_id).setLevel(logging.NOTSET) self._current_config = config - logging.basicConfig( - format=self._format, - level=self._current_config.root_logger.level, - datefmt=self._datefmt, + _logger.debug( + "Setting root logger level to '%s'", self._current_config.root_logger.level ) + logging.getLogger().setLevel(self._current_config.root_logger.level) # For each logger in the new config, set the log level for logger_id, logger_config in self._current_config.loggers.items():