]> granicus.if.org Git - python/commitdiff
Merged revisions 77791 via svnmerge from
authorBenjamin Peterson <benjamin@python.org>
Wed, 27 Jan 2010 02:28:22 +0000 (02:28 +0000)
committerBenjamin Peterson <benjamin@python.org>
Wed, 27 Jan 2010 02:28:22 +0000 (02:28 +0000)
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
  ........
................

Lib/abc.py
Lib/test/test_abc.py
Misc/NEWS

index f9b49ac3d1c143b5adb8b48f8e6293b79599954f..0f980363046034c816756759b684691b087ec4e6 100644 (file)
@@ -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
index c3482d6f63d8b0b7ce480e8fdb2cc3634fed7179..51fd9bbfb0f413d75956754b9858ddefdde6bb81 100644 (file)
@@ -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
index 2a66d01d199d281689364cff94ffa8e2e8de87a6..e3d94da82db32d4791a147b665fdbde6f8b2867a 100644 (file)
--- 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