diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2012-03-02 17:12:43 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2012-03-02 17:12:43 (GMT) |
commit | 679e9d36f78de3ac18abaaddbcf4f73fcef55b7e (patch) | |
tree | 79bb8e94300dbb8ccb5eb2743a898149a62130ea /Lib/test | |
parent | b2b18632ce5f8067b2925f4ba2cf783479759ab4 (diff) | |
download | cpython-679e9d36f78de3ac18abaaddbcf4f73fcef55b7e.zip cpython-679e9d36f78de3ac18abaaddbcf4f73fcef55b7e.tar.gz cpython-679e9d36f78de3ac18abaaddbcf4f73fcef55b7e.tar.bz2 |
Issue #14172: Fix reference leak when marshalling a buffer-like object (other than a bytes object).
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_marshal.py | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/Lib/test/test_marshal.py b/Lib/test/test_marshal.py index cd100f9..9a25012 100644 --- a/Lib/test/test_marshal.py +++ b/Lib/test/test_marshal.py @@ -1,6 +1,7 @@ #!/usr/bin/env python3 from test import support +import array import marshal import sys import unittest @@ -137,6 +138,27 @@ class ContainerTestCase(unittest.TestCase, HelperMixin): for constructor in (set, frozenset): self.helper(constructor(self.d.keys())) + +class BufferTestCase(unittest.TestCase, HelperMixin): + + def test_bytearray(self): + b = bytearray(b"abc") + self.helper(b) + new = marshal.loads(marshal.dumps(b)) + self.assertEqual(type(new), bytes) + + def test_memoryview(self): + b = memoryview(b"abc") + self.helper(b) + new = marshal.loads(marshal.dumps(b)) + self.assertEqual(type(new), bytes) + + def test_array(self): + a = array.array('B', b"abc") + new = marshal.loads(marshal.dumps(a)) + self.assertEqual(new, b"abc") + + class BugsTestCase(unittest.TestCase): def test_bug_5888452(self): # Simple-minded check for SF 588452: Debug build crashes @@ -243,6 +265,7 @@ def test_main(): CodeTestCase, ContainerTestCase, ExceptionTestCase, + BufferTestCase, BugsTestCase) if __name__ == "__main__": |