aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/Lib/test/test_bigaddrspace.py
diff options
context:
space:
mode:
Diffstat (limited to 'Lib/test/test_bigaddrspace.py')
-rw-r--r--Lib/test/test_bigaddrspace.py103
1 files changed, 79 insertions, 24 deletions
diff --git a/Lib/test/test_bigaddrspace.py b/Lib/test/test_bigaddrspace.py
index db19a53c709..b8c59d41d39 100644
--- a/Lib/test/test_bigaddrspace.py
+++ b/Lib/test/test_bigaddrspace.py
@@ -1,46 +1,101 @@
-from test import test_support
-from test.test_support import bigaddrspacetest, MAX_Py_ssize_t
+"""
+These tests are meant to exercise that requests to create objects bigger
+than what the address space allows are properly met with an OverflowError
+(rather than crash weirdly).
+
+Primarily, this means 32-bit builds with at least 2 GB of available memory.
+You need to pass the -M option to regrtest (e.g. "-M 2.1G") for tests to
+be enabled.
+"""
+
+from test import support
+from test.support import bigaddrspacetest, MAX_Py_ssize_t
import unittest
import operator
import sys
-class StrTest(unittest.TestCase):
+class BytesTest(unittest.TestCase):
@bigaddrspacetest
def test_concat(self):
- s1 = 'x' * MAX_Py_ssize_t
- self.assertRaises(OverflowError, operator.add, s1, '?')
+ # Allocate a bytestring that's near the maximum size allowed by
+ # the address space, and then try to build a new, larger one through
+ # concatenation.
+ try:
+ x = b"x" * (MAX_Py_ssize_t - 128)
+ self.assertRaises(OverflowError, operator.add, x, b"x" * 128)
+ finally:
+ x = None
@bigaddrspacetest
def test_optimized_concat(self):
- x = 'x' * MAX_Py_ssize_t
try:
- x = x + '?' # this statement uses a fast path in ceval.c
- except OverflowError:
- pass
- else:
- self.fail("should have raised OverflowError")
+ x = b"x" * (MAX_Py_ssize_t - 128)
+
+ with self.assertRaises(OverflowError) as cm:
+ # this statement used a fast path in ceval.c
+ x = x + b"x" * 128
+
+ with self.assertRaises(OverflowError) as cm:
+ # this statement used a fast path in ceval.c
+ x += b"x" * 128
+ finally:
+ x = None
+
+ @bigaddrspacetest
+ def test_repeat(self):
+ try:
+ x = b"x" * (MAX_Py_ssize_t - 128)
+ self.assertRaises(OverflowError, operator.mul, x, 128)
+ finally:
+ x = None
+
+
+class StrTest(unittest.TestCase):
+
+ unicodesize = 2 if sys.maxunicode < 65536 else 4
+
+ @bigaddrspacetest
+ def test_concat(self):
+ try:
+ # Create a string that would fill almost the address space
+ x = "x" * int(MAX_Py_ssize_t // (1.1 * self.unicodesize))
+ # Unicode objects trigger MemoryError in case an operation that's
+ # going to cause a size overflow is executed
+ self.assertRaises(MemoryError, operator.add, x, x)
+ finally:
+ x = None
+
+ @bigaddrspacetest
+ def test_optimized_concat(self):
try:
- x += '?' # this statement uses a fast path in ceval.c
- except OverflowError:
- pass
- else:
- self.fail("should have raised OverflowError")
- self.assertEqual(len(x), MAX_Py_ssize_t)
+ x = "x" * int(MAX_Py_ssize_t // (1.1 * self.unicodesize))
+
+ with self.assertRaises(MemoryError) as cm:
+ # this statement uses a fast path in ceval.c
+ x = x + x
- ### the following test is pending a patch
- # (http://mail.python.org/pipermail/python-dev/2006-July/067774.html)
- #@bigaddrspacetest
- #def test_repeat(self):
- # self.assertRaises(OverflowError, operator.mul, 'x', MAX_Py_ssize_t + 1)
+ with self.assertRaises(MemoryError) as cm:
+ # this statement uses a fast path in ceval.c
+ x += x
+ finally:
+ x = None
+
+ @bigaddrspacetest
+ def test_repeat(self):
+ try:
+ x = "x" * int(MAX_Py_ssize_t // (1.1 * self.unicodesize))
+ self.assertRaises(MemoryError, operator.mul, x, 2)
+ finally:
+ x = None
def test_main():
- test_support.run_unittest(StrTest)
+ support.run_unittest(BytesTest, StrTest)
if __name__ == '__main__':
if len(sys.argv) > 1:
- test_support.set_memlimit(sys.argv[1])
+ support.set_memlimit(sys.argv[1])
test_main()