Merge remote-tracking branch 'origin/dev' into feat/norms-and-goals-program

This commit is contained in:
Twirre Meulenbelt
2025-11-25 11:29:27 +01:00
10 changed files with 26 additions and 59 deletions

View File

@@ -25,24 +25,14 @@ async def test_setup_bind(zmq_context, mocker):
settings = mocker.patch("control_backend.agents.actuation.robot_speech_agent.settings")
settings.zmq_settings.internal_sub_address = "tcp://internal:1234"
# Swallow background task coroutines to avoid un-awaited warnings
class Swallow:
def __init__(self):
self.calls = 0
async def __call__(self, coro):
self.calls += 1
coro.close()
swallow = Swallow()
agent.add_behavior = swallow
agent.add_behavior = MagicMock()
await agent.setup()
fake_socket.bind.assert_any_call("tcp://localhost:5555")
fake_socket.connect.assert_any_call("tcp://internal:1234")
fake_socket.setsockopt.assert_any_call(zmq.SUBSCRIBE, b"command")
assert swallow.calls == 1
agent.add_behavior.assert_called_once()
@pytest.mark.asyncio
@@ -53,22 +43,13 @@ async def test_setup_connect(zmq_context, mocker):
settings = mocker.patch("control_backend.agents.actuation.robot_speech_agent.settings")
settings.zmq_settings.internal_sub_address = "tcp://internal:1234"
class Swallow:
def __init__(self):
self.calls = 0
async def __call__(self, coro):
self.calls += 1
coro.close()
swallow = Swallow()
agent.add_behavior = swallow
agent.add_behavior = MagicMock()
await agent.setup()
fake_socket.connect.assert_any_call("tcp://localhost:5555")
fake_socket.connect.assert_any_call("tcp://internal:1234")
assert swallow.calls == 1
agent.add_behavior.assert_called_once()
@pytest.mark.asyncio

View File

@@ -46,16 +46,7 @@ async def test_setup_success_connects_and_starts_robot(zmq_context):
robot_instance.start = AsyncMock()
agent = RICommunicationAgent("ri_comm", address="tcp://localhost:5555", bind=False)
class Swallow:
def __init__(self):
self.calls = 0
async def __call__(self, coro):
self.calls += 1
coro.close()
swallow = Swallow()
agent.add_behavior = swallow
agent.add_behavior = MagicMock()
await agent.setup()
@@ -63,7 +54,7 @@ async def test_setup_success_connects_and_starts_robot(zmq_context):
fake_socket.send_json.assert_any_call({"endpoint": "negotiate/ports", "data": {}})
robot_instance.start.assert_awaited_once()
MockRobot.assert_called_once_with(ANY, address="tcp://*:5556", bind=True)
assert swallow.calls == 1
agent.add_behavior.assert_called_once()
assert agent.connected is True
@@ -76,23 +67,14 @@ async def test_setup_binds_when_requested(zmq_context):
agent = RICommunicationAgent("ri_comm", address="tcp://localhost:5555", bind=True)
class Swallow:
def __init__(self):
self.calls = 0
async def __call__(self, coro):
self.calls += 1
coro.close()
swallow = Swallow()
agent.add_behavior = swallow
agent.add_behavior = MagicMock()
with patch(speech_agent_path(), autospec=True) as MockRobot:
MockRobot.return_value.start = AsyncMock()
await agent.setup()
fake_socket.bind.assert_any_call("tcp://localhost:5555")
assert swallow.calls == 1
agent.add_behavior.assert_called_once()
@pytest.mark.asyncio

View File

@@ -33,14 +33,16 @@ async def test_agent_lifecycle():
# Test background task
async def dummy_task():
await asyncio.sleep(0.01)
pass
await agent.add_behavior(dummy_task())
assert len(agent._tasks) > 0
task = agent.add_behavior(dummy_task())
assert task in agent._tasks
await task
# Wait for task to finish
await asyncio.sleep(0.02)
assert len(agent._tasks) == 2 # message handling tasks are running
assert task not in agent._tasks
assert len(agent._tasks) == 2 # message handling tasks are still running
await agent.stop()
assert agent._running is False