Convert test_module to use unittest.
This commit is contained in:
parent
fef1dcf433
commit
69c955f05d
|
@ -1,48 +1,61 @@
|
|||
# Test the module type
|
||||
|
||||
from test.test_support import verify, vereq, verbose, TestFailed
|
||||
import unittest
|
||||
from test.test_support import verbose, run_unittest
|
||||
|
||||
import sys
|
||||
module = type(sys)
|
||||
ModuleType = type(sys)
|
||||
|
||||
# An uninitialized module has no __dict__ or __name__, and __doc__ is None
|
||||
foo = module.__new__(module)
|
||||
verify(foo.__dict__ is None)
|
||||
try:
|
||||
class ModuleTests(unittest.TestCase):
|
||||
def test_uninitialized(self):
|
||||
# An uninitialized module has no __dict__ or __name__,
|
||||
# and __doc__ is None
|
||||
foo = ModuleType.__new__(ModuleType)
|
||||
self.failUnless(foo.__dict__ is None)
|
||||
try:
|
||||
s = foo.__name__
|
||||
except AttributeError:
|
||||
self.fail("__name__ = %s" % repr(s))
|
||||
except AttributeError:
|
||||
pass
|
||||
else:
|
||||
raise TestFailed, "__name__ = %s" % repr(s)
|
||||
vereq(foo.__doc__, module.__doc__)
|
||||
self.assertEqual(foo.__doc__, ModuleType.__doc__)
|
||||
|
||||
# Regularly initialized module, no docstring
|
||||
foo = module("foo")
|
||||
vereq(foo.__name__, "foo")
|
||||
vereq(foo.__doc__, None)
|
||||
vereq(foo.__dict__, {"__name__": "foo", "__doc__": None})
|
||||
def test_no_docstring(self):
|
||||
# Regularly initialized module, no docstring
|
||||
foo = ModuleType("foo")
|
||||
self.assertEqual(foo.__name__, "foo")
|
||||
self.assertEqual(foo.__doc__, None)
|
||||
self.assertEqual(foo.__dict__, {"__name__": "foo", "__doc__": None})
|
||||
|
||||
# ASCII docstring
|
||||
foo = module("foo", "foodoc")
|
||||
vereq(foo.__name__, "foo")
|
||||
vereq(foo.__doc__, "foodoc")
|
||||
vereq(foo.__dict__, {"__name__": "foo", "__doc__": "foodoc"})
|
||||
def test_ascii_docstring(self):
|
||||
# ASCII docstring
|
||||
foo = ModuleType("foo", "foodoc")
|
||||
self.assertEqual(foo.__name__, "foo")
|
||||
self.assertEqual(foo.__doc__, "foodoc")
|
||||
self.assertEqual(foo.__dict__,
|
||||
{"__name__": "foo", "__doc__": "foodoc"})
|
||||
|
||||
# Unicode docstring
|
||||
foo = module("foo", u"foodoc\u1234")
|
||||
vereq(foo.__name__, "foo")
|
||||
vereq(foo.__doc__, u"foodoc\u1234")
|
||||
vereq(foo.__dict__, {"__name__": "foo", "__doc__": u"foodoc\u1234"})
|
||||
def test_unicode_docstring(self):
|
||||
# Unicode docstring
|
||||
foo = ModuleType("foo", u"foodoc\u1234")
|
||||
self.assertEqual(foo.__name__, "foo")
|
||||
self.assertEqual(foo.__doc__, u"foodoc\u1234")
|
||||
self.assertEqual(foo.__dict__,
|
||||
{"__name__": "foo", "__doc__": u"foodoc\u1234"})
|
||||
|
||||
# Reinitialization should not replace the __dict__
|
||||
foo.bar = 42
|
||||
d = foo.__dict__
|
||||
foo.__init__("foo", "foodoc")
|
||||
vereq(foo.__name__, "foo")
|
||||
vereq(foo.__doc__, "foodoc")
|
||||
vereq(foo.bar, 42)
|
||||
vereq(foo.__dict__, {"__name__": "foo", "__doc__": "foodoc", "bar": 42})
|
||||
verify(foo.__dict__ is d)
|
||||
def test_reinit(self):
|
||||
# Reinitialization should not replace the __dict__
|
||||
foo = ModuleType("foo", u"foodoc\u1234")
|
||||
foo.bar = 42
|
||||
d = foo.__dict__
|
||||
foo.__init__("foo", "foodoc")
|
||||
self.assertEqual(foo.__name__, "foo")
|
||||
self.assertEqual(foo.__doc__, "foodoc")
|
||||
self.assertEqual(foo.bar, 42)
|
||||
self.assertEqual(foo.__dict__,
|
||||
{"__name__": "foo", "__doc__": "foodoc", "bar": 42})
|
||||
self.failUnless(foo.__dict__ is d)
|
||||
|
||||
if verbose:
|
||||
print "All OK"
|
||||
def test_main():
|
||||
run_unittest(ModuleTests)
|
||||
|
||||
if __name__ == '__main__':
|
||||
test_main()
|
||||
|
|
Loading…
Reference in New Issue