# ChatScope 测试计划 > CHAT-702/703/704 | 2026-06-06 --- ## 1. Scope 回归测试 (#89 CHAT-702) ### 1.1 创建会话 — open-or-create | # | 测试用例 | 预期 | |---|---------|------| | 1 | 新建 material scope 会话 | HTTP 201, scopeType=material, scopeId=sourceId | | 2 | 相同 scope 再次调用 | HTTP 200, 返回同一个 session id | | 3 | 不同 scopeId 调用 | HTTP 201, 创建新会话 | | 4 | global scope 调用 | HTTP 201, scopeId=null, 每次都新建 | | 5 | scopeType 不合法 | HTTP 400 | | 6 | scopeType=material 但 scopeId 为空 | HTTP 400 | ### 1.2 会话列表 — scope 过滤 | # | 测试用例 | 预期 | |---|---------|------| | 7 | scopeType + scopeId 精确过滤 | 只返回匹配的会话 | | 8 | parentKnowledgeBaseId 过滤 | 返回该 KB 下所有会话 | | 9 | 无过滤(全局列表) | 返回用户所有未删除会话 | | 10 | isDeleted 会话不出现在列表 | 过滤掉 | ### 1.3 发送消息 — scope 快照 | # | 测试用例 | 预期 | |---|---------|------| | 11 | 发消息后检查 scopeSnapshot | 用户消息和 AI 消息都有正确的 scopeSnapshot | | 12 | 历史消息查询 | 每条消息都带 scopeSnapshot | ### 1.4 检索范围 | # | 测试用例 | 预期 | |---|---------|------| | 13 | material scope: 只检索 sourceRef=scopeId 的内容 | 检索结果只来自该资料 | | 14 | knowledge_item scope: 只检索 id=scopeId 的内容 | 检索结果只来自该知识点 | | 15 | knowledge_base scope: 检索整个知识库 | 检索结果覆盖整个 KB | | 16 | global scope: 不检索 | 返回空上下文 | ### 1.5 会话管理 | # | 测试用例 | 预期 | |---|---------|------| | 17 | PATCH 更新 title | 成功更新 | | 18 | PATCH 尝试修改 scopeType | 静默忽略,scopeType 不变 | | 19 | PATCH 尝试修改 scopeId | 静默忽略,scopeId 不变 | | 20 | DELETE 软删除 | isDeleted=true,消息保留 | | 21 | 软删除后 open-or-create | 创建新会话,不返回已删除的 | --- ## 2. 防上下文污染测试 (#90 CHAT-703) ### 2.1 跨 scope 隔离 | # | 测试用例 | 步骤 | 预期 | |---|---------|------|------| | 22 | 资料 A 和资料 B 不串 | 1. 在 material/A 会话问"这篇文章讲了什么" 2. 切到 material/B 会话问"和之前那篇比呢" | AI 不知道 A 的内容 | | 23 | 知识点和知识库不串 | 1. 在 knowledge_item/I 会话问 2. 切到 knowledge_base 会话继续问 | AI 应能检索整个 KB | | 24 | 全局和绑定不串 | 1. 在 knowledge_base/K 会话问 2. 切到 global 会话问"刚才那个知识库里有什么" | AI 不知道之前的对话 | ### 2.2 并发会话 | # | 测试用例 | 预期 | |---|---------|------| | 25 | 同一 scope 多会话(手动新对话创建多个) | 每个会话的消息互不干扰 | | 26 | 快速切换会话发消息 | 每条消息写入正确的 sessionId | --- ## 3. 来源删除测试 (#91 CHAT-704) ### 3.1 知识库删除 | # | 测试用例 | 步骤 | 预期 | |---|---------|------|------| | 27 | 知识库被删除后 | 1. 创建 kb/K 的会话 2. 删除知识库 K 3. 打开会话 | 会话仍存在,需手动处理 | | 28 | 知识库被删除后检索 | 同上,发消息 | 检索结果为空,提示知识库已删除 | ### 3.2 资料/知识点删除 | # | 测试用例 | 步骤 | 预期 | |---|---------|------|------| | 29 | 资料被删除后 | 1. 创建 material/M 的会话 2. 删除资料 M 3. 打开会话 | 会话仍然存在 | | 30 | 资料被删除后检索 | 同上,发消息 | 检索不到被删资料的内容 | | 31 | 知识点被删除后 | 1. 创建 knowledge_item/I 的会话 2. 删除知识点 I 3. 打开会话 | 会话仍然存在,标题不变 | | 32 | 知识点被删除后检索 | 同上,发消息 | 检索结果为空 | ### 3.3 恢复 | # | 测试用例 | 预期 | |---|---------|------| | 33 | 删除资料后重新导入同名资料 | scopeId 不同,不会关联到旧会话 | --- ## 执行方式 ```bash # 后端启动后在本地执行 npx jest --config jest.config.ts --testPathPattern="rag-chat" # 或手动 curl 测试 curl -X POST http://localhost:3000/rag-chat/sessions \ -H "Authorization: Bearer $TOKEN" \ -H "Content-Type: application/json" \ -d '{"scopeType":"material","scopeId":"test_source_id","createdFrom":"material_detail"}' ```