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

相关推荐
GISer_Jing21 小时前
AI原生全栈架构理论体系:从分布式范式演进到全链路工程化理论基石
前端·人工智能·学习·ai编程
一只叫煤球的猫21 小时前
别再把 Codex 念成“Code-X”,全错了,AI编程英语发音纠正
人工智能·面试·程序员
GISer_Jing21 小时前
从“切图仔”到“增长架构师”:AI时代营销前端的范式革命
前端·人工智能·ai编程
lohiecan21 小时前
国产自研开源新语言|梦丘 MOS-LANG 重磅登场!深耕 AI 编程与嵌入式生态
人工智能·junit
一水鉴天21 小时前
从“AI内在机制探询”到“三重三九格人本主权智能体架构”的演进 之1 20260503 (腾讯元宝)
人工智能
Hello world.Joey21 小时前
OSTrack
人工智能·算法·目标检测·目标跟踪
AI科技星21 小时前
全域数学·数术本源·第四卷《分析原本》【乖乖数学】
人工智能·机器学习·数学建模·数据挖掘·agi
早日退休!!!21 小时前
PyTorch适配NPU
人工智能·pytorch·python
qcx2321 小时前
【AI Agent通识九课】01 · Agent 和 ChatGPT 到底差在哪?
人工智能·ai·chatgpt·agent
小手智联老徐21 小时前
Claude Code CLI + DeepSeek V4:终结 AI 编程高成本时代的王炸组合
人工智能