diff options
author | Benjamin Peterson <benjamin@python.org> | 2008-10-10 22:20:52 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2008-10-10 22:20:52 (GMT) |
commit | bcd8ac396426f4bf649266aec5bbcf46f851a188 (patch) | |
tree | 940c3ef58d3ce33c95c65f51c3db80166f19606d /Lib/test/test_array.py | |
parent | cf8016a8d6b3fed550ed961ffd957ab3d19f04da (diff) | |
download | cpython-bcd8ac396426f4bf649266aec5bbcf46f851a188.zip cpython-bcd8ac396426f4bf649266aec5bbcf46f851a188.tar.gz cpython-bcd8ac396426f4bf649266aec5bbcf46f851a188.tar.bz2 |
Merged revisions 66703,66708 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r66703 | gregory.p.smith | 2008-09-30 15:41:13 -0500 (Tue, 30 Sep 2008) | 6 lines
Works around issue3863: freebsd4/5/6 and os2emx are known to have OS bugs when
calling fork() from a child thread. This disables that unit test (with a note
printed to stderr) on those platforms.
A caveat about buggy platforms is added to the os.fork documentation.
........
r66708 | andrew.macintyre | 2008-09-30 22:25:25 -0500 (Tue, 30 Sep 2008) | 9 lines
fix for issue 3862: test_array fails FreeBSD 7 amd64
FreeBSD 7's underlying malloc() is behaves differently to earlier versions
and seriously overcommits available memory on amd64. This may affect
other 64bit platforms in some circumstances, so the scale of the
problematic test is wound back.
Patch by Mark Dickinson, reviewed by Martin von Loewis.
........
Diffstat (limited to 'Lib/test/test_array.py')
-rwxr-xr-x | Lib/test/test_array.py | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/Lib/test/test_array.py b/Lib/test/test_array.py index 5b6b9f2..ff9026a 100755 --- a/Lib/test/test_array.py +++ b/Lib/test/test_array.py @@ -964,20 +964,21 @@ class DoubleTest(FPTest): minitemsize = 8 def test_alloc_overflow(self): + from sys import maxsize a = array.array('d', [-1]*65536) try: - a *= 65536 + a *= maxsize//65536 + 1 except MemoryError: pass else: - self.fail("a *= 2**16 didn't raise MemoryError") + self.fail("Array of size > maxsize created - MemoryError expected") b = array.array('d', [ 2.71828183, 3.14159265, -1]) try: - b * 1431655766 + b * (maxsize//3 + 1) except MemoryError: pass else: - self.fail("a * 1431655766 didn't raise MemoryError") + self.fail("Array of size > maxsize created - MemoryError expected") tests.append(DoubleTest) |