summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_zlib.py
diff options
context:
space:
mode:
authorNadeem Vawda <nadeem.vawda@gmail.com>2012-02-26 22:42:58 (GMT)
committerNadeem Vawda <nadeem.vawda@gmail.com>2012-02-26 22:42:58 (GMT)
commit05a4dd83af7c9b7feae88abc6b8be21924e8a4a0 (patch)
tree6c25bb1ae089d8f37be4e193749e8b4c9efdbf4d /Lib/test/test_zlib.py
parent3bbdc8e822b483fdfb66e0422e94630af10d1b80 (diff)
downloadcpython-05a4dd83af7c9b7feae88abc6b8be21924e8a4a0.zip
cpython-05a4dd83af7c9b7feae88abc6b8be21924e8a4a0.tar.gz
cpython-05a4dd83af7c9b7feae88abc6b8be21924e8a4a0.tar.bz2
Issue #13873: Fix crash in test_zlib when running on a small (<4GB) tmpfs.
Diffstat (limited to 'Lib/test/test_zlib.py')
-rw-r--r--Lib/test/test_zlib.py23
1 files changed, 5 insertions, 18 deletions
diff --git a/Lib/test/test_zlib.py b/Lib/test/test_zlib.py
index dffa2ca..60081e2 100644
--- a/Lib/test/test_zlib.py
+++ b/Lib/test/test_zlib.py
@@ -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):