1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
# Test asyncio TCP server and client with TLS, and an incorrect server_hostname.
try:
import os
import asyncio
import ssl
except ImportError:
print("SKIP")
raise SystemExit
PORT = 8000
# These are test certificates. See tests/README.md for details.
cert = cafile = "ec_cert.der"
key = "ec_key.der"
try:
os.stat(cafile)
os.stat(key)
except OSError:
print("SKIP")
raise SystemExit
async def handle_connection(reader, writer):
print("handle connection")
try:
data = await reader.read(100)
except Exception as e:
print(e)
ev.set()
async def tcp_server():
global ev
server_ctx = ssl.SSLContext(ssl.PROTOCOL_TLS_SERVER)
server_ctx.load_cert_chain(cert, key)
ev = asyncio.Event()
server = await asyncio.start_server(handle_connection, "0.0.0.0", PORT, ssl=server_ctx)
print("server running")
multitest.next()
async with server:
await asyncio.wait_for(ev.wait(), 10)
print("server done")
multitest.broadcast("finished")
async def tcp_client(message):
client_ctx = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT)
client_ctx.verify_mode = ssl.CERT_REQUIRED
client_ctx.load_verify_locations(cafile=cafile)
reader, writer = await asyncio.open_connection(
IP,
PORT,
ssl=client_ctx,
server_hostname="foobar.local", # incorrect server_hostname
)
try:
print("write:", message)
writer.write(message)
print("drain")
await writer.drain()
except Exception as e:
print(e)
multitest.wait("finished")
print("client done")
def instance0():
multitest.globals(IP=multitest.get_network_ip())
asyncio.run(tcp_server())
def instance1():
multitest.next()
asyncio.run(tcp_client(b"client data"))
|