diff options
author | Raymond Hettinger <python@rcn.com> | 2014-06-25 04:36:58 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2014-06-25 04:36:58 (GMT) |
commit | 97d3555029b02fa4b432c1a1259b64aaa31e4e3e (patch) | |
tree | b986e1e25c2184d7c53b6cdb16e30487c3a7c733 /Lib | |
parent | ca5c7153de0e14052483676b2cdf6791f1eeb7d2 (diff) | |
download | cpython-97d3555029b02fa4b432c1a1259b64aaa31e4e3e.zip cpython-97d3555029b02fa4b432c1a1259b64aaa31e4e3e.tar.gz cpython-97d3555029b02fa4b432c1a1259b64aaa31e4e3e.tar.bz2 |
Issue #19145: Fix handling of negative values for a "times" keyword argument to itertools.repeat()>
(Patch contributed by Vajrasky Kok.)
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/test_itertools.py | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_itertools.py b/Lib/test/test_itertools.py index 70517f0..fea6816 100644 --- a/Lib/test/test_itertools.py +++ b/Lib/test/test_itertools.py @@ -967,6 +967,12 @@ class TestBasicOps(unittest.TestCase): self.assertEqual(take(2, copy.deepcopy(c)), list('a' * 2)) self.pickletest(repeat(object='a', times=10)) + def test_repeat_with_negative_times(self): + self.assertEqual(repr(repeat('a', -1)), "repeat('a', 0)") + self.assertEqual(repr(repeat('a', -2)), "repeat('a', 0)") + self.assertEqual(repr(repeat('a', times=-1)), "repeat('a', 0)") + self.assertEqual(repr(repeat('a', times=-2)), "repeat('a', 0)") + def test_map(self): self.assertEqual(list(map(operator.pow, range(3), range(1,7))), [0**1, 1**2, 2**3]) @@ -1741,8 +1747,15 @@ class LengthTransparency(unittest.TestCase): def test_repeat(self): self.assertEqual(operator.length_hint(repeat(None, 50)), 50) + self.assertEqual(operator.length_hint(repeat(None, 0)), 0) self.assertEqual(operator.length_hint(repeat(None), 12), 12) + def test_repeat_with_negative_times(self): + self.assertEqual(operator.length_hint(repeat(None, -1)), 0) + self.assertEqual(operator.length_hint(repeat(None, -2)), 0) + self.assertEqual(operator.length_hint(repeat(None, times=-1)), 0) + self.assertEqual(operator.length_hint(repeat(None, times=-2)), 0) + class RegressionTests(unittest.TestCase): def test_sf_793826(self): |