Skip to content

Instantly share code, notes, and snippets.

@eestrada
Last active November 3, 2021 20:42
Show Gist options
  • Save eestrada/0cfdc8b2662200b9e26e197712302a68 to your computer and use it in GitHub Desktop.
Save eestrada/0cfdc8b2662200b9e26e197712302a68 to your computer and use it in GitHub Desktop.
Example(s) of how to force iteration of lazy iterators.
# This is free and unencumbered software released into the public domain.
#
# Anyone is free to copy, modify, publish, use, compile, sell, or
# distribute this software, either in source code form or as a compiled
# binary, for any purpose, commercial or non-commercial, and by any
# means.
#
# In jurisdictions that recognize copyright laws, the author or authors
# of this software dedicate any and all copyright interest in the
# software to the public domain. We make this dedication for the benefit
# of the public at large and to the detriment of our heirs and
# successors. We intend this dedication to be an overt act of
# relinquishment in perpetuity of all present and future rights to this
# software under copyright law.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
# IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
# OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
# OTHER DEALINGS IN THE SOFTWARE.
#
# For more information, please refer to <http://unlicense.org/>
import unittest
def force(it, num=None):
"""Force an iterator to completely exhaust itself.
This is useful for iterators that work via side effect."""
if num is None:
for _ in it:
pass
else:
if num > 0:
for i, _ in enumerate(it, start=1):
if i >= num:
break
class TestForceIter(unittest.TestCase):
def test_without_num(self):
expected = ['result 1', 'result 2', 'result 3']
result = []
# A function that works by side effect
def func(i):
result.append('result {0}'.format(i))
self.assertEqual(result, [])
force(map(func, range(1, 4)))
self.assertEqual(result, expected)
def test_with_num(self):
expected = ['result 1', 'result 2', 'result 3']
result = []
# A function that works by side effect
def func(i):
result.append('result {0}'.format(i))
self.assertEqual(result, [])
force(map(func, range(1, 5)), num=3)
self.assertEqual(result, expected)
def test_with_num0(self):
result = []
# A function that works by side effect
def func(i):
result.append('result {0}'.format(i))
self.assertEqual(result, [])
force(map(func, range(1, 5)), num=0)
self.assertEqual(result, [])
def _test():
unittest.main()
if __name__ == '__main__':
_test()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment