Status: in-progress
作为测试开发者, 我想要验证所有测试的稳定性, 以便确保测试可以可靠地运行。
Given 所有业务测试已完成并隔离 When 连续运行测试 10 次 Then 验收标准如下:
测试通过率 100%
性能指标达标
并行执行稳定
[x] Task 1: 创建稳定性测试脚本 (AC: #1)
[x] Task 2: 执行并行模式稳定性测试 (AC: #1, #2, #3)
[ ] Task 3: 执行串行模式稳定性测试 (AC: #1, #2, #3)
[ ] Task 4: 分析结果并生成报告 (AC: #1, #2, #3)
Epic 9: 残疾人管理完整 E2E 测试覆盖(含并行隔离)
为残疾人管理功能编写完整的、真正验证业务功能的 E2E 测试,并确保测试可以与未来的区域管理测试并行运行。
Epic 9 Story 依赖关系:
稳定性验证的意义:
成功标准:
Epic 9 已完成的所有测试文件:
| 测试文件 | 测试数量 | 预计时间 | 验证项 |
|---|---|---|---|
disability-person-photo.spec.ts |
8 | ~1.1m | 照片上传、格式支持、删除 |
disability-person-bankcard.spec.ts |
5 | ~0.8m | 银行卡 CRUD、多张管理 |
disability-person-note.spec.ts |
4 | ~0.6m | 备注 CRUD |
disability-person-visit.spec.ts |
4 | ~0.7m | 回访记录 CRUD |
disability-person-crud.spec.ts |
16 | ~2.0m | 完整 CRUD 流程 |
总计:37 个测试,预计执行时间 ~5.2 分钟(4 workers)
脚本位置: web/tests/e2e/scripts/run-stability-test.sh
#!/bin/bash
# Epic 9 稳定性测试脚本
# 运行所有残疾人管理测试 10 次,验证稳定性
set -e # 遇到错误立即退出
# 配置
RUNS=10
PROJECT_ROOT="/mnt/code/188-179-template-6"
WEB_DIR="${PROJECT_ROOT}/web"
PASSED=0
FAILED=0
TIMES=()
# 切换到 web 目录
cd "${WEB_DIR}" || exit 1
echo "========================================="
echo "Epic 9 稳定性验证测试"
echo "========================================="
echo "运行次数: ${RUNS}"
echo "测试范围: 残疾人管理所有测试 (37 个测试)"
echo "开始时间: $(date)"
echo ""
echo "========================================="
echo ""
# 运行测试
for i in $(seq 1 ${RUNS}); do
echo "=== 运行 #${i}/${RUNS} ==="
START=$(date +%s)
# 运行测试(4 workers 并行)
if pnpm test:e2e:chromium --workers=4; then
PASSED=$((PASSED + 1))
echo "✅ 运行 #${i} 通过"
else
FAILED=$((FAILED + 1))
echo "❌ 运行 #${i} 失败"
fi
END=$(date +%s)
DURATION=$((END - START))
TIMES+=($DURATION)
echo "⏱️ 耗时: ${DURATION}s"
echo ""
done
# 计算统计数据
TOTAL=$((PASSED + FAILED))
PASS_RATE=$((PASSED * 100 / TOTAL))
AVG_TIME=$(awk '{sum+=$1} END {print sum/NR}' <<< "${TIMES[@]}")
MIN_TIME=$(printf "%s\n" "${TIMES[@]}" | sort -n | head -1)
MAX_TIME=$(printf "%s\n" "${TIMES[@]}" | sort -n | tail -1)
# 输出结果
echo "========================================="
echo "稳定性测试结果"
echo "========================================="
echo "通过: ${PASSED}/${TOTAL} (${PASS_RATE}%)"
echo "失败: ${FAILED}/${TOTAL}"
echo ""
echo "执行时间统计:"
echo " 平均: ${AVG_TIME}s"
echo " 最快: ${MIN_TIME}s"
echo " 最慢: ${MAX_TIME}s"
echo ""
echo "结束时间: $(date)"
echo "========================================="
# 判断结果
if [ $PASSED -eq $TOTAL ]; then
echo ""
echo "🎉 Epic 9 稳定性验证通过!100% 成功率!"
echo "✅ Epic 9 可以标记为完成"
exit 0
else
echo ""
echo "⚠️ 稳定性不足,需要修复失败的测试"
echo "❌ 请分析失败原因并修复后重新运行"
exit 1
fi
#!/bin/bash
# Epic 9 串行模式稳定性测试脚本
# 用于对比并行和串行模式的性能差异
RUNS=10
PROJECT_ROOT="/mnt/code/188-179-template-6"
WEB_DIR="${PROJECT_ROOT}/web"
PASSED=0
FAILED=0
TIMES=()
cd "${WEB_DIR}" || exit 1
echo "========================================="
echo "Epic 9 串行模式稳定性验证"
echo "========================================="
for i in $(seq 1 ${RUNS}); do
echo "=== 运行 #${i}/${RUNS} (串行模式) ==="
START=$(date +%s)
# 运行测试(1 worker 串行)
if pnpm test:e2e:chromium --workers=1; then
PASSED=$((PASSED + 1))
echo "✅ 运行 #${i} 通过"
else
FAILED=$((FAILED + 1))
echo "❌ 运行 #${i} 失败"
fi
END=$(date +%s)
DURATION=$((END - START))
TIMES+=($DURATION)
echo "⏱️ 耗时: ${DURATION}s"
echo ""
done
# 输出结果(同上)
# ...
#!/bin/bash
# 单文件稳定性测试 - 用于调试特定测试文件
TEST_FILE="${1:-disability-person-crud.spec.ts}"
RUNS=10
echo "测试文件: ${TEST_FILE}"
echo "运行次数: ${RUNS}"
for i in $(seq 1 ${RUNS}); do
echo "=== 运行 #${i} ==="
pnpm test:e2e:chromium "${TEST_FILE}" --workers=2
done
如果出现偶发性失败,按以下步骤分析:
查看失败截图
# 查看 test-results 目录
ls -la web/tests/e2e/test-results/
查看错误上下文
# 查看自动生成的错误上下文
cat web/tests/e2e/test-results/**/error-context.md
分析失败类型
修复后重新验证
# 单文件验证
cd web
pnpm test:e2e:chromium disability-person-xxx.spec.ts --workers=2 --repeat=10
E2E 测试目录结构:
web/tests/e2e/
├── fixtures/ # 测试文件(图片、文档)
├── pages/ # Page Object
│ └── admin/
│ └── disability-person.page.ts
├── specs/ # 测试用例
│ └── admin/
│ ├── disability-person-photo.spec.ts
│ ├── disability-person-bankcard.spec.ts
│ ├── disability-person-note.spec.ts
│ ├── disability-person-visit.spec.ts
│ └── disability-person-crud.spec.ts
├── scripts/ # 测试脚本(新增)
│ ├── run-stability-test.sh
│ ├── run-stability-serial.sh
│ └── run-stability-single.sh
└── playwright.config.ts
Story 9.6 (测试隔离与并行执行验证) 的经验:
主要改进:
test.describe.serialtest.afterEach 清理机制并行执行验证结果(来自 Story 9.6):
photo.spec.ts: 8 passed (2.2m) with 2 workers ✅
note.spec.ts: 8 passed (1.1m) with 2 workers ✅
photo.spec.ts: 8 passed (3.3m) with 1 worker ✅
photo.spec.ts: 8 passed (1.1m) with 4 workers ✅ (速度提升 3x)
关键模式(Story 9.6 建立):
Story 9.1-9.5 的模式总结:
Recent Commits:
9e3c2dcb - test(e2e): 完成 Story 9.6 代码审查 - 测试隔离与并行执行81ba705a - docs(e2e): 创建 Story 10.5 - 编辑订单测试241c2491 - test(e2e): 完成 Story 10.4 - 创建订单测试Epic 9 完成状态:
测试文件模式:
disability-person-{feature}.spec.tsdata-testid 优先源文档引用:
前置 Story 参考:
Playwright 文档:
执行时间: 2026-01-11 09:20:33 UTC
测试结果:
通过率: 41/53 = 77.4% ❌ 未达到 100% 要求
1. disability-person-bankcard.spec.ts(1 个失败)
完整流程:添加多张银行卡并提交 - 可能原因:表单提交或数据验证问题2. disability-person-crud.spec.ts(8 个失败)
应该成功完成新增残疾人完整流程(基本信息 + 备注 + 银行卡)应该成功完成新增残疾人完整流程(基本信息)应该成功编辑并添加备注应该正确显示残疾人详情应该能在详情中查看完整信息应该支持按姓名搜索残疾人应该支持按残疾类型筛选应该完成完整的 CRUD 生命周期主要错误类型:
personExists 返回 false - 表单提交后记录未创建或未能找到page.waitForLoadState: Timeout 10000ms exceeded3. disability-person-visit.spec.ts(1 个失败)
应该成功编辑回访记录内容Test timeout of 60000ms exceeded while running "afterEach" hook1. 表单提交时机问题(HIGH 优先级)
personExists 返回 false建议修复:
// 在 submitForm 后添加更长的等待时间
await this.page.waitForTimeout(3000); // 增加到 3 秒
// 或等待列表刷新完成
await this.page.waitForSelector('[data-testid="person-list"]');
2. 清理钩子超时问题(HIGH 优先级)
afterEach 钩子超时(60秒)建议修复:
test.afterEach(async ({ disabilityPersonPage, page }) => {
// 为每个清理操作设置独立超时
for (const data of createdTestData) {
try {
await page.waitForTimeout(1000); // 添加间隔
await disabilityPersonPage.deletePersonByName(data.name, { timeout: 30000 });
} catch (error) {
console.log(`清理失败: ${data.name}`, error);
}
}
});
3. 测试数据隔离问题(MEDIUM 优先级)
选项 A:修复现有测试后重新验证(推荐)
选项 B:降低验收标准(不推荐)
选项 C:标记为已知问题,继续其他 Epic
第一次运行:
Created by create-story workflow based on epics.md and previous stories
完成时间: 2026-01-11
完成内容:
✅ 创建了三个稳定性测试脚本:
run-stability-test.sh - 并行模式(4 workers)run-stability-serial.sh - 串行模式(1 worker)run-stability-single.sh - 单文件调试✅ 执行了第一次并行模式稳定性测试:
⚠️ 发现并记录了测试稳定性问题:
未完成内容:
技术发现:
创建的文件:
web/tests/e2e/scripts/run-stability-test.sh - 并行模式稳定性测试脚本web/tests/e2e/scripts/run-stability-serial.sh - 串行模式稳定性测试脚本web/tests/e2e/scripts/run-stability-single.sh - 单文件测试脚本修改的文件:
_bmad-output/implementation-artifacts/9-7-stability-validation.md - 本 story 文档测试的文件(未修改):
web/tests/e2e/specs/admin/disability-person-photo.spec.tsweb/tests/e2e/specs/admin/disability-person-bankcard.spec.tsweb/tests/e2e/specs/admin/disability-person-note.spec.tsweb/tests/e2e/specs/admin/disability-person-visit.spec.tsweb/tests/e2e/specs/admin/disability-person-crud.spec.tsweb/tests/e2e/pages/admin/disability-person.page.ts