]> granicus.if.org Git - python/commitdiff
#7782: merge with 3.3.
authorEzio Melotti <ezio.melotti@gmail.com>
Sun, 18 Nov 2012 21:16:02 +0000 (23:16 +0200)
committerEzio Melotti <ezio.melotti@gmail.com>
Sun, 18 Nov 2012 21:16:02 +0000 (23:16 +0200)
Lib/test/test_iter.py

index b2f3e652325f38aa29831814c5896039f24c73bf..43f8e1588bd47df545ce07834084afc3d9efe034 100644 (file)
@@ -903,6 +903,21 @@ class TestCase(unittest.TestCase):
         except TypeError:
             pass
 
+    def test_extending_list_with_iterator_does_not_segfault(self):
+        # The code to extend a list with an iterator has a fair
+        # amount of nontrivial logic in terms of guessing how
+        # much memory to allocate in advance, "stealing" refs,
+        # and then shrinking at the end.  This is a basic smoke
+        # test for that scenario.
+        def gen():
+            for i in range(500):
+                yield i
+        lst = [0] * 500
+        for i in range(240):
+            lst.pop(0)
+        lst.extend(gen())
+        self.assertEqual(len(lst), 760)
+
 
 def test_main():
     run_unittest(TestCase)