60 lines
1.7 KiB
Python
Raw Normal View History

2025-06-17 16:50:54 -04:00
"""Create a cluster."""
from aiohttp import ClientSession
2025-06-22 17:04:37 -04:00
from release_tests.support import get_port
2025-06-17 16:50:54 -04:00
from release_tests.support.mttserver import MTTServer
from release_tests.support.translate import Translate
2025-06-22 17:04:37 -04:00
ADDR = "127.56.0.1"
2025-06-17 16:56:04 -04:00
class Cluster:
2025-06-17 16:50:54 -04:00
"""cluster of MoreThanText."""
def __init__(self, num=2, transurl=None, transreplies=None):
2025-06-17 16:50:54 -04:00
"""initialization"""
2025-06-22 17:04:37 -04:00
self.num = num
self.translate = Translate(url=transurl, replies=transreplies)
self.session = None
2025-06-17 16:50:54 -04:00
self.servers = []
async def start(self):
"""Start the cluster."""
await self.translate.start()
2025-06-22 17:04:37 -04:00
for _ in range(self.num):
port = get_port()
server = MTTServer("-a", ADDR, "-p", port)
2025-06-17 16:50:54 -04:00
await server.start()
2025-06-22 17:04:37 -04:00
self.servers.append(server)
self.session = ClientSession()
async def start_a_server(self, *args):
"""Creates a single server."""
self.num = 1
server = MTTServer(*args)
await server.start()
self.servers.append(server)
self.session = ClientSession()
2025-06-17 16:50:54 -04:00
async def stop(self):
"""Stops cluster."""
2025-06-22 17:04:37 -04:00
if self.session:
await self.session.close()
2025-06-17 16:50:54 -04:00
await self.translate.stop()
for server in self.servers:
await server.stop()
2025-06-22 17:04:37 -04:00
async def cleanup(self):
"""Cleans up the cluster."""
await self.stop()
for server in self.servers:
await server.cleanup()
async def get(self, url):
"""get from each server in the cluster."""
replies = []
for server in self.servers:
async with self.session.get(f"{server.baseurl}{url}") as resp:
replies.append(resp)
return replies