aboutsummaryrefslogtreecommitdiff
path: root/testserver.py
blob: 1710a4a9481002c74254ad3b89872086173d8868 (about) (plain) (blame)
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
import asyncio
import logging
import random


logging.basicConfig(level = logging.INFO, format = '{asctime} {levelname} {message}', style = '{')


class FakeIRCServerProtocol(asyncio.Protocol):
	def __init__(self, loop = None):
		self.loop = loop or asyncio.get_event_loop()

	def send(self, data):
		logging.info(f'Send: {data!r}')
		self.transport.write(data)

	def connection_made(self, transport):
		logging.info(f'Connection from {transport.get_extra_info("peername")}')
		self.transport = transport
		self.connected = True
		asyncio.create_task(self.pingloop())

	async def pingloop(self):
		while self.connected:
			self.send(b'PING :' + str(random.randint(0, 10000)).encode('ascii') + b'\r\n')
			await asyncio.sleep(10)

	def data_received(self, data):
		logging.info(f'Data received: {data!r}')

	def connection_lost(self, exc):
		logging.info(f'Connection to {self.transport.get_extra_info("peername")} lost')
		self.connected = False


async def main():
	loop = asyncio.get_running_loop()
	server = await loop.create_server(lambda: FakeIRCServerProtocol(), '127.0.0.1', 8888)
	async with server:
		await server.serve_forever()


asyncio.run(main())