mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	bpo-44011: Revert "New asyncio ssl implementation (GH-17975)" (GH-25848)
This reverts commit 5fb06edbbb and all
subsequent dependent commits.
			
			
This commit is contained in:
		
							parent
							
								
									39494285e1
								
							
						
					
					
						commit
						7719953b30
					
				
					 12 changed files with 524 additions and 2477 deletions
				
			
		|  | @ -15,6 +15,7 @@ | |||
| from asyncio import log | ||||
| from asyncio import protocols | ||||
| from asyncio import sslproto | ||||
| from test import support | ||||
| from test.test_asyncio import utils as test_utils | ||||
| from test.test_asyncio import functional as func_tests | ||||
| 
 | ||||
|  | @ -43,13 +44,16 @@ def ssl_protocol(self, *, waiter=None, proto=None): | |||
| 
 | ||||
|     def connection_made(self, ssl_proto, *, do_handshake=None): | ||||
|         transport = mock.Mock() | ||||
|         sslobj = mock.Mock() | ||||
|         # emulate reading decompressed data | ||||
|         sslobj.read.side_effect = ssl.SSLWantReadError | ||||
|         if do_handshake is not None: | ||||
|             sslobj.do_handshake = do_handshake | ||||
|         ssl_proto._sslobj = sslobj | ||||
|         ssl_proto.connection_made(transport) | ||||
|         sslpipe = mock.Mock() | ||||
|         sslpipe.shutdown.return_value = b'' | ||||
|         if do_handshake: | ||||
|             sslpipe.do_handshake.side_effect = do_handshake | ||||
|         else: | ||||
|             def mock_handshake(callback): | ||||
|                 return [] | ||||
|             sslpipe.do_handshake.side_effect = mock_handshake | ||||
|         with mock.patch('asyncio.sslproto._SSLPipe', return_value=sslpipe): | ||||
|             ssl_proto.connection_made(transport) | ||||
|         return transport | ||||
| 
 | ||||
|     def test_handshake_timeout_zero(self): | ||||
|  | @ -71,10 +75,7 @@ def test_handshake_timeout_negative(self): | |||
|     def test_eof_received_waiter(self): | ||||
|         waiter = self.loop.create_future() | ||||
|         ssl_proto = self.ssl_protocol(waiter=waiter) | ||||
|         self.connection_made( | ||||
|             ssl_proto, | ||||
|             do_handshake=mock.Mock(side_effect=ssl.SSLWantReadError) | ||||
|         ) | ||||
|         self.connection_made(ssl_proto) | ||||
|         ssl_proto.eof_received() | ||||
|         test_utils.run_briefly(self.loop) | ||||
|         self.assertIsInstance(waiter.exception(), ConnectionResetError) | ||||
|  | @ -99,10 +100,7 @@ def test_connection_lost(self): | |||
|         # yield from waiter hang if lost_connection was called. | ||||
|         waiter = self.loop.create_future() | ||||
|         ssl_proto = self.ssl_protocol(waiter=waiter) | ||||
|         self.connection_made( | ||||
|             ssl_proto, | ||||
|             do_handshake=mock.Mock(side_effect=ssl.SSLWantReadError) | ||||
|         ) | ||||
|         self.connection_made(ssl_proto) | ||||
|         ssl_proto.connection_lost(ConnectionAbortedError) | ||||
|         test_utils.run_briefly(self.loop) | ||||
|         self.assertIsInstance(waiter.exception(), ConnectionAbortedError) | ||||
|  | @ -112,10 +110,7 @@ def test_close_during_handshake(self): | |||
|         waiter = self.loop.create_future() | ||||
|         ssl_proto = self.ssl_protocol(waiter=waiter) | ||||
| 
 | ||||
|         transport = self.connection_made( | ||||
|             ssl_proto, | ||||
|             do_handshake=mock.Mock(side_effect=ssl.SSLWantReadError) | ||||
|         ) | ||||
|         transport = self.connection_made(ssl_proto) | ||||
|         test_utils.run_briefly(self.loop) | ||||
| 
 | ||||
|         ssl_proto._app_transport.close() | ||||
|  | @ -148,7 +143,7 @@ def test_data_received_after_closing(self): | |||
|         transp.close() | ||||
| 
 | ||||
|         # should not raise | ||||
|         self.assertIsNone(ssl_proto.buffer_updated(5)) | ||||
|         self.assertIsNone(ssl_proto.data_received(b'data')) | ||||
| 
 | ||||
|     def test_write_after_closing(self): | ||||
|         ssl_proto = self.ssl_protocol() | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Pablo Galindo
						Pablo Galindo