AI测试用例检查

1. 入口与路由

  • HTTP:POST /api/v1/test-case/check/consistency(在 api.py 里挂到 prefix="/test-case/check")。
  • 实现文件:backend/app/api/v1/endpoints/check.py
  • 前端:frontend/src/views/test-case/check/index.vue 优先带 ?stream=true 走 SSE 式流式;失败时再 request.upload 到同一路径(不传 stream,相当于非流式)。

2. 三条执行路径(由查询参数决定)

条件 实际做的事
stream=true(页面主路径) StreamingResponse_check_with_stream:AutoGen 的 AssistantAgent + DeepSeek 客户端,model_client_stream=True,把 chunk 打成 data: {...}\n\n 推给前端。
use_agent=true(前端默认不传,一般为 false) _check_with_agent:试图用 agent_factory.create_agent(AgentTypes.TEST_CASE_CHECKER) 创建 TestCaseCheckerAgent,并往 SingleThreadedAgentRuntimeregister_agent。当前代码里 若运行时不存在 register_agent会直接降级 到下面的「旧方法」。
默认(stream=falseuse_agent=false _check_with_legacy_method:同样是 AssistantAgent + DeepSeek,on_messages 一次性拿完整回复再解析 JSON。

因此:日常从页面点「检查」时,主要是流式路径;兜底是非流式的「直接 LLM」路径。
TestCaseCheckerAgent 只有在显式 use_agent=true 且运行时支持 register_agent 时才会真正跑通;否则会在 check.py 里降级到 _check_with_legacy_method


3. 用了哪个「智能体」

  • 名义上的业务智能体:TestCaseCheckerAgentbackend/app/agents/test_case/test_case_checker_agent.py),在工厂里注册为 AgentTypes.TEST_CASE_CHECKERapp/agents/factory.py)。
  • 实际承担推理的组件(流式 / 非流式主路径):都是 AutoGen AssistantAgent,名字在代码里写死为 "consistency_checker",并不是多智能体编排,而是 单助手 + 一次大模型调用。
  • TestCaseCheckerAgent 内部:若被调用,会通过 BaseAgent 发进度/流式片段,核心对比仍是对 get_deepseek_model_client()create_stream,再本地拼 JSON 解析。

4. 调用了哪些模块(按数据流)

  1. 上传与解析(CPU 密集丢线程池):app.utils.file_parser --- parse_docxparse_pdfparse_xmindextract_text_from_xmind
  2. 消息模型(仅智能体路径):TestCaseCheckRequest / TestCaseCheckResponse 等 --- app.core.messages.test_case
  3. 工厂(仅 use_agent 路径):agent_factory --- app.agents.factorycreate_agent 对非图类智能体默认会注入 get_deepseek_model_client()
  4. 流收集(仅 use_agent 路径):StreamResponseCollector --- app.core.agents.collector
  5. 大模型:get_deepseek_model_client --- app.core.llms(基于 autogen_ext.models.openai.OpenAIChatCompletionClient)。
  6. AutoGen:AssistantAgentTextMessageCancellationToken;流式路径还用 ModelClientStreamingChunkEvent;智能体路径用 SingleThreadedAgentRuntimeTopicIdTopicTypes 等。

5. 用的是什么大模型

  • 提供商 / 协议:DeepSeek 的 OpenAI 兼容接口(DEEPSEEK_BASE_URL,默认 https://api.deepseek.com/v1)。
  • 模型名:配置为 deepseek-chat(见 get_deepseek_model_client)。
  • 密钥:仅 DEEPSEEK_API_KEY(与你在项目里「只用 DeepSeek」的设定一致)。
  • 超时:用例检查里常量 CHECK_LLM_TIMEOUT = 420秒(7 分钟) 传给 get_deepseek_model_client;智能体路径若走通,还有 asyncio.wait_for(..., 60) 等待最终回调的上限(与 LLM 7 分钟是不同层)。

6. 内容截断

  • 流式 / legacy:CHECK_CONTENT_LIMIT = 35000 字符,PRD 与用例各截断后再拼进 prompt。
  • TestCaseCheckerAgent:内部 max_content_length 为 50000(若智能体路径生效,截断策略与上面两条略有不同)。

架构图

"真实生效"的主链路是 前端 stream=true → 后端 _check_with_streamAssistantAgentDeepSeek(deepseek-chat) → SSE 回前端。

相关推荐
二等饼干~za8986682 小时前
云罗 GEO 优化系统源码厂家测评报告
大数据·网络·数据库·人工智能·django
GISer_Jing2 小时前
前端视频多模态:编解码、传输、渲染全链路详解
前端·人工智能·音视频
乔公子搬砖2 小时前
告别识别率焦虑:视频 AI 工程化实战 —— 检测→判定→聚合→治理全链路拆解
人工智能·yolo·决策树·计算机视觉·视觉检测
视觉&物联智能2 小时前
【杂谈】-人工智能疲劳是真实存在的,但它并非你想象的那样
人工智能·ai·chatgpt·agi·deepseek
GlobalInfo2 小时前
工业控制类芯片市场份额、市场占有率、行业调研报告2026
大数据·人工智能·物联网
kuankeTech2 小时前
汇信云·盘古发布 开启外贸AI新时代
大数据·人工智能·自动化·数据可视化·软件开发
uzong2 小时前
107K Star:火爆的MarkItDown--一款用于将文件和办公文档转换为 Markdown 的 Python 工具
人工智能·后端·开源
江瀚视野2 小时前
电竞苏超即将上线,虎牙发力电竞苏超意欲何为?
大数据·人工智能
xiaoduo AI2 小时前
客服机器人首响时长最快可优化至几秒?智能 Agent 预加载常用语,响应比人工快多少?
大数据·人工智能·机器人