6df02f8efec9e3749133177eda3373cfbdaac2ae
补强 F1-5a runtime_context 落地后的测试覆盖,防止未来 PR 回归。 测试文件本地通过,因 .gitignore:71 不入仓(同 T1 / T2 /af02446处理)。 BE-3 ai_run_logs runtime 写入回归(5 case,本地 PASS): - apps/backend/tests/test_ai_run_logs_runtime.py - 覆盖 AIRunLogService.create_log() 在 live / sandbox 模式下分别写入 正确的 runtime_mode + sandbox_instance_id 字段 - 边界:prompt 截断、INSERT 失败 rollback、bind_to_session=True 调用 T3 dispatcher runtime 单测(5 case,本地 PASS): - apps/backend/tests/test_dispatcher_runtime.py - 覆盖 AIDispatcher._run_step 在 4 条路径(circuit_open / rate_limited / budget_exceeded / 正常)下都把 context["site_id"] 正确传给 run_log_svc.create_log - 防御目标:dispatcher 内部不该意外丢失 site_id,否则 sandbox 切换 在 dispatcher 路径上失效 依赖 F1-5b A3(commitaf02446)的 RuntimeContext 接口契约。 两份测试与 T2(test_admin_ai_batch_runtime,af02446 已 PASS)互补, 一起构成 F1-5a 落地后的回归守护网。 审计: - docs/audit/changes/2026-05-05__wave1_f1_5b_be3_run_log_runtime_regression.md - docs/audit/changes/2026-05-05__wave1_f1_5b_t3_dispatcher_runtime.md Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
NeoZQYY Monorepo
台球门店运营助手一体化平台,整合 ETL 数据 Connector、微信小程序后端、小程序前端与管理后台。
项目结构
| 目录 | 说明 | 文档 |
|---|---|---|
apps/etl/connectors/feiqiu/ |
飞球 Connector(API → ODS → DWD → DWS) | docs/ |
apps/backend/ |
FastAPI 后端(13 个路由 · JWT 双认证 · WebSocket) | README · API 参考 |
apps/miniprogram/ |
微信小程序(Donut + TDesign + TypeScript) | README |
apps/admin-web/ |
管理后台(React + Vite + Ant Design) | README |
apps/mcp-server/ |
MCP Server(AI 工具集成,PostgreSQL 只读查询) | README |
packages/shared/ |
共享包(枚举、金额精度、时间工具) | README |
db/etl_feiqiu/ |
ETL 数据库(6 层 Schema:meta/ods/dwd/core/dws/app) | README |
db/zqyy_app/ |
业务数据库(auth 认证 + 任务队列 + 调度) | README |
docs/ |
项目文档中心(架构、数据库、部署、审计) | README |
scripts/ |
运维/工具脚本 | — |
tests/ |
Monorepo 级属性测试 | — |
快速开始
# 安装全部依赖(需要 uv)
uv sync
# 运行 ETL
cd apps/etl/connectors/feiqiu
python -m cli.main --pg-dsn "$PG_DSN" --store-id "$STORE_ID" --api-token "$API_TOKEN"
# 启动后端 API
cd apps/backend
uvicorn app.main:app --reload
# 运行 ETL 单元测试
cd apps/etl/connectors/feiqiu
pytest tests/unit
配置
配置采用分层叠加:根 .env -> 应用 .env.local -> 环境变量 -> CLI 参数。
参见 .env.template 了解可用配置项。
技术栈
- Python 3.10+, uv workspace(4 个成员:etl、backend、mcp-server、shared)
- PostgreSQL 四库:
etl_feiqiu/test_etl_feiqiu(ETL)、zqyy_app/test_zqyy_app(业务) - FastAPI + Uvicorn(后端 API)
- React 19 + Vite 6 + Ant Design 5(管理后台,独立 pnpm)
- 微信小程序原生 + Donut + TDesign + TypeScript(C 端)
- JWT 双认证(管理后台用户名密码 + 小程序微信登录)
- 多门店隔离(
site_id+ RLS)
Description
Languages
Python
79.6%
TypeScript
17.4%
PLpgSQL
1.9%
HTML
0.7%
PowerShell
0.4%