summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_tempfile.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-03-19 13:23:15 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2015-03-19 13:23:15 (GMT)
commit56cefa69ee919559cf3ca2388d12371c24402df3 (patch)
tree5fc0f839259759a19ca05b5a68072a6ad00bce8c /Lib/test/test_tempfile.py
parent86fdbf3152f2c19c483da5cce4b4d74539d1407b (diff)
downloadcpython-56cefa69ee919559cf3ca2388d12371c24402df3.zip
cpython-56cefa69ee919559cf3ca2388d12371c24402df3.tar.gz
cpython-56cefa69ee919559cf3ca2388d12371c24402df3.tar.bz2
Issue #23700: Iterator of NamedTemporaryFile now keeps a reference to
NamedTemporaryFile instance. Patch by Bohuslav Kabrda.
Diffstat (limited to 'Lib/test/test_tempfile.py')
-rw-r--r--Lib/test/test_tempfile.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_tempfile.py b/Lib/test/test_tempfile.py
index 2e10fdd..576cf4d 100644
--- a/Lib/test/test_tempfile.py
+++ b/Lib/test/test_tempfile.py
@@ -707,6 +707,19 @@ class TestNamedTemporaryFile(BaseTestCase):
# No reference cycle was created.
self.assertIsNone(wr())
+ def test_iter(self):
+ # Issue #23700: getting iterator from a temporary file should keep
+ # it alive as long as it's being iterated over
+ lines = [b'spam\n', b'eggs\n', b'beans\n']
+ def make_file():
+ f = tempfile.NamedTemporaryFile(mode='w+b')
+ f.write(b''.join(lines))
+ f.seek(0)
+ return f
+ for i, l in enumerate(make_file()):
+ self.assertEqual(l, lines[i])
+ self.assertEqual(i, len(lines) - 1)
+
def test_creates_named(self):
# NamedTemporaryFile creates files with names
f = tempfile.NamedTemporaryFile()