TaskFlow / tests /contract /test_get_task_contract.py
BilalCode's picture
taskflow todo app
310260a
Raw
History Blame Contribute Delete
3.25 kB
"""
Contract Tests for get_task Tool
Validates that get_task tool adheres to its defined contract.
"""
import pytest
import json
from src.tools.get_task import get_task_internal, get_tool_definition
from tests.utils.task_helpers import create_test_task
@pytest.mark.contract
@pytest.mark.asyncio
async def test_get_task_input_schema_validation(mock_mcp_context, test_session):
"""
Test: get_task input schema validation
Verifies that get_task accepts inputs matching the defined schema.
"""
# Get tool definition
tool_def = get_tool_definition()
# Verify tool definition structure
assert tool_def["type"] == "function"
assert "function" in tool_def
assert tool_def["function"]["name"] == "get_task"
# Verify parameters schema
params = tool_def["function"]["parameters"]
assert params["type"] == "object"
assert "properties" in params
assert "task_id" in params["properties"]
assert params["required"] == ["task_id"]
# Test valid input
task = create_test_task(test_session, mock_mcp_context.user_id, title="Test")
result = await get_task_internal(
ctx=mock_mcp_context,
task_id=task.id
)
assert result["status"] == "success"
@pytest.mark.contract
@pytest.mark.asyncio
async def test_get_task_output_schema_validation(mock_mcp_context, test_session):
"""
Test: get_task output schema validation
Verifies that get_task returns outputs matching the defined schema.
"""
# Setup
task = create_test_task(test_session, mock_mcp_context.user_id, title="Test Task")
# Execute
result = await get_task_internal(
ctx=mock_mcp_context,
task_id=task.id
)
# Verify output schema
assert "status" in result
assert result["status"] == "success"
assert "task" in result
task_data = result["task"]
assert "id" in task_data
assert isinstance(task_data["id"], int)
assert "title" in task_data
assert isinstance(task_data["title"], str)
assert "completed" in task_data
assert isinstance(task_data["completed"], bool)
assert "created_at" in task_data
assert isinstance(task_data["created_at"], str)
assert "updated_at" in task_data
assert isinstance(task_data["updated_at"], str)
@pytest.mark.contract
def test_get_task_tool_definition_matches_contract():
"""
Test: get_task tool definition matches contract
Verifies that the tool definition matches the contract specification.
"""
# Load contract from file
import os
contract_path = os.path.join(
os.path.dirname(__file__),
"../../../specs/001-mcp-server-tools/contracts/get_task.json"
)
with open(contract_path, "r") as f:
contract = json.load(f)
# Get tool definition
tool_def = get_tool_definition()
# Verify tool name matches
assert tool_def["function"]["name"] == contract["tool_name"]
# Verify input schema structure matches
tool_params = tool_def["function"]["parameters"]
contract_input = contract["input_schema"]
assert tool_params["type"] == contract_input["type"]
assert "task_id" in tool_params["properties"]
assert tool_params["required"] == contract_input["required"]