summaryrefslogtreecommitdiff
path: root/Lib/test/test_memoryview.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-12-25 21:05:35 +0200
committerSerhiy Storchaka <storchaka@gmail.com>2015-12-25 21:05:35 +0200
commitf9253c96fdff3ae1fcdacc72c06632f41df0424c (patch)
tree85e1a5bea8c837974ea404ac031894f85c4394bd /Lib/test/test_memoryview.py
parentef1585eb9a488ae8ce3ff057f43a7048b941cc1c (diff)
parentf81be8aa3ff3cbae66686482219bd7c7561f3de8 (diff)
downloadcpython-git-f9253c96fdff3ae1fcdacc72c06632f41df0424c.tar.gz
Issue #22995: Instances of extension types with a state that aren't
subclasses of list or dict and haven't implemented any pickle-related methods (__reduce__, __reduce_ex__, __getnewargs__, __getnewargs_ex__, or __getstate__), can no longer be pickled. Including memoryview.
Diffstat (limited to 'Lib/test/test_memoryview.py')
-rw-r--r--Lib/test/test_memoryview.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_memoryview.py b/Lib/test/test_memoryview.py
index d2bab38104..ddd5b9a8e2 100644
--- a/Lib/test/test_memoryview.py
+++ b/Lib/test/test_memoryview.py
@@ -11,6 +11,8 @@ import gc
import weakref
import array
import io
+import copy
+import pickle
class AbstractMemoryTests:
@@ -519,6 +521,17 @@ class OtherTest(unittest.TestCase):
m2 = m1[::-1]
self.assertEqual(m2.hex(), '30' * 200000)
+ def test_copy(self):
+ m = memoryview(b'abc')
+ with self.assertRaises(TypeError):
+ copy.copy(m)
+
+ def test_pickle(self):
+ m = memoryview(b'abc')
+ for proto in range(pickle.HIGHEST_PROTOCOL + 1):
+ with self.assertRaises(TypeError):
+ pickle.dumps(m, proto)
+
if __name__ == "__main__":
unittest.main()