| # 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() |