|
from abc import ABC, abstractmethod
|
|
|
|
from pydantic import BaseModel
|
|
|
|
from openhands.events.event import Event
|
|
from openhands.runtime.base import Runtime
|
|
|
|
|
|
class TestResult(BaseModel):
|
|
success: bool
|
|
reason: str | None = None
|
|
|
|
|
|
class BaseIntegrationTest(ABC):
|
|
"""Base class for integration tests."""
|
|
|
|
INSTRUCTION: str
|
|
|
|
@classmethod
|
|
@abstractmethod
|
|
def initialize_runtime(cls, runtime: Runtime) -> None:
|
|
"""Initialize the runtime for the test to run."""
|
|
pass
|
|
|
|
@classmethod
|
|
@abstractmethod
|
|
def verify_result(cls, runtime: Runtime, histories: list[Event]) -> TestResult:
|
|
"""Verify the result of the test.
|
|
|
|
This method will be called after the agent performs the task on the runtime.
|
|
"""
|
|
pass
|
|
|