2008-06-22 20:19:14 -03:00
|
|
|
import cPickle, unittest
|
2001-10-15 18:38:56 -03:00
|
|
|
from cStringIO import StringIO
|
2006-03-24 04:58:38 -04:00
|
|
|
from test.pickletester import AbstractPickleTests, AbstractPickleModuleTests
|
2009-04-09 13:46:46 -03:00
|
|
|
from test.pickletester import AbstractPicklerUnpicklerObjectTests
|
2002-07-23 16:04:11 -03:00
|
|
|
from test import test_support
|
2001-10-15 18:38:56 -03:00
|
|
|
|
|
|
|
class cPickleTests(AbstractPickleTests, AbstractPickleModuleTests):
|
2001-10-18 18:57:37 -03:00
|
|
|
|
2001-10-15 18:38:56 -03:00
|
|
|
def setUp(self):
|
|
|
|
self.dumps = cPickle.dumps
|
|
|
|
self.loads = cPickle.loads
|
|
|
|
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
module = cPickle
|
|
|
|
|
|
|
|
class cPicklePicklerTests(AbstractPickleTests):
|
|
|
|
|
2003-01-28 18:26:28 -04:00
|
|
|
def dumps(self, arg, proto=0):
|
2001-10-15 18:38:56 -03:00
|
|
|
f = StringIO()
|
2003-01-28 18:26:28 -04:00
|
|
|
p = cPickle.Pickler(f, proto)
|
2001-10-15 18:38:56 -03:00
|
|
|
p.dump(arg)
|
|
|
|
f.seek(0)
|
|
|
|
return f.read()
|
|
|
|
|
|
|
|
def loads(self, buf):
|
|
|
|
f = StringIO(buf)
|
|
|
|
p = cPickle.Unpickler(f)
|
|
|
|
return p.load()
|
|
|
|
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
|
|
|
|
class cPickleListPicklerTests(AbstractPickleTests):
|
|
|
|
|
2003-01-28 18:26:28 -04:00
|
|
|
def dumps(self, arg, proto=0):
|
|
|
|
p = cPickle.Pickler(proto)
|
2001-10-15 18:38:56 -03:00
|
|
|
p.dump(arg)
|
|
|
|
return p.getvalue()
|
|
|
|
|
|
|
|
def loads(self, *args):
|
|
|
|
f = StringIO(args[0])
|
|
|
|
p = cPickle.Unpickler(f)
|
|
|
|
return p.load()
|
|
|
|
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
|
|
|
|
class cPickleFastPicklerTests(AbstractPickleTests):
|
|
|
|
|
2003-01-28 18:26:28 -04:00
|
|
|
def dumps(self, arg, proto=0):
|
2001-10-15 18:38:56 -03:00
|
|
|
f = StringIO()
|
2003-01-28 18:26:28 -04:00
|
|
|
p = cPickle.Pickler(f, proto)
|
2001-10-15 18:38:56 -03:00
|
|
|
p.fast = 1
|
|
|
|
p.dump(arg)
|
|
|
|
f.seek(0)
|
|
|
|
return f.read()
|
|
|
|
|
|
|
|
def loads(self, *args):
|
|
|
|
f = StringIO(args[0])
|
|
|
|
p = cPickle.Unpickler(f)
|
|
|
|
return p.load()
|
|
|
|
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
|
|
|
|
def test_recursive_list(self):
|
|
|
|
self.assertRaises(ValueError,
|
|
|
|
AbstractPickleTests.test_recursive_list,
|
|
|
|
self)
|
|
|
|
|
2009-05-26 01:12:39 -03:00
|
|
|
def test_recursive_tuple(self):
|
|
|
|
self.assertRaises(ValueError,
|
|
|
|
AbstractPickleTests.test_recursive_tuple,
|
|
|
|
self)
|
|
|
|
|
2001-10-15 18:38:56 -03:00
|
|
|
def test_recursive_inst(self):
|
|
|
|
self.assertRaises(ValueError,
|
|
|
|
AbstractPickleTests.test_recursive_inst,
|
|
|
|
self)
|
|
|
|
|
|
|
|
def test_recursive_dict(self):
|
|
|
|
self.assertRaises(ValueError,
|
|
|
|
AbstractPickleTests.test_recursive_dict,
|
|
|
|
self)
|
|
|
|
|
|
|
|
def test_recursive_multi(self):
|
|
|
|
self.assertRaises(ValueError,
|
|
|
|
AbstractPickleTests.test_recursive_multi,
|
|
|
|
self)
|
|
|
|
|
2001-12-21 16:04:22 -04:00
|
|
|
def test_nonrecursive_deep(self):
|
2003-02-21 16:14:35 -04:00
|
|
|
# If it's not cyclic, it should pickle OK even if the nesting
|
|
|
|
# depth exceeds PY_CPICKLE_FAST_LIMIT. That happens to be
|
|
|
|
# 50 today. Jack Jansen reported stack overflow on Mac OS 9
|
|
|
|
# at 64.
|
2001-12-21 16:04:22 -04:00
|
|
|
a = []
|
2003-02-21 16:14:35 -04:00
|
|
|
for i in range(60):
|
2001-12-21 16:04:22 -04:00
|
|
|
a = [a]
|
|
|
|
b = self.loads(self.dumps(a))
|
|
|
|
self.assertEqual(a, b)
|
|
|
|
|
2009-04-09 13:46:46 -03:00
|
|
|
class cPicklePicklerUnpicklerObjectTests(AbstractPicklerUnpicklerObjectTests):
|
|
|
|
|
|
|
|
pickler_class = cPickle.Pickler
|
|
|
|
unpickler_class = cPickle.Unpickler
|
|
|
|
|
|
|
|
|
2008-06-22 20:19:14 -03:00
|
|
|
class Node(object):
|
|
|
|
pass
|
|
|
|
|
|
|
|
class cPickleDeepRecursive(unittest.TestCase):
|
2008-06-29 22:10:55 -03:00
|
|
|
def test_issue2702(self):
|
|
|
|
# This should raise a RecursionLimit but in some
|
|
|
|
# platforms (FreeBSD, win32) sometimes raises KeyError instead,
|
|
|
|
# or just silently terminates the interpreter (=crashes).
|
|
|
|
nodes = [Node() for i in range(500)]
|
|
|
|
for n in nodes:
|
|
|
|
n.connections = list(nodes)
|
|
|
|
n.connections.remove(n)
|
2009-03-22 19:24:58 -03:00
|
|
|
self.assertRaises((AttributeError, RuntimeError), cPickle.dumps, n)
|
2008-06-25 16:24:53 -03:00
|
|
|
|
|
|
|
def test_issue3179(self):
|
2008-06-29 22:10:55 -03:00
|
|
|
# Safe test, because I broke this case when fixing the
|
|
|
|
# behaviour for the previous test.
|
2008-06-25 16:24:53 -03:00
|
|
|
res=[]
|
|
|
|
for x in range(1,2000):
|
|
|
|
res.append(dict(doc=x, similar=[]))
|
|
|
|
cPickle.dumps(res)
|
|
|
|
|
2008-06-22 20:19:14 -03:00
|
|
|
|
2001-12-19 12:42:15 -04:00
|
|
|
def test_main():
|
2003-05-01 14:45:56 -03:00
|
|
|
test_support.run_unittest(
|
|
|
|
cPickleTests,
|
|
|
|
cPicklePicklerTests,
|
|
|
|
cPickleListPicklerTests,
|
2008-06-22 20:19:14 -03:00
|
|
|
cPickleFastPicklerTests,
|
|
|
|
cPickleDeepRecursive,
|
2009-04-09 13:46:46 -03:00
|
|
|
cPicklePicklerUnpicklerObjectTests,
|
2003-05-01 14:45:56 -03:00
|
|
|
)
|
2001-12-19 12:42:15 -04:00
|
|
|
|
2001-10-15 18:38:56 -03:00
|
|
|
if __name__ == "__main__":
|
2001-12-19 12:42:15 -04:00
|
|
|
test_main()
|