3.2 KiB
3.2 KiB
Issues E2E 测试套件
这个目录包含了专门针对已知问题的端到端测试,用于重现、验证和防止回归。
测试文件说明
1. platform-folders.e2e.test.js
目标问题: Windows环境下platform-folders包的兼容性问题
测试内容:
- 模拟Windows环境和NPX执行环境
- 重现platform-folders包导入失败的问题
- 验证fallback机制的有效性
- 测试替代方案(env-paths)的可行性
- 验证跨平台路径解析的一致性
运行方式:
# 运行platform-folders相关测试
npm run test:e2e -- --testNamePattern="Platform-Folders"
2. protocol-path-warning.e2e.test.js
目标问题: 协议文件路径解析中的警告问题
测试内容:
- 重现协议路径转换错误(@package:// → @packages://promptx/)
- 模拟PackageProtocol路径解析问题
- 验证文件访问验证逻辑
- 测试CLI命令中的协议警告
- 验证核心功能不受路径警告影响
运行方式:
# 运行协议路径警告相关测试
npm run test:e2e -- --testNamePattern="协议路径警告"
测试策略
问题重现
- 精确模拟问题环境: 通过mock和环境变量模拟实际问题场景
- 捕获错误信息: 详细记录错误消息和警告,与实际问题描述对比
- 验证影响范围: 确认问题对系统功能的实际影响程度
解决方案验证
- 替代方案测试: 验证建议的解决方案是否有效
- 回归防护: 确保修复不会引入新问题
- 兼容性测试: 验证解决方案在不同环境下的表现
错误处理
- Graceful degradation: 验证系统在问题出现时的优雅降级
- Fallback机制: 测试备用方案的有效性
- 用户体验: 确保即使有问题,用户仍能正常使用核心功能
运行所有问题测试
# 运行所有issues相关的e2e测试
npm run test:e2e -- src/tests/issues/
# 运行单个问题测试
npm run test:e2e -- src/tests/issues/platform-folders.e2e.test.js
npm run test:e2e -- src/tests/issues/protocol-path-warning.e2e.test.js
# 以详细模式运行,查看所有输出
npm run test:e2e -- --verbose src/tests/issues/
测试结果解读
成功情况
- ✅ 表示成功重现了问题
- ✅ 表示验证了解决方案有效性
- ℹ️ 表示信息性输出,无问题发现
失败情况
测试失败可能意味着:
- 问题已经被修复(好事!)
- 测试环境设置有误
- 问题重现条件不准确
警告情况
- ⚠️ 表示检测到了预期的警告信息
- 这些警告不一定是错误,可能是已知的非关键问题
添加新的问题测试
当发现新问题时,请:
- 创建新的测试文件:
new-issue-name.e2e.test.js - 遵循现有模式:
- 问题重现
- 解决方案验证
- 回归防护
- 更新本文档: 添加新测试的说明
注意事项
- 测试隔离: 每个测试都应该独立运行,不依赖其他测试的状态
- 环境清理: 使用beforeAll/afterAll进行环境设置和清理
- Mock恢复: 确保所有mock在测试结束后都被正确恢复
- 超时设置: E2E测试可能需要较长时间,设置合适的超时时间