diff options
author | Stefan Krah <skrah@bytereef.org> | 2015-11-10 17:17:22 (GMT) |
---|---|---|
committer | Stefan Krah <skrah@bytereef.org> | 2015-11-10 17:17:22 (GMT) |
commit | 0ce5b6e2688ddf342780b663a095b3e0c9f5cc72 (patch) | |
tree | 36f44f86940823483ac4aef497fe37058bcf35e7 /Lib/test | |
parent | e46e09d0f5fc5b47d508abc510d92be0aba95599 (diff) | |
download | cpython-0ce5b6e2688ddf342780b663a095b3e0c9f5cc72.zip cpython-0ce5b6e2688ddf342780b663a095b3e0c9f5cc72.tar.gz cpython-0ce5b6e2688ddf342780b663a095b3e0c9f5cc72.tar.bz2 |
Iaaue #25598: Fix memory_hex from #9951 for non-contiguous buffers.
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_buffer.py | 5 | ||||
-rw-r--r-- | Lib/test/test_memoryview.py | 7 |
2 files changed, 12 insertions, 0 deletions
diff --git a/Lib/test/test_buffer.py b/Lib/test/test_buffer.py index a653390..2eef9fc 100644 --- a/Lib/test/test_buffer.py +++ b/Lib/test/test_buffer.py @@ -841,6 +841,11 @@ class TestBufferProtocol(unittest.TestCase): # test tobytes() self.assertEqual(result.tobytes(), b) + # test hex() + m = memoryview(result) + h = "".join("%02x" % c for c in b) + self.assertEqual(m.hex(), h) + # lst := expected multi-dimensional logical representation # flatten(lst) := elements in C-order ff = fmt if fmt else 'B' diff --git a/Lib/test/test_memoryview.py b/Lib/test/test_memoryview.py index da01a84..d2bab38 100644 --- a/Lib/test/test_memoryview.py +++ b/Lib/test/test_memoryview.py @@ -512,6 +512,13 @@ class OtherTest(unittest.TestCase): m[2:] = memoryview(p6).cast(format)[2:] self.assertEqual(d.value, 0.6) + def test_memoryview_hex(self): + # Issue #9951: memoryview.hex() segfaults with non-contiguous buffers. + x = b'0' * 200000 + m1 = memoryview(x) + m2 = m1[::-1] + self.assertEqual(m2.hex(), '30' * 200000) + if __name__ == "__main__": unittest.main() |