1999-03-25 22:38:49 +00:00
|
|
|
# Test the pickle module
|
|
|
|
|
2000-09-15 15:14:51 +00:00
|
|
|
# break into multiple strings to please font-lock-mode
|
1999-03-25 22:38:49 +00:00
|
|
|
DATA = """(lp0
|
|
|
|
I0
|
|
|
|
aL1L
|
|
|
|
aF2.0
|
|
|
|
ac__builtin__
|
|
|
|
complex
|
|
|
|
p1
|
2000-09-15 15:14:51 +00:00
|
|
|
""" \
|
|
|
|
"""(F3.0
|
1999-03-25 22:38:49 +00:00
|
|
|
F0.0
|
|
|
|
tp2
|
|
|
|
Rp3
|
|
|
|
a(S'abc'
|
|
|
|
p4
|
|
|
|
g4
|
2000-09-15 15:14:51 +00:00
|
|
|
""" \
|
|
|
|
"""(i__main__
|
1999-03-25 22:38:49 +00:00
|
|
|
C
|
|
|
|
p5
|
2000-09-15 15:14:51 +00:00
|
|
|
""" \
|
|
|
|
"""(dp6
|
1999-03-25 22:38:49 +00:00
|
|
|
S'foo'
|
|
|
|
p7
|
|
|
|
I1
|
|
|
|
sS'bar'
|
|
|
|
p8
|
|
|
|
I2
|
|
|
|
sbg5
|
|
|
|
tp9
|
|
|
|
ag9
|
|
|
|
aI5
|
|
|
|
a.
|
|
|
|
"""
|
|
|
|
|
|
|
|
BINDATA = ']q\000(K\000L1L\012G@\000\000\000\000\000\000\000c__builtin__\012complex\012q\001(G@\010\000\000\000\000\000\000G\000\000\000\000\000\000\000\000tq\002Rq\003(U\003abcq\004h\004(c__main__\012C\012q\005oq\006}q\007(U\003fooq\010K\001U\003barq\011K\002ubh\006tq\012h\012K\005e.'
|
|
|
|
|
|
|
|
class C:
|
|
|
|
def __cmp__(self, other):
|
|
|
|
return cmp(self.__dict__, other.__dict__)
|
|
|
|
|
|
|
|
import __main__
|
|
|
|
__main__.C = C
|
|
|
|
|
2000-09-15 15:14:51 +00:00
|
|
|
def dotest(pickle):
|
1999-03-25 22:38:49 +00:00
|
|
|
c = C()
|
|
|
|
c.foo = 1
|
|
|
|
c.bar = 2
|
|
|
|
x = [0, 1L, 2.0, 3.0+0j]
|
|
|
|
y = ('abc', 'abc', c, c)
|
|
|
|
x.append(y)
|
|
|
|
x.append(y)
|
|
|
|
x.append(5)
|
2000-09-15 15:14:51 +00:00
|
|
|
r = []
|
|
|
|
r.append(r)
|
1999-03-25 22:38:49 +00:00
|
|
|
print "dumps()"
|
|
|
|
s = pickle.dumps(x)
|
|
|
|
print "loads()"
|
|
|
|
x2 = pickle.loads(s)
|
|
|
|
if x2 == x: print "ok"
|
|
|
|
else: print "bad"
|
|
|
|
print "loads() DATA"
|
|
|
|
x2 = pickle.loads(DATA)
|
|
|
|
if x2 == x: print "ok"
|
|
|
|
else: print "bad"
|
|
|
|
print "dumps() binary"
|
|
|
|
s = pickle.dumps(x, 1)
|
|
|
|
print "loads() binary"
|
|
|
|
x2 = pickle.loads(s)
|
|
|
|
if x2 == x: print "ok"
|
|
|
|
else: print "bad"
|
|
|
|
print "loads() BINDATA"
|
|
|
|
x2 = pickle.loads(BINDATA)
|
|
|
|
if x2 == x: print "ok"
|
|
|
|
else: print "bad"
|
2000-09-15 15:14:51 +00:00
|
|
|
s = pickle.dumps(r)
|
|
|
|
print "dumps() RECURSIVE"
|
|
|
|
x2 = pickle.loads(s)
|
|
|
|
if x2 == r: print "ok"
|
|
|
|
else: print "bad"
|
1999-03-25 22:38:49 +00:00
|
|
|
|
2000-09-15 15:14:51 +00:00
|
|
|
# Test protection against closed files
|
|
|
|
import tempfile, os
|
|
|
|
fn = tempfile.mktemp()
|
|
|
|
f = open(fn, "w")
|
|
|
|
f.close()
|
|
|
|
try:
|
|
|
|
pickle.dump(123, f)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
print "dump to closed file should raise ValueError"
|
|
|
|
f = open(fn, "r")
|
|
|
|
f.close()
|
|
|
|
try:
|
|
|
|
pickle.load(f)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
print "load from closed file should raise ValueError"
|
|
|
|
os.remove(fn)
|
|
|
|
|
|
|
|
# Test specific bad cases
|
|
|
|
for i in range(10):
|
|
|
|
try:
|
|
|
|
x = pickle.loads('garyp')
|
|
|
|
except KeyError, y:
|
|
|
|
# pickle
|
|
|
|
del y
|
|
|
|
except pickle.BadPickleGet, y:
|
|
|
|
# cPickle
|
|
|
|
del y
|
|
|
|
else:
|
|
|
|
print "unexpected success!"
|
|
|
|
break
|
|
|
|
|
|
|
|
# Test insecure strings
|
|
|
|
insecure = ["abc", "2 + 2", # not quoted
|
|
|
|
"'abc' + 'def'", # not a single quoted string
|
|
|
|
"'abc", # quote is not closed
|
|
|
|
"'abc\"", # open quote and close quote don't match
|
|
|
|
"'abc' ?", # junk after close quote
|
|
|
|
# some tests of the quoting rules
|
|
|
|
"'abc\"\''",
|
|
|
|
"'\\\\a\'\'\'\\\'\\\\\''",
|
|
|
|
]
|
|
|
|
for s in insecure:
|
|
|
|
buf = "S" + s + "\012p0\012."
|
|
|
|
try:
|
|
|
|
x = pickle.loads(buf)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
print "accepted insecure string: %s" % repr(buf)
|
|
|
|
|
|
|
|
|
|
|
|
import pickle
|
|
|
|
dotest(pickle)
|