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