summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2013-10-03 17:55:41 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2013-10-03 17:55:41 (GMT)
commit60b183407cbcd19b211c2dd7ed9a59ff189844a8 (patch)
tree8d57a6e32f03b9bb54fcd23e7b2b14ea57691e76 /Lib/test
parentdef0a4c298358c50b0b53a8113551e9aee3532e5 (diff)
downloadcpython-60b183407cbcd19b211c2dd7ed9a59ff189844a8.zip
cpython-60b183407cbcd19b211c2dd7ed9a59ff189844a8.tar.gz
cpython-60b183407cbcd19b211c2dd7ed9a59ff189844a8.tar.bz2
Issue #19014: memoryview.cast() is now allowed on zero-length views.
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_buffer.py13
1 files changed, 10 insertions, 3 deletions
diff --git a/Lib/test/test_buffer.py b/Lib/test/test_buffer.py
index 747e2a2..04e3f61 100644
--- a/Lib/test/test_buffer.py
+++ b/Lib/test/test_buffer.py
@@ -2432,15 +2432,22 @@ class TestBufferProtocol(unittest.TestCase):
self.assertRaises(ValueError, get_contiguous, nd[::-1], PyBUF_READ, 'C')
def test_memoryview_cast_zero_shape(self):
- # Casts are undefined if shape contains zeros. These arrays are
- # regarded as C-contiguous by Numpy and PyBuffer_GetContiguous(),
- # so they are not caught by the test for C-contiguity in memory_cast().
+ # Casts are undefined if buffer is multidimensional and shape
+ # contains zeros. These arrays are regarded as C-contiguous by
+ # Numpy and PyBuffer_GetContiguous(), so they are not caught by
+ # the test for C-contiguity in memory_cast().
items = [1,2,3]
for shape in ([0,3,3], [3,0,3], [0,3,3]):
ex = ndarray(items, shape=shape)
self.assertTrue(ex.c_contiguous)
msrc = memoryview(ex)
self.assertRaises(TypeError, msrc.cast, 'c')
+ # Monodimensional empty view can be cast (issue #19014).
+ for fmt, _, _ in iter_format(1, 'memoryview'):
+ msrc = memoryview(b'')
+ m = msrc.cast(fmt)
+ self.assertEqual(m.tobytes(), b'')
+ self.assertEqual(m.tolist(), [])
def test_memoryview_struct_module(self):