From 1b792c5ee205272adec6a856ebe6118178ac687b Mon Sep 17 00:00:00 2001 From: amit lissack Date: Sat, 23 Oct 2021 09:32:49 -0400 Subject: [PATCH] implement connection listener. --- .../emulation/module_server/helpers.py | 25 +++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/api/src/opentrons/hardware_control/emulation/module_server/helpers.py b/api/src/opentrons/hardware_control/emulation/module_server/helpers.py index 450bf8ad1d34..153a67b4dc45 100644 --- a/api/src/opentrons/hardware_control/emulation/module_server/helpers.py +++ b/api/src/opentrons/hardware_control/emulation/module_server/helpers.py @@ -1,6 +1,7 @@ import asyncio from typing import Sequence, Set, Callable, List, Awaitable +from opentrons.drivers.rpi_drivers.types import USBPort from opentrons.hardware_control.emulation.module_server.client import ModuleServerClient from opentrons.hardware_control.emulation.module_server.models import Message from opentrons.hardware_control.emulation.module_server.server import log @@ -28,14 +29,34 @@ def __init__(self, client: ModuleServerClient, notify_method: NotifyMethod) -> N self._notify_method = notify_method async def run(self) -> None: - """""" + """Run the listener.""" while True: m = await self._client.read() await self.message_to_notify(message=m, notify_method=self._notify_method) @staticmethod async def message_to_notify(message: Message, notify_method: NotifyMethod) -> None: - await notify_method([], []) + """Call callback with results of message. + + Args: + message: Message object from module server + notify_method: callback method + + Returns: + None + """ + connections = [ + ModuleAtPort( + port=c.url, + name=c.module_type, + usb_port=USBPort(name=c.identifier, sub_names=[]), + ) + for c in message.connections + ] + if message.status == "connected" or message.status == "dump": + await notify_method(connections, []) + elif message.status == "disconnected": + await notify_method([], connections) async def wait_emulators(