- 完善管家意图识别、模型计划构建与规划器调度 - 重构差旅报销提交编排器与管家计划流程前端交互 - 优化报销消息项样式与文档中心视图 - 新增小财管家与附件上传风险前置复核设计文档 - 补充管家规划器与文档中心测试覆盖
2.7 KiB
2.7 KiB
附件上传风险前置复核 TODO
调研与契约
- 盘点附件上传、预审、提交链路,确认完整风险复核当前在提交阶段重复执行。[CONCEPT: 背景与问题]
- 明确上传后复核 helper 的输入输出契约,不新增业务字段。[CONCEPT: 方案设计] 证据:新增
_refresh_claim_pre_review_flags()复用现有风险字段。
后端实现
- 在附件上传完成后触发报销级风险复核,并保持单据状态为草稿。[CONCEPT: 功能能力] 证据:
upload_claim_item_attachment()调用_refresh_claim_pre_review_flags()。 - 上传后风险复核写回
ai_pre_review和submission_review风险结果。[CONCEPT: 功能能力] 证据:test_upload_attachment_refreshes_claim_pre_review通过。 - 规则中心风险在上传后写入
risk_observations,避免提交阶段集中写入。[CONCEPT: 方案设计] 证据:上传后复核复用_run_ai_submission_review(),平台风险仍调用RiskObservationService.upsert_platform_risk_flags()。 - 提交阶段改为读取既有风险结果,只做最终校验、预算占用和流转。[CONCEPT: 目标与非目标] 证据:
submit_claim()仅在缺少ai_pre_review时兜底复核。 - 保留“无附件直接提交”的兜底检查,避免绕过风险复核。[CONCEPT: 风险与开放问题] 证据:
test_submit_claim_runs_ai_review_and_routes_to_direct_manager通过。
前端实现
- 确认上传完成后 UI 使用接口返回的
claim_risk_flags刷新 AI 建议与行风险标识。[CONCEPT: 前端] 证据:travel-request-detail-risk-advice.test.mjs通过。 - 确认提交阶段不恢复阻塞弹窗,只显示轻量后台提交提示。[CONCEPT: 前端] 证据:
travel-request-detail-submit-confirm.test.mjs通过。
测试与验证
- 后端测试:附件上传后自动生成预审风险结果。[CONCEPT: 测试方案] 证据:
test_upload_attachment_refreshes_claim_pre_review通过。 - 后端测试:提交阶段不重复调用完整风险复核。[CONCEPT: 测试方案] 证据:
test_submit_claim_reuses_upload_pre_review_without_rerunning_review通过。 - 后端测试:风险观测仍被持久化。[CONCEPT: 测试方案] 证据:
test_risk_observation_storage_ready_is_cached_per_bind通过。 - 前端回归测试通过。[CONCEPT: 测试方案] 证据:54 个详情页风险/提交测试通过。
npm.cmd --prefix web run build通过。[CONCEPT: 测试方案] 证据:前端生产构建通过,仅保留既有 Rollup 注释与 chunk size 警告。- Docker
x-financial-main容器内后端定向测试通过。[CONCEPT: 测试方案] 证据:核心上传前置复核、提交复用预审、申请/报销风险回归测试通过。