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 回前端。

相关推荐
梓色系4 小时前
Spring AI 实战:从零搭建 MCP 客户端与服务端,让大模型拥有“手脚“
java·人工智能·spring
“码”力全开4 小时前
解构企业级安防中台:基于Docker容器化与GB28181/RTSP多协议汇聚的边缘计算AI视频管理平台(全量源码交付)
人工智能·docker·边缘计算
GeeLark4 小时前
TikTok自动化 我们有在优化
人工智能
秦时星星4 小时前
Spring AI + FastMCP 跨语言集成踩坑实录
java·人工智能·spring
码农小白AI4 小时前
单据审核难度大?IACheck AI 报告审核联动全流程高效核验
人工智能
聚城云-GeecityCloud4 小时前
数字化破局|不分物业规模,皆可全新升级
大数据·人工智能
小白考证进阶中4 小时前
阿里云ACA大模型|6月15日课程和大纲大改⚠️
人工智能·阿里云·阿里云认证·阿里云acp备考·阿里云aca证书·ai证书·阿里云aca大模型
Esaka_Forever4 小时前
FAISS (Facebook AI Similarity Search)
人工智能·faiss
摄影图4 小时前
[图片素材]大模型训练开发 场景覆盖适配各类科技
人工智能·科技·aigc·贴图
CSND7404 小时前
零基础学Python合集---3:字符串的定义和常用方法
人工智能·python