mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 13:41:24 +00:00 
			
		
		
		
	Issue #23004: mock_open() now reads binary data correctly when the type of read_data is bytes.
Initial patch by Aaron Hill.
This commit is contained in:
		
							parent
							
								
									0b2833eaf2
								
							
						
					
					
						commit
						86b34da5ef
					
				
					 3 changed files with 35 additions and 3 deletions
				
			
		|  | @ -2250,9 +2250,10 @@ def _iterate_read_data(read_data): | ||||||
|     # Helper for mock_open: |     # Helper for mock_open: | ||||||
|     # Retrieve lines from read_data via a generator so that separate calls to |     # Retrieve lines from read_data via a generator so that separate calls to | ||||||
|     # readline, read, and readlines are properly interleaved |     # 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 |         # If the last line ended in a newline, the list comprehension will have an | ||||||
|         # extra entry that's just a newline.  Remove this. |         # extra entry that's just a newline.  Remove this. | ||||||
|         data_as_list = data_as_list[:-1] |         data_as_list = data_as_list[:-1] | ||||||
|  | @ -2286,7 +2287,7 @@ def _readlines_side_effect(*args, **kwargs): | ||||||
|     def _read_side_effect(*args, **kwargs): |     def _read_side_effect(*args, **kwargs): | ||||||
|         if handle.read.return_value is not None: |         if handle.read.return_value is not None: | ||||||
|             return handle.read.return_value |             return handle.read.return_value | ||||||
|         return ''.join(_state[0]) |         return type(read_data)().join(_state[0]) | ||||||
| 
 | 
 | ||||||
|     def _readline_side_effect(): |     def _readline_side_effect(): | ||||||
|         if handle.readline.return_value is not None: |         if handle.readline.return_value is not None: | ||||||
|  |  | ||||||
|  | @ -224,6 +224,34 @@ def test_readlines_data(self): | ||||||
|         self.assertEqual(result, ['foo\n', 'bar\n', 'baz']) |         self.assertEqual(result, ['foo\n', 'bar\n', 'baz']) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |     def test_read_bytes(self): | ||||||
|  |         mock = mock_open(read_data=b'\xc6') | ||||||
|  |         with patch('%s.open' % __name__, mock, create=True): | ||||||
|  |             with open('abc', 'rb') as f: | ||||||
|  |                 result = f.read() | ||||||
|  |         self.assertEqual(result, b'\xc6') | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def test_readline_bytes(self): | ||||||
|  |         m = mock_open(read_data=b'abc\ndef\nghi\n') | ||||||
|  |         with patch('%s.open' % __name__, m, create=True): | ||||||
|  |             with open('abc', 'rb') as f: | ||||||
|  |                 line1 = f.readline() | ||||||
|  |                 line2 = f.readline() | ||||||
|  |                 line3 = f.readline() | ||||||
|  |         self.assertEqual(line1, b'abc\n') | ||||||
|  |         self.assertEqual(line2, b'def\n') | ||||||
|  |         self.assertEqual(line3, b'ghi\n') | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def test_readlines_bytes(self): | ||||||
|  |         m = mock_open(read_data=b'abc\ndef\nghi\n') | ||||||
|  |         with patch('%s.open' % __name__, m, create=True): | ||||||
|  |             with open('abc', 'rb') as f: | ||||||
|  |                 result = f.readlines() | ||||||
|  |         self.assertEqual(result, [b'abc\n', b'def\n', b'ghi\n']) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|     def test_mock_open_read_with_argument(self): |     def test_mock_open_read_with_argument(self): | ||||||
|         # At one point calling read with an argument was broken |         # At one point calling read with an argument was broken | ||||||
|         # for mocks returned by mock_open |         # for mocks returned by mock_open | ||||||
|  |  | ||||||
|  | @ -71,6 +71,9 @@ Library | ||||||
| 
 | 
 | ||||||
| - Issue #23888: Handle fractional time in cookie expiry. Patch by ssh. | - Issue #23888: Handle fractional time in cookie expiry. Patch by ssh. | ||||||
| 
 | 
 | ||||||
|  | - Issue #23004: mock_open() now reads binary data correctly when the type of | ||||||
|  |   read_data is bytes.  Initial patch by Aaron Hill. | ||||||
|  | 
 | ||||||
| - Issue #23652: Make it possible to compile the select module against the | - Issue #23652: Make it possible to compile the select module against the | ||||||
|   libc headers from the Linux Standard Base, which do not include some |   libc headers from the Linux Standard Base, which do not include some | ||||||
|   EPOLL macros.  Patch by Matt Frank. |   EPOLL macros.  Patch by Matt Frank. | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Berker Peksag
						Berker Peksag