blob: 602e0d929f901f9574781df41d5583b00a04c386 [file] [log] [blame]
Guido van Rossum1968ad32006-02-25 22:38:04 +00001"""Unit tests for collections.defaultdict."""
2
3import os
4import copy
5import tempfile
6import unittest
Thomas Wouters0e3f5912006-08-11 14:57:12 +00007from test import test_support
Guido van Rossum1968ad32006-02-25 22:38:04 +00008
9from collections import defaultdict
10
11def foobar():
12 return list
13
14class TestDefaultDict(unittest.TestCase):
15
16 def test_basic(self):
17 d1 = defaultdict()
18 self.assertEqual(d1.default_factory, None)
19 d1.default_factory = list
20 d1[12].append(42)
21 self.assertEqual(d1, {12: [42]})
22 d1[12].append(24)
23 self.assertEqual(d1, {12: [42, 24]})
24 d1[13]
25 d1[14]
26 self.assertEqual(d1, {12: [42, 24], 13: [], 14: []})
27 self.assert_(d1[12] is not d1[13] is not d1[14])
28 d2 = defaultdict(list, foo=1, bar=2)
29 self.assertEqual(d2.default_factory, list)
30 self.assertEqual(d2, {"foo": 1, "bar": 2})
31 self.assertEqual(d2["foo"], 1)
32 self.assertEqual(d2["bar"], 2)
33 self.assertEqual(d2[42], [])
34 self.assert_("foo" in d2)
35 self.assert_("foo" in d2.keys())
36 self.assert_("bar" in d2)
37 self.assert_("bar" in d2.keys())
38 self.assert_(42 in d2)
39 self.assert_(42 in d2.keys())
40 self.assert_(12 not in d2)
41 self.assert_(12 not in d2.keys())
42 d2.default_factory = None
43 self.assertEqual(d2.default_factory, None)
44 try:
45 d2[15]
Guido van Rossumb940e112007-01-10 16:19:56 +000046 except KeyError as err:
Guido van Rossum1968ad32006-02-25 22:38:04 +000047 self.assertEqual(err.args, (15,))
48 else:
49 self.fail("d2[15] didn't raise KeyError")
50
51 def test_missing(self):
52 d1 = defaultdict()
53 self.assertRaises(KeyError, d1.__missing__, 42)
54 d1.default_factory = list
55 self.assertEqual(d1.__missing__(42), [])
56
57 def test_repr(self):
58 d1 = defaultdict()
59 self.assertEqual(d1.default_factory, None)
60 self.assertEqual(repr(d1), "defaultdict(None, {})")
61 d1[11] = 41
62 self.assertEqual(repr(d1), "defaultdict(None, {11: 41})")
63 d2 = defaultdict(0)
64 self.assertEqual(d2.default_factory, 0)
65 d2[12] = 42
66 self.assertEqual(repr(d2), "defaultdict(0, {12: 42})")
67 def foo(): return 43
68 d3 = defaultdict(foo)
69 self.assert_(d3.default_factory is foo)
70 d3[13]
71 self.assertEqual(repr(d3), "defaultdict(%s, {13: 43})" % repr(foo))
72
73 def test_print(self):
74 d1 = defaultdict()
75 def foo(): return 42
76 d2 = defaultdict(foo, {1: 2})
77 # NOTE: We can't use tempfile.[Named]TemporaryFile since this
78 # code must exercise the tp_print C code, which only gets
79 # invoked for *real* files.
80 tfn = tempfile.mktemp()
81 try:
82 f = open(tfn, "w+")
83 try:
84 print >>f, d1
85 print >>f, d2
86 f.seek(0)
87 self.assertEqual(f.readline(), repr(d1) + "\n")
88 self.assertEqual(f.readline(), repr(d2) + "\n")
89 finally:
90 f.close()
91 finally:
92 os.remove(tfn)
93
94 def test_copy(self):
95 d1 = defaultdict()
96 d2 = d1.copy()
97 self.assertEqual(type(d2), defaultdict)
98 self.assertEqual(d2.default_factory, None)
99 self.assertEqual(d2, {})
100 d1.default_factory = list
101 d3 = d1.copy()
102 self.assertEqual(type(d3), defaultdict)
103 self.assertEqual(d3.default_factory, list)
104 self.assertEqual(d3, {})
105 d1[42]
106 d4 = d1.copy()
107 self.assertEqual(type(d4), defaultdict)
108 self.assertEqual(d4.default_factory, list)
109 self.assertEqual(d4, {42: []})
110 d4[12]
111 self.assertEqual(d4, {42: [], 12: []})
112
113 def test_shallow_copy(self):
114 d1 = defaultdict(foobar, {1: 1})
115 d2 = copy.copy(d1)
116 self.assertEqual(d2.default_factory, foobar)
117 self.assertEqual(d2, d1)
118 d1.default_factory = list
119 d2 = copy.copy(d1)
120 self.assertEqual(d2.default_factory, list)
121 self.assertEqual(d2, d1)
122
123 def test_deep_copy(self):
124 d1 = defaultdict(foobar, {1: [1]})
125 d2 = copy.deepcopy(d1)
126 self.assertEqual(d2.default_factory, foobar)
127 self.assertEqual(d2, d1)
128 self.assert_(d1[1] is not d2[1])
129 d1.default_factory = list
130 d2 = copy.deepcopy(d1)
131 self.assertEqual(d2.default_factory, list)
132 self.assertEqual(d2, d1)
133
134
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000135def test_main():
136 test_support.run_unittest(TestDefaultDict)
137
Guido van Rossum1968ad32006-02-25 22:38:04 +0000138if __name__ == "__main__":
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000139 test_main()