chore(graph): Relocate QueryAnalysis schema and update existing tests for Orchestrator architecture

This commit is contained in:
Yunxiao Xu
2026-02-23 05:58:58 -08:00
parent ad7845cc6a
commit f4d09c07c4
7 changed files with 199 additions and 227 deletions

View File

@@ -1,6 +1,7 @@
import pytest
from unittest.mock import MagicMock, patch
from ea_chatbot.graph.nodes.planner import planner_node
from ea_chatbot.schemas import ChecklistResponse, ChecklistTask
@pytest.fixture
def mock_state():
@@ -8,39 +9,40 @@ def mock_state():
"messages": [],
"question": "Show me results for New Jersey",
"analysis": {
# "requires_dataset" removed as it's no longer used
"expert": "Data Analyst",
"data": "NJ data",
"unknown": "results",
"condition": "state=NJ"
},
"next_action": "plan",
"plan": None
"checklist": [],
"current_step": 0
}
@patch("ea_chatbot.graph.nodes.planner.get_llm_model")
@patch("ea_chatbot.utils.database_inspection.get_data_summary")
def test_planner_node(mock_get_summary, mock_get_llm, mock_state):
"""Test planner node with unified prompt."""
"""Test planner node with checklist generation."""
mock_get_summary.return_value = "Column: Name, Type: text"
mock_llm = MagicMock()
mock_get_llm.return_value = mock_llm
from ea_chatbot.schemas import TaskPlanResponse, TaskPlanContext
mock_plan = TaskPlanResponse(
mock_response = ChecklistResponse(
goal="Get NJ results",
reflection="The user wants NJ results",
context=TaskPlanContext(initial_context="NJ data", assumptions=[], constraints=[]),
steps=["Step 1: Load data", "Step 2: Filter by NJ"]
checklist=[
ChecklistTask(task="Query NJ data", worker="data_analyst")
]
)
mock_llm.with_structured_output.return_value.invoke.return_value = mock_plan
mock_llm.with_structured_output.return_value.invoke.return_value = mock_response
result = planner_node(mock_state)
assert "plan" in result
assert "Step 1: Load data" in result["plan"]
assert "Step 2: Filter by NJ" in result["plan"]
assert "checklist" in result
assert result["checklist"][0]["task"] == "Query NJ data"
assert result["current_step"] == 0
assert result["summary"] == "The user wants NJ results"
# Verify helper was called
mock_get_summary.assert_called_once()
mock_get_summary.assert_called_once()