summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVinay Sajip <vinay_sajip@yahoo.co.uk>2017-01-11 17:35:36 (GMT)
committerVinay Sajip <vinay_sajip@yahoo.co.uk>2017-01-11 17:35:36 (GMT)
commit924aaae4c2a99015ca6b448f16eed31bbb598b98 (patch)
treefd60c3aefa82b95cec40429bbd975348b82b6669
parent9da31f7274472903a32407a4e8227d1f295672a6 (diff)
downloadcpython-924aaae4c2a99015ca6b448f16eed31bbb598b98.zip
cpython-924aaae4c2a99015ca6b448f16eed31bbb598b98.tar.gz
cpython-924aaae4c2a99015ca6b448f16eed31bbb598b98.tar.bz2
Issue #29220: Improved fix and test.
-rw-r--r--Lib/logging/__init__.py11
-rw-r--r--Lib/test/test_logging.py8
2 files changed, 16 insertions, 3 deletions
diff --git a/Lib/logging/__init__.py b/Lib/logging/__init__.py
index 22744e1..6455f39 100644
--- a/Lib/logging/__init__.py
+++ b/Lib/logging/__init__.py
@@ -129,9 +129,14 @@ def getLevelName(level):
Otherwise, the string "Level %s" % level is returned.
"""
- # See Issues #22386 and #27937 for why it's this way
- return (_levelToName.get(level) or _nameToLevel.get(level) or
- "Level %s" % level)
+ # See Issues #22386, #27937 and #29220 for why it's this way
+ result = _levelToName.get(level)
+ if result is not None:
+ return result
+ result = _nameToLevel.get(level)
+ if result is not None:
+ return result
+ return "Level %s" % level
def addLevelName(level, levelName):
"""
diff --git a/Lib/test/test_logging.py b/Lib/test/test_logging.py
index 0e70ccd..1c85045 100644
--- a/Lib/test/test_logging.py
+++ b/Lib/test/test_logging.py
@@ -308,6 +308,14 @@ class BuiltinLevelsTest(BaseTest):
self.assertEqual(logging.getLevelName('INFO'), logging.INFO)
self.assertEqual(logging.getLevelName(logging.INFO), 'INFO')
+ def test_regression_29220(self):
+ """See issue #29220 for more information."""
+ logging.addLevelName(logging.INFO, '')
+ self.addCleanup(logging.addLevelName, logging.INFO, 'INFO')
+ self.assertEqual(logging.getLevelName(logging.INFO), '')
+ self.assertEqual(logging.getLevelName(logging.NOTSET), 'NOTSET')
+ self.assertEqual(logging.getLevelName('NOTSET'), logging.NOTSET)
+
class BasicFilterTest(BaseTest):
"""Test the bundled Filter class."""