- .gitignore 新增 .zcode/(ZCode 工具本地配置,不入库) - 更新交通/通信/差旅等财务规则表 - 补充 2026-06-25/26 开发日志(chat UI SaaS 化、主题企业 AI 风格、bug 日志)
9.5 KiB
9.5 KiB
多 task 串行推进时 task2(业务招待费报销)无法启动
修复记录
-
12:14:记录 bug 修复:多 task 串行推进时,task1(出差申请)做完后点击"继续处理费用报销",task2(业务招待费报销)根本无法启动,报销草稿交互不起来,task2 语义(招待费/2000元/昨天)全部丢失。
- Git 提交检查:
git fetch --all --prune因远端 SSL 连接失败未拉到新内容;HEAD..@{u}为空(无 upstream 新提交);@{u}..HEAD本地领先 8 个提交,其中与本 bug 相关的前置提交为3a5664c4 feat(web): 多 task 串行推进、3e4b1e15 fix(web): 保存草稿/提交成功后也推进到下一个 task、43c3ff86 fix(web): steward plan 确认按钮直接拉起申请预览,不丢失 remaining tasks。 - 修改:
web/src/composables/workbenchAiMode/useWorkbenchAiActionRouter.js:travel_reimbursement分支不再硬编码requiresApplicationBeforeReimbursement=true,改为从steward_current_task.ontology_fields解析费用类型并调requiresApplicationBeforeReimbursement(expenseType)判断;用buildAiExpenseDraftPrefillValues把 task 语义(金额/时间/事由/地点)预填进报销草稿;透传steward_remaining_tasks。ai_application_start_inline分支也透传prefill_values和steward_remaining_tasks,让"查不到申请单→发起申请单"后能回到 task2。buildNextTaskSuggestedActionpayload 补steward_remaining_tasks: remainingTasks.slice(1),防 3+ task 断链。web/src/composables/workbenchAiMode/useWorkbenchAiExpenseFlow.js:startAiExpenseDraft扩展第 4 参options(prefillValues/stewardRemainingTasks);resolveAiExpenseApplicationLink接收 options,查不到申请单时按费用类型动态生成"确认发起业务招待申请"按钮(不再写死"出差申请"),并透传prefill_values/steward_remaining_tasks;新增attachStewardRemainingTasks/resolveStewardRemainingTasks/resolveRequiredApplicationLabel/buildExpenseDraftNextTaskActionhelper,把 remaining tasks 上下文挂在 draft 上贯穿报销→关联申请单→pollLinkedDraftJob 全流程;advanceAiExpenseDraft、linkAiExpenseApplication、replaceInlineAssistantMessage、resumePendingLinkedReimbursementDraftJobs均补 remaining tasks 透传。web/src/composables/workbenchAiMode/useWorkbenchAiApplicationPreviewFlow.js:buildApplicationPreviewNextTaskActionpayload 补steward_remaining_tasks: remainingTasks.slice(1)。web/src/utils/aiExpenseDraftModel.js:createAiExpenseDraft新增第三参prefillValues,按已填值推进stepKey到第一个未填字段;新增buildAiExpenseDraftPrefillValues把 task ontology 映射到草稿字段。web/src/composables/workbenchAiMode/workbenchAiMessageModel.js:createInlineMessage/normalizeRuntimeMessage/serializeRuntimeMessage三处补stewardRemainingTasks字段读写,避免消息重建/刷新丢失推进上下文。web/src/utils/aiWorkbenchConversationStore.js:normalizeMessage持久化时保留stewardRemainingTasks。
- 操作:未提交(工作区有大量预先存在的未提交改动,未自动提交)。容器
local-x-financial-linux此前未运行,已docker start恢复。 - 验证:在容器内(node v22.22.3)跑
node --test tests/ai-expense-draft-model.test.mjs tests/ai-workbench-conversation-store.test.mjs tests/workbench-ai-action-router.test.mjs,16 个测试全部通过(含新增的buildAiExpenseDraftPrefillValues、createAiExpenseDraft预填、stewardRemainingTasks持久化、travel_reimbursement分支预填+透传 4 个用例)。其余前端测试失败为基线已存在(git stash 对比确认,与本次改动无关,多为正则匹配源码文本的断言因工作区其他未提交改动而失败)。 - 影响:用户一次提问含"出差申请 + 招待费报销"等多 task 时,task1 完成后 task2 现在能正常启动:招待费类型、2000元金额、时间、事由会预填到报销草稿;招待费需要前置招待申请单(业务规则保留),查不到时按钮文案按类型动态展示并承接语义,发起申请单后能回到 task2;3+ task 不再断链;刷新会话后推进上下文不丢失。
- Git 提交检查:
-
12:23:继续修复同一 bug:模型计划已经返回“出差申请 + 业务招待费报销”两个 task 时,AI 工作台入口只消费第一个申请 task,第二个 task 没有自动开始。
- Git 提交检查:
git fetch --all --prune仍因LibreSSL SSL_connect: SSL_ERROR_SYSCALL失败;HEAD..@{u}为空,未发现可见 upstream 新提交;@{u}..HEAD本地领先 8 个提交:43c3ff86 fix(web): steward plan 确认按钮直接拉起申请预览,不丢失 remaining tasks、3e4b1e15 fix(web): 保存草稿/提交成功后也推进到下一个 task、3a5664c4 feat(web): 多 task 串行推进 - task1 完成后自动展示 task2 确认按钮、d139a63e refactor(server): 意图识别改 LLM 驱动,规则只做闲聊拦截+resume 兜底、8a2ae6eb fix(server): gate_classify 复用 _classify_irrelevant_input 修复 off_topic 误杀、992cf71f refactor(server): Phase 1 图拓扑重构 - LangGraph 成为唯一编排者、54356ba8 refactor(server): scene 注册表骨架 + 统一门控管道设计文档、e9d7c56d feat(server): 会话上下文保留(LLM 历史 + 确定性兜底双保险)。 - 修改:
workbenchAiIntentPlannerModel.js在归一化模型计划时保留 application task 后面的stewardRemainingTasks,并只在存在剩余 task 时放进可执行申请请求;usePersonalWorkbenchAiMode.js把 remaining tasks 传入申请预览,并在预览生成后通过现有steward_continue_next_task路由自动启动下一个 task;低置信确认按钮 payload 也继续携带队列;useWorkbenchAiApplicationPreviewFlow.js在普通申请预览完成后调用onPreviewReadyForNextTask;useWorkbenchAiActionRouter.js的ai_application_confirm_intent分支同样透传 remaining tasks 并注册自动续跑回调。 - 操作:新增回归测试覆盖“模型返回申请 task + 业务招待报销 task 时,前端可执行请求保留第二个 task”,以及“低置信确认按钮不丢队列并提供自动续跑回调”;保留既有未提交工作区改动,没有回滚或提交其他文件。
- 验证:先看到新增测试红灯(
plan.stewardRemainingTasks为undefined,确认按钮 options 也没有 remaining tasks),修复后node --test web/tests/workbench-ai-intent-planner-model.test.mjs web/tests/workbench-ai-action-router.test.mjs通过 24/24;git diff --check通过;docker exec -w /app -e SERVER_VENV_DIR=/tmp/x-financial-server-venv x-financial-local-linux timeout 60s /tmp/x-financial-server-venv/bin/pytest -q server/tests/test_steward_planner.py -k 'future_travel_without_apply_word_as_application or uses_llm_for_multi_financial_demands'通过 2/2;同命令在local-x-financial-linux收集阶段因该容器缺langgraph失败,已改用当前映射 5173 的x-financial-local-linux验证;npm --prefix web run build通过;真实http://localhost:5173/api/v1/steward/plans采样确认该用户句子返回expense_application与reimbursement两个 task。 - 影响:用户输入“2月20-23日去上海出差3天,服务国网服务器部署,并且报销昨天的业务招待费2000元”时,前端不再在第一个申请预览处截断队列;申请预览生成后会自动把第二个业务招待费报销 task 交给现有报销流程继续处理,同时刷新/低置信确认路径也不丢 task 队列。
- Git 提交检查:
-
22:30:继续修复同一 bug:用户点击“保存草稿”后,task1 已经完成,但界面仍只展示“继续处理费用报销”按钮,没有自动开始 task2。
- Git 提交检查:
git fetch --all --prune仍因LibreSSL SSL_connect: SSL_ERROR_SYSCALL失败;HEAD..@{u}为空,未发现可见 upstream 新提交;@{u}..HEAD本地仍领先 8 个提交:43c3ff86、3e4b1e15、3a5664c4、d139a63e、8a2ae6eb、992cf71f、54356ba8、e9d7c56d。 - 修改:
useWorkbenchAiApplicationPreviewFlow.js在保存草稿/提交申请成功后,如果当前申请消息还有stewardRemainingTasks,就调用onApplicationActionCompleted自动续跑下一项;自动续跑时结果消息只保留查看详情动作,不再额外保留“继续处理”按钮,避免重复触发同一个 task。usePersonalWorkbenchAiMode.js将该回调接到startModelPlannedNextTask;useWorkbenchAiActionRouter.js的低置信确认路径也同步传入保存/提交成功回调。 - 操作:先补红灯断言,要求工作台入口向申请预览流传
onApplicationActionCompleted,且申请预览流在保存/提交成功分支调用该回调;然后按同一条steward_continue_next_task路由复用原有报销启动逻辑。 - 验证:红灯阶段
node --test web/tests/workbench-ai-intent-planner-model.test.mjs失败在缺少onApplicationActionCompleted;修复后node --test web/tests/workbench-ai-intent-planner-model.test.mjs17/17 通过,node --test web/tests/workbench-ai-action-router.test.mjs7/7 通过;git diff --check通过;npm --prefix web run build通过。 - 影响:复合任务里用户保存第一张出差申请草稿后,系统会立即进入第二个业务招待费报销任务,不再要求用户手动点击“继续处理费用报销”;低置信确认后再保存草稿也保持同样行为。
- Git 提交检查: