Files
fquiz/memory/2026-06-08.md
T
2026-06-08 23:40:17 +08:00

6.7 KiB
Raw Blame History

Work Log - 当前环境将线路管理菜单置顶(2026-06-08)

  • 背景:

    • 仓库代码已支持 admin.power_lines 菜单,但默认排序仍落在其他后台一级菜单之后。
    • 用户要求在当前环境中让“线路管理”展示在后台菜单最前面。
  • 本次处理:

    • 当前环境数据库:
      • menus.code='admin.power_lines'sort_order 调整为 0
    • 仓库代码:
      • api/app/services/seed_service.py
        • 将默认种子菜单中 admin.power_linessort_order 同步改为 0,避免后续补种回退。
      • MEMORY.md
        • 补充“线路管理默认置顶”的长期口径。
  • 验证:

    • 复核后台菜单排序后,线路管理 已位于一级菜单首位。
  • 风险与关注点:

    • 已登录后台的浏览器会话需要刷新页面后才会看到最新菜单顺序。

Work Log - 放出后台剩余目录菜单并补齐保护(2026-06-08)

  • 背景:

    • 当前仓库默认菜单集合缺少 admin.basic_dataadmin.system_monitoradmin.system 3 个目录菜单。
    • admin.fl_analysis 已有完整页面,但旧权限映射与菜单保护集合仍未完全覆盖。
  • 本次处理:

    • api/app/services/seed_service.py
      • 补齐上述 3 个目录菜单,并将其加入 admin 默认菜单绑定。
    • api/app/services/admin_service.py
      • admin.systemadmin.system_monitoradmin.basic_dataadmin.fl_analysisadmin.fault_recurrence 加入现代菜单删除保护集合。
    • api/app/services/legacy_admin_rbac_service.py
      • admin.systemadmin.system_monitoradmin.basic_dataadmin.fl_analysis 加入 legacy 受保护菜单集合。
    • api/app/services/legacy_authz_service.py
      • 补齐 admin.fl_analysis 的 legacy 权限映射。
  • 验证:

    • git diff --check 通过。
    • npm --workspace web exec tsc --noEmit 通过。
    • npm --workspace web exec eslint src/app/admin/fl-analysis/page.tsx src/app/admin/fault-recurrence/page.tsx 通过。
    • Python 变更文件 AST 语法解析通过。
  • 风险与关注点:

    • admin.basic_dataadmin.system_monitoradmin.system 仍为无 path 的目录菜单,只承担菜单树占位与分组作用。

Work Log - 在共享后端镜像内置 Wine2026-06-08

  • 背景:

    • 新需求要求把 Wine 安装到 fquiz-celery-worker
    • 当前仓库中 celery-workerapicelery-beatflower 复用同一个 api/Dockerfile / ${API_IMAGE},且后端已有 /api/v1/wine/* 直接探测与执行 Wine 的能力。
  • 本次处理:

    • api/Dockerfile
      • 在系统依赖安装阶段加入 wine,并用 command -v wine 做镜像构建期存在性校验。
    • MEMORY.md
      • 将 Wine 口径从“运行环境自行安装”更新为“共享后端镜像已内置 Wine”。
  • 验证:

    • python3 -c "import yaml; ..." 解析 deploy/dev-deploy/compose.ymldeploy/pro-deploy/compose.yml.github/workflows/main.yml 通过。
    • git diff --check 通过。
    • python3 -m py_compile api/app/services/wine_service.py api/app/services/fl_analysis_external.py api/app/tasks/fl_analysis_tasks.py api/app/core/config.py 通过。
    • 当前执行环境无 docker 命令,未能本地实际跑 docker compose build / docker compose config
  • 风险与关注点:

    • 由于部署链路复用同一个后端镜像,本次会同时影响 api/celery-worker/celery-beat/flower 的基础镜像体积,而不只是 celery-worker

Work Log - 修正 Wine 缺少 wine32 时的误报(2026-06-08

  • 背景:

    • 当前环境里 wine --version 会输出 it looks like wine32 is missing,但后端 /api/v1/wine/status 之前只按返回码判定,可能把半可用环境误报成“可用”。
    • ATP 的 Wine 引擎状态也复用同一 Wine 二进制,存在同类误报风险。
  • 本次处理:

    • api/app/services/wine_probe.py
      • 新增共享 Wine 探测 helper,统一将 wine32 is missing 识别为不可用状态。
    • api/app/services/wine_service.py
      • Wine 状态接口与测试执行前校验改为复用共享探测 helper。
    • api/app/services/atp_model_service.py
      • ATP Wine 引擎状态与执行前校验同步复用共享探测 helper。
    • api/Dockerfile
      • 构建阶段显式开启 i386 并安装 wine32:i386,避免镜像只装到半套 Wine 运行时。
    • api/tests/test_wine_probe.py
      • 新增针对 wine32 is missing 误报场景的最小单测。
  • 验证:

    • 变更前基线:python3 -m pytest api/tests/test_fl_analysis_external.pypython3 -m pytest api/tests/test_fl_analysis_service.py 因本地运行环境缺少 pytest/sqlalchemy 无法执行。
    • 变更后执行:
      • python3 -m py_compile api/app/services/wine_probe.py api/app/services/wine_service.py api/app/services/atp_model_service.py api/tests/test_wine_probe.py 通过。
      • ./.venv/bin/python -m pytest api/tests/test_wine_probe.py 通过(3 passed)。
      • git diff --check 通过。
  • 风险与关注点:

    • 当前本地环境仍不具备完整后端依赖,无法直接回归所有 FastAPI/SQLAlchemy 相关测试;本次验证聚焦在 Wine 探测逻辑和语法层面。

Work Log - 修复 ATP 文本上传中文乱码(2026-06-08)

  • 背景:

    • ATP文本转换与预览 页面上传 .atp/.txt 文件时直接使用 file.text(),浏览器会按 UTF-8 解码。
    • 现场 ATP 文件常见为 Windows 导出的 GBK/GB18030 文本,导致导入后编辑区和转换预览中的中文注释/名称乱码。
  • 本次处理:

    • web/src/lib/text-file.ts
      • 新增前端文本解码工具,优先识别 BOM、兼容无 BOM 的 UTF-16,并在 UTF-8 严格解码失败时回退到 GB18030
    • web/src/app/admin/power-lines/atp-viewer/page.tsx
      • 上传 ATP 文本时改为基于 arrayBuffer + TextDecoder 自动判定编码,不再固定走 UTF-8。
    • web/src/lib/text-file.test.js
      • 补充最小测试,覆盖 UTF-8GB18030(兼容 GBK)、无 BOM UTF-16LE 三类输入。
  • 验证:

    • 基线:npm_config_cache=/tmp/npm-cache npm --workspace web exec tsc --noEmit 通过;npm_config_cache=/tmp/npm-cache npm --workspace web exec eslint src/app/admin/power-lines/atp-viewer/page.tsx 通过。
    • 修改后:
      • npm_config_cache=/tmp/npm-cache npm --workspace web exec tsc --noEmit
      • npm_config_cache=/tmp/npm-cache npm --workspace web exec eslint src/app/admin/power-lines/atp-viewer/page.tsx src/lib/text-file.ts src/lib/text-file.test.js
      • node --test web/src/lib/text-file.test.js
  • 风险与关注点:

    • 已经以错误编码写入数据库的历史 ATP 文本不会被自动修复;本次修复只覆盖后续上传与预览入口。