summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorMark Dickinson <dickinsm@gmail.com>2010-01-29 17:11:39 (GMT)
committerMark Dickinson <dickinsm@gmail.com>2010-01-29 17:11:39 (GMT)
commit36ecd676eac6c9d7ace41a1ff35124912371e91d (patch)
tree4b0feee8c71c1921b339e69a57f72dce9a1ba857 /Lib
parentb5d7400e8a62ebedb8575cca8cd777e29c230e91 (diff)
downloadcpython-36ecd676eac6c9d7ace41a1ff35124912371e91d.zip
cpython-36ecd676eac6c9d7ace41a1ff35124912371e91d.tar.gz
cpython-36ecd676eac6c9d7ace41a1ff35124912371e91d.tar.bz2
Issue #7788: Fix a crash produced by deleting a list slice with huge
step value. Patch by Marcin Bachry.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/list_tests.py3
-rwxr-xr-xLib/test/test_array.py3
-rw-r--r--Lib/test/test_bytes.py2
3 files changed, 7 insertions, 1 deletions
diff --git a/Lib/test/list_tests.py b/Lib/test/list_tests.py
index c9aa316..8dd6de6 100644
--- a/Lib/test/list_tests.py
+++ b/Lib/test/list_tests.py
@@ -519,6 +519,9 @@ class CommonTest(seq_tests.CommonTest):
a = self.type2test(range(10))
a[::2] = tuple(range(5))
self.assertEqual(a, self.type2test([0, 1, 1, 3, 2, 5, 3, 7, 4, 9]))
+ # test issue7788
+ a = self.type2test(range(10))
+ del a[9::1<<333]
def test_constructor_exception_handling(self):
# Bug #1242657
diff --git a/Lib/test/test_array.py b/Lib/test/test_array.py
index dfd0fa4..9b289ab 100755
--- a/Lib/test/test_array.py
+++ b/Lib/test/test_array.py
@@ -882,6 +882,9 @@ class NumberTest(BaseTest):
a = array.array(self.typecode, range(10))
del a[::1000]
self.assertEqual(a, array.array(self.typecode, [1,2,3,4,5,6,7,8,9]))
+ # test issue7788
+ a = array.array(self.typecode, range(10))
+ del a[9::1<<333]
def test_assignment(self):
a = array.array(self.typecode, range(10))
diff --git a/Lib/test/test_bytes.py b/Lib/test/test_bytes.py
index aab51da..70cab1c 100644
--- a/Lib/test/test_bytes.py
+++ b/Lib/test/test_bytes.py
@@ -565,7 +565,7 @@ class ByteArrayTest(BaseBytesTest):
self.assertEqual(b, bytearray([0, 1, 2, 42, 42, 42, 3, 4, 5, 6, 7, 8, 9]))
def test_extended_set_del_slice(self):
- indices = (0, None, 1, 3, 19, 300, -1, -2, -31, -300)
+ indices = (0, None, 1, 3, 19, 300, 1<<333, -1, -2, -31, -300)
for start in indices:
for stop in indices:
# Skip invalid step 0