Commit d71f3170 authored by Serhiy Storchaka's avatar Serhiy Storchaka Committed by GitHub

Add more tests for preserving identity in marshal. (GH-13736)

parent b7daabd7
...@@ -383,10 +383,7 @@ def CollectObjectIDs(ids, obj): ...@@ -383,10 +383,7 @@ def CollectObjectIDs(ids, obj):
return len(ids) return len(ids)
class InstancingTestCase(unittest.TestCase, HelperMixin): class InstancingTestCase(unittest.TestCase, HelperMixin):
intobj = 123321 keys = (123, 1.2345, 'abc', (123, 'abc'), frozenset({123, 'abc'}))
floatobj = 1.2345
strobj = "abcde"*3
dictobj = {"hello":floatobj, "goodbye":floatobj, floatobj:"hello"}
def helper3(self, rsample, recursive=False, simple=False): def helper3(self, rsample, recursive=False, simple=False):
#we have two instances #we have two instances
...@@ -394,11 +391,12 @@ class InstancingTestCase(unittest.TestCase, HelperMixin): ...@@ -394,11 +391,12 @@ class InstancingTestCase(unittest.TestCase, HelperMixin):
n0 = CollectObjectIDs(set(), sample) n0 = CollectObjectIDs(set(), sample)
s3 = marshal.dumps(sample, 3) for v in range(3, marshal.version + 1):
n3 = CollectObjectIDs(set(), marshal.loads(s3)) s3 = marshal.dumps(sample, v)
n3 = CollectObjectIDs(set(), marshal.loads(s3))
#same number of instances generated #same number of instances generated
self.assertEqual(n3, n0) self.assertEqual(n3, n0)
if not recursive: if not recursive:
#can compare with version 2 #can compare with version 2
...@@ -414,20 +412,54 @@ class InstancingTestCase(unittest.TestCase, HelperMixin): ...@@ -414,20 +412,54 @@ class InstancingTestCase(unittest.TestCase, HelperMixin):
self.assertGreaterEqual(len(s2), len(s3)) self.assertGreaterEqual(len(s2), len(s3))
def testInt(self): def testInt(self):
self.helper(self.intobj) intobj = 123321
self.helper3(self.intobj, simple=True) self.helper(intobj)
self.helper3(intobj, simple=True)
def testFloat(self): def testFloat(self):
self.helper(self.floatobj) floatobj = 1.2345
self.helper3(self.floatobj) self.helper(floatobj)
self.helper3(floatobj)
def testStr(self): def testStr(self):
self.helper(self.strobj) strobj = "abcde"*3
self.helper3(self.strobj) self.helper(strobj)
self.helper3(strobj)
def testBytes(self):
bytesobj = b"abcde"*3
self.helper(bytesobj)
self.helper3(bytesobj)
def testList(self):
for obj in self.keys:
listobj = [obj, obj]
self.helper(listobj)
self.helper3(listobj)
def testTuple(self):
for obj in self.keys:
tupleobj = (obj, obj)
self.helper(tupleobj)
self.helper3(tupleobj)
def testSet(self):
for obj in self.keys:
setobj = {(obj, 1), (obj, 2)}
self.helper(setobj)
self.helper3(setobj)
def testFrozenSet(self):
for obj in self.keys:
frozensetobj = frozenset({(obj, 1), (obj, 2)})
self.helper(frozensetobj)
self.helper3(frozensetobj)
def testDict(self): def testDict(self):
self.helper(self.dictobj) for obj in self.keys:
self.helper3(self.dictobj) dictobj = {"hello": obj, "goodbye": obj, obj: "hello"}
self.helper(dictobj)
self.helper3(dictobj)
def testModule(self): def testModule(self):
with open(__file__, "rb") as f: with open(__file__, "rb") as f:
...@@ -438,10 +470,11 @@ class InstancingTestCase(unittest.TestCase, HelperMixin): ...@@ -438,10 +470,11 @@ class InstancingTestCase(unittest.TestCase, HelperMixin):
self.helper3(code) self.helper3(code)
def testRecursion(self): def testRecursion(self):
d = dict(self.dictobj) obj = 1.2345
d = {"hello": obj, "goodbye": obj, obj: "hello"}
d["self"] = d d["self"] = d
self.helper3(d, recursive=True) self.helper3(d, recursive=True)
l = [self.dictobj] l = [obj, obj]
l.append(l) l.append(l)
self.helper3(l, recursive=True) self.helper3(l, recursive=True)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment