forked from M-Labs/artiq
84 lines
2.8 KiB
Python
84 lines
2.8 KiB
Python
import os
|
|
import sys
|
|
import unittest
|
|
import logging
|
|
import asyncio
|
|
|
|
from artiq.master.ctlmgr import Controllers
|
|
from artiq.protocols.pc_rpc import AsyncioClient
|
|
from artiq.tools import expect_no_log_messages
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class ControllerCase(unittest.TestCase):
|
|
def setUp(self):
|
|
if os.name == "nt":
|
|
self.loop = asyncio.ProactorEventLoop()
|
|
else:
|
|
self.loop = asyncio.new_event_loop()
|
|
asyncio.set_event_loop(self.loop)
|
|
self.addCleanup(self.loop.close)
|
|
|
|
self.controllers = Controllers()
|
|
self.controllers.host_filter = "::1"
|
|
self.addCleanup(
|
|
self.loop.run_until_complete, self.controllers.shutdown())
|
|
|
|
async def start(self, name, entry):
|
|
self.controllers[name] = entry
|
|
await self.controllers.queue.join()
|
|
await self.wait_for_ping(entry["host"], entry["port"])
|
|
|
|
async def get_client(self, host, port):
|
|
remote = AsyncioClient()
|
|
await remote.connect_rpc(host, port, None)
|
|
targets, _ = remote.get_rpc_id()
|
|
await remote.select_rpc_target(targets[0])
|
|
self.addCleanup(remote.close_rpc)
|
|
return remote
|
|
|
|
async def wait_for_ping(self, host, port, retries=5, timeout=2):
|
|
dt = timeout/retries
|
|
while timeout > 0:
|
|
try:
|
|
remote = await self.get_client(host, port)
|
|
ok = await asyncio.wait_for(remote.ping(), dt)
|
|
if not ok:
|
|
raise ValueError("unexcepted ping() response from "
|
|
"controller: `{}`".format(ok))
|
|
return ok
|
|
except asyncio.TimeoutError:
|
|
timeout -= dt
|
|
except (ConnectionAbortedError, ConnectionError,
|
|
ConnectionRefusedError, ConnectionResetError):
|
|
await asyncio.sleep(dt)
|
|
timeout -= dt
|
|
raise asyncio.TimeoutError
|
|
|
|
def test_start_ping_stop_controller(self):
|
|
entry = {
|
|
"type": "controller",
|
|
"host": "::1",
|
|
"port": 1068,
|
|
"command": (sys.executable.replace("\\", "\\\\")
|
|
+ " -m artiq.frontend.aqctl_corelog "
|
|
+ "-p {port} --simulation foo")
|
|
}
|
|
async def test():
|
|
await self.start("corelog", entry)
|
|
remote = await self.get_client(entry["host"], entry["port"])
|
|
await remote.ping()
|
|
|
|
self.loop.run_until_complete(test())
|
|
|
|
def test_no_command_controller(self):
|
|
entry = {
|
|
"type": "controller",
|
|
"host": "::1",
|
|
"port": 1068
|
|
}
|
|
with expect_no_log_messages(logging.ERROR):
|
|
self.controllers["corelog"] = entry
|
|
self.assertTrue(self.controllers.queue.empty())
|