PageRenderTime 58ms CodeModel.GetById 17ms RepoModel.GetById 1ms app.codeStats 0ms

/External.LCA_RESTRICTED/Languages/CPython/27/Lib/test/test_itertools.py

http://github.com/IronLanguages/main
Python | 1650 lines | 1617 code | 25 blank | 8 comment | 13 complexity | 946ff5e12890f7b13d563916eff80943 MD5 | raw file
Possible License(s): CPL-1.0, BSD-3-Clause, ISC, GPL-2.0, MPL-2.0-no-copyleft-exception

Large files files are truncated, but you can click here to view the full file

  1. import unittest
  2. from test import test_support
  3. from itertools import *
  4. from weakref import proxy
  5. from decimal import Decimal
  6. from fractions import Fraction
  7. import sys
  8. import operator
  9. import random
  10. import copy
  11. import pickle
  12. from functools import reduce
  13. maxsize = test_support.MAX_Py_ssize_t
  14. minsize = -maxsize-1
  15. def onearg(x):
  16. 'Test function of one argument'
  17. return 2*x
  18. def errfunc(*args):
  19. 'Test function that raises an error'
  20. raise ValueError
  21. def gen3():
  22. 'Non-restartable source sequence'
  23. for i in (0, 1, 2):
  24. yield i
  25. def isEven(x):
  26. 'Test predicate'
  27. return x%2==0
  28. def isOdd(x):
  29. 'Test predicate'
  30. return x%2==1
  31. class StopNow:
  32. 'Class emulating an empty iterable.'
  33. def __iter__(self):
  34. return self
  35. def next(self):
  36. raise StopIteration
  37. def take(n, seq):
  38. 'Convenience function for partially consuming a long of infinite iterable'
  39. return list(islice(seq, n))
  40. def prod(iterable):
  41. return reduce(operator.mul, iterable, 1)
  42. def fact(n):
  43. 'Factorial'
  44. return prod(range(1, n+1))
  45. class TestBasicOps(unittest.TestCase):
  46. def test_chain(self):
  47. def chain2(*iterables):
  48. 'Pure python version in the docs'
  49. for it in iterables:
  50. for element in it:
  51. yield element
  52. for c in (chain, chain2):
  53. self.assertEqual(list(c('abc', 'def')), list('abcdef'))
  54. self.assertEqual(list(c('abc')), list('abc'))
  55. self.assertEqual(list(c('')), [])
  56. self.assertEqual(take(4, c('abc', 'def')), list('abcd'))
  57. self.assertRaises(TypeError, list,c(2, 3))
  58. def test_chain_from_iterable(self):
  59. self.assertEqual(list(chain.from_iterable(['abc', 'def'])), list('abcdef'))
  60. self.assertEqual(list(chain.from_iterable(['abc'])), list('abc'))
  61. self.assertEqual(list(chain.from_iterable([''])), [])
  62. self.assertEqual(take(4, chain.from_iterable(['abc', 'def'])), list('abcd'))
  63. self.assertRaises(TypeError, list, chain.from_iterable([2, 3]))
  64. def test_combinations(self):
  65. self.assertRaises(TypeError, combinations, 'abc') # missing r argument
  66. self.assertRaises(TypeError, combinations, 'abc', 2, 1) # too many arguments
  67. self.assertRaises(TypeError, combinations, None) # pool is not iterable
  68. self.assertRaises(ValueError, combinations, 'abc', -2) # r is negative
  69. self.assertEqual(list(combinations('abc', 32)), []) # r > n
  70. self.assertEqual(list(combinations(range(4), 3)),
  71. [(0,1,2), (0,1,3), (0,2,3), (1,2,3)])
  72. def combinations1(iterable, r):
  73. 'Pure python version shown in the docs'
  74. pool = tuple(iterable)
  75. n = len(pool)
  76. if r > n:
  77. return
  78. indices = range(r)
  79. yield tuple(pool[i] for i in indices)
  80. while 1:
  81. for i in reversed(range(r)):
  82. if indices[i] != i + n - r:
  83. break
  84. else:
  85. return
  86. indices[i] += 1
  87. for j in range(i+1, r):
  88. indices[j] = indices[j-1] + 1
  89. yield tuple(pool[i] for i in indices)
  90. def combinations2(iterable, r):
  91. 'Pure python version shown in the docs'
  92. pool = tuple(iterable)
  93. n = len(pool)
  94. for indices in permutations(range(n), r):
  95. if sorted(indices) == list(indices):
  96. yield tuple(pool[i] for i in indices)
  97. def combinations3(iterable, r):
  98. 'Pure python version from cwr()'
  99. pool = tuple(iterable)
  100. n = len(pool)
  101. for indices in combinations_with_replacement(range(n), r):
  102. if len(set(indices)) == r:
  103. yield tuple(pool[i] for i in indices)
  104. for n in range(7):
  105. values = [5*x-12 for x in range(n)]
  106. for r in range(n+2):
  107. result = list(combinations(values, r))
  108. self.assertEqual(len(result), 0 if r>n else fact(n) // fact(r) // fact(n-r)) # right number of combs
  109. self.assertEqual(len(result), len(set(result))) # no repeats
  110. self.assertEqual(result, sorted(result)) # lexicographic order
  111. for c in result:
  112. self.assertEqual(len(c), r) # r-length combinations
  113. self.assertEqual(len(set(c)), r) # no duplicate elements
  114. self.assertEqual(list(c), sorted(c)) # keep original ordering
  115. self.assertTrue(all(e in values for e in c)) # elements taken from input iterable
  116. self.assertEqual(list(c),
  117. [e for e in values if e in c]) # comb is a subsequence of the input iterable
  118. self.assertEqual(result, list(combinations1(values, r))) # matches first pure python version
  119. self.assertEqual(result, list(combinations2(values, r))) # matches second pure python version
  120. self.assertEqual(result, list(combinations3(values, r))) # matches second pure python version
  121. # Test implementation detail: tuple re-use
  122. self.assertEqual(len(set(map(id, combinations('abcde', 3)))), 1)
  123. self.assertNotEqual(len(set(map(id, list(combinations('abcde', 3))))), 1)
  124. def test_combinations_with_replacement(self):
  125. cwr = combinations_with_replacement
  126. self.assertRaises(TypeError, cwr, 'abc') # missing r argument
  127. self.assertRaises(TypeError, cwr, 'abc', 2, 1) # too many arguments
  128. self.assertRaises(TypeError, cwr, None) # pool is not iterable
  129. self.assertRaises(ValueError, cwr, 'abc', -2) # r is negative
  130. self.assertEqual(list(cwr('ABC', 2)),
  131. [('A','A'), ('A','B'), ('A','C'), ('B','B'), ('B','C'), ('C','C')])
  132. def cwr1(iterable, r):
  133. 'Pure python version shown in the docs'
  134. # number items returned: (n+r-1)! / r! / (n-1)! when n>0
  135. pool = tuple(iterable)
  136. n = len(pool)
  137. if not n and r:
  138. return
  139. indices = [0] * r
  140. yield tuple(pool[i] for i in indices)
  141. while 1:
  142. for i in reversed(range(r)):
  143. if indices[i] != n - 1:
  144. break
  145. else:
  146. return
  147. indices[i:] = [indices[i] + 1] * (r - i)
  148. yield tuple(pool[i] for i in indices)
  149. def cwr2(iterable, r):
  150. 'Pure python version shown in the docs'
  151. pool = tuple(iterable)
  152. n = len(pool)
  153. for indices in product(range(n), repeat=r):
  154. if sorted(indices) == list(indices):
  155. yield tuple(pool[i] for i in indices)
  156. def numcombs(n, r):
  157. if not n:
  158. return 0 if r else 1
  159. return fact(n+r-1) // fact(r) // fact(n-1)
  160. for n in range(7):
  161. values = [5*x-12 for x in range(n)]
  162. for r in range(n+2):
  163. result = list(cwr(values, r))
  164. self.assertEqual(len(result), numcombs(n, r)) # right number of combs
  165. self.assertEqual(len(result), len(set(result))) # no repeats
  166. self.assertEqual(result, sorted(result)) # lexicographic order
  167. regular_combs = list(combinations(values, r)) # compare to combs without replacement
  168. if n == 0 or r <= 1:
  169. self.assertEqual(result, regular_combs) # cases that should be identical
  170. else:
  171. self.assertTrue(set(result) >= set(regular_combs)) # rest should be supersets of regular combs
  172. for c in result:
  173. self.assertEqual(len(c), r) # r-length combinations
  174. noruns = [k for k,v in groupby(c)] # combo without consecutive repeats
  175. self.assertEqual(len(noruns), len(set(noruns))) # no repeats other than consecutive
  176. self.assertEqual(list(c), sorted(c)) # keep original ordering
  177. self.assertTrue(all(e in values for e in c)) # elements taken from input iterable
  178. self.assertEqual(noruns,
  179. [e for e in values if e in c]) # comb is a subsequence of the input iterable
  180. self.assertEqual(result, list(cwr1(values, r))) # matches first pure python version
  181. self.assertEqual(result, list(cwr2(values, r))) # matches second pure python version
  182. # Test implementation detail: tuple re-use
  183. self.assertEqual(len(set(map(id, cwr('abcde', 3)))), 1)
  184. self.assertNotEqual(len(set(map(id, list(cwr('abcde', 3))))), 1)
  185. def test_permutations(self):
  186. self.assertRaises(TypeError, permutations) # too few arguments
  187. self.assertRaises(TypeError, permutations, 'abc', 2, 1) # too many arguments
  188. self.assertRaises(TypeError, permutations, None) # pool is not iterable
  189. self.assertRaises(ValueError, permutations, 'abc', -2) # r is negative
  190. self.assertEqual(list(permutations('abc', 32)), []) # r > n
  191. self.assertRaises(TypeError, permutations, 'abc', 's') # r is not an int or None
  192. self.assertEqual(list(permutations(range(3), 2)),
  193. [(0,1), (0,2), (1,0), (1,2), (2,0), (2,1)])
  194. def permutations1(iterable, r=None):
  195. 'Pure python version shown in the docs'
  196. pool = tuple(iterable)
  197. n = len(pool)
  198. r = n if r is None else r
  199. if r > n:
  200. return
  201. indices = range(n)
  202. cycles = range(n, n-r, -1)
  203. yield tuple(pool[i] for i in indices[:r])
  204. while n:
  205. for i in reversed(range(r)):
  206. cycles[i] -= 1
  207. if cycles[i] == 0:
  208. indices[i:] = indices[i+1:] + indices[i:i+1]
  209. cycles[i] = n - i
  210. else:
  211. j = cycles[i]
  212. indices[i], indices[-j] = indices[-j], indices[i]
  213. yield tuple(pool[i] for i in indices[:r])
  214. break
  215. else:
  216. return
  217. def permutations2(iterable, r=None):
  218. 'Pure python version shown in the docs'
  219. pool = tuple(iterable)
  220. n = len(pool)
  221. r = n if r is None else r
  222. for indices in product(range(n), repeat=r):
  223. if len(set(indices)) == r:
  224. yield tuple(pool[i] for i in indices)
  225. for n in range(7):
  226. values = [5*x-12 for x in range(n)]
  227. for r in range(n+2):
  228. result = list(permutations(values, r))
  229. self.assertEqual(len(result), 0 if r>n else fact(n) // fact(n-r)) # right number of perms
  230. self.assertEqual(len(result), len(set(result))) # no repeats
  231. self.assertEqual(result, sorted(result)) # lexicographic order
  232. for p in result:
  233. self.assertEqual(len(p), r) # r-length permutations
  234. self.assertEqual(len(set(p)), r) # no duplicate elements
  235. self.assertTrue(all(e in values for e in p)) # elements taken from input iterable
  236. self.assertEqual(result, list(permutations1(values, r))) # matches first pure python version
  237. self.assertEqual(result, list(permutations2(values, r))) # matches second pure python version
  238. if r == n:
  239. self.assertEqual(result, list(permutations(values, None))) # test r as None
  240. self.assertEqual(result, list(permutations(values))) # test default r
  241. # Test implementation detail: tuple re-use
  242. self.assertEqual(len(set(map(id, permutations('abcde', 3)))), 1)
  243. self.assertNotEqual(len(set(map(id, list(permutations('abcde', 3))))), 1)
  244. def test_combinatorics(self):
  245. # Test relationships between product(), permutations(),
  246. # combinations() and combinations_with_replacement().
  247. for n in range(6):
  248. s = 'ABCDEFG'[:n]
  249. for r in range(8):
  250. prod = list(product(s, repeat=r))
  251. cwr = list(combinations_with_replacement(s, r))
  252. perm = list(permutations(s, r))
  253. comb = list(combinations(s, r))
  254. # Check size
  255. self.assertEqual(len(prod), n**r)
  256. self.assertEqual(len(cwr), (fact(n+r-1) // fact(r) // fact(n-1)) if n else (not r))
  257. self.assertEqual(len(perm), 0 if r>n else fact(n) // fact(n-r))
  258. self.assertEqual(len(comb), 0 if r>n else fact(n) // fact(r) // fact(n-r))
  259. # Check lexicographic order without repeated tuples
  260. self.assertEqual(prod, sorted(set(prod)))
  261. self.assertEqual(cwr, sorted(set(cwr)))
  262. self.assertEqual(perm, sorted(set(perm)))
  263. self.assertEqual(comb, sorted(set(comb)))
  264. # Check interrelationships
  265. self.assertEqual(cwr, [t for t in prod if sorted(t)==list(t)]) # cwr: prods which are sorted
  266. self.assertEqual(perm, [t for t in prod if len(set(t))==r]) # perm: prods with no dups
  267. self.assertEqual(comb, [t for t in perm if sorted(t)==list(t)]) # comb: perms that are sorted
  268. self.assertEqual(comb, [t for t in cwr if len(set(t))==r]) # comb: cwrs without dups
  269. self.assertEqual(comb, filter(set(cwr).__contains__, perm)) # comb: perm that is a cwr
  270. self.assertEqual(comb, filter(set(perm).__contains__, cwr)) # comb: cwr that is a perm
  271. self.assertEqual(comb, sorted(set(cwr) & set(perm))) # comb: both a cwr and a perm
  272. def test_compress(self):
  273. self.assertEqual(list(compress(data='ABCDEF', selectors=[1,0,1,0,1,1])), list('ACEF'))
  274. self.assertEqual(list(compress('ABCDEF', [1,0,1,0,1,1])), list('ACEF'))
  275. self.assertEqual(list(compress('ABCDEF', [0,0,0,0,0,0])), list(''))
  276. self.assertEqual(list(compress('ABCDEF', [1,1,1,1,1,1])), list('ABCDEF'))
  277. self.assertEqual(list(compress('ABCDEF', [1,0,1])), list('AC'))
  278. self.assertEqual(list(compress('ABC', [0,1,1,1,1,1])), list('BC'))
  279. n = 10000
  280. data = chain.from_iterable(repeat(range(6), n))
  281. selectors = chain.from_iterable(repeat((0, 1)))
  282. self.assertEqual(list(compress(data, selectors)), [1,3,5] * n)
  283. self.assertRaises(TypeError, compress, None, range(6)) # 1st arg not iterable
  284. self.assertRaises(TypeError, compress, range(6), None) # 2nd arg not iterable
  285. self.assertRaises(TypeError, compress, range(6)) # too few args
  286. self.assertRaises(TypeError, compress, range(6), None) # too many args
  287. def test_count(self):
  288. self.assertEqual(zip('abc',count()), [('a', 0), ('b', 1), ('c', 2)])
  289. self.assertEqual(zip('abc',count(3)), [('a', 3), ('b', 4), ('c', 5)])
  290. self.assertEqual(take(2, zip('abc',count(3))), [('a', 3), ('b', 4)])
  291. self.assertEqual(take(2, zip('abc',count(-1))), [('a', -1), ('b', 0)])
  292. self.assertEqual(take(2, zip('abc',count(-3))), [('a', -3), ('b', -2)])
  293. self.assertRaises(TypeError, count, 2, 3, 4)
  294. self.assertRaises(TypeError, count, 'a')
  295. self.assertEqual(list(islice(count(maxsize-5), 10)), range(maxsize-5, maxsize+5))
  296. self.assertEqual(list(islice(count(-maxsize-5), 10)), range(-maxsize-5, -maxsize+5))
  297. c = count(3)
  298. self.assertEqual(repr(c), 'count(3)')
  299. c.next()
  300. self.assertEqual(repr(c), 'count(4)')
  301. c = count(-9)
  302. self.assertEqual(repr(c), 'count(-9)')
  303. c.next()
  304. self.assertEqual(repr(count(10.25)), 'count(10.25)')
  305. self.assertEqual(c.next(), -8)
  306. for i in (-sys.maxint-5, -sys.maxint+5 ,-10, -1, 0, 10, sys.maxint-5, sys.maxint+5):
  307. # Test repr (ignoring the L in longs)
  308. r1 = repr(count(i)).replace('L', '')
  309. r2 = 'count(%r)'.__mod__(i).replace('L', '')
  310. self.assertEqual(r1, r2)
  311. # check copy, deepcopy, pickle
  312. for value in -3, 3, sys.maxint-5, sys.maxint+5:
  313. c = count(value)
  314. self.assertEqual(next(copy.copy(c)), value)
  315. self.assertEqual(next(copy.deepcopy(c)), value)
  316. self.assertEqual(next(pickle.loads(pickle.dumps(c))), value)
  317. def test_count_with_stride(self):
  318. self.assertEqual(zip('abc',count(2,3)), [('a', 2), ('b', 5), ('c', 8)])
  319. self.assertEqual(zip('abc',count(start=2,step=3)),
  320. [('a', 2), ('b', 5), ('c', 8)])
  321. self.assertEqual(zip('abc',count(step=-1)),
  322. [('a', 0), ('b', -1), ('c', -2)])
  323. self.assertEqual(zip('abc',count(2,0)), [('a', 2), ('b', 2), ('c', 2)])
  324. self.assertEqual(zip('abc',count(2,1)), [('a', 2), ('b', 3), ('c', 4)])
  325. self.assertEqual(take(20, count(maxsize-15, 3)), take(20, range(maxsize-15, maxsize+100, 3)))
  326. self.assertEqual(take(20, count(-maxsize-15, 3)), take(20, range(-maxsize-15,-maxsize+100, 3)))
  327. self.assertEqual(take(3, count(2, 3.25-4j)), [2, 5.25-4j, 8.5-8j])
  328. self.assertEqual(take(3, count(Decimal('1.1'), Decimal('.1'))),
  329. [Decimal('1.1'), Decimal('1.2'), Decimal('1.3')])
  330. self.assertEqual(take(3, count(Fraction(2,3), Fraction(1,7))),
  331. [Fraction(2,3), Fraction(17,21), Fraction(20,21)])
  332. self.assertEqual(repr(take(3, count(10, 2.5))), repr([10, 12.5, 15.0]))
  333. c = count(3, 5)
  334. self.assertEqual(repr(c), 'count(3, 5)')
  335. c.next()
  336. self.assertEqual(repr(c), 'count(8, 5)')
  337. c = count(-9, 0)
  338. self.assertEqual(repr(c), 'count(-9, 0)')
  339. c.next()
  340. self.assertEqual(repr(c), 'count(-9, 0)')
  341. c = count(-9, -3)
  342. self.assertEqual(repr(c), 'count(-9, -3)')
  343. c.next()
  344. self.assertEqual(repr(c), 'count(-12, -3)')
  345. self.assertEqual(repr(c), 'count(-12, -3)')
  346. self.assertEqual(repr(count(10.5, 1.25)), 'count(10.5, 1.25)')
  347. self.assertEqual(repr(count(10.5, 1)), 'count(10.5)') # suppress step=1 when it's an int
  348. self.assertEqual(repr(count(10.5, 1.00)), 'count(10.5, 1.0)') # do show float values lilke 1.0
  349. for i in (-sys.maxint-5, -sys.maxint+5 ,-10, -1, 0, 10, sys.maxint-5, sys.maxint+5):
  350. for j in (-sys.maxint-5, -sys.maxint+5 ,-10, -1, 0, 1, 10, sys.maxint-5, sys.maxint+5):
  351. # Test repr (ignoring the L in longs)
  352. r1 = repr(count(i, j)).replace('L', '')
  353. if j == 1:
  354. r2 = ('count(%r)' % i).replace('L', '')
  355. else:
  356. r2 = ('count(%r, %r)' % (i, j)).replace('L', '')
  357. self.assertEqual(r1, r2)
  358. def test_cycle(self):
  359. self.assertEqual(take(10, cycle('abc')), list('abcabcabca'))
  360. self.assertEqual(list(cycle('')), [])
  361. self.assertRaises(TypeError, cycle)
  362. self.assertRaises(TypeError, cycle, 5)
  363. self.assertEqual(list(islice(cycle(gen3()),10)), [0,1,2,0,1,2,0,1,2,0])
  364. def test_groupby(self):
  365. # Check whether it accepts arguments correctly
  366. self.assertEqual([], list(groupby([])))
  367. self.assertEqual([], list(groupby([], key=id)))
  368. self.assertRaises(TypeError, list, groupby('abc', []))
  369. self.assertRaises(TypeError, groupby, None)
  370. self.assertRaises(TypeError, groupby, 'abc', lambda x:x, 10)
  371. # Check normal input
  372. s = [(0, 10, 20), (0, 11,21), (0,12,21), (1,13,21), (1,14,22),
  373. (2,15,22), (3,16,23), (3,17,23)]
  374. dup = []
  375. for k, g in groupby(s, lambda r:r[0]):
  376. for elem in g:
  377. self.assertEqual(k, elem[0])
  378. dup.append(elem)
  379. self.assertEqual(s, dup)
  380. # Check nested case
  381. dup = []
  382. for k, g in groupby(s, lambda r:r[0]):
  383. for ik, ig in groupby(g, lambda r:r[2]):
  384. for elem in ig:
  385. self.assertEqual(k, elem[0])
  386. self.assertEqual(ik, elem[2])
  387. dup.append(elem)
  388. self.assertEqual(s, dup)
  389. # Check case where inner iterator is not used
  390. keys = [k for k, g in groupby(s, lambda r:r[0])]
  391. expectedkeys = set([r[0] for r in s])
  392. self.assertEqual(set(keys), expectedkeys)
  393. self.assertEqual(len(keys), len(expectedkeys))
  394. # Exercise pipes and filters style
  395. s = 'abracadabra'
  396. # sort s | uniq
  397. r = [k for k, g in groupby(sorted(s))]
  398. self.assertEqual(r, ['a', 'b', 'c', 'd', 'r'])
  399. # sort s | uniq -d
  400. r = [k for k, g in groupby(sorted(s)) if list(islice(g,1,2))]
  401. self.assertEqual(r, ['a', 'b', 'r'])
  402. # sort s | uniq -c
  403. r = [(len(list(g)), k) for k, g in groupby(sorted(s))]
  404. self.assertEqual(r, [(5, 'a'), (2, 'b'), (1, 'c'), (1, 'd'), (2, 'r')])
  405. # sort s | uniq -c | sort -rn | head -3
  406. r = sorted([(len(list(g)) , k) for k, g in groupby(sorted(s))], reverse=True)[:3]
  407. self.assertEqual(r, [(5, 'a'), (2, 'r'), (2, 'b')])
  408. # iter.next failure
  409. class ExpectedError(Exception):
  410. pass
  411. def delayed_raise(n=0):
  412. for i in range(n):
  413. yield 'yo'
  414. raise ExpectedError
  415. def gulp(iterable, keyp=None, func=list):
  416. return [func(g) for k, g in groupby(iterable, keyp)]
  417. # iter.next failure on outer object
  418. self.assertRaises(ExpectedError, gulp, delayed_raise(0))
  419. # iter.next failure on inner object
  420. self.assertRaises(ExpectedError, gulp, delayed_raise(1))
  421. # __cmp__ failure
  422. class DummyCmp:
  423. def __cmp__(self, dst):
  424. raise ExpectedError
  425. s = [DummyCmp(), DummyCmp(), None]
  426. # __cmp__ failure on outer object
  427. self.assertRaises(ExpectedError, gulp, s, func=id)
  428. # __cmp__ failure on inner object
  429. self.assertRaises(ExpectedError, gulp, s)
  430. # keyfunc failure
  431. def keyfunc(obj):
  432. if keyfunc.skip > 0:
  433. keyfunc.skip -= 1
  434. return obj
  435. else:
  436. raise ExpectedError
  437. # keyfunc failure on outer object
  438. keyfunc.skip = 0
  439. self.assertRaises(ExpectedError, gulp, [None], keyfunc)
  440. keyfunc.skip = 1
  441. self.assertRaises(ExpectedError, gulp, [None, None], keyfunc)
  442. def test_ifilter(self):
  443. self.assertEqual(list(ifilter(isEven, range(6))), [0,2,4])
  444. self.assertEqual(list(ifilter(None, [0,1,0,2,0])), [1,2])
  445. self.assertEqual(list(ifilter(bool, [0,1,0,2,0])), [1,2])
  446. self.assertEqual(take(4, ifilter(isEven, count())), [0,2,4,6])
  447. self.assertRaises(TypeError, ifilter)
  448. self.assertRaises(TypeError, ifilter, lambda x:x)
  449. self.assertRaises(TypeError, ifilter, lambda x:x, range(6), 7)
  450. self.assertRaises(TypeError, ifilter, isEven, 3)
  451. self.assertRaises(TypeError, ifilter(range(6), range(6)).next)
  452. def test_ifilterfalse(self):
  453. self.assertEqual(list(ifilterfalse(isEven, range(6))), [1,3,5])
  454. self.assertEqual(list(ifilterfalse(None, [0,1,0,2,0])), [0,0,0])
  455. self.assertEqual(list(ifilterfalse(bool, [0,1,0,2,0])), [0,0,0])
  456. self.assertEqual(take(4, ifilterfalse(isEven, count())), [1,3,5,7])
  457. self.assertRaises(TypeError, ifilterfalse)
  458. self.assertRaises(TypeError, ifilterfalse, lambda x:x)
  459. self.assertRaises(TypeError, ifilterfalse, lambda x:x, range(6), 7)
  460. self.assertRaises(TypeError, ifilterfalse, isEven, 3)
  461. self.assertRaises(TypeError, ifilterfalse(range(6), range(6)).next)
  462. def test_izip(self):
  463. ans = [(x,y) for x, y in izip('abc',count())]
  464. self.assertEqual(ans, [('a', 0), ('b', 1), ('c', 2)])
  465. self.assertEqual(list(izip('abc', range(6))), zip('abc', range(6)))
  466. self.assertEqual(list(izip('abcdef', range(3))), zip('abcdef', range(3)))
  467. self.assertEqual(take(3,izip('abcdef', count())), zip('abcdef', range(3)))
  468. self.assertEqual(list(izip('abcdef')), zip('abcdef'))
  469. self.assertEqual(list(izip()), zip())
  470. self.assertRaises(TypeError, izip, 3)
  471. self.assertRaises(TypeError, izip, range(3), 3)
  472. # Check tuple re-use (implementation detail)
  473. self.assertEqual([tuple(list(pair)) for pair in izip('abc', 'def')],
  474. zip('abc', 'def'))
  475. self.assertEqual([pair for pair in izip('abc', 'def')],
  476. zip('abc', 'def'))
  477. ids = map(id, izip('abc', 'def'))
  478. self.assertEqual(min(ids), max(ids))
  479. ids = map(id, list(izip('abc', 'def')))
  480. self.assertEqual(len(dict.fromkeys(ids)), len(ids))
  481. def test_iziplongest(self):
  482. for args in [
  483. ['abc', range(6)],
  484. [range(6), 'abc'],
  485. [range(1000), range(2000,2100), range(3000,3050)],
  486. [range(1000), range(0), range(3000,3050), range(1200), range(1500)],
  487. [range(1000), range(0), range(3000,3050), range(1200), range(1500), range(0)],
  488. ]:
  489. # target = map(None, *args) <- this raises a py3k warning
  490. # this is the replacement:
  491. target = [tuple([arg[i] if i < len(arg) else None for arg in args])
  492. for i in range(max(map(len, args)))]
  493. self.assertEqual(list(izip_longest(*args)), target)
  494. self.assertEqual(list(izip_longest(*args, **{})), target)
  495. target = [tuple((e is None and 'X' or e) for e in t) for t in target] # Replace None fills with 'X'
  496. self.assertEqual(list(izip_longest(*args, **dict(fillvalue='X'))), target)
  497. self.assertEqual(take(3,izip_longest('abcdef', count())), zip('abcdef', range(3))) # take 3 from infinite input
  498. self.assertEqual(list(izip_longest()), zip())
  499. self.assertEqual(list(izip_longest([])), zip([]))
  500. self.assertEqual(list(izip_longest('abcdef')), zip('abcdef'))
  501. self.assertEqual(list(izip_longest('abc', 'defg', **{})),
  502. zip(list('abc') + [None], 'defg')) # empty keyword dict
  503. self.assertRaises(TypeError, izip_longest, 3)
  504. self.assertRaises(TypeError, izip_longest, range(3), 3)
  505. for stmt in [
  506. "izip_longest('abc', fv=1)",
  507. "izip_longest('abc', fillvalue=1, bogus_keyword=None)",
  508. ]:
  509. try:
  510. eval(stmt, globals(), locals())
  511. except TypeError:
  512. pass
  513. else:
  514. self.fail('Did not raise Type in: ' + stmt)
  515. # Check tuple re-use (implementation detail)
  516. self.assertEqual([tuple(list(pair)) for pair in izip_longest('abc', 'def')],
  517. zip('abc', 'def'))
  518. self.assertEqual([pair for pair in izip_longest('abc', 'def')],
  519. zip('abc', 'def'))
  520. ids = map(id, izip_longest('abc', 'def'))
  521. self.assertEqual(min(ids), max(ids))
  522. ids = map(id, list(izip_longest('abc', 'def')))
  523. self.assertEqual(len(dict.fromkeys(ids)), len(ids))
  524. def test_bug_7244(self):
  525. class Repeater(object):
  526. # this class is similar to itertools.repeat
  527. def __init__(self, o, t, e):
  528. self.o = o
  529. self.t = int(t)
  530. self.e = e
  531. def __iter__(self): # its iterator is itself
  532. return self
  533. def next(self):
  534. if self.t > 0:
  535. self.t -= 1
  536. return self.o
  537. else:
  538. raise self.e
  539. # Formerly this code in would fail in debug mode
  540. # with Undetected Error and Stop Iteration
  541. r1 = Repeater(1, 3, StopIteration)
  542. r2 = Repeater(2, 4, StopIteration)
  543. def run(r1, r2):
  544. result = []
  545. for i, j in izip_longest(r1, r2, fillvalue=0):
  546. with test_support.captured_output('stdout'):
  547. print (i, j)
  548. result.append((i, j))
  549. return result
  550. self.assertEqual(run(r1, r2), [(1,2), (1,2), (1,2), (0,2)])
  551. # Formerly, the RuntimeError would be lost
  552. # and StopIteration would stop as expected
  553. r1 = Repeater(1, 3, RuntimeError)
  554. r2 = Repeater(2, 4, StopIteration)
  555. it = izip_longest(r1, r2, fillvalue=0)
  556. self.assertEqual(next(it), (1, 2))
  557. self.assertEqual(next(it), (1, 2))
  558. self.assertEqual(next(it), (1, 2))
  559. self.assertRaises(RuntimeError, next, it)
  560. def test_product(self):
  561. for args, result in [
  562. ([], [()]), # zero iterables
  563. (['ab'], [('a',), ('b',)]), # one iterable
  564. ([range(2), range(3)], [(0,0), (0,1), (0,2), (1,0), (1,1), (1,2)]), # two iterables
  565. ([range(0), range(2), range(3)], []), # first iterable with zero length
  566. ([range(2), range(0), range(3)], []), # middle iterable with zero length
  567. ([range(2), range(3), range(0)], []), # last iterable with zero length
  568. ]:
  569. self.assertEqual(list(product(*args)), result)
  570. for r in range(4):
  571. self.assertEqual(list(product(*(args*r))),
  572. list(product(*args, **dict(repeat=r))))
  573. self.assertEqual(len(list(product(*[range(7)]*6))), 7**6)
  574. self.assertRaises(TypeError, product, range(6), None)
  575. def product1(*args, **kwds):
  576. pools = map(tuple, args) * kwds.get('repeat', 1)
  577. n = len(pools)
  578. if n == 0:
  579. yield ()
  580. return
  581. if any(len(pool) == 0 for pool in pools):
  582. return
  583. indices = [0] * n
  584. yield tuple(pool[i] for pool, i in zip(pools, indices))
  585. while 1:
  586. for i in reversed(range(n)): # right to left
  587. if indices[i] == len(pools[i]) - 1:
  588. continue
  589. indices[i] += 1
  590. for j in range(i+1, n):
  591. indices[j] = 0
  592. yield tuple(pool[i] for pool, i in zip(pools, indices))
  593. break
  594. else:
  595. return
  596. def product2(*args, **kwds):
  597. 'Pure python version used in docs'
  598. pools = map(tuple, args) * kwds.get('repeat', 1)
  599. result = [[]]
  600. for pool in pools:
  601. result = [x+[y] for x in result for y in pool]
  602. for prod in result:
  603. yield tuple(prod)
  604. argtypes = ['', 'abc', '', xrange(0), xrange(4), dict(a=1, b=2, c=3),
  605. set('abcdefg'), range(11), tuple(range(13))]
  606. for i in range(100):
  607. args = [random.choice(argtypes) for j in range(random.randrange(5))]
  608. expected_len = prod(map(len, args))
  609. self.assertEqual(len(list(product(*args))), expected_len)
  610. self.assertEqual(list(product(*args)), list(product1(*args)))
  611. self.assertEqual(list(product(*args)), list(product2(*args)))
  612. args = map(iter, args)
  613. self.assertEqual(len(list(product(*args))), expected_len)
  614. # Test implementation detail: tuple re-use
  615. self.assertEqual(len(set(map(id, product('abc', 'def')))), 1)
  616. self.assertNotEqual(len(set(map(id, list(product('abc', 'def'))))), 1)
  617. def test_repeat(self):
  618. self.assertEqual(list(repeat(object='a', times=3)), ['a', 'a', 'a'])
  619. self.assertEqual(zip(xrange(3),repeat('a')),
  620. [(0, 'a'), (1, 'a'), (2, 'a')])
  621. self.assertEqual(list(repeat('a', 3)), ['a', 'a', 'a'])
  622. self.assertEqual(take(3, repeat('a')), ['a', 'a', 'a'])
  623. self.assertEqual(list(repeat('a', 0)), [])
  624. self.assertEqual(list(repeat('a', -3)), [])
  625. self.assertRaises(TypeError, repeat)
  626. self.assertRaises(TypeError, repeat, None, 3, 4)
  627. self.assertRaises(TypeError, repeat, None, 'a')
  628. r = repeat(1+0j)
  629. self.assertEqual(repr(r), 'repeat((1+0j))')
  630. r = repeat(1+0j, 5)
  631. self.assertEqual(repr(r), 'repeat((1+0j), 5)')
  632. list(r)
  633. self.assertEqual(repr(r), 'repeat((1+0j), 0)')
  634. def test_imap(self):
  635. self.assertEqual(list(imap(operator.pow, range(3), range(1,7))),
  636. [0**1, 1**2, 2**3])
  637. self.assertEqual(list(imap(None, 'abc', range(5))),
  638. [('a',0),('b',1),('c',2)])
  639. self.assertEqual(list(imap(None, 'abc', count())),
  640. [('a',0),('b',1),('c',2)])
  641. self.assertEqual(take(2,imap(None, 'abc', count())),
  642. [('a',0),('b',1)])
  643. self.assertEqual(list(imap(operator.pow, [])), [])
  644. self.assertRaises(TypeError, imap)
  645. self.assertRaises(TypeError, imap, operator.neg)
  646. self.assertRaises(TypeError, imap(10, range(5)).next)
  647. self.assertRaises(ValueError, imap(errfunc, [4], [5]).next)
  648. self.assertRaises(TypeError, imap(onearg, [4], [5]).next)
  649. def test_starmap(self):
  650. self.assertEqual(list(starmap(operator.pow, zip(range(3), range(1,7)))),
  651. [0**1, 1**2, 2**3])
  652. self.assertEqual(take(3, starmap(operator.pow, izip(count(), count(1)))),
  653. [0**1, 1**2, 2**3])
  654. self.assertEqual(list(starmap(operator.pow, [])), [])
  655. self.assertEqual(list(starmap(operator.pow, [iter([4,5])])), [4**5])
  656. self.assertRaises(TypeError, list, starmap(operator.pow, [None]))
  657. self.assertRaises(TypeError, starmap)
  658. self.assertRaises(TypeError, starmap, operator.pow, [(4,5)], 'extra')
  659. self.assertRaises(TypeError, starmap(10, [(4,5)]).next)
  660. self.assertRaises(ValueError, starmap(errfunc, [(4,5)]).next)
  661. self.assertRaises(TypeError, starmap(onearg, [(4,5)]).next)
  662. def test_islice(self):
  663. for args in [ # islice(args) should agree with range(args)
  664. (10, 20, 3),
  665. (10, 3, 20),
  666. (10, 20),
  667. (10, 3),
  668. (20,)
  669. ]:
  670. self.assertEqual(list(islice(xrange(100), *args)), range(*args))
  671. for args, tgtargs in [ # Stop when seqn is exhausted
  672. ((10, 110, 3), ((10, 100, 3))),
  673. ((10, 110), ((10, 100))),
  674. ((110,), (100,))
  675. ]:
  676. self.assertEqual(list(islice(xrange(100), *args)), range(*tgtargs))
  677. # Test stop=None
  678. self.assertEqual(list(islice(xrange(10), None)), range(10))
  679. self.assertEqual(list(islice(xrange(10), None, None)), range(10))
  680. self.assertEqual(list(islice(xrange(10), None, None, None)), range(10))
  681. self.assertEqual(list(islice(xrange(10), 2, None)), range(2, 10))
  682. self.assertEqual(list(islice(xrange(10), 1, None, 2)), range(1, 10, 2))
  683. # Test number of items consumed SF #1171417
  684. it = iter(range(10))
  685. self.assertEqual(list(islice(it, 3)), range(3))
  686. self.assertEqual(list(it), range(3, 10))
  687. # Test invalid arguments
  688. self.assertRaises(TypeError, islice, xrange(10))
  689. self.assertRaises(TypeError, islice, xrange(10), 1, 2, 3, 4)
  690. self.assertRaises(ValueError, islice, xrange(10), -5, 10, 1)
  691. self.assertRaises(ValueError, islice, xrange(10), 1, -5, -1)
  692. self.assertRaises(ValueError, islice, xrange(10), 1, 10, -1)
  693. self.assertRaises(ValueError, islice, xrange(10), 1, 10, 0)
  694. self.assertRaises(ValueError, islice, xrange(10), 'a')
  695. self.assertRaises(ValueError, islice, xrange(10), 'a', 1)
  696. self.assertRaises(ValueError, islice, xrange(10), 1, 'a')
  697. self.assertRaises(ValueError, islice, xrange(10), 'a', 1, 1)
  698. self.assertRaises(ValueError, islice, xrange(10), 1, 'a', 1)
  699. self.assertEqual(len(list(islice(count(), 1, 10, maxsize))), 1)
  700. # Issue #10323: Less islice in a predictable state
  701. c = count()
  702. self.assertEqual(list(islice(c, 1, 3, 50)), [1])
  703. self.assertEqual(next(c), 3)
  704. def test_takewhile(self):
  705. data = [1, 3, 5, 20, 2, 4, 6, 8]
  706. underten = lambda x: x<10
  707. self.assertEqual(list(takewhile(underten, data)), [1, 3, 5])
  708. self.assertEqual(list(takewhile(underten, [])), [])
  709. self.assertRaises(TypeError, takewhile)
  710. self.assertRaises(TypeError, takewhile, operator.pow)
  711. self.assertRaises(TypeError, takewhile, operator.pow, [(4,5)], 'extra')
  712. self.assertRaises(TypeError, takewhile(10, [(4,5)]).next)
  713. self.assertRaises(ValueError, takewhile(errfunc, [(4,5)]).next)
  714. t = takewhile(bool, [1, 1, 1, 0, 0, 0])
  715. self.assertEqual(list(t), [1, 1, 1])
  716. self.assertRaises(StopIteration, t.next)
  717. def test_dropwhile(self):
  718. data = [1, 3, 5, 20, 2, 4, 6, 8]
  719. underten = lambda x: x<10
  720. self.assertEqual(list(dropwhile(underten, data)), [20, 2, 4, 6, 8])
  721. self.assertEqual(list(dropwhile(underten, [])), [])
  722. self.assertRaises(TypeError, dropwhile)
  723. self.assertRaises(TypeError, dropwhile, operator.pow)
  724. self.assertRaises(TypeError, dropwhile, operator.pow, [(4,5)], 'extra')
  725. self.assertRaises(TypeError, dropwhile(10, [(4,5)]).next)
  726. self.assertRaises(ValueError, dropwhile(errfunc, [(4,5)]).next)
  727. def test_tee(self):
  728. n = 200
  729. def irange(n):
  730. for i in xrange(n):
  731. yield i
  732. a, b = tee([]) # test empty iterator
  733. self.assertEqual(list(a), [])
  734. self.assertEqual(list(b), [])
  735. a, b = tee(irange(n)) # test 100% interleaved
  736. self.assertEqual(zip(a,b), zip(range(n),range(n)))
  737. a, b = tee(irange(n)) # test 0% interleaved
  738. self.assertEqual(list(a), range(n))
  739. self.assertEqual(list(b), range(n))
  740. a, b = tee(irange(n)) # test dealloc of leading iterator
  741. for i in xrange(100):
  742. self.assertEqual(a.next(), i)
  743. del a
  744. self.assertEqual(list(b), range(n))
  745. a, b = tee(irange(n)) # test dealloc of trailing iterator
  746. for i in xrange(100):
  747. self.assertEqual(a.next(), i)
  748. del b
  749. self.assertEqual(list(a), range(100, n))
  750. for j in xrange(5): # test randomly interleaved
  751. order = [0]*n + [1]*n
  752. random.shuffle(order)
  753. lists = ([], [])
  754. its = tee(irange(n))
  755. for i in order:
  756. value = its[i].next()
  757. lists[i].append(value)
  758. self.assertEqual(lists[0], range(n))
  759. self.assertEqual(lists[1], range(n))
  760. # test argument format checking
  761. self.assertRaises(TypeError, tee)
  762. self.assertRaises(TypeError, tee, 3)
  763. self.assertRaises(TypeError, tee, [1,2], 'x')
  764. self.assertRaises(TypeError, tee, [1,2], 3, 'x')
  765. # tee object should be instantiable
  766. a, b = tee('abc')
  767. c = type(a)('def')
  768. self.assertEqual(list(c), list('def'))
  769. # test long-lagged and multi-way split
  770. a, b, c = tee(xrange(2000), 3)
  771. for i in xrange(100):
  772. self.assertEqual(a.next(), i)
  773. self.assertEqual(list(b), range(2000))
  774. self.assertEqual([c.next(), c.next()], range(2))
  775. self.assertEqual(list(a), range(100,2000))
  776. self.assertEqual(list(c), range(2,2000))
  777. # test values of n
  778. self.assertRaises(TypeError, tee, 'abc', 'invalid')
  779. self.assertRaises(ValueError, tee, [], -1)
  780. for n in xrange(5):
  781. result = tee('abc', n)
  782. self.assertEqual(type(result), tuple)
  783. self.assertEqual(len(result), n)
  784. self.assertEqual(map(list, result), [list('abc')]*n)
  785. # tee pass-through to copyable iterator
  786. a, b = tee('abc')
  787. c, d = tee(a)
  788. self.assertTrue(a is c)
  789. # test tee_new
  790. t1, t2 = tee('abc')
  791. tnew = type(t1)
  792. self.assertRaises(TypeError, tnew)
  793. self.assertRaises(TypeError, tnew, 10)
  794. t3 = tnew(t1)
  795. self.assertTrue(list(t1) == list(t2) == list(t3) == list('abc'))
  796. # test that tee objects are weak referencable
  797. a, b = tee(xrange(10))
  798. p = proxy(a)
  799. self.assertEqual(getattr(p, '__class__'), type(b))
  800. del a
  801. self.assertRaises(ReferenceError, getattr, p, '__class__')
  802. def test_StopIteration(self):
  803. self.assertRaises(StopIteration, izip().next)
  804. for f in (chain, cycle, izip, groupby):
  805. self.assertRaises(StopIteration, f([]).next)
  806. self.assertRaises(StopIteration, f(StopNow()).next)
  807. self.assertRaises(StopIteration, islice([], None).next)
  808. self.assertRaises(StopIteration, islice(StopNow(), None).next)
  809. p, q = tee([])
  810. self.assertRaises(StopIteration, p.next)
  811. self.assertRaises(StopIteration, q.next)
  812. p, q = tee(StopNow())
  813. self.assertRaises(StopIteration, p.next)
  814. self.assertRaises(StopIteration, q.next)
  815. self.assertRaises(StopIteration, repeat(None, 0).next)
  816. for f in (ifilter, ifilterfalse, imap, takewhile, dropwhile, starmap):
  817. self.assertRaises(StopIteration, f(lambda x:x, []).next)
  818. self.assertRaises(StopIteration, f(lambda x:x, StopNow()).next)
  819. class TestExamples(unittest.TestCase):
  820. def test_chain(self):
  821. self.assertEqual(''.join(chain('ABC', 'DEF')), 'ABCDEF')
  822. def test_chain_from_iterable(self):
  823. self.assertEqual(''.join(chain.from_iterable(['ABC', 'DEF'])), 'ABCDEF')
  824. def test_combinations(self):
  825. self.assertEqual(list(combinations('ABCD', 2)),
  826. [('A','B'), ('A','C'), ('A','D'), ('B','C'), ('B','D'), ('C','D')])
  827. self.assertEqual(list(combinations(range(4), 3)),
  828. [(0,1,2), (0,1,3), (0,2,3), (1,2,3)])
  829. def test_combinations_with_replacement(self):
  830. self.assertEqual(list(combinations_with_replacement('ABC', 2)),
  831. [('A','A'), ('A','B'), ('A','C'), ('B','B'), ('B','C'), ('C','C')])
  832. def test_compress(self):
  833. self.assertEqual(list(compress('ABCDEF', [1,0,1,0,1,1])), list('ACEF'))
  834. def test_count(self):
  835. self.assertEqual(list(islice(count(10), 5)), [10, 11, 12, 13, 14])
  836. def test_cycle(self):
  837. self.assertEqual(list(islice(cycle('ABCD'), 12)), list('ABCDABCDABCD'))
  838. def test_dropwhile(self):
  839. self.assertEqual(list(dropwhile(lambda x: x<5, [1,4,6,4,1])), [6,4,1])
  840. def test_groupby(self):
  841. self.assertEqual([k for k, g in groupby('AAAABBBCCDAABBB')],
  842. list('ABCDAB'))
  843. self.assertEqual([(list(g)) for k, g in groupby('AAAABBBCCD')],
  844. [list('AAAA'), list('BBB'), list('CC'), list('D')])
  845. def test_ifilter(self):
  846. self.assertEqual(list(ifilter(lambda x: x%2, range(10))), [1,3,5,7,9])
  847. def test_ifilterfalse(self):
  848. self.assertEqual(list(ifilterfalse(lambda x: x%2, range(10))), [0,2,4,6,8])
  849. def test_imap(self):
  850. self.assertEqual(list(imap(pow, (2,3,10), (5,2,3))), [32, 9, 1000])
  851. def test_islice(self):
  852. self.assertEqual(list(islice('ABCDEFG', 2)), list('AB'))
  853. self.assertEqual(list(islice('ABCDEFG', 2, 4)), list('CD'))
  854. self.assertEqual(list(islice('ABCDEFG', 2, None)), list('CDEFG'))
  855. self.assertEqual(list(islice('ABCDEFG', 0, None, 2)), list('ACEG'))
  856. def test_izip(self):
  857. self.assertEqual(list(izip('ABCD', 'xy')), [('A', 'x'), ('B', 'y')])
  858. def test_izip_longest(self):
  859. self.assertEqual(list(izip_longest('ABCD', 'xy', fillvalue='-')),
  860. [('A', 'x'), ('B', 'y'), ('C', '-'), ('D', '-')])
  861. def test_permutations(self):
  862. self.assertEqual(list(permutations('ABCD', 2)),
  863. map(tuple, 'AB AC AD BA BC BD CA CB CD DA DB DC'.split()))
  864. self.assertEqual(list(permutations(range(3))),
  865. [(0,1,2), (0,2,1), (1,0,2), (1,2,0), (2,0,1), (2,1,0)])
  866. def test_product(self):
  867. self.assertEqual(list(product('ABCD', 'xy')),
  868. map(tuple, 'Ax Ay Bx By Cx Cy Dx Dy'.split()))
  869. self.assertEqual(list(product(range(2), repeat=3)),
  870. [(0,0,0), (0,0,1), (0,1,0), (0,1,1),
  871. (1,0,0), (1,0,1), (1,1,0), (1,1,1)])
  872. def test_repeat(self):
  873. self.assertEqual(list(repeat(10, 3)), [10, 10, 10])
  874. def test_stapmap(self):
  875. self.assertEqual(list(starmap(pow, [(2,5), (3,2), (10,3)])),
  876. [32, 9, 1000])
  877. def test_takewhile(self):
  878. self.assertEqual(list(takewhile(lambda x: x<5, [1,4,6,4,1])), [1,4])
  879. class TestGC(unittest.TestCase):
  880. def makecycle(self, iterator, container):
  881. container.append(iterator)
  882. iterator.next()
  883. del container, iterator
  884. def test_chain(self):
  885. a = []
  886. self.makecycle(chain(a), a)
  887. def test_chain_from_iterable(self):
  888. a = []
  889. self.makecycle(chain.from_iterable([a]), a)
  890. def test_combinations(self):
  891. a = []
  892. self.makecycle(combinations([1,2,a,3], 3), a)
  893. def test_combinations_with_replacement(self):
  894. a = []
  895. self.makecycle(combinations_with_replacement([1,2,a,3], 3), a)
  896. def test_compress(self):
  897. a = []
  898. self.makecycle(compress('ABCDEF', [1,0,1,0,1,0]), a)
  899. def test_count(self):
  900. a = []
  901. Int = type('Int', (int,), dict(x=a))
  902. self.makecycle(count(Int(0), Int(1)), a)
  903. def test_cycle(self):
  904. a = []
  905. self.makecycle(cycle([a]*2), a)
  906. def test_dropwhile(self):
  907. a = []
  908. self.makecycle(dropwhile(bool, [0, a, a]), a)
  909. def test_groupby(self):
  910. a = []
  911. self.makecycle(groupby([a]*2, lambda x:x), a)
  912. def test_issue2246(self):
  913. # Issue 2246 -- the _grouper iterator was not included in GC
  914. n = 10
  915. keyfunc = lambda x: x
  916. for i, j in groupby(xrange(n), key=keyfunc):
  917. keyfunc.__dict__.setdefault('x',[]).append(j)
  918. def test_ifilter(self):
  919. a = []
  920. self.makecycle(ifilter(lambda x:True, [a]*2), a)
  921. def test_ifilterfalse(self):
  922. a = []
  923. self.makecycle(ifilterfalse(lambda x:False, a), a)
  924. def test_izip(self):
  925. a = []
  926. self.makecycle(izip([a]*2, [a]*3), a)
  927. def test_izip_longest(self):
  928. a = []
  929. self.makecycle(izip_longest([a]*2, [a]*3), a)
  930. b = [a, None]
  931. self.makecycle(izip_longest([a]*2, [a]*3, fillvalue=b), a)
  932. def test_imap(self):
  933. a = []
  934. self.makecycle(imap(lambda x:x, [a]*2), a)
  935. def test_islice(self):
  936. a = []
  937. self.makecycle(islice([a]*2, None), a)
  938. def test_permutations(self):
  939. a = []
  940. self.makecycle(permutations([1,2,a,3], 3), a)
  941. def test_product(self):
  942. a = []
  943. self.makecycle(product([1,2,a,3], repeat=3), a)
  944. def test_repeat(self):
  945. a = []
  946. self.makecycle(repeat(a), a)
  947. def test_starmap(self):
  948. a = []
  949. self.makecycle(starmap(lambda *t: t, [(a,a)]*2), a)
  950. def test_takewhile(self):
  951. a = []
  952. self.makecycle(takewhile(bool, [1, 0, a, a]), a)
  953. def R(seqn):
  954. 'Regular generator'
  955. for i in seqn:
  956. yield i
  957. class G:
  958. 'Sequence using __getitem__'
  959. def __init__(self, seqn):
  960. self.seqn = seqn
  961. def __getitem__(self, i):
  962. return self.seqn[i]
  963. class I:
  964. 'Sequence using iterator protocol'
  965. def __init__(self, seqn):
  966. self.seqn = seqn
  967. self.i = 0
  968. def __iter__(self):
  969. return self
  970. def next(self):
  971. if self.i >= len(self.seqn): raise StopIteration
  972. v = self.seqn[self.i]
  973. self.i += 1
  974. return v
  975. class Ig:
  976. 'Sequence using iterator protocol defined with a generator'
  977. def __init__(self, seqn):
  978. self.seqn = seqn
  979. self.i = 0
  980. def __iter__(self):
  981. for val in self.seqn:
  982. yield val
  983. class X:
  984. 'Missing __getitem__ and __iter__'
  985. def __init__(self, seqn):
  986. self.seqn = seqn
  987. self.i = 0
  988. def next(self):
  989. if self.i >= len(self.seqn): raise StopIteration
  990. v = self.seqn[self.i]
  991. self.i += 1
  992. return v
  993. class N:
  994. 'Iterator missing next()'
  995. def __init__(self, seqn):
  996. self.seqn = seqn
  997. self.i = 0
  998. def __iter__(self):
  999. return self
  1000. class E:
  1001. 'Test propagation of exceptions'
  1002. def __init__(self, seqn):
  1003. self.seqn = seqn
  1004. self.i = 0
  1005. def __iter__(self):
  1006. return self
  1007. def next(self):
  1008. 3 // 0
  1009. class S:
  1010. 'Test immediate stop'
  1011. def __init__(self, seqn):
  1012. pass
  1013. def __iter__(self):
  1014. return self
  1015. def next(self):
  1016. raise StopIteration
  1017. def L(seqn):
  1018. 'Test multiple tiers of iterators'
  1019. return chain(imap(lambda x:x, R(Ig(G(seqn)))))
  1020. class TestVariousIteratorArgs(unittest.TestCase):
  1021. def test_chain(self):
  1022. for s in ("123", "", range(1000), ('do', 1.2), xrange(2000,2200,5)):
  1023. for g in (G

Large files files are truncated, but you can click here to view the full file