diff options
author | Hirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp> | 2009-03-31 20:14:04 (GMT) |
---|---|---|
committer | Hirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp> | 2009-03-31 20:14:04 (GMT) |
commit | 1d7d5325be5c766c3446dcf0fce4ebce73d83fa7 (patch) | |
tree | 60b65d642fc02ece812c0f6c069d259a19014c64 /Lib/test/test_mmap.py | |
parent | 65ff00559a1192bccb23b5af9abb54db361d9124 (diff) | |
download | cpython-1d7d5325be5c766c3446dcf0fce4ebce73d83fa7.zip cpython-1d7d5325be5c766c3446dcf0fce4ebce73d83fa7.tar.gz cpython-1d7d5325be5c766c3446dcf0fce4ebce73d83fa7.tar.bz2 |
Issue #5387: Fixed mmap.move crash by integer overflow. (take2)
Diffstat (limited to 'Lib/test/test_mmap.py')
-rw-r--r-- | Lib/test/test_mmap.py | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/Lib/test/test_mmap.py b/Lib/test/test_mmap.py index b8998ea..1a23f2e 100644 --- a/Lib/test/test_mmap.py +++ b/Lib/test/test_mmap.py @@ -1,6 +1,6 @@ from test.test_support import TESTFN, run_unittest, import_module import unittest -import os, re +import os, re, itertools mmap = import_module('mmap') @@ -351,9 +351,21 @@ class MmapTests(unittest.TestCase): self.assertEqual(m[:], expected) m.close() - # should not crash - m = mmap.mmap(-1, 1) - self.assertRaises(ValueError, m.move, 1, 1, -1) + # segfault test (Issue 5387) + m = mmap.mmap(-1, 100) + offsets = [-100, -1, 0, 1, 100] + for source, dest, size in itertools.product(offsets, offsets, offsets): + try: + m.move(source, dest, size) + except ValueError: + pass + self.assertRaises(ValueError, m.move, -1, -1, -1) + self.assertRaises(ValueError, m.move, -1, -1, 0) + self.assertRaises(ValueError, m.move, -1, 0, -1) + self.assertRaises(ValueError, m.move, 0, -1, -1) + self.assertRaises(ValueError, m.move, -1, 0, 0) + self.assertRaises(ValueError, m.move, 0, -1, 0) + self.assertRaises(ValueError, m.move, 0, 0, -1) m.close() def test_anonymous(self): |