diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-18 21:16:02 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-18 21:16:02 (GMT) |
commit | 739e1790f8576543b4058cc60a993be643367c91 (patch) | |
tree | e29761d148c9b556a420b1a0d2de3747744b0706 /Lib/test/test_iter.py | |
parent | 99f57942e050d03d14f44b1755dd81478e7cddfb (diff) | |
download | cpython-739e1790f8576543b4058cc60a993be643367c91.zip cpython-739e1790f8576543b4058cc60a993be643367c91.tar.gz cpython-739e1790f8576543b4058cc60a993be643367c91.tar.bz2 |
#7782: merge with 3.3.
Diffstat (limited to 'Lib/test/test_iter.py')
-rw-r--r-- | Lib/test/test_iter.py | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/Lib/test/test_iter.py b/Lib/test/test_iter.py index b2f3e65..43f8e15 100644 --- a/Lib/test/test_iter.py +++ b/Lib/test/test_iter.py @@ -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) |