From ced1056925420a67a5cce86287122429700ad52e Mon Sep 17 00:00:00 2001 From: Nadeem Vawda Date: Sat, 7 May 2011 13:01:50 +0200 Subject: [PATCH] Issue #11277: Add tests for mmap crash when using large sparse files on OS X. Also, reduce code duplication in LargeMmapTests. Original patch by Steffen Daode Nurpmeso. --- Lib/test/test_mmap.py | 60 ++++++++++++++++++++++++------------------- 1 file changed, 34 insertions(+), 26 deletions(-) diff --git a/Lib/test/test_mmap.py b/Lib/test/test_mmap.py index 7c51085a99..fbc34ed789 100644 --- a/Lib/test/test_mmap.py +++ b/Lib/test/test_mmap.py @@ -1,4 +1,5 @@ -from test.support import TESTFN, run_unittest, import_module, unlink, requires +from test.support import (TESTFN, run_unittest, import_module, unlink, + requires, _2G, _4G) import unittest import os, re, itertools, socket, sys @@ -653,28 +654,20 @@ class LargeMmapTests(unittest.TestCase): def tearDown(self): unlink(TESTFN) - def _working_largefile(self): - # Only run if the current filesystem supports large files. - f = open(TESTFN, 'wb', buffering=0) - try: - f.seek(0x80000001) - f.write(b'x') - f.flush() - except (IOError, OverflowError): - raise unittest.SkipTest("filesystem does not have largefile support") - finally: - f.close() - unlink(TESTFN) - - def test_large_offset(self): + def _create_test_file(self, num_zeroes, tail): if sys.platform[:3] == 'win' or sys.platform == 'darwin': requires('largefile', 'test requires %s bytes and a long time to run' % str(0x180000000)) - self._working_largefile() with open(TESTFN, 'wb') as f: - f.seek(0x14FFFFFFF) - f.write(b" ") + try: + f.seek(num_zeroes) + f.write(tail) + f.flush() + except (IOError, OverflowError): + raise unittest.SkipTest("filesystem does not have largefile support") + def test_large_offset(self): + self._create_test_file(0x14FFFFFFF, b" ") with open(TESTFN, 'rb') as f: m = mmap.mmap(f.fileno(), 0, offset=0x140000000, access=mmap.ACCESS_READ) try: @@ -683,14 +676,7 @@ class LargeMmapTests(unittest.TestCase): m.close() def test_large_filesize(self): - if sys.platform[:3] == 'win' or sys.platform == 'darwin': - requires('largefile', - 'test requires %s bytes and a long time to run' % str(0x180000000)) - self._working_largefile() - with open(TESTFN, 'wb') as f: - f.seek(0x17FFFFFFF) - f.write(b" ") - + self._create_test_file(0x17FFFFFFF, b" ") with open(TESTFN, 'rb') as f: m = mmap.mmap(f.fileno(), 0x10000, access=mmap.ACCESS_READ) try: @@ -698,6 +684,28 @@ class LargeMmapTests(unittest.TestCase): finally: m.close() + # Issue 11277: mmap() with large (~4GB) sparse files crashes on OS X. + + def _test_around_boundary(self, boundary): + tail = b' DEARdear ' + start = boundary - len(tail) // 2 + end = start + len(tail) + self._create_test_file(start, tail) + with open(TESTFN, 'rb') as f: + m = mmap.mmap(f.fileno(), 0, access=mmap.ACCESS_READ) + try: + self.assertEqual(m[start:end], tail) + finally: + m.close() + + @unittest.skipUnless(sys.maxsize > _4G, "test cannot run on 32-bit systems") + def test_around_2GB(self): + self._test_around_boundary(_2G) + + @unittest.skipUnless(sys.maxsize > _4G, "test cannot run on 32-bit systems") + def test_around_4GB(self): + self._test_around_boundary(_4G) + def test_main(): run_unittest(MmapTests, LargeMmapTests) -- 2.40.0