238 lines
6.1 KiB
Python
238 lines
6.1 KiB
Python
import cPickle
|
|
import cStringIO
|
|
import io
|
|
import unittest
|
|
from test.pickletester import (AbstractPickleTests,
|
|
AbstractPickleModuleTests,
|
|
AbstractPicklerUnpicklerObjectTests,
|
|
BigmemPickleTests)
|
|
from test import test_support
|
|
|
|
class cStringIOMixin:
|
|
output = input = cStringIO.StringIO
|
|
|
|
def close(self, f):
|
|
pass
|
|
|
|
class BytesIOMixin:
|
|
output = input = io.BytesIO
|
|
|
|
def close(self, f):
|
|
pass
|
|
|
|
class FileIOMixin:
|
|
|
|
def output(self):
|
|
return open(test_support.TESTFN, 'wb+')
|
|
|
|
def input(self, data):
|
|
f = open(test_support.TESTFN, 'wb+')
|
|
try:
|
|
f.write(data)
|
|
f.seek(0)
|
|
return f
|
|
except:
|
|
f.close()
|
|
raise
|
|
|
|
def close(self, f):
|
|
f.close()
|
|
test_support.unlink(test_support.TESTFN)
|
|
|
|
|
|
class cPickleTests(AbstractPickleTests, AbstractPickleModuleTests):
|
|
|
|
def setUp(self):
|
|
self.dumps = cPickle.dumps
|
|
self.loads = cPickle.loads
|
|
|
|
error = cPickle.BadPickleGet
|
|
module = cPickle
|
|
|
|
class cPicklePicklerTests(AbstractPickleTests):
|
|
|
|
def dumps(self, arg, proto=0):
|
|
f = self.output()
|
|
try:
|
|
p = cPickle.Pickler(f, proto)
|
|
p.dump(arg)
|
|
f.seek(0)
|
|
return f.read()
|
|
finally:
|
|
self.close(f)
|
|
|
|
def loads(self, buf):
|
|
f = self.input(buf)
|
|
try:
|
|
p = cPickle.Unpickler(f)
|
|
return p.load()
|
|
finally:
|
|
self.close(f)
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
class cStringIOCPicklerTests(cStringIOMixin, cPicklePicklerTests):
|
|
pass
|
|
|
|
class BytesIOCPicklerTests(BytesIOMixin, cPicklePicklerTests):
|
|
pass
|
|
|
|
class FileIOCPicklerTests(FileIOMixin, cPicklePicklerTests):
|
|
pass
|
|
|
|
|
|
class cPickleListPicklerTests(AbstractPickleTests):
|
|
|
|
def dumps(self, arg, proto=0):
|
|
p = cPickle.Pickler(proto)
|
|
p.dump(arg)
|
|
return p.getvalue()
|
|
|
|
def loads(self, *args):
|
|
f = self.input(args[0])
|
|
try:
|
|
p = cPickle.Unpickler(f)
|
|
return p.load()
|
|
finally:
|
|
self.close(f)
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
class cStringIOCPicklerListTests(cStringIOMixin, cPickleListPicklerTests):
|
|
pass
|
|
|
|
class BytesIOCPicklerListTests(BytesIOMixin, cPickleListPicklerTests):
|
|
pass
|
|
|
|
class FileIOCPicklerListTests(FileIOMixin, cPickleListPicklerTests):
|
|
pass
|
|
|
|
|
|
class cPickleFastPicklerTests(AbstractPickleTests):
|
|
|
|
def dumps(self, arg, proto=0):
|
|
f = self.output()
|
|
try:
|
|
p = cPickle.Pickler(f, proto)
|
|
p.fast = 1
|
|
p.dump(arg)
|
|
f.seek(0)
|
|
return f.read()
|
|
finally:
|
|
self.close(f)
|
|
|
|
def loads(self, *args):
|
|
f = self.input(args[0])
|
|
try:
|
|
p = cPickle.Unpickler(f)
|
|
return p.load()
|
|
finally:
|
|
self.close(f)
|
|
|
|
error = cPickle.BadPickleGet
|
|
|
|
def test_recursive_list(self):
|
|
self.assertRaises(ValueError,
|
|
AbstractPickleTests.test_recursive_list,
|
|
self)
|
|
|
|
def test_recursive_tuple(self):
|
|
self.assertRaises(ValueError,
|
|
AbstractPickleTests.test_recursive_tuple,
|
|
self)
|
|
|
|
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)
|
|
|
|
def test_nonrecursive_deep(self):
|
|
# 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.
|
|
a = []
|
|
for i in range(60):
|
|
a = [a]
|
|
b = self.loads(self.dumps(a))
|
|
self.assertEqual(a, b)
|
|
|
|
class cStringIOCPicklerFastTests(cStringIOMixin, cPickleFastPicklerTests):
|
|
pass
|
|
|
|
class BytesIOCPicklerFastTests(BytesIOMixin, cPickleFastPicklerTests):
|
|
pass
|
|
|
|
class FileIOCPicklerFastTests(FileIOMixin, cPickleFastPicklerTests):
|
|
pass
|
|
|
|
|
|
class cPicklePicklerUnpicklerObjectTests(AbstractPicklerUnpicklerObjectTests):
|
|
|
|
pickler_class = cPickle.Pickler
|
|
unpickler_class = cPickle.Unpickler
|
|
|
|
class cPickleBigmemPickleTests(BigmemPickleTests):
|
|
|
|
def dumps(self, arg, proto=0, fast=0):
|
|
# Ignore fast
|
|
return cPickle.dumps(arg, proto)
|
|
|
|
def loads(self, buf):
|
|
# Ignore fast
|
|
return cPickle.loads(buf)
|
|
|
|
|
|
class Node(object):
|
|
pass
|
|
|
|
class cPickleDeepRecursive(unittest.TestCase):
|
|
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)
|
|
self.assertRaises((AttributeError, RuntimeError), cPickle.dumps, n)
|
|
|
|
def test_issue3179(self):
|
|
# Safe test, because I broke this case when fixing the
|
|
# behaviour for the previous test.
|
|
res=[]
|
|
for x in range(1,2000):
|
|
res.append(dict(doc=x, similar=[]))
|
|
cPickle.dumps(res)
|
|
|
|
|
|
def test_main():
|
|
test_support.run_unittest(
|
|
cPickleTests,
|
|
cStringIOCPicklerTests,
|
|
BytesIOCPicklerTests,
|
|
FileIOCPicklerTests,
|
|
cStringIOCPicklerListTests,
|
|
BytesIOCPicklerListTests,
|
|
FileIOCPicklerListTests,
|
|
cStringIOCPicklerFastTests,
|
|
BytesIOCPicklerFastTests,
|
|
FileIOCPicklerFastTests,
|
|
cPickleDeepRecursive,
|
|
cPicklePicklerUnpicklerObjectTests,
|
|
cPickleBigmemPickleTests,
|
|
)
|
|
|
|
if __name__ == "__main__":
|
|
test_main()
|