summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorMatthias Bussonnier <bussonniermatthias@gmail.com>2020-12-16 09:43:39 (GMT)
committerGitHub <noreply@github.com>2020-12-16 09:43:39 (GMT)
commitb32d8b4f9bcd2e7d11240b6b9de0262cf8f5e09d (patch)
tree93929faaa993c0a8de14e46bf1991b1e7805c49a /Lib/test
parent3f9fe23c05280dc5736c07bb0e968cdaf8c503d0 (diff)
downloadcpython-b32d8b4f9bcd2e7d11240b6b9de0262cf8f5e09d.zip
cpython-b32d8b4f9bcd2e7d11240b6b9de0262cf8f5e09d.tar.gz
cpython-b32d8b4f9bcd2e7d11240b6b9de0262cf8f5e09d.tar.bz2
bpo-42644: Validate values in logging.disable() (#23786)
* bpo-42644: Validate values in logging.disable() Technically make the value of manager a property that checks and convert values assigned to it properly. This has the side effect of making `logging.disable` also accept strings representing the various level of warnings. We want to validate the type of the disable attribute at assignment time, as it is later compared to other levels when emitting warnings and would generate a `TypeError: '>=' not supported between ....` in a different part of the code base, which can make it difficult to track down. When assigned an incorrect value; it will raise a TypeError when the wrong type, or ValueError if an invalid str. Co-authored-by: Andrew Svetlov <andrew.svetlov@gmail.com>
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_logging.py9
1 files changed, 9 insertions, 0 deletions
diff --git a/Lib/test/test_logging.py b/Lib/test/test_logging.py
index e219673..859baa4 100644
--- a/Lib/test/test_logging.py
+++ b/Lib/test/test_logging.py
@@ -4219,6 +4219,15 @@ class ModuleLevelMiscTest(BaseTest):
logging.disable(83)
self.assertEqual(logging.root.manager.disable, 83)
+ self.assertRaises(ValueError, logging.disable, "doesnotexists")
+
+ class _NotAnIntOrString:
+ pass
+
+ self.assertRaises(TypeError, logging.disable, _NotAnIntOrString())
+
+ logging.disable("WARN")
+
# test the default value introduced in 3.7
# (Issue #28524)
logging.disable()