blob: 8014efe8c1c6614e1514efa75f3dd0b857a2ddf6 [file] [log] [blame]
Tim Peters763cb0a2001-01-22 22:43:35 +00001# test_pickle and test_cpickle both use this.
Tim Peterse9358162001-01-22 22:05:20 +00002
Tim Peterse089c682001-04-10 03:41:41 +00003from test_support import TestFailed
4import sys
5
Tim Peterse9358162001-01-22 22:05:20 +00006# break into multiple strings to please font-lock-mode
Tim Peters461922a2001-04-09 20:07:05 +00007DATA = """(lp1
Tim Peterse9358162001-01-22 22:05:20 +00008I0
9aL1L
Tim Peters461922a2001-04-09 20:07:05 +000010aF2
Tim Peterse9358162001-01-22 22:05:20 +000011ac__builtin__
12complex
Tim Peters461922a2001-04-09 20:07:05 +000013p2
14""" + \
15"""(F3
16F0
17tRp3
18aI1
19aI-1
20aI255
21aI-255
22aI-256
23aI65535
24aI-65535
25aI-65536
26aI2147483647
27aI-2147483647
28aI-2147483648
29a""" + \
30"""(S'abc'
Tim Peterse9358162001-01-22 22:05:20 +000031p4
32g4
Tim Peters461922a2001-04-09 20:07:05 +000033""" + \
34"""(ipickletester
Tim Peterse9358162001-01-22 22:05:20 +000035C
36p5
Tim Peters461922a2001-04-09 20:07:05 +000037""" + \
Tim Peterse9358162001-01-22 22:05:20 +000038"""(dp6
39S'foo'
40p7
41I1
42sS'bar'
43p8
44I2
45sbg5
46tp9
47ag9
48aI5
49a.
50"""
51
Tim Peters461922a2001-04-09 20:07:05 +000052BINDATA = ']q\x01(K\x00L1L\nG@\x00\x00\x00\x00\x00\x00\x00' + \
53 'c__builtin__\ncomplex\nq\x02(G@\x08\x00\x00\x00\x00\x00' + \
54 '\x00G\x00\x00\x00\x00\x00\x00\x00\x00tRq\x03K\x01J\xff\xff' + \
55 '\xff\xffK\xffJ\x01\xff\xff\xffJ\x00\xff\xff\xffM\xff\xff' + \
56 'J\x01\x00\xff\xffJ\x00\x00\xff\xffJ\xff\xff\xff\x7fJ\x01\x00' + \
57 '\x00\x80J\x00\x00\x00\x80(U\x03abcq\x04h\x04(cpickletester\n' + \
58 'C\nq\x05oq\x06}q\x07(U\x03fooq\x08K\x01U\x03barq\tK\x02ubh' + \
59 '\x06tq\nh\nK\x05e.'
Tim Peterse9358162001-01-22 22:05:20 +000060
61class C:
62 def __cmp__(self, other):
63 return cmp(self.__dict__, other.__dict__)
64
65import __main__
66__main__.C = C
67
68# Call this with the module to be tested (pickle or cPickle).
69
70def dotest(pickle):
71 c = C()
72 c.foo = 1
73 c.bar = 2
74 x = [0, 1L, 2.0, 3.0+0j]
Tim Peters461922a2001-04-09 20:07:05 +000075 # Append some integer test cases at cPickle.c's internal size
76 # cutoffs.
77 uint1max = 0xff
78 uint2max = 0xffff
79 int4max = 0x7fffffff
80 x.extend([1, -1,
81 uint1max, -uint1max, -uint1max-1,
82 uint2max, -uint2max, -uint2max-1,
83 int4max, -int4max, -int4max-1])
Tim Peterse9358162001-01-22 22:05:20 +000084 y = ('abc', 'abc', c, c)
85 x.append(y)
86 x.append(y)
87 x.append(5)
88 r = []
89 r.append(r)
Tim Petersc58440f2001-04-09 17:16:31 +000090
Tim Peterse9358162001-01-22 22:05:20 +000091 print "dumps()"
92 s = pickle.dumps(x)
Tim Petersc58440f2001-04-09 17:16:31 +000093
Tim Peterse9358162001-01-22 22:05:20 +000094 print "loads()"
95 x2 = pickle.loads(s)
Tim Petersc58440f2001-04-09 17:16:31 +000096 if x2 == x:
97 print "ok"
98 else:
99 print "bad"
100
Tim Peterse9358162001-01-22 22:05:20 +0000101 print "loads() DATA"
102 x2 = pickle.loads(DATA)
Tim Petersc58440f2001-04-09 17:16:31 +0000103 if x2 == x:
104 print "ok"
105 else:
106 print "bad"
107
Tim Peterse9358162001-01-22 22:05:20 +0000108 print "dumps() binary"
109 s = pickle.dumps(x, 1)
Tim Petersc58440f2001-04-09 17:16:31 +0000110
Tim Peterse9358162001-01-22 22:05:20 +0000111 print "loads() binary"
112 x2 = pickle.loads(s)
Tim Petersc58440f2001-04-09 17:16:31 +0000113 if x2 == x:
114 print "ok"
115 else:
116 print "bad"
117
Tim Peterse9358162001-01-22 22:05:20 +0000118 print "loads() BINDATA"
119 x2 = pickle.loads(BINDATA)
Tim Petersc58440f2001-04-09 17:16:31 +0000120 if x2 == x:
121 print "ok"
122 else:
123 print "bad"
124
Tim Peterse9358162001-01-22 22:05:20 +0000125 print "dumps() RECURSIVE"
Tim Petersc58440f2001-04-09 17:16:31 +0000126 s = pickle.dumps(r)
Tim Peterse9358162001-01-22 22:05:20 +0000127 x2 = pickle.loads(s)
Tim Petersc58440f2001-04-09 17:16:31 +0000128 if x2 == r:
129 print "ok"
130 else:
131 print "bad"
132
Tim Peterse9358162001-01-22 22:05:20 +0000133 # don't create cyclic garbage
134 del x2[0]
135 del r[0]
136
137 # Test protection against closed files
138 import tempfile, os
139 fn = tempfile.mktemp()
140 f = open(fn, "w")
141 f.close()
142 try:
143 pickle.dump(123, f)
144 except ValueError:
145 pass
146 else:
147 print "dump to closed file should raise ValueError"
Tim Petersc58440f2001-04-09 17:16:31 +0000148
Tim Peterse9358162001-01-22 22:05:20 +0000149 f = open(fn, "r")
150 f.close()
151 try:
152 pickle.load(f)
153 except ValueError:
154 pass
155 else:
156 print "load from closed file should raise ValueError"
157 os.remove(fn)
158
159 # Test specific bad cases
160 for i in range(10):
161 try:
162 x = pickle.loads('garyp')
163 except KeyError, y:
164 # pickle
165 del y
166 except pickle.BadPickleGet, y:
167 # cPickle
168 del y
169 else:
170 print "unexpected success!"
171 break
172
173 # Test insecure strings
174 insecure = ["abc", "2 + 2", # not quoted
175 "'abc' + 'def'", # not a single quoted string
176 "'abc", # quote is not closed
177 "'abc\"", # open quote and close quote don't match
178 "'abc' ?", # junk after close quote
179 # some tests of the quoting rules
180 "'abc\"\''",
181 "'\\\\a\'\'\'\\\'\\\\\''",
182 ]
183 for s in insecure:
184 buf = "S" + s + "\012p0\012."
185 try:
186 x = pickle.loads(buf)
187 except ValueError:
188 pass
189 else:
190 print "accepted insecure string: %s" % repr(buf)
191
192 # Test some Unicode end cases
193 endcases = [u'', u'<\\u>', u'<\\\u1234>', u'<\n>', u'<\\>']
194 for u in endcases:
195 try:
196 u2 = pickle.loads(pickle.dumps(u))
197 except Exception, msg:
198 print "Endcase exception: %s => %s(%s)" % \
199 (`u`, msg.__class__.__name__, str(msg))
200 else:
201 if u2 != u:
202 print "Endcase failure: %s => %s" % (`u`, `u2`)
Tim Peterse089c682001-04-10 03:41:41 +0000203
204 # Test the full range of Python ints.
205 n = sys.maxint
206 while n:
207 for expected in (-n, n):
208 for binary_mode in (0, 1):
209 s = pickle.dumps(expected, binary_mode)
210 got = pickle.loads(s)
211 if expected != got:
212 raise TestFailed("for %s-mode pickle of %d, pickle "
213 "string is %s, loaded back as %s" % (
214 binary_mode and "binary" or "text",
215 expected,
216 repr(s),
217 got))
218 n = n >> 1