summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2010-01-27 02:28:22 (GMT)
committerBenjamin Peterson <benjamin@python.org>2010-01-27 02:28:22 (GMT)
commit69de157237b501e1eb6c7cde3f4c15d75ae65f2c (patch)
treeafade754af352b442376c76281567cbffc0bb9e4
parentccea47ea86cf89b9eb4be25d1ec4831628e57a9d (diff)
downloadcpython-69de157237b501e1eb6c7cde3f4c15d75ae65f2c.zip
cpython-69de157237b501e1eb6c7cde3f4c15d75ae65f2c.tar.gz
cpython-69de157237b501e1eb6c7cde3f4c15d75ae65f2c.tar.bz2
Merged revisions 77791 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ................ r77791 | benjamin.peterson | 2010-01-26 20:25:58 -0600 (Tue, 26 Jan 2010) | 9 lines Merged revisions 77789 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r77789 | benjamin.peterson | 2010-01-26 20:16:42 -0600 (Tue, 26 Jan 2010) | 1 line raise a clear TypeError when trying to register a non-class ........ ................
-rw-r--r--Lib/abc.py2
-rw-r--r--Lib/test/test_abc.py6
-rw-r--r--Misc/NEWS2
3 files changed, 9 insertions, 1 deletions
diff --git a/Lib/abc.py b/Lib/abc.py
index f9b49ac..0f98036 100644
--- a/Lib/abc.py
+++ b/Lib/abc.py
@@ -94,7 +94,7 @@ class ABCMeta(type):
def register(cls, subclass):
"""Register a virtual subclass of an ABC."""
- if not isinstance(cls, type):
+ if not isinstance(subclass, type):
raise TypeError("Can only register classes")
if issubclass(subclass, cls):
return # Already a subclass
diff --git a/Lib/test/test_abc.py b/Lib/test/test_abc.py
index c3482d6..51fd9bb 100644
--- a/Lib/test/test_abc.py
+++ b/Lib/test/test_abc.py
@@ -139,6 +139,12 @@ class TestABC(unittest.TestCase):
self.assertRaises(RuntimeError, C.register, A) # cycles not allowed
C.register(B) # ok
+ def test_register_non_class(self):
+ class A(metaclass=abc.ABCMeta):
+ pass
+ self.assertRaisesRegexp(TypeError, "Can only register classes",
+ A.register, 4)
+
def test_registration_transitiveness(self):
class A(metaclass=abc.ABCMeta):
pass
diff --git a/Misc/NEWS b/Misc/NEWS
index 2a66d01..e3d94da 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -73,6 +73,8 @@ Core and Builtins
Library
-------
+- Issue #7792: Registering non-classes to ABCs raised an obscure error.
+
- Issue #7785: Don't accept bytes in FileIO.write().
- Issue #7773: Fix an UnboundLocalError in platform.linux_distribution() when