import sys
from pathlib import Path

ROOT = Path(__file__).resolve().parents[1]
if str(ROOT) not in sys.path:
    sys.path.insert(0, str(ROOT))

from agent_evaluation import SemLlmConfig, Situation, append_run_result, extract_graph_transitions


def test_extract_graph_transitions_from_executor_log():
    log_content = "\n".join(
        [
            "action: register_profile",
            "graph_transition: __start__ -> start",
            'graph_transition: read_signifier1 -> error | condition: "current_goal missing"',
        ]
    )

    assert extract_graph_transitions(log_content) == [
        "__start__ -> start",
        'read_signifier1 -> error | condition: "current_goal missing"',
    ]


def test_append_run_result_includes_cherrybot_operation_logs(tmp_path):
    results_path = tmp_path / "agent_results.txt"
    situation = Situation(
        app_config="config_app.json",
        sem_llm=SemLlmConfig(provider="ollama", model="ministral-3:14b"),
        goal="Move the robot by 10 centimeters",
    )

    append_run_result(
        results_path=results_path,
        situation=situation,
        run_index=1,
        runs=1,
        elapsed_s=1.23,
        log_content="graph_transition: __start__ -> start",
        app_ready=True,
        agent_exit_code=0,
        agent_timed_out=False,
        error=None,
        cherrybot_logs={
            "count": 1,
            "operations": [{"operation": "move", "value": 10.0, "status": 200}],
        },
    )

    content = results_path.read_text(encoding="utf-8")

    assert "Cherrybot operation logs:" in content
    assert '"operation": "move"' in content
    assert '"value": 10.0' in content
