Commit 9f9991c2 authored by Vinay Sajip's avatar Vinay Sajip

#Issue 11424: added equivalent fixes for dictConfig.

parent e783553d
...@@ -596,15 +596,14 @@ class DictConfigurator(BaseConfigurator): ...@@ -596,15 +596,14 @@ class DictConfigurator(BaseConfigurator):
loggers = config.get('loggers', EMPTY_DICT) loggers = config.get('loggers', EMPTY_DICT)
for name in loggers: for name in loggers:
if name in existing: if name in existing:
i = existing.index(name) i = existing.index(name) + 1 # look after name
prefixed = name + "." prefixed = name + "."
pflen = len(prefixed) pflen = len(prefixed)
num_existing = len(existing) num_existing = len(existing)
i = i + 1 # look at the entry after name while i < num_existing:
while (i < num_existing) and\ if existing[i][:pflen] == prefixed:
(existing[i][:pflen] == prefixed):
child_loggers.append(existing[i]) child_loggers.append(existing[i])
i = i + 1 i += 1
existing.remove(name) existing.remove(name)
try: try:
self.configure_logger(name, loggers[name]) self.configure_logger(name, loggers[name])
......
...@@ -1170,6 +1170,33 @@ class ConfigDictTest(BaseTest): ...@@ -1170,6 +1170,33 @@ class ConfigDictTest(BaseTest):
}, },
} }
# config1a moves the handler to the root. Used with config8a
config1a = {
'version': 1,
'formatters': {
'form1' : {
'format' : '%(levelname)s ++ %(message)s',
},
},
'handlers' : {
'hand1' : {
'class' : 'logging.StreamHandler',
'formatter' : 'form1',
'level' : 'NOTSET',
'stream' : 'ext://sys.stdout',
},
},
'loggers' : {
'compiler.parser' : {
'level' : 'DEBUG',
},
},
'root' : {
'level' : 'WARNING',
'handlers' : ['hand1'],
},
}
# config2 has a subtle configuration error that should be reported # config2 has a subtle configuration error that should be reported
config2 = { config2 = {
'version': 1, 'version': 1,
...@@ -1420,6 +1447,9 @@ class ConfigDictTest(BaseTest): ...@@ -1420,6 +1447,9 @@ class ConfigDictTest(BaseTest):
}, },
} }
# config8 defines both compiler and compiler.lexer
# so compiler.parser should not be disabled (since
# compiler is defined)
config8 = { config8 = {
'version': 1, 'version': 1,
'disable_existing_loggers' : False, 'disable_existing_loggers' : False,
...@@ -1449,6 +1479,36 @@ class ConfigDictTest(BaseTest): ...@@ -1449,6 +1479,36 @@ class ConfigDictTest(BaseTest):
}, },
} }
# config8a disables existing loggers
config8a = {
'version': 1,
'disable_existing_loggers' : True,
'formatters': {
'form1' : {
'format' : '%(levelname)s ++ %(message)s',
},
},
'handlers' : {
'hand1' : {
'class' : 'logging.StreamHandler',
'formatter' : 'form1',
'level' : 'NOTSET',
'stream' : 'ext://sys.stdout',
},
},
'loggers' : {
'compiler' : {
'level' : 'DEBUG',
'handlers' : ['hand1'],
},
'compiler.lexer' : {
},
},
'root' : {
'level' : 'WARNING',
},
}
config9 = { config9 = {
'version': 1, 'version': 1,
'formatters': { 'formatters': {
...@@ -1749,7 +1809,7 @@ class ConfigDictTest(BaseTest): ...@@ -1749,7 +1809,7 @@ class ConfigDictTest(BaseTest):
with captured_stdout() as output: with captured_stdout() as output:
self.apply_config(self.config1) self.apply_config(self.config1)
logger = logging.getLogger("compiler.parser") logger = logging.getLogger("compiler.parser")
# Both will output a message # All will output a message
logger.info(self.next_message()) logger.info(self.next_message())
logger.error(self.next_message()) logger.error(self.next_message())
self.assert_log_lines([ self.assert_log_lines([
...@@ -1778,6 +1838,49 @@ class ConfigDictTest(BaseTest): ...@@ -1778,6 +1838,49 @@ class ConfigDictTest(BaseTest):
# Original logger output is empty. # Original logger output is empty.
self.assert_log_lines([]) self.assert_log_lines([])
def test_config_8a_ok(self):
with captured_stdout() as output:
self.apply_config(self.config1a)
logger = logging.getLogger("compiler.parser")
# See issue #11424. compiler-hyphenated sorts
# between compiler and compiler.xyz and this
# was preventing compiler.xyz from being included
# in the child loggers of compiler because of an
# overzealous loop termination condition.
hyphenated = logging.getLogger('compiler-hyphenated')
# All will output a message
logger.info(self.next_message())
logger.error(self.next_message())
hyphenated.critical(self.next_message())
self.assert_log_lines([
('INFO', '1'),
('ERROR', '2'),
('CRITICAL', '3'),
], stream=output)
# Original logger output is empty.
self.assert_log_lines([])
with captured_stdout() as output:
self.apply_config(self.config8a)
logger = logging.getLogger("compiler.parser")
self.assertFalse(logger.disabled)
# Both will output a message
logger.info(self.next_message())
logger.error(self.next_message())
logger = logging.getLogger("compiler.lexer")
# Both will output a message
logger.info(self.next_message())
logger.error(self.next_message())
# Will not appear
hyphenated.critical(self.next_message())
self.assert_log_lines([
('INFO', '4'),
('ERROR', '5'),
('INFO', '6'),
('ERROR', '7'),
], stream=output)
# Original logger output is empty.
self.assert_log_lines([])
def test_config_9_ok(self): def test_config_9_ok(self):
with captured_stdout() as output: with captured_stdout() as output:
self.apply_config(self.config9) self.apply_config(self.config9)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment