1. 單元測試 (Middleware) Test-DB-Connect: 嘗試連線至 mysql.theaken.com:33306。 驗證 meeting_ 前綴表是否存在,若不存在則執行 CREATE TABLE 初始化腳本。 驗證 ymirliu@panjit.com.tw 是否能被識別為管理員。 Test-Dify-Proxy: 發送 Mock 文字至 /api/ai/summarize。 驗證 Server 能否正確解析 Dify 回傳的 JSON,並處理 Dify 可能的 Timeout 或 500 錯誤。 2. 整合測試 (Client-Server) Test-Auth-Flow: Client 輸入帳密 -> Middleware -> Vercel Auth API。 驗證 Token 取得後,Client 能否成功存取 /api/meetings。 重要: 驗證 Token 過期模擬(手動失效 Token),Client 攔截器是否觸發重試。 Test-Full-Cycle: 建立: 填寫表單(主席、地點...)。 錄音: 模擬 1 分鐘語音輸入。 摘要: 點擊「AI 摘要」,確認 Dify 回傳資料填入右側欄位。 補填: 手動修改「負責人」欄位。 存檔: 檢查 MySQL 資料庫是否正確寫入 meeting_action_items 且 status 預設為 'Open'。 匯出: 下載 Excel,檢查所有欄位(包含手動補填的負責人)是否正確顯示。 3. 部署檢核表 (Deployment Checklist) [ ] Middleware Server 的 requirements.txt 包含 mysql-connector-python, fastapi, requests, openpyxl。 [ ] Middleware Server 的環境變數 (.env) 已設定且保密。 [ ] Client 端 electron-builder 設定 target: portable。 [ ] Client 端 Python Sidecar 已包含 faster-whisper, opencc 並完成 PyInstaller 打包。