mirror of https://github.com/python/cpython
Merge for issue #15744: add tests for the writelines() method of file objects.
This commit is contained in:
commit
8261f838ff
|
@ -10,6 +10,7 @@ from weakref import proxy
|
|||
from functools import wraps
|
||||
|
||||
from test.support import TESTFN, check_warnings, run_unittest, make_bad_fd
|
||||
from collections import UserList
|
||||
|
||||
from _io import FileIO as _FileIO
|
||||
|
||||
|
@ -68,6 +69,27 @@ class AutoFileTests(unittest.TestCase):
|
|||
n = self.f.readinto(a)
|
||||
self.assertEqual(array('b', [1, 2]), a[:n])
|
||||
|
||||
def testWritelinesList(self):
|
||||
l = [b'123', b'456']
|
||||
self.f.writelines(l)
|
||||
self.f.close()
|
||||
self.f = _FileIO(TESTFN, 'rb')
|
||||
buf = self.f.read()
|
||||
self.assertEqual(buf, b'123456')
|
||||
|
||||
def testWritelinesUserList(self):
|
||||
l = UserList([b'123', b'456'])
|
||||
self.f.writelines(l)
|
||||
self.f.close()
|
||||
self.f = _FileIO(TESTFN, 'rb')
|
||||
buf = self.f.read()
|
||||
self.assertEqual(buf, b'123456')
|
||||
|
||||
def testWritelinesError(self):
|
||||
self.assertRaises(TypeError, self.f.writelines, [1, 2, 3])
|
||||
self.assertRaises(TypeError, self.f.writelines, None)
|
||||
self.assertRaises(TypeError, self.f.writelines, "abc")
|
||||
|
||||
def test_none_args(self):
|
||||
self.f.write(b"hi\nbye\nabc")
|
||||
self.f.close()
|
||||
|
|
|
@ -32,7 +32,7 @@ import time
|
|||
import unittest
|
||||
import warnings
|
||||
import weakref
|
||||
from collections import deque
|
||||
from collections import deque, UserList
|
||||
from itertools import cycle, count
|
||||
from test import support
|
||||
|
||||
|
@ -1201,6 +1201,29 @@ class BufferedWriterTest(unittest.TestCase, CommonBufferedTests):
|
|||
bufio.flush()
|
||||
self.assertEqual(b"abc", writer._write_stack[0])
|
||||
|
||||
def test_writelines(self):
|
||||
l = [b'ab', b'cd', b'ef']
|
||||
writer = self.MockRawIO()
|
||||
bufio = self.tp(writer, 8)
|
||||
bufio.writelines(l)
|
||||
bufio.flush()
|
||||
self.assertEqual(b''.join(writer._write_stack), b'abcdef')
|
||||
|
||||
def test_writelines_userlist(self):
|
||||
l = UserList([b'ab', b'cd', b'ef'])
|
||||
writer = self.MockRawIO()
|
||||
bufio = self.tp(writer, 8)
|
||||
bufio.writelines(l)
|
||||
bufio.flush()
|
||||
self.assertEqual(b''.join(writer._write_stack), b'abcdef')
|
||||
|
||||
def test_writelines_error(self):
|
||||
writer = self.MockRawIO()
|
||||
bufio = self.tp(writer, 8)
|
||||
self.assertRaises(TypeError, bufio.writelines, [1, 2, 3])
|
||||
self.assertRaises(TypeError, bufio.writelines, None)
|
||||
self.assertRaises(TypeError, bufio.writelines, 'abc')
|
||||
|
||||
def test_destructor(self):
|
||||
writer = self.MockRawIO()
|
||||
bufio = self.tp(writer, 8)
|
||||
|
@ -2304,6 +2327,28 @@ class TextIOWrapperTest(unittest.TestCase):
|
|||
reads += c
|
||||
self.assertEqual(reads, "A"*127+"\nB")
|
||||
|
||||
def test_writelines(self):
|
||||
l = ['ab', 'cd', 'ef']
|
||||
buf = self.BytesIO()
|
||||
txt = self.TextIOWrapper(buf)
|
||||
txt.writelines(l)
|
||||
txt.flush()
|
||||
self.assertEqual(buf.getvalue(), b'abcdef')
|
||||
|
||||
def test_writelines_userlist(self):
|
||||
l = UserList(['ab', 'cd', 'ef'])
|
||||
buf = self.BytesIO()
|
||||
txt = self.TextIOWrapper(buf)
|
||||
txt.writelines(l)
|
||||
txt.flush()
|
||||
self.assertEqual(buf.getvalue(), b'abcdef')
|
||||
|
||||
def test_writelines_error(self):
|
||||
txt = self.TextIOWrapper(self.BytesIO())
|
||||
self.assertRaises(TypeError, txt.writelines, [1, 2, 3])
|
||||
self.assertRaises(TypeError, txt.writelines, None)
|
||||
self.assertRaises(TypeError, txt.writelines, b'abc')
|
||||
|
||||
def test_issue1395_1(self):
|
||||
txt = self.TextIOWrapper(self.BytesIO(self.testdata), encoding="ascii")
|
||||
|
||||
|
|
Loading…
Reference in New Issue