003 File Manager
Current Path:
/usr/local/lib/python3.8/test/test_asyncio
usr
/
local
/
lib
/
python3.8
/
test
/
test_asyncio
/
📁
..
📄
__init__.py
(244 B)
📄
__main__.py
(58 B)
📁
__pycache__
📄
echo.py
(148 B)
📄
echo2.py
(123 B)
📄
echo3.py
(276 B)
📄
functional.py
(7.47 KB)
📄
test_asyncio_waitfor.py
(1.45 KB)
📄
test_base_events.py
(78.14 KB)
📄
test_buffered_proto.py
(2.28 KB)
📄
test_context.py
(1020 B)
📄
test_events.py
(99.68 KB)
📄
test_futures.py
(26.42 KB)
📄
test_futures2.py
(694 B)
📄
test_locks.py
(33.67 KB)
📄
test_pep492.py
(6.04 KB)
📄
test_proactor_events.py
(35.04 KB)
📄
test_protocols.py
(2 KB)
📄
test_queues.py
(21.16 KB)
📄
test_runners.py
(5.06 KB)
📄
test_selector_events.py
(47.17 KB)
📄
test_sendfile.py
(19.67 KB)
📄
test_server.py
(3.93 KB)
📄
test_sock_lowlevel.py
(11.84 KB)
📄
test_sslproto.py
(25.78 KB)
📄
test_streams.py
(36.21 KB)
📄
test_subprocess.py
(25.33 KB)
📄
test_tasks.py
(107.17 KB)
📄
test_transports.py
(3.53 KB)
📄
test_unix_events.py
(66.23 KB)
📄
test_windows_events.py
(8.92 KB)
📄
test_windows_utils.py
(4.07 KB)
📄
utils.py
(16.83 KB)
Editing: test_sock_lowlevel.py
import socket import asyncio import sys from asyncio import proactor_events from itertools import cycle, islice from test.test_asyncio import utils as test_utils from test import support class MyProto(asyncio.Protocol): connected = None done = None def __init__(self, loop=None): self.transport = None self.state = 'INITIAL' self.nbytes = 0 if loop is not None: self.connected = loop.create_future() self.done = loop.create_future() def connection_made(self, transport): self.transport = transport assert self.state == 'INITIAL', self.state self.state = 'CONNECTED' if self.connected: self.connected.set_result(None) transport.write(b'GET / HTTP/1.0\r\nHost: example.com\r\n\r\n') def data_received(self, data): assert self.state == 'CONNECTED', self.state self.nbytes += len(data) def eof_received(self): assert self.state == 'CONNECTED', self.state self.state = 'EOF' def connection_lost(self, exc): assert self.state in ('CONNECTED', 'EOF'), self.state self.state = 'CLOSED' if self.done: self.done.set_result(None) class BaseSockTestsMixin: def create_event_loop(self): raise NotImplementedError def setUp(self): self.loop = self.create_event_loop() self.set_event_loop(self.loop) super().setUp() def tearDown(self): # just in case if we have transport close callbacks if not self.loop.is_closed(): test_utils.run_briefly(self.loop) self.doCleanups() support.gc_collect() super().tearDown() def _basetest_sock_client_ops(self, httpd, sock): if not isinstance(self.loop, proactor_events.BaseProactorEventLoop): # in debug mode, socket operations must fail # if the socket is not in blocking mode self.loop.set_debug(True) sock.setblocking(True) with self.assertRaises(ValueError): self.loop.run_until_complete( self.loop.sock_connect(sock, httpd.address)) with self.assertRaises(ValueError): self.loop.run_until_complete( self.loop.sock_sendall(sock, b'GET / HTTP/1.0\r\n\r\n')) with self.assertRaises(ValueError): self.loop.run_until_complete( self.loop.sock_recv(sock, 1024)) with self.assertRaises(ValueError): self.loop.run_until_complete( self.loop.sock_recv_into(sock, bytearray())) with self.assertRaises(ValueError): self.loop.run_until_complete( self.loop.sock_accept(sock)) # test in non-blocking mode sock.setblocking(False) self.loop.run_until_complete( self.loop.sock_connect(sock, httpd.address)) self.loop.run_until_complete( self.loop.sock_sendall(sock, b'GET / HTTP/1.0\r\n\r\n')) data = self.loop.run_until_complete( self.loop.sock_recv(sock, 1024)) # consume data self.loop.run_until_complete( self.loop.sock_recv(sock, 1024)) sock.close() self.assertTrue(data.startswith(b'HTTP/1.0 200 OK')) def _basetest_sock_recv_into(self, httpd, sock): # same as _basetest_sock_client_ops, but using sock_recv_into sock.setblocking(False) self.loop.run_until_complete( self.loop.sock_connect(sock, httpd.address)) self.loop.run_until_complete( self.loop.sock_sendall(sock, b'GET / HTTP/1.0\r\n\r\n')) data = bytearray(1024) with memoryview(data) as buf: nbytes = self.loop.run_until_complete( self.loop.sock_recv_into(sock, buf[:1024])) # consume data self.loop.run_until_complete( self.loop.sock_recv_into(sock, buf[nbytes:])) sock.close() self.assertTrue(data.startswith(b'HTTP/1.0 200 OK')) def test_sock_client_ops(self): with test_utils.run_test_server() as httpd: sock = socket.socket() self._basetest_sock_client_ops(httpd, sock) sock = socket.socket() self._basetest_sock_recv_into(httpd, sock) async def _basetest_huge_content(self, address): sock = socket.socket() sock.setblocking(False) DATA_SIZE = 10_000_00 chunk = b'0123456789' * (DATA_SIZE // 10) await self.loop.sock_connect(sock, address) await self.loop.sock_sendall(sock, (b'POST /loop HTTP/1.0\r\n' + b'Content-Length: %d\r\n' % DATA_SIZE + b'\r\n')) task = asyncio.create_task(self.loop.sock_sendall(sock, chunk)) data = await self.loop.sock_recv(sock, DATA_SIZE) # HTTP headers size is less than MTU, # they are sent by the first packet always self.assertTrue(data.startswith(b'HTTP/1.0 200 OK')) while data.find(b'\r\n\r\n') == -1: data += await self.loop.sock_recv(sock, DATA_SIZE) # Strip headers headers = data[:data.index(b'\r\n\r\n') + 4] data = data[len(headers):] size = DATA_SIZE checker = cycle(b'0123456789') expected = bytes(islice(checker, len(data))) self.assertEqual(data, expected) size -= len(data) while True: data = await self.loop.sock_recv(sock, DATA_SIZE) if not data: break expected = bytes(islice(checker, len(data))) self.assertEqual(data, expected) size -= len(data) self.assertEqual(size, 0) await task sock.close() def test_huge_content(self): with test_utils.run_test_server() as httpd: self.loop.run_until_complete( self._basetest_huge_content(httpd.address)) async def _basetest_huge_content_recvinto(self, address): sock = socket.socket() sock.setblocking(False) DATA_SIZE = 10_000_00 chunk = b'0123456789' * (DATA_SIZE // 10) await self.loop.sock_connect(sock, address) await self.loop.sock_sendall(sock, (b'POST /loop HTTP/1.0\r\n' + b'Content-Length: %d\r\n' % DATA_SIZE + b'\r\n')) task = asyncio.create_task(self.loop.sock_sendall(sock, chunk)) array = bytearray(DATA_SIZE) buf = memoryview(array) nbytes = await self.loop.sock_recv_into(sock, buf) data = bytes(buf[:nbytes]) # HTTP headers size is less than MTU, # they are sent by the first packet always self.assertTrue(data.startswith(b'HTTP/1.0 200 OK')) while data.find(b'\r\n\r\n') == -1: nbytes = await self.loop.sock_recv_into(sock, buf) data = bytes(buf[:nbytes]) # Strip headers headers = data[:data.index(b'\r\n\r\n') + 4] data = data[len(headers):] size = DATA_SIZE checker = cycle(b'0123456789') expected = bytes(islice(checker, len(data))) self.assertEqual(data, expected) size -= len(data) while True: nbytes = await self.loop.sock_recv_into(sock, buf) data = buf[:nbytes] if not data: break expected = bytes(islice(checker, len(data))) self.assertEqual(data, expected) size -= len(data) self.assertEqual(size, 0) await task sock.close() def test_huge_content_recvinto(self): with test_utils.run_test_server() as httpd: self.loop.run_until_complete( self._basetest_huge_content_recvinto(httpd.address)) @support.skip_unless_bind_unix_socket def test_unix_sock_client_ops(self): with test_utils.run_test_unix_server() as httpd: sock = socket.socket(socket.AF_UNIX) self._basetest_sock_client_ops(httpd, sock) sock = socket.socket(socket.AF_UNIX) self._basetest_sock_recv_into(httpd, sock) def test_sock_client_fail(self): # Make sure that we will get an unused port address = None try: s = socket.socket() s.bind(('127.0.0.1', 0)) address = s.getsockname() finally: s.close() sock = socket.socket() sock.setblocking(False) with self.assertRaises(ConnectionRefusedError): self.loop.run_until_complete( self.loop.sock_connect(sock, address)) sock.close() def test_sock_accept(self): listener = socket.socket() listener.setblocking(False) listener.bind(('127.0.0.1', 0)) listener.listen(1) client = socket.socket() client.connect(listener.getsockname()) f = self.loop.sock_accept(listener) conn, addr = self.loop.run_until_complete(f) self.assertEqual(conn.gettimeout(), 0) self.assertEqual(addr, client.getsockname()) self.assertEqual(client.getpeername(), listener.getsockname()) client.close() conn.close() listener.close() def test_create_connection_sock(self): with test_utils.run_test_server() as httpd: sock = None infos = self.loop.run_until_complete( self.loop.getaddrinfo( *httpd.address, type=socket.SOCK_STREAM)) for family, type, proto, cname, address in infos: try: sock = socket.socket(family=family, type=type, proto=proto) sock.setblocking(False) self.loop.run_until_complete( self.loop.sock_connect(sock, address)) except BaseException: pass else: break else: assert False, 'Can not create socket.' f = self.loop.create_connection( lambda: MyProto(loop=self.loop), sock=sock) tr, pr = self.loop.run_until_complete(f) self.assertIsInstance(tr, asyncio.Transport) self.assertIsInstance(pr, asyncio.Protocol) self.loop.run_until_complete(pr.done) self.assertGreater(pr.nbytes, 0) tr.close() if sys.platform == 'win32': class SelectEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.SelectorEventLoop() class ProactorEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.ProactorEventLoop() else: import selectors if hasattr(selectors, 'KqueueSelector'): class KqueueEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.SelectorEventLoop( selectors.KqueueSelector()) if hasattr(selectors, 'EpollSelector'): class EPollEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.SelectorEventLoop(selectors.EpollSelector()) if hasattr(selectors, 'PollSelector'): class PollEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.SelectorEventLoop(selectors.PollSelector()) # Should always exist. class SelectEventLoopTests(BaseSockTestsMixin, test_utils.TestCase): def create_event_loop(self): return asyncio.SelectorEventLoop(selectors.SelectSelector())
Upload File
Create Folder