summaryrefslogtreecommitdiffstats
path: root/Lib/unittest/mock.py
diff options
context:
space:
mode:
authorBerker Peksag <berker.peksag@gmail.com>2015-08-06 10:16:52 (GMT)
committerBerker Peksag <berker.peksag@gmail.com>2015-08-06 10:16:52 (GMT)
commitabfaecdfdd9c10732e221eada3c259523fd14a8f (patch)
treebf41008c5b0dada835fb70aa471617b55348e03c /Lib/unittest/mock.py
parent888a6729da50a819438c6aa47e5ea7999d039b24 (diff)
parent86b34da5ef249b865281704a5f6721391edb0c1c (diff)
downloadcpython-abfaecdfdd9c10732e221eada3c259523fd14a8f.zip
cpython-abfaecdfdd9c10732e221eada3c259523fd14a8f.tar.gz
cpython-abfaecdfdd9c10732e221eada3c259523fd14a8f.tar.bz2
Issue #23004: mock_open() now reads binary data correctly when the type of read_data is bytes.
Initial patch by Aaron Hill.
Diffstat (limited to 'Lib/unittest/mock.py')
-rw-r--r--Lib/unittest/mock.py7
1 files changed, 4 insertions, 3 deletions
diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py
index efe5763..4c58639 100644
--- a/Lib/unittest/mock.py
+++ b/Lib/unittest/mock.py
@@ -2271,9 +2271,10 @@ def _iterate_read_data(read_data):
# Helper for mock_open:
# Retrieve lines from read_data via a generator so that separate calls to
# readline, read, and readlines are properly interleaved
- data_as_list = ['{}\n'.format(l) for l in read_data.split('\n')]
+ sep = b'\n' if isinstance(read_data, bytes) else '\n'
+ data_as_list = [l + sep for l in read_data.split(sep)]
- if data_as_list[-1] == '\n':
+ if data_as_list[-1] == sep:
# If the last line ended in a newline, the list comprehension will have an
# extra entry that's just a newline. Remove this.
data_as_list = data_as_list[:-1]
@@ -2307,7 +2308,7 @@ def mock_open(mock=None, read_data=''):
def _read_side_effect(*args, **kwargs):
if handle.read.return_value is not None:
return handle.read.return_value
- return ''.join(_state[0])
+ return type(read_data)().join(_state[0])
def _readline_side_effect():
if handle.readline.return_value is not None: