Raymond Hettinger | c37e5e0 | 2007-03-01 06:16:43 +0000 | [diff] [blame] | 1 | import unittest |
| 2 | from test import test_support |
| 3 | from collections import NamedTuple |
| 4 | |
| 5 | class TestNamedTuple(unittest.TestCase): |
| 6 | |
| 7 | def test_factory(self): |
| 8 | Point = NamedTuple('Point', 'x y') |
| 9 | self.assertEqual(Point.__name__, 'Point') |
| 10 | self.assertEqual(Point.__doc__, 'Point(x, y)') |
| 11 | self.assertEqual(Point.__slots__, ()) |
| 12 | self.assertEqual(Point.__module__, __name__) |
| 13 | self.assertEqual(Point.__getitem__, tuple.__getitem__) |
Raymond Hettinger | 767debb | 2007-05-21 16:40:10 +0000 | [diff] [blame] | 14 | self.assertRaises(ValueError, NamedTuple, 'abc%', 'def ghi') |
| 15 | self.assertRaises(ValueError, NamedTuple, 'abc', 'def g%hi') |
| 16 | NamedTuple('Point0', 'x1 y2') # Verify that numbers are allowed in names |
Raymond Hettinger | c37e5e0 | 2007-03-01 06:16:43 +0000 | [diff] [blame] | 17 | |
| 18 | def test_instance(self): |
| 19 | Point = NamedTuple('Point', 'x y') |
| 20 | p = Point(11, 22) |
| 21 | self.assertEqual(p, Point(x=11, y=22)) |
| 22 | self.assertEqual(p, Point(11, y=22)) |
| 23 | self.assertEqual(p, Point(y=22, x=11)) |
| 24 | self.assertEqual(p, Point(*(11, 22))) |
| 25 | self.assertEqual(p, Point(**dict(x=11, y=22))) |
| 26 | self.assertRaises(TypeError, Point, 1) # too few args |
| 27 | self.assertRaises(TypeError, Point, 1, 2, 3) # too many args |
| 28 | self.assertRaises(TypeError, eval, 'Point(XXX=1, y=2)', locals()) # wrong keyword argument |
| 29 | self.assertRaises(TypeError, eval, 'Point(x=1)', locals()) # missing keyword argument |
| 30 | self.assertEqual(repr(p), 'Point(x=11, y=22)') |
| 31 | self.assert_('__dict__' not in dir(p)) # verify instance has no dict |
| 32 | self.assert_('__weakref__' not in dir(p)) |
Raymond Hettinger | d36a60e | 2007-09-17 00:55:00 +0000 | [diff] [blame^] | 33 | self.assertEqual(p.__fields__, ('x', 'y')) # test __fields__ attribute |
| 34 | self.assertEqual(p.__replace__('x', 1), (1, 22)) # test __replace__ method |
| 35 | |
| 36 | # verify that field string can have commas |
| 37 | Point = NamedTuple('Point', 'x, y') |
| 38 | p = Point(x=11, y=22) |
| 39 | self.assertEqual(repr(p), 'Point(x=11, y=22)') |
Raymond Hettinger | c37e5e0 | 2007-03-01 06:16:43 +0000 | [diff] [blame] | 40 | |
| 41 | def test_tupleness(self): |
| 42 | Point = NamedTuple('Point', 'x y') |
| 43 | p = Point(11, 22) |
| 44 | |
| 45 | self.assert_(isinstance(p, tuple)) |
| 46 | self.assertEqual(p, (11, 22)) # matches a real tuple |
| 47 | self.assertEqual(tuple(p), (11, 22)) # coercable to a real tuple |
| 48 | self.assertEqual(list(p), [11, 22]) # coercable to a list |
| 49 | self.assertEqual(max(p), 22) # iterable |
| 50 | self.assertEqual(max(*p), 22) # star-able |
| 51 | x, y = p |
| 52 | self.assertEqual(p, (x, y)) # unpacks like a tuple |
| 53 | self.assertEqual((p[0], p[1]), (11, 22)) # indexable like a tuple |
| 54 | self.assertRaises(IndexError, p.__getitem__, 3) |
| 55 | |
| 56 | self.assertEqual(p.x, x) |
| 57 | self.assertEqual(p.y, y) |
| 58 | self.assertRaises(AttributeError, eval, 'p.z', locals()) |
| 59 | |
| 60 | |
| 61 | def test_main(verbose=None): |
Raymond Hettinger | 5a41daf | 2007-05-19 01:11:16 +0000 | [diff] [blame] | 62 | import collections as CollectionsModule |
Raymond Hettinger | c37e5e0 | 2007-03-01 06:16:43 +0000 | [diff] [blame] | 63 | test_classes = [TestNamedTuple] |
| 64 | test_support.run_unittest(*test_classes) |
Raymond Hettinger | 5a41daf | 2007-05-19 01:11:16 +0000 | [diff] [blame] | 65 | test_support.run_doctest(CollectionsModule, verbose) |
Raymond Hettinger | c37e5e0 | 2007-03-01 06:16:43 +0000 | [diff] [blame] | 66 | |
| 67 | if __name__ == "__main__": |
| 68 | test_main(verbose=True) |