summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_abc.py
diff options
context:
space:
mode:
authorChristian Heimes <christian@cheimes.de>2008-03-03 18:28:04 (GMT)
committerChristian Heimes <christian@cheimes.de>2008-03-03 18:28:04 (GMT)
commit608c1d8e87b20116011fe8fce634e980e115d514 (patch)
treee7204b4c31d30b37d308dda03cc03c032f5df08e /Lib/test/test_abc.py
parent1f178a6fac790f380b6830642b8c9afc0a3a9931 (diff)
downloadcpython-608c1d8e87b20116011fe8fce634e980e115d514.zip
cpython-608c1d8e87b20116011fe8fce634e980e115d514.tar.gz
cpython-608c1d8e87b20116011fe8fce634e980e115d514.tar.bz2
Since abc._Abstract was replaces by a new type flags the regression test suite fails. I've added a new function inspect.isabstract(). Is the mmethod fine or should I check if object is a instance of type or subclass of object, too?
Diffstat (limited to 'Lib/test/test_abc.py')
-rw-r--r--Lib/test/test_abc.py5
1 files changed, 5 insertions, 0 deletions
diff --git a/Lib/test/test_abc.py b/Lib/test/test_abc.py
index c53dcea..f1c0c3b 100644
--- a/Lib/test/test_abc.py
+++ b/Lib/test/test_abc.py
@@ -7,6 +7,7 @@ import unittest
from test import test_support
import abc
+from inspect import isabstract
class TestABC(unittest.TestCase):
@@ -43,19 +44,23 @@ class TestABC(unittest.TestCase):
def bar(self): pass # concrete
self.assertEqual(C.__abstractmethods__, set(["foo"]))
self.assertRaises(TypeError, C) # because foo is abstract
+ self.assert_(isabstract(C))
class D(C):
def bar(self): pass # concrete override of concrete
self.assertEqual(D.__abstractmethods__, set(["foo"]))
self.assertRaises(TypeError, D) # because foo is still abstract
+ self.assert_(isabstract(D))
class E(D):
def foo(self): pass
self.assertEqual(E.__abstractmethods__, set())
E() # now foo is concrete, too
+ self.failIf(isabstract(E))
class F(E):
@abstractthing
def bar(self): pass # abstract override of concrete
self.assertEqual(F.__abstractmethods__, set(["bar"]))
self.assertRaises(TypeError, F) # because bar is abstract now
+ self.assert_(isabstract(F))
def test_subclass_oldstyle_class(self):
class A: