mirror of
https://github.com/python/cpython.git
synced 2025-10-09 08:31:26 +00:00
merge 3.3 (#16597)
This commit is contained in:
commit
4c05969fc4
5 changed files with 80 additions and 13 deletions
|
@ -603,6 +603,7 @@ class IOTest(unittest.TestCase):
|
|||
raise IOError()
|
||||
f.flush = bad_flush
|
||||
self.assertRaises(IOError, f.close) # exception not swallowed
|
||||
self.assertTrue(f.closed)
|
||||
|
||||
def test_multi_close(self):
|
||||
f = self.open(support.TESTFN, "wb", buffering=0)
|
||||
|
@ -780,6 +781,22 @@ class CommonBufferedTests:
|
|||
raw.flush = bad_flush
|
||||
b = self.tp(raw)
|
||||
self.assertRaises(IOError, b.close) # exception not swallowed
|
||||
self.assertTrue(b.closed)
|
||||
|
||||
def test_close_error_on_close(self):
|
||||
raw = self.MockRawIO()
|
||||
def bad_flush():
|
||||
raise IOError('flush')
|
||||
def bad_close():
|
||||
raise IOError('close')
|
||||
raw.close = bad_close
|
||||
b = self.tp(raw)
|
||||
b.flush = bad_flush
|
||||
with self.assertRaises(IOError) as err: # exception not swallowed
|
||||
b.close()
|
||||
self.assertEqual(err.exception.args, ('close',))
|
||||
self.assertEqual(err.exception.__context__.args, ('flush',))
|
||||
self.assertFalse(b.closed)
|
||||
|
||||
def test_multi_close(self):
|
||||
raw = self.MockRawIO()
|
||||
|
@ -1304,6 +1321,16 @@ class BufferedWriterTest(unittest.TestCase, CommonBufferedTests):
|
|||
with self.assertRaises(TypeError):
|
||||
self.tp(self.MockRawIO(), 8, 12)
|
||||
|
||||
def test_write_error_on_close(self):
|
||||
raw = self.MockRawIO()
|
||||
def bad_write(b):
|
||||
raise IOError()
|
||||
raw.write = bad_write
|
||||
b = self.tp(raw)
|
||||
b.write(b'spam')
|
||||
self.assertRaises(IOError, b.close) # exception not swallowed
|
||||
self.assertTrue(b.closed)
|
||||
|
||||
|
||||
class CBufferedWriterTest(BufferedWriterTest, SizeofTest):
|
||||
tp = io.BufferedWriter
|
||||
|
@ -2473,6 +2500,7 @@ class TextIOWrapperTest(unittest.TestCase):
|
|||
raise IOError()
|
||||
txt.flush = bad_flush
|
||||
self.assertRaises(IOError, txt.close) # exception not swallowed
|
||||
self.assertTrue(txt.closed)
|
||||
|
||||
def test_multi_close(self):
|
||||
txt = self.TextIOWrapper(self.BytesIO(self.testdata), encoding="ascii")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue