summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_mmap.py
diff options
context:
space:
mode:
authorHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2009-03-31 20:14:04 (GMT)
committerHirokazu Yamamoto <ocean-city@m2.ccsnet.ne.jp>2009-03-31 20:14:04 (GMT)
commit1d7d5325be5c766c3446dcf0fce4ebce73d83fa7 (patch)
tree60b65d642fc02ece812c0f6c069d259a19014c64 /Lib/test/test_mmap.py
parent65ff00559a1192bccb23b5af9abb54db361d9124 (diff)
downloadcpython-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.py20
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):