76 lines
1.3 KiB
Python
76 lines
1.3 KiB
Python
|
# Test the pickle module
|
||
|
|
||
|
DATA = """(lp0
|
||
|
I0
|
||
|
aL1L
|
||
|
aF2.0
|
||
|
ac__builtin__
|
||
|
complex
|
||
|
p1
|
||
|
(F3.0
|
||
|
F0.0
|
||
|
tp2
|
||
|
Rp3
|
||
|
a(S'abc'
|
||
|
p4
|
||
|
g4
|
||
|
(i__main__
|
||
|
C
|
||
|
p5
|
||
|
(dp6
|
||
|
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.'
|
||
|
|
||
|
import pickle
|
||
|
|
||
|
class C:
|
||
|
def __cmp__(self, other):
|
||
|
return cmp(self.__dict__, other.__dict__)
|
||
|
|
||
|
import __main__
|
||
|
__main__.C = C
|
||
|
|
||
|
def dotest():
|
||
|
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)
|
||
|
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"
|
||
|
|
||
|
dotest()
|