dramaling-app/docs/01_requirement/acceptance-criteria.md

18 KiB
Raw Blame History

Drama Ling 驗收標準與測試條件

文檔概述

文檔名稱: Drama Ling 驗收標準和測試條件
建立日期: 2025-09-09
版本: v1.0
適用範圍: 開發團隊、測試團隊、產品經理

驗收標準框架

🎯 標準分類體系

功能性驗收標準 (Functional Acceptance Criteria)

  • 核心功能是否按規格運作
  • 用戶流程是否順暢完整
  • 系統回應是否符合預期

非功能性驗收標準 (Non-Functional Acceptance Criteria)

  • 效能表現是否達標
  • 安全性措施是否到位
  • 可用性體驗是否良好

業務邏輯驗收標準 (Business Logic Acceptance Criteria)

  • 商業規則執行是否正確
  • 數據計算是否準確
  • 權限控制是否有效

🔐 用戶認證與引導系統驗收標準

AC-ENT-01: 社群登入功能

功能: Apple ID 和 Google 帳號登入
驗收標準:
  功能性:
    - ✅ 點擊 Apple ID 登入按鈕成功跳轉到 Apple 認證頁面
    - ✅ Apple 認證成功後自動返回應用並登入
    - ✅ Google 登入流程與 Apple ID 相同邏輯運作
    - ✅ 首次登入自動創建用戶帳戶
    - ✅ 已註冊用戶直接登入到主頁面
  
  非功能性:
    - ✅ 登入流程在5秒內完成
    - ✅ 網路中斷時顯示適當錯誤訊息
    - ✅ 支援 iOS 12+ 和 Android 8+ 系統
    
  業務邏輯:
    - ✅ 一個社群帳號只能對應一個 Drama Ling 帳戶
    - ✅ 社群帳號註銷後 Drama Ling 帳戶保持獨立存在
    - ✅ 登入失敗不影響現有本地數據

測試案例:
  TC-ENT-01-001: Apple ID 正常登入流程
  TC-ENT-01-002: Google 帳號正常登入流程
  TC-ENT-01-003: 社群帳號已綁定的處理
  TC-ENT-01-004: 網路異常情況處理
  TC-ENT-01-005: 用戶取消授權的處理

AC-ENT-02: 7天免費試用

功能: 新用戶免費體驗機制
驗收標準:
  功能性:
    - ✅ 新用戶註冊後自動啟動7天免費試用
    - ✅ 試用期間可使用所有付費功能
    - ✅ 應用內明顯顯示試用剩餘天數
    - ✅ 試用期結束前24小時發送通知
    - ✅ 試用期間可隨時取消,不產生費用
    
  非功能性:
    - ✅ 試用狀態查詢響應時間 <200ms
    - ✅ 試用到期檢查每小時執行一次
    - ✅ 時區變更不影響試用期計算
    
  業務邏輯:
    - ✅ 同一設備/帳戶/信用卡只能試用一次
    - ✅ 試用到期後自動限制付費功能
    - ✅ 付費轉換後試用期立即結束

測試案例:
  TC-ENT-02-001: 新用戶試用自動啟動
  TC-ENT-02-002: 試用期功能完整可用
  TC-ENT-02-003: 試用倒數計時準確顯示
  TC-ENT-02-004: 試用結束功能限制生效
  TC-ENT-02-005: 重複試用防範機制

AC-ENT-03: 個人化引導流程

功能: 7步驟新用戶設定
驗收標準:
  功能性:
    - ✅ 所有7個設定步驟依序呈現
    - ✅ 每個步驟都有清楚的說明和範例
    - ✅ 可以返回修改前面步驟的選擇
    - ✅ 完成所有步驟後生成個人化建議
    - ✅ 可以跳過引導直接進入主功能
    
  非功能性:
    - ✅ 每個步驟載入時間 <2秒
    - ✅ 介面在各種螢幕尺寸正常顯示
    - ✅ 支援橫向和直向螢幕方向
    
  業務邏輯:
    - ✅ 引導完成後設定結果永久保存
    - ✅ 用戶可在設定中重新修改偏好
    - ✅ 跳過引導使用預設設定不影響功能

測試案例:
  TC-ENT-03-001: 7步驟完整流程測試
  TC-ENT-03-002: 步驟間前後導航功能
  TC-ENT-03-003: 個人化建議生成準確性
  TC-ENT-03-004: 跳過引導功能測試
  TC-ENT-03-005: 設定修改和保存功能

🎭 學習任務與活動驗收標準

AC-TASK-01: 場景對話系統

功能: 沉浸式對話學習體驗
驗收標準:
  功能性:
    - ✅ 關卡地圖顯示用戶進度和可用關卡
    - ✅ 場景對話包含明確的角色和目標設定
    - ✅ 語音輸入和文字輸入都能正確識別
    - ✅ AI 回饋針對用戶回答給出具體建議
    - ✅ 完成對話後顯示詳細成績分析
    
  非功能性:
    - ✅ 語音識別準確率 >85%
    - ✅ AI 回饋生成時間 <3秒
    - ✅ 對話介面載入時間 <2秒
    - ✅ 支援各種網路環境穩定運作
    
  業務邏輯:
    - ✅ 答錯消耗1條生命生命為0時無法繼續
    - ✅ 完成對話獲得經驗值和鑽石獎勵
    - ✅ 關卡解鎖順序符合學習進度邏輯

測試案例:
  TC-TASK-01-001: 完整對話場景流程
  TC-TASK-01-002: 語音和文字輸入準確性
  TC-TASK-01-003: AI 回饋品質和相關性
  TC-TASK-01-004: 生命值消耗和恢復機制
  TC-TASK-01-005: 獎勵計算和發放準確性

AC-TASK-02: 300秒限時挑戰

功能: 限時對話挑戰模式
驗收標準:
  功能性:
    - ✅ 挑戰開始前清楚顯示規則和消耗
    - ✅ 倒數計時器準確顯示剩餘時間
    - ✅ 時間道具使用後正確調整計時器
    - ✅ 時間結束立即停止並顯示結果
    - ✅ 成績計算包含正確率和時間因素
    
  非功能性:
    - ✅ 計時器精確度誤差 <1秒
    - ✅ 挑戰過程中無卡頓或延遲
    - ✅ 道具使用響應時間 <500ms
    
  業務邏輯:
    - ✅ 消耗1張門票才能開始挑戰
    - ✅ 挑戰失敗仍消耗門票但不扣生命
    - ✅ 特殊獎勵根據成績等級發放

測試案例:
  TC-TASK-02-001: 完整限時挑戰流程
  TC-TASK-02-002: 計時器準確性測試
  TC-TASK-02-003: 時間道具功能測試
  TC-TASK-02-004: 門票消耗機制測試
  TC-TASK-02-005: 成績計算準確性驗證

AC-TASK-03: 詞彙學習系統

功能: 三階段詞彙記憶循環
驗收標準:
  功能性:
    - ✅ 詞彙介紹包含發音、定義、例句
    - ✅ 流暢度訓練提供多種練習類型
    - ✅ 複習系統根據記憶曲線安排時間
    - ✅ 詞彙掌握度即時更新和顯示
    - ✅ 學習進度在三個階段間正確流轉
    
  非功能性:
    - ✅ 詞彙卡片載入時間 <1秒
    - ✅ 練習回答判斷響應時間 <500ms
    - ✅ 複習推送準時且準確
    
  業務邏輯:
    - ✅ 掌握度計算符合學習科學原理
    - ✅ 複習間隔根據表現動態調整
    - ✅ 已掌握詞彙不再出現在新學習中

測試案例:
  TC-TASK-03-001: 三階段學習完整流程
  TC-TASK-03-002: 詞彙掌握度計算準確性
  TC-TASK-03-003: 複習時機安排正確性
  TC-TASK-03-004: 學習數據統計準確性
  TC-TASK-03-005: 詞彙狀態轉換邏輯

💎 商業模式功能驗收標準

AC-BIZ-01: 鑽石購買系統

功能: 虛擬貨幣購買流程
驗收標準:
  功能性:
    - ✅ 顯示所有可購買的鑽石套餐和價格
    - ✅ 支援多種付款方式(Apple Pay, Google Pay, 信用卡)
    - ✅ 購買確認彈窗顯示詳細資訊
    - ✅ 付款成功後鑽石立即到帳
    - ✅ 交易記錄完整保存並可查詢
    
  非功能性:
    - ✅ 付款流程安全性符合 PCI DSS 標準
    - ✅ 交易處理時間 <30秒
    - ✅ 支援各平台商店的付費政策
    
  業務邏輯:
    - ✅ 購買限制符合防沉迷和未成年保護規定
    - ✅ 退款政策和流程清楚執行
    - ✅ 鑽石餘額計算和顯示準確

測試案例:
  TC-BIZ-01-001: 各種套餐購買流程
  TC-BIZ-01-002: 多種付款方式測試
  TC-BIZ-01-003: 購買失敗處理測試
  TC-BIZ-01-004: 退款申請和處理流程
  TC-BIZ-01-005: 鑽石餘額同步和計算

AC-BIZ-02: 道具商店系統

功能: 遊戲化道具購買和使用
驗收標準:
  功能性:
    - ✅ 道具商店分類清楚且易於瀏覽
    - ✅ 每種道具都有詳細的功能說明
    - ✅ 購買道具後立即加入用戶道具庫
    - ✅ 道具使用時機和效果明確顯示
    - ✅ 道具庫存和使用歷史可查詢
    
  非功能性:
    - ✅ 商店載入時間 <2秒
    - ✅ 道具使用效果即時生效
    - ✅ 庫存同步無延遲
    
  業務邏輯:
    - ✅ 道具價格和效果比例合理
    - ✅ 使用限制和冷卻時間正確執行
    - ✅ 道具效果不能疊加使用

測試案例:
  TC-BIZ-02-001: 道具購買完整流程
  TC-BIZ-02-002: 各類道具功能測試
  TC-BIZ-02-003: 道具庫存管理測試
  TC-BIZ-02-004: 道具使用限制測試
  TC-BIZ-02-005: 道具效果計算準確性

AC-BIZ-03: 訂閱服務系統

功能: 月費和年費訂閱管理
驗收標準:
  功能性:
    - ✅ 訂閱方案和特權清楚列出
    - ✅ 訂閱後立即享有所有付費功能
    - ✅ 訂閱狀態在各裝置同步顯示
    - ✅ 可隨時查看訂閱詳情和到期時間
    - ✅ 取消訂閱功能易於找到和使用
    
  非功能性:
    - ✅ 訂閱狀態變更響應時間 <5秒
    - ✅ 自動續費提醒準時發送
    - ✅ 跨平台訂閱狀態同步準確
    
  業務邏輯:
    - ✅ 試用期轉訂閱邏輯正確執行
    - ✅ 訂閱到期後功能限制及時生效
    - ✅ 重新訂閱後所有資料完整恢復

測試案例:
  TC-BIZ-03-001: 訂閱購買和啟用流程
  TC-BIZ-03-002: 訂閱功能權限測試
  TC-BIZ-03-003: 自動續費機制測試
  TC-BIZ-03-004: 取消訂閱流程測試
  TC-BIZ-03-005: 訂閱狀態同步測試

🏆 核心學習功能驗收標準

AC-CORE-01: 個人中心系統

功能: 綜合學習數據和社群功能
驗收標準:
  功能性:
    - ✅ 學習統計數據準確顯示(時間、進度、成就)
    - ✅ 好友系統支援添加、刪除、搜尋功能
    - ✅ 個人設定可修改且即時生效
    - ✅ 他人資料瀏覽符合隱私設定
    - ✅ 成就展示包含獲得時間和條件
    
  非功能性:
    - ✅ 個人中心載入時間 <3秒
    - ✅ 數據統計更新延遲 <1分鐘
    - ✅ 好友操作響應時間 <2秒
    
  業務邏輯:
    - ✅ 學習數據計算符合業務規則
    - ✅ 隱私設定有效保護用戶資訊
    - ✅ 好友關係建立需要雙方確認

測試案例:
  TC-CORE-01-001: 學習統計準確性測試
  TC-CORE-01-002: 好友系統完整功能測試
  TC-CORE-01-003: 個人設定修改和保存
  TC-CORE-01-004: 隱私保護功能測試
  TC-CORE-01-005: 成就系統展示和獲得

AC-CORE-02: 排行榜系統

功能: 社群競爭和激勵機制
驗收標準:
  功能性:
    - ✅ 好友榜和全球榜分別顯示
    - ✅ 排名計算包含多個維度指標
    - ✅ 排行榜定期更新且時間準確
    - ✅ 用戶可查看自己的排名變化
    - ✅ 排行榜前列用戶有特殊標識
    
  非功能性:
    - ✅ 排行榜載入時間 <2秒
    - ✅ 排名更新延遲 <10分鐘
    - ✅ 大量用戶同時查看時系統穩定
    
  業務邏輯:
    - ✅ 排名計算公式公平且透明
    - ✅ 作弊用戶被排除在榜單外
    - ✅ 獎勵發放根據最終排名結算

測試案例:
  TC-CORE-02-001: 排行榜顯示和更新測試
  TC-CORE-02-002: 排名計算準確性驗證
  TC-CORE-02-003: 作弊檢測和處理測試
  TC-CORE-02-004: 獎勵發放機制測試
  TC-CORE-02-005: 高並發訪問穩定性測試

🛡️ 非功能性驗收標準

AC-PERF-01: 效能要求

系統效能基準線:
  回應時間:
    - ✅ 應用啟動時間 <3秒
    - ✅ 頁面切換時間 <1秒  
    - ✅ API 請求回應時間 <2秒
    - ✅ 離線到線上同步時間 <5秒
    
  並發處理:
    - ✅ 支援10,000個同時在線用戶
    - ✅ 數據庫查詢 QPS >1000
    - ✅ 檔案上傳處理 >100MB/s
    
  資源使用:
    - ✅ 記憶體使用 <200MB (移動端)
    - ✅ CPU 使用率峰值 <70%
    - ✅ 電池消耗低於同類應用平均值

測試案例:
  TC-PERF-01-001: 負載測試 - 高並發用戶
  TC-PERF-01-002: 壓力測試 - 極限資源使用
  TC-PERF-01-003: 持久測試 - 長時間穩定運行

AC-SEC-01: 安全性要求

安全防護標準:
  數據保護:
    - ✅ 用戶密碼不可逆加密存儲
    - ✅ 敏感數據傳輸使用 HTTPS
    - ✅ API 請求有適當的身份驗證
    - ✅ 數據備份加密且定期測試恢復
    
  存取控制:
    - ✅ 角色權限控制正確執行
    - ✅ API 端點有適當的存取限制
    - ✅ 會話管理符合安全最佳實踐
    
  漏洞防護:
    - ✅ 防範 SQL 注入攻擊
    - ✅ 防範 XSS 跨站腳本攻擊
    - ✅ 防範 CSRF 跨站請求偽造
    - ✅ 定期安全掃描無嚴重漏洞

測試案例:
  TC-SEC-01-001: 滲透測試 - 常見攻擊防護
  TC-SEC-01-002: 權限測試 - 非法存取防範
  TC-SEC-01-003: 數據測試 - 敏感資訊保護

AC-USAB-01: 可用性要求

用戶體驗標準:
  介面設計:
    - ✅ 所有功能在3次點擊內可達
    - ✅ 重要操作有明確的確認機制
    - ✅ 錯誤訊息清楚且提供解決方案
    - ✅ 載入過程有視覺化進度提示
    
  無障礙設計:
    - ✅ 支援螢幕閱讀器
    - ✅ 色彩對比度符合 WCAG 2.1 AA 標準
    - ✅ 字體大小可調整
    - ✅ 支援語音導航
    
  多語言支持:
    - ✅ 介面支援中文和英文
    - ✅ 學習內容支援多種目標語言
    - ✅ 時區和貨幣自動適配用戶地區

測試案例:
  TC-USAB-01-001: 可用性測試 - 用戶操作流暢度
  TC-USAB-01-002: 無障礙測試 - 輔助技術相容性
  TC-USAB-01-003: 國際化測試 - 多語言環境

🧪 測試執行策略

測試層級結構

單元測試 (Unit Testing)

覆蓋範圍: 個別函數和組件邏輯
執行頻率: 每次程式碼提交
覆蓋率目標: >80%
重點項目:
  - 業務邏輯計算準確性
  - 錯誤處理機制
  - 邊界條件處理
  - 數據驗證邏輯

整合測試 (Integration Testing)

覆蓋範圍: API 和服務間互動
執行頻率: 每日自動化執行
重點項目:
  - 前後端 API 整合
  - 第三方服務整合
  - 數據庫操作
  - 支付系統整合

系統測試 (System Testing)

覆蓋範圍: 完整用戶流程
執行頻率: 每週完整執行
重點項目:
  - 端到端用戶旅程
  - 跨平台相容性
  - 效能基準測試
  - 安全性掃描

驗收測試 (User Acceptance Testing)

覆蓋範圍: 業務需求符合度
執行頻率: 功能完成後
參與角色: 產品經理、業務用戶
重點項目:
  - 用戶故事驗證
  - 業務流程確認
  - 使用者體驗評估

🚀 測試自動化策略

自動化測試金字塔

graph TB
    A[手動測試 - 探索性測試] --> B[UI自動化測試 - 關鍵用戶流程]
    B --> C[API自動化測試 - 業務邏輯驗證]
    C --> D[單元自動化測試 - 程式邏輯覆蓋]
    
    style D fill:#4CAF50
    style C fill:#2196F3  
    style B fill:#FF9800
    style A fill:#F44336

持續整合流程

觸發條件: 程式碼提交到主分支
執行步驟:
  1. 程式碼品質檢查 (ESLint, SonarQube)
  2. 單元測試執行 (Jest, JUnit)
  3. 整合測試執行 (Postman, REST Assured)
  4. 建置和部署到測試環境
  5. 自動化 UI 測試執行 (Selenium, Cypress)
  6. 測試報告生成和通知

失敗處理:
  - 任一步驟失敗立即停止流程
  - 自動發送失敗通知給開發團隊
  - 提供詳細的失敗日誌和截圖

📋 驗收檢核清單

📱 移動應用檢核

功能完整性:
  - [ ] 所有規格功能正常運作
  - [ ] 用戶流程順暢無中斷
  - [ ] 錯誤處理適當且友善
  - [ ] 離線功能正常運作

效能表現:
  - [ ] 啟動時間符合標準
  - [ ] 記憶體使用量合理
  - [ ] 電池消耗在可接受範圍
  - [ ] 網路使用量優化

裝置相容性:
  - [ ] iOS 和 Android 主流版本支援
  - [ ] 不同螢幕尺寸適配良好
  - [ ] 橫豎螢幕切換正常
  - [ ] 各品牌手機無特異問題

💻 後端服務檢核

API 品質:
  - [ ] 所有 API 端點正常回應
  - [ ] 錯誤回應格式統一且清楚
  - [ ] API 文件與實際行為一致
  - [ ] 版本控制和向後相容性

數據處理:
  - [ ] 數據驗證邏輯正確
  - [ ] 數據庫操作事務完整性
  - [ ] 數據備份和恢復機制
  - [ ] 數據遷移腳本測試通過

安全防護:
  - [ ] 認證和授權機制完整
  - [ ] 敏感數據加密保護
  - [ ] API 速率限制有效
  - [ ] 日誌記錄不包含敏感資訊

🌐 前端應用檢核

用戶介面:
  - [ ] 設計稿還原度 >95%
  - [ ] 互動效果流暢自然
  - [ ] 響應式設計在各裝置正常
  - [ ] 無障礙設計符合標準

程式品質:
  - [ ] 程式碼結構清晰且可維護
  - [ ] 元件重用性良好
  - [ ] 錯誤邊界處理完整
  - [ ] 效能優化措施到位

整合品質:
  - [ ] 與後端 API 整合無誤
  - [ ] 狀態管理邏輯正確
  - [ ] 路由和導航運作正常
  - [ ] 第三方服務整合穩定

📊 驗收報告模板

功能驗收報告

# 功能驗收報告

## 基本資訊
- 功能模組: [模組名稱]
- 測試版本: [版本號]
- 測試日期: [日期範圍]
- 測試人員: [負責人員]

## 驗收結果總覽
- 總測試案例: X 個
- 通過案例: X 個 (X%)
- 失敗案例: X 個 (X%)
- 阻塞問題: X 個
- 建議改進: X 項

## 詳細結果
### ✅ 已通過驗收標準
- [AC-XXX-XX]: [標準描述] - PASS
- ...

### ❌ 未通過驗收標準  
- [AC-XXX-XX]: [標準描述] - FAIL
  - 問題描述: [具體問題]
  - 影響程度: [高/中/低]
  - 建議解決方案: [解決建議]

## 整體評估
[整體功能品質評估和發布建議]

維護說明: 驗收標準應隨著產品功能演進持續更新,確保涵蓋所有重要的業務需求和技術要求。

相關文檔: