]> granicus.if.org Git - python/commitdiff
Issue #13873: Fix crash in test_zlib when running on a small (<4GB) tmpfs.
authorNadeem Vawda <nadeem.vawda@gmail.com>
Sun, 26 Feb 2012 22:42:58 +0000 (00:42 +0200)
committerNadeem Vawda <nadeem.vawda@gmail.com>
Sun, 26 Feb 2012 22:42:58 +0000 (00:42 +0200)
Lib/test/test_zlib.py

index dffa2ca0da97b02ca6d5ec20539ec0eed793d4d7..60081e241c6bb15e862d3a03e87ae103a1484868 100644 (file)
@@ -66,24 +66,11 @@ class ChecksumTestCase(unittest.TestCase):
 # Issue #10276 - check that inputs >=4GB are handled correctly.
 class ChecksumBigBufferTestCase(unittest.TestCase):
 
-    def setUp(self):
-        with open(support.TESTFN, "wb+") as f:
-            f.seek(_4G)
-            f.write(b"asdf")
-            f.flush()
-            self.mapping = mmap.mmap(f.fileno(), 0, access=mmap.ACCESS_READ)
-
-    def tearDown(self):
-        self.mapping.close()
-        support.unlink(support.TESTFN)
-
-    @unittest.skipUnless(mmap, "mmap() is not available.")
-    @unittest.skipUnless(sys.maxsize > _4G, "Can't run on a 32-bit system.")
-    @unittest.skipUnless(support.is_resource_enabled("largefile"),
-                         "May use lots of disk space.")
-    def test_big_buffer(self):
-        self.assertEqual(zlib.crc32(self.mapping), 3058686908)
-        self.assertEqual(zlib.adler32(self.mapping), 82837919)
+    @bigmemtest(size=_4G + 4, memuse=1, dry_run=False)
+    def test_big_buffer(self, size):
+        data = b"nyan" * (_1G + 1)
+        self.assertEqual(zlib.crc32(data), 1044521549)
+        self.assertEqual(zlib.adler32(data), 2256789997)
 
 
 class ExceptionTestCase(unittest.TestCase):