测试指南
语言: English | 简体中文
版本: 1.1.0 最後更新: 2025-12-29 適用範圍: Claude Code Skills
目的
本 Skill 提供测试金字塔标准和系统化测试的最佳实踐,支援 ISTQB 和业界通行金字塔框架。
框架选择
| 框架 | 层级 | 適用場景 |
|---|---|---|
| ISTQB | UT → IT/SIT → ST → AT/UAT | 企业级、合規性、正式 QA |
| 业界通行金字塔 | UT (70%) → IT (20%) → E2E (10%) | 敏捷、DevOps、CI/CD |
集成测试縮写说明:
- •IT (Integration Testing):敏捷/DevOps 社群常用
- •SIT (System Integration Testing):企业/ISTQB 環境常用
- •兩者指的是相同的测试层级
快速參考
测试金字塔(业界标准)
code
┌─────────┐
│ E2E │ ← 10%(較少、較慢)
─┴─────────┴─
┌─────────────┐
│ IT/SIT │ ← 20%(集成测试)
─┴─────────────┴─
┌─────────────────┐
│ UT │ ← 70%(单元测试)
└─────────────────┘
测试层级概覽
| 层级 | 範圍 | 速度 | 相依性 |
|---|---|---|---|
| UT | 单一函式/类别 | < 100ms | Mock |
| IT/SIT | 元件互动 | 1-10秒 | 真实数据庫(容器化) |
| ST | 完整系统(ISTQB) | 分鐘级 | 类生产環境 |
| E2E | 使用者旅程 | 30秒+ | 所有真实環境 |
| AT/UAT | 业务验证(ISTQB) | 视情况 | 所有真实環境 |
覆蓋率目標
| 指標 | 最低要求 | 建议值 |
|---|---|---|
| 行覆蓋率 | 70% | 85% |
| 分支覆蓋率 | 60% | 80% |
| 函式覆蓋率 | 80% | 90% |
详细指南
完整标准請參考:
AI 優化格式(Token 高效)
供 AI 助理使用,請採用 YAML 格式文件以減少 Token 使用量:
- •基礎标准:
ai/standards/testing.ai.yaml - •框架选项:
- •ISTQB 框架:
ai/options/testing/istqb-framework.ai.yaml - •业界通行金字塔:
ai/options/testing/industry-pyramid.ai.yaml
- •ISTQB 框架:
- •测试层级选项:
- •单元测试:
ai/options/testing/unit-testing.ai.yaml - •集成测试:
ai/options/testing/integration-testing.ai.yaml - •系统测试:
ai/options/testing/system-testing.ai.yaml - •E2E 测试:
ai/options/testing/e2e-testing.ai.yaml
- •单元测试:
命名慣例
文件命名
code
[ClassName]Tests.cs # C# [ClassName].test.ts # TypeScript [class_name]_test.py # Python [class_name]_test.go # Go
方法命名
code
[MethodName]_[Scenario]_[ExpectedResult]() should_[behavior]_when_[condition]() test_[method]_[scenario]_[expected]()
测试替身
| 类型 | 用途 | 使用时机 |
|---|---|---|
| Stub | 回传预定義值 | 固定 API 响应 |
| Mock | 验证互动 | 检查方法是否被呼叫 |
| Fake | 簡化实作 | 记忆体数据庫 |
| Spy | 记录呼叫、委派 | 部分 Mock |
何时使用
- •UT: 对所有外部相依使用 mock/stub
- •IT: 数据庫使用 fake,外部 API 使用 stub
- •ST: 真实元件,僅对外部服务使用 fake
- •E2E: 全部使用真实環境
AAA 模式
typescript
test('method_scenario_expected', () => {
// Arrange - 设置测试数据
const input = createTestInput();
const sut = new SystemUnderTest();
// Act - 执行行为
const result = sut.execute(input);
// Assert - 验证結果
expect(result).toBe(expected);
});
FIRST 原則
- •Fast(快速) - 测试执行快速
- •Independent(獨立) - 测试之间不互相影響
- •Repeatable(可重複) - 每次执行結果相同
- •Self-validating(自我验证) - 明确的通過/失败
- •Timely(及时) - 与产品代码一起撰写
应避免的反模式
- •❌ 测试相依(测试必須按順序执行)
- •❌ 不穩定测试(有时通過、有时失败)
- •❌ 测试实作細节
- •❌ 過度 Mock
- •❌ 缺少斷言
- •❌ 魔術數字/字串
设置偵测
本 Skill 支援项目特定设置。
偵测順序
- •检查
CONTRIBUTING.md的「停用 Skills」區段- •如果列出此 Skill,則为該项目停用
- •检查
CONTRIBUTING.md的「测试标准」區段 - •若未找到,预设使用标准覆蓋率目標
首次设置
若未找到设置且上下文不清楚时:
- •詢問使用者:「此项目尚未设置测试标准。您想要自订覆蓋率目標嗎?」
- •使用者选择後,建议在
CONTRIBUTING.md中记录:
markdown
## Testing Standards ### Coverage Targets | Metric | Target | |--------|--------| | Line | 80% | | Branch | 70% | | Function | 85% |
设置範例
在项目的 CONTRIBUTING.md 中:
markdown
## Testing Standards ### Coverage Targets | Metric | Target | |--------|--------| | Line | 80% | | Branch | 70% | | Function | 85% | ### Testing Framework - Unit Tests: Jest - Integration Tests: Supertest - E2E Tests: Playwright
相关标准
版本历史
| 版本 | 日期 | 变更内容 |
|---|---|---|
| 1.1.0 | 2025-12-29 | 新增:框架选择(ISTQB/业界通行金字塔)、IT/SIT 縮写说明 |
| 1.0.0 | 2025-12-24 | 新增:标准區段(目的、相关标准、版本历史、授权) |
授权
本 Skill 以 CC BY 4.0 授权發布。