mirror of
https://github.com/OpenHands/OpenHands.git
synced 2025-12-26 05:48:36 +08:00
Co-authored-by: Engel Nyst <enyst@users.noreply.github.com> Co-authored-by: Xingyao Wang <xingyao@all-hands.dev> Co-authored-by: Xingyao Wang <xingyao6@illinois.edu>
51 lines
1.7 KiB
Python
51 lines
1.7 KiB
Python
import asyncio
|
|
|
|
from openhands.controller import AgentController
|
|
from openhands.core.logger import openhands_logger as logger
|
|
from openhands.core.schema import AgentState
|
|
from openhands.runtime.base import Runtime
|
|
|
|
|
|
async def run_agent_until_done(
|
|
controller: AgentController,
|
|
runtime: Runtime,
|
|
end_states: list[AgentState],
|
|
):
|
|
"""
|
|
run_agent_until_done takes a controller and a runtime, and will run
|
|
the agent until it reaches a terminal state.
|
|
Note that runtime must be connected before being passed in here.
|
|
"""
|
|
controller.agent_task = asyncio.create_task(controller.start_step_loop())
|
|
|
|
def status_callback(msg_type, msg_id, msg):
|
|
if msg_type == 'error':
|
|
logger.error(msg)
|
|
if controller:
|
|
controller.state.last_error = msg
|
|
asyncio.create_task(controller.set_agent_state_to(AgentState.ERROR))
|
|
else:
|
|
logger.info(msg)
|
|
|
|
if hasattr(runtime, 'status_callback') and runtime.status_callback:
|
|
raise ValueError(
|
|
'Runtime status_callback was set, but run_agent_until_done will override it'
|
|
)
|
|
if hasattr(controller, 'status_callback') and controller.status_callback:
|
|
raise ValueError(
|
|
'Controller status_callback was set, but run_agent_until_done will override it'
|
|
)
|
|
|
|
runtime.status_callback = status_callback
|
|
controller.status_callback = status_callback
|
|
|
|
while controller.state.agent_state not in end_states:
|
|
await asyncio.sleep(1)
|
|
|
|
if not controller.agent_task.done():
|
|
controller.agent_task.cancel()
|
|
try:
|
|
await controller.agent_task
|
|
except asyncio.CancelledError:
|
|
pass
|