diff options
author | Benjamin Peterson <benjamin@python.org> | 2009-04-24 23:14:50 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2009-04-24 23:14:50 (GMT) |
commit | 45cec32f7de0fc65c7321d34dda92c57cee1217d (patch) | |
tree | 783362895a447fb099893ae50561d9340e2ed9f2 /Lib/test/test_io.py | |
parent | b01138a66ec36104079987fdd12155716bda3686 (diff) | |
download | cpython-45cec32f7de0fc65c7321d34dda92c57cee1217d.zip cpython-45cec32f7de0fc65c7321d34dda92c57cee1217d.tar.gz cpython-45cec32f7de0fc65c7321d34dda92c57cee1217d.tar.bz2 |
make sure to close files
Diffstat (limited to 'Lib/test/test_io.py')
-rw-r--r-- | Lib/test/test_io.py | 96 |
1 files changed, 43 insertions, 53 deletions
diff --git a/Lib/test/test_io.py b/Lib/test/test_io.py index 7459714..ec390ab 100644 --- a/Lib/test/test_io.py +++ b/Lib/test/test_io.py @@ -291,48 +291,42 @@ class IOTest(unittest.TestCase): self.assertEqual(f.read(2), b"x") def test_raw_file_io(self): - f = self.open(support.TESTFN, "wb", buffering=0) - self.assertEqual(f.readable(), False) - self.assertEqual(f.writable(), True) - self.assertEqual(f.seekable(), True) - self.write_ops(f) - f.close() - f = self.open(support.TESTFN, "rb", buffering=0) - self.assertEqual(f.readable(), True) - self.assertEqual(f.writable(), False) - self.assertEqual(f.seekable(), True) - self.read_ops(f) - f.close() + with self.open(support.TESTFN, "wb", buffering=0) as f: + self.assertEqual(f.readable(), False) + self.assertEqual(f.writable(), True) + self.assertEqual(f.seekable(), True) + self.write_ops(f) + with self.open(support.TESTFN, "rb", buffering=0) as f: + self.assertEqual(f.readable(), True) + self.assertEqual(f.writable(), False) + self.assertEqual(f.seekable(), True) + self.read_ops(f) def test_buffered_file_io(self): - f = self.open(support.TESTFN, "wb") - self.assertEqual(f.readable(), False) - self.assertEqual(f.writable(), True) - self.assertEqual(f.seekable(), True) - self.write_ops(f) - f.close() - f = self.open(support.TESTFN, "rb") - self.assertEqual(f.readable(), True) - self.assertEqual(f.writable(), False) - self.assertEqual(f.seekable(), True) - self.read_ops(f, True) - f.close() + with self.open(support.TESTFN, "wb") as f: + self.assertEqual(f.readable(), False) + self.assertEqual(f.writable(), True) + self.assertEqual(f.seekable(), True) + self.write_ops(f) + with self.open(support.TESTFN, "rb") as f: + self.assertEqual(f.readable(), True) + self.assertEqual(f.writable(), False) + self.assertEqual(f.seekable(), True) + self.read_ops(f, True) def test_readline(self): - f = self.open(support.TESTFN, "wb") - f.write(b"abc\ndef\nxyzzy\nfoo\x00bar\nanother line") - f.close() - f = self.open(support.TESTFN, "rb") - self.assertEqual(f.readline(), b"abc\n") - self.assertEqual(f.readline(10), b"def\n") - self.assertEqual(f.readline(2), b"xy") - self.assertEqual(f.readline(4), b"zzy\n") - self.assertEqual(f.readline(), b"foo\x00bar\n") - self.assertEqual(f.readline(), b"another line") - self.assertRaises(TypeError, f.readline, 5.3) - f.close() - f = self.open(support.TESTFN, "r") - self.assertRaises(TypeError, f.readline, 5.3) + with self.open(support.TESTFN, "wb") as f: + f.write(b"abc\ndef\nxyzzy\nfoo\x00bar\nanother line") + with self.open(support.TESTFN, "rb") as f: + self.assertEqual(f.readline(), b"abc\n") + self.assertEqual(f.readline(10), b"def\n") + self.assertEqual(f.readline(2), b"xy") + self.assertEqual(f.readline(4), b"zzy\n") + self.assertEqual(f.readline(), b"foo\x00bar\n") + self.assertEqual(f.readline(), b"another line") + self.assertRaises(TypeError, f.readline, 5.3) + with self.open(support.TESTFN, "r") as f: + self.assertRaises(TypeError, f.readline, 5.3) def test_raw_bytes_io(self): f = self.BytesIO() @@ -407,8 +401,8 @@ class IOTest(unittest.TestCase): f.write(b"xxx") del f self.assertEqual(record, [1, 2, 3]) - f = open(support.TESTFN, "rb") - self.assertEqual(f.read(), b"xxx") + with open(support.TESTFN, "rb") as f: + self.assertEqual(f.read(), b"xxx") def _check_base_destructor(self, base): record = [] @@ -452,22 +446,18 @@ class IOTest(unittest.TestCase): self._check_base_destructor(self.TextIOBase) def test_close_flushes(self): - f = self.open(support.TESTFN, "wb") - f.write(b"xxx") - f.close() - f = self.open(support.TESTFN, "rb") - self.assertEqual(f.read(), b"xxx") - f.close() + with self.open(support.TESTFN, "wb") as f: + f.write(b"xxx") + with self.open(support.TESTFN, "rb") as f: + self.assertEqual(f.read(), b"xxx") def test_array_writes(self): a = array.array('i', range(10)) n = len(a.tostring()) - f = self.open(support.TESTFN, "wb", 0) - self.assertEqual(f.write(a), n) - f.close() - f = self.open(support.TESTFN, "wb") - self.assertEqual(f.write(a), n) - f.close() + with self.open(support.TESTFN, "wb", 0) as f: + self.assertEqual(f.write(a), n) + with self.open(support.TESTFN, "wb") as f: + self.assertEqual(f.write(a), n) def test_closefd(self): self.assertRaises(ValueError, self.open, support.TESTFN, 'w', @@ -792,7 +782,7 @@ class CBufferedReaderTest(BufferedReaderTest): f.f = f wr = weakref.ref(f) del f - gc.collect() + support.gc_collect() self.assert_(wr() is None, wr) class PyBufferedReaderTest(BufferedReaderTest): |