summaryrefslogtreecommitdiffstats
path: root/Lib/unittest/mock.py
diff options
context:
space:
mode:
authorRobert Collins <rbtcollins@hp.com>2015-07-17 08:10:23 (GMT)
committerRobert Collins <rbtcollins@hp.com>2015-07-17 08:10:23 (GMT)
commit4838717b53eaaa686f301458d298751893e58055 (patch)
treec5b8fbaecbdd6a7c299ed4002e1134228ebf5b04 /Lib/unittest/mock.py
parent2237bdc595e3d33f941c40108eddfa262c19d960 (diff)
parent5329aaa74bfe48a3be4fcd15d070bacfde682267 (diff)
downloadcpython-4838717b53eaaa686f301458d298751893e58055.zip
cpython-4838717b53eaaa686f301458d298751893e58055.tar.gz
cpython-4838717b53eaaa686f301458d298751893e58055.tar.bz2
Issue #21750: mock_open.read_data can now be read from each instance, as it
could in Python 3.3.
Diffstat (limited to 'Lib/unittest/mock.py')
-rw-r--r--Lib/unittest/mock.py70
1 files changed, 37 insertions, 33 deletions
diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py
index 944029b..86043b0 100644
--- a/Lib/unittest/mock.py
+++ b/Lib/unittest/mock.py
@@ -2286,6 +2286,7 @@ def _iterate_read_data(read_data):
for line in data_as_list:
yield line
+
def mock_open(mock=None, read_data=''):
"""
A helper function to create a mock to replace the use of `open`. It works
@@ -2298,24 +2299,6 @@ def mock_open(mock=None, read_data=''):
`read_data` is a string for the `read` methoddline`, and `readlines` of the
file handle to return. This is an empty string by default.
"""
- def _readlines_side_effect(*args, **kwargs):
- if handle.readlines.return_value is not None:
- return handle.readlines.return_value
- return list(_data)
-
- def _read_side_effect(*args, **kwargs):
- if handle.read.return_value is not None:
- return handle.read.return_value
- return ''.join(_data)
-
- def _readline_side_effect():
- if handle.readline.return_value is not None:
- while True:
- yield handle.readline.return_value
- for line in _data:
- yield line
-
-
global file_spec
if file_spec is None:
import _io
@@ -2324,21 +2307,42 @@ def mock_open(mock=None, read_data=''):
if mock is None:
mock = MagicMock(name='open', spec=open)
- handle = MagicMock(spec=file_spec)
- handle.__enter__.return_value = handle
-
- _data = _iterate_read_data(read_data)
-
- handle.write.return_value = None
- handle.read.return_value = None
- handle.readline.return_value = None
- handle.readlines.return_value = None
-
- handle.read.side_effect = _read_side_effect
- handle.readline.side_effect = _readline_side_effect()
- handle.readlines.side_effect = _readlines_side_effect
-
- mock.return_value = handle
+ def make_handle(*args, **kwargs):
+ # Arg checking is handled by __call__
+ def _readlines_side_effect(*args, **kwargs):
+ if handle.readlines.return_value is not None:
+ return handle.readlines.return_value
+ return list(_data)
+
+ def _read_side_effect(*args, **kwargs):
+ if handle.read.return_value is not None:
+ return handle.read.return_value
+ return ''.join(_data)
+
+ def _readline_side_effect():
+ if handle.readline.return_value is not None:
+ while True:
+ yield handle.readline.return_value
+ for line in _data:
+ yield line
+
+ handle = MagicMock(spec=file_spec)
+ handle.__enter__.return_value = handle
+
+ _data = _iterate_read_data(read_data)
+
+ handle.write.return_value = None
+ handle.read.return_value = None
+ handle.readline.return_value = None
+ handle.readlines.return_value = None
+
+ handle.read.side_effect = _read_side_effect
+ handle.readline.side_effect = _readline_side_effect()
+ handle.readlines.side_effect = _readlines_side_effect
+ _check_and_set_parent(mock, handle, None, '()')
+ return handle
+
+ mock.side_effect = make_handle
return mock