Commit Graph

195 Commits

Author SHA1 Message Date
张翔 92df794cc8 feat(e2e): 使用dev配置和PostgreSQL数据库进行测试
问题:
- H2数据库与PostgreSQL存在兼容性差异
- Flyway脚本在H2和PostgreSQL上的执行结果不一致
- 密码哈希验证失败

修复:
- 修改后端服务配置:test -> dev
- 修改网关服务配置:test -> dev
- 使用PostgreSQL数据库(localhost:55432)

优势:
- 更接近生产环境
- 避免H2兼容性问题
- 数据库行为一致
- Flyway脚本执行可靠
2026-04-07 10:36:58 +08:00
张翔 bfe55a1a21 fix(e2e): 修改H2数据库scope为runtime
问题:
- manage-db模块中H2数据库scope为test
- 导致H2数据库不会被打包到JAR文件中
- 测试环境无法使用H2数据库

修复:
- 修改H2数据库scope:test -> runtime
- 修改R2DBC H2 scope:test -> runtime

预期效果:
- H2数据库被打包到JAR文件中
- 测试环境可以使用H2数据库
- Flyway脚本可以正常运行
2026-04-07 10:25:08 +08:00
张翔 4ae0e8d125 fix(e2e): 启用Flyway数据库初始化
问题:
- 后端服务使用H2内存数据库
- Flyway被禁用,导致数据库初始化脚本未运行
- admin用户不存在,登录API返回401错误

修复:
- 启用Flyway(flyway.enabled: true)
- 指定迁移脚本位置(locations: classpath:db/migration)
- 启用基线迁移(baseline-on-migrate: true)

预期效果:
- 数据库初始化脚本自动运行
- admin用户自动创建
- 登录API正常工作
2026-04-07 10:20:13 +08:00
张翔 3e6b2ac057 feat(e2e): 增强服务启动稳定性和健康检查
优化内容:

1. 增加服务启动超时时间
   - 后端服务:60秒 -> 90秒
   - 网关服务:60秒 -> 90秒
   - 前端服务:60秒 -> 90秒

2. 改进健康检查逻辑
   - 添加请求超时控制(5秒)
   - 后端服务:增加登录API连通性验证
   - 网关服务:增加登录API连通性验证
   - 确保服务真正可用后才继续

3. 增强服务状态监控
   - 监控所有服务(后端、网关、前端)
   - 每30秒检查一次服务状态
   - 发现异常立即报警

4. 添加综合验证机制
   - 验证所有服务健康状态
   - 验证网关到后端的连通性
   - 确保整个链路可用

预期效果:
- 提高服务启动成功率
- 及早发现服务问题
- 确保测试环境稳定
2026-04-07 10:17:47 +08:00
张翔 8ddd99f54f fix(e2e): 添加网关服务启动,修复架构问题
问题:
- 前端直接访问后端(8084),未通过网关
- 网关服务(8080)未启动
- 导致认证和授权流程失败

修复:
1. 前端配置:
   - 修改 vite.config.ts,代理目标改为网关(8080)
   - 支持环境变量 VITE_API_TARGET

2. 测试环境:
   - 添加网关服务启动逻辑
   - 添加 waitForGatewayReady 健康检查
   - 添加网关服务停止逻辑
   - 修改 cleanupTestData API 地址(8084 -> 8080)

架构:
- 前端(3002)-> 网关(8080)-> 后端(8084)
- 网关负责:JWT认证、RBAC授权、限流、熔断
2026-04-07 09:57:06 +08:00
张翔 aaba9a8e64 fix(e2e): 添加前端服务启动逻辑
问题:
- 测试访问 http://localhost:3002 但前端服务未启动
- 导致所有登录测试失败

修复:
- 在 global-setup 中添加前端服务启动(pnpm run dev)
- 添加 waitForFrontendReady 函数等待前端服务就绪
- 在 global-teardown 中添加前端服务停止逻辑
- 前端服务健康检查:http://localhost:3002
2026-04-07 09:50:09 +08:00
张翔 b3201b61fb fix(e2e): 修复测试失败问题
数据库修复:
- 添加测试用户 'user'(密码:admin123)

测试代码优化:
- 添加页面加载等待逻辑(waitForLoadState)
- 添加元素可见性等待(waitFor visible)
- 修复用户密码错误(user123 -> admin123)
- 改进错误处理和稳定性
2026-04-07 09:37:11 +08:00
张翔 2ed3a96136 docs(e2e): 更新测试文档
- 添加用户旅程测试章节
- 更新统计信息
- 添加测试优化成果对比
- 更新更新日志至 v2.0.0
2026-04-07 08:23:02 +08:00
张翔 a113be036a feat(e2e): 添加测试脚本命令
- test:e2e:journeys - 运行用户旅程测试
- test:e2e:role-based - 运行角色基础测试
- test:e2e:headed - 有头模式运行测试
- test:e2e:debug - 调试模式运行测试
2026-04-07 08:20:40 +08:00
张翔 bfdfbc3093 refactor(e2e): 优化 Playwright 配置
- 启用并行执行(fullyParallel: true)
- 调整 workers 为 CI: 4, 本地: 50%
- 添加 journeys 测试项目配置
2026-04-07 08:20:05 +08:00
张翔 bfc2ab2a63 feat(e2e): 创建文件管理和系统配置工作流测试
文件管理工作流测试:
- 文件上传流程
- 文件搜索和筛选
- 文件删除流程

系统配置工作流测试:
- 查看系统配置
- 修改系统配置
- 字典管理流程
- 参数管理流程
2026-04-07 08:19:14 +08:00
张翔 da5adbb05c feat(e2e): 创建审计工作流测试
实现审计工作流测试:
- 执行操作并查看操作日志
- 查看登录日志
- 搜索和筛选日志
2026-04-07 08:18:22 +08:00
张翔 93fc011385 feat(e2e): 创建用户权限边界验证测试
实现权限边界验证:
- 管理员可以访问所有管理功能
- 普通用户只能访问个人信息
- 权限不足时显示提示信息
2026-04-07 08:17:47 +08:00
张翔 00b0d3413b feat(e2e): 创建管理员完整工作流测试
实现用户旅程测试:
- 管理员登录
- 创建角色并分配权限
- 创建用户并分配角色
- 验证新用户登录
- 清理测试数据

采用 serial 模式确保测试顺序执行
2026-04-07 08:17:11 +08:00
张翔 356de2e5e2 refactor(e2e): 删除 UAT 阶段性测试
- 删除 comprehensive-uat.spec.ts
- 删除 uat-phase1 到 uat-phase8 所有文件

原因:这些测试与 comprehensive-e2e.spec.ts 重复,将被用户旅程测试替代
2026-04-07 08:16:01 +08:00
张翔 477e428e95 refactor(e2e): 删除重复的登录测试
- 删除 login-test.spec.ts
- 删除 simple-login.spec.ts
- 删除 login-stability.spec.ts
- 删除 login-diagnostic.spec.ts
- 保留 role-based-tests/scenarios/authentication/login-flow.spec.ts

原因:避免测试重复,保留最完整的角色基础登录测试
2026-04-07 08:15:36 +08:00
张翔 37b829716b refactor(e2e): 删除诊断性测试文件
- 删除 diagnostic-test.spec.ts
- 删除 integration-diagnostic.spec.ts
- 删除 user-create-diagnostic.spec.ts
- 删除 user-create-diagnostic-v2.spec.ts
- 删除 debug-network.spec.ts

原因:这些文件是临时调试文件,不应包含在生产测试套件中
2026-04-07 08:15:05 +08:00
张翔 6f2cd315ff refactor: 清理迁移相关的未使用变量
- 移除 permission-helper.test.ts 中未使用的 RoleDefinition 导入
- 使用下划线前缀标记 permission-helper.ts 中有意未使用的参数
- 删除 role-auth-manager.ts 中未使用的 generateSignatureHeaders 方法及相关导入
- 为 test-data-manager.ts 添加 getPage 方法以使用 _page 变量

修复所有迁移相关的 TS6133 类型错误
2026-04-05 09:27:42 +08:00
张翔 80f6c7173a refactor: 更新E2E测试导入路径,使用@/别名 2026-04-05 09:15:49 +08:00
张翔 d4de8acf47 refactor: 更新vitest配置,指向新的单元测试路径 2026-04-05 09:14:16 +08:00
张翔 5db1e03fc4 refactor: 迁移roles单元测试到src目录 2026-04-05 09:12:49 +08:00
张翔 cd1211702e refactor: 迁移角色定义到src目录 2026-04-05 09:12:15 +08:00
张翔 e63a23a4ad refactor: 迁移shared单元测试到src目录 2026-04-05 09:11:29 +08:00
张翔 993753bf4f refactor: 迁移shared工具类到src目录 2026-04-05 09:10:52 +08:00
张翔 1e9ce8ee88 docs: 添加角色测试框架迁移实现计划
目的:
- 提供详细的实施步骤,确保迁移过程可执行
- 每个任务包含具体代码、命令和预期输出

内容:
- 15个任务,覆盖文件迁移、配置更新、验证等所有步骤
- 详细的命令和预期输出
- 完整的自检清单
2026-04-05 08:44:58 +08:00
张翔 84e843232c docs: 添加角色测试框架迁移设计文档
目的:
- 解决Playwright与Vitest冲突问题
- 规范项目结构,单元测试和E2E测试分离

变更:
- 将工具类和单元测试从e2e/迁移到src/目录
- 更新vitest配置和E2E测试导入路径
- 提供详细的实施步骤和验证方案
2026-04-05 08:42:22 +08:00
张翔 e2cb7a5ad4 fix: 修复SecurityConfig环境判断,支持h2-test配置 2026-04-05 08:09:57 +08:00
张翔 3051aa7e81 feat: 将诊断端点添加到permitAll列表 2026-04-05 08:07:13 +08:00
张翔 b316c47f05 fix: 修复PasswordDiagnosticHandler编译错误 2026-04-05 08:04:40 +08:00
张翔 51119c7457 fix: 添加PasswordDiagnosticHandler导入语句 2026-04-05 08:01:23 +08:00
张翔 0b0c2527a5 feat: 添加密码验证诊断端点
目的:
- 系统化调试密码验证失败问题
- 验证passwordEncoder是否正确工作
- 收集诊断数据以定位根本原因

诊断端点:
- GET /api/diagnostic/password
- 测试密码: Test@123
- 数据库哈希: $2a$12$...
- 返回验证结果和编码器类型
2026-04-05 07:58:53 +08:00
张翔 47611e55c3 fix: RoleAuthManager直接连接manage-app,不添加签名头
根本原因:
- 测试环境启动的是manage-app(8084端口),不是gateway(8080端口)
- manage-app没有签名验证过滤器
- 添加签名头会导致认证失败

修复方案:
- 改回8084端口
- 不添加签名头,直接发送请求

影响范围:
- Token注入登录测试
- 所有需要认证的测试
2026-04-05 07:51:49 +08:00
张翔 c2820d6b07 fix: 修正RoleAuthManager的API_BASE_URL指向gateway
根本原因:
- RoleAuthManager直接向后端发送请求(http://localhost:8084)
- 绕过了gateway的签名验证
- 导致认证失败

修复方案:
- 修改API_BASE_URL指向gateway(http://localhost:8080)
- 确保所有请求都通过gateway进行签名验证

影响范围:
- Token注入登录测试
- 所有需要认证的测试
2026-04-05 07:50:24 +08:00
张翔 04e385a0a2 fix: 统一签名策略,签名不包含body
根本原因:
- 前端签名生成时包含body
- 后端WebFlux验证时body为空
- 导致签名不匹配,认证失败

修复方案:
- 修改前端signature.ts,签名时不包含body
- 修改测试role-auth-manager.ts,与前端保持一致
- 与后端WebFlux实现保持一致

影响范围:
- 所有需要签名验证的API请求
- Token注入登录测试
- 用户管理相关测试
2026-04-05 07:47:28 +08:00
张翔 a1497a480b fix: 修复登录页面401错误处理问题
根本原因:
- request拦截器在收到401错误时立即重定向到登录页
- 这会中断Login.vue的错误处理逻辑
- 导致ElMessage.error()无法执行,错误消息toast无法显示

修复方案:
- 在登录页面时不执行重定向
- 允许Login.vue正常处理错误并显示toast消息
- 改进测试等待策略,确保toast消息出现
2026-04-04 23:25:36 +08:00
张翔 977e283fbd fix: 修复E2E测试选择器和等待策略
问题分析:
1. 错误消息使用ElMessage toast,测试期望页面文本
2. 登出下拉菜单选择器不够精确
3. 用户管理页面按钮文本不匹配
4. 缺少适当的等待策略

修复内容:
- 登录流程测试:检测.el-message--error toast消息
- 表单验证测试:触发blur事件后检测.el-form-item__error
- 登出流程测试:使用更精确的下拉菜单选择器
- 用户管理测试:修正按钮文本为'新增用户'
- 添加waitForLoadState确保页面加载完成
- 增加timeout参数提高测试稳定性
2026-04-04 22:43:15 +08:00
张翔 f2dde38467 fix: 修正R2DBC URL格式为三个斜杠
问题:R2DBC URL格式错误导致连接失败
修复:使用正确的r2dbc:h2:mem:///格式
2026-04-04 21:46:08 +08:00
张翔 83b814dd28 fix: 统一R2DBC和JDBC数据库URL配置
根本原因:
- R2DBC URL: r2dbc:h2:mem:///testdb (三个斜杠)
- JDBC URL: jdbc:h2:mem:testdb (不同格式)
- 两个URL指向不同的H2内存数据库实例
- spring.sql.init通过JDBC初始化,但应用使用R2DBC访问

修复方案:
- 统一数据库实例名称为testdb
- 添加DB_CLOSE_DELAY=-1保持连接
- 添加DB_CLOSE_ON_EXIT=FALSE防止退出时关闭
- 确保R2DBC和JDBC共享同一数据库实例
2026-04-04 21:42:48 +08:00
张翔 9745114c8d fix: 添加API请求签名支持
问题:认证管理器缺少签名头导致登录失败
修复:添加签名生成逻辑,与前端保持一致
- 使用crypto模块生成HMAC-SHA256签名
- 添加X-Signature、X-Timestamp、X-Nonce头
- 改进错误消息显示详细错误信息
2026-04-04 21:36:27 +08:00
张翔 109d184f91 fix: 修复E2E测试选择器和路径问题
问题分析:
1. 登录按钮使用native-type而非type属性
2. 登录后跳转到/而非/dashboard
3. 路径映射错误:/user-management应为/users等

修复内容:
- 登录流程测试:修复按钮选择器和URL断言
- 登出流程测试:修复下拉菜单选择器
- 用户管理测试:修正路径为/users
- 权限边界测试:修正路径为/users、/roles、/menus
- 移除不存在的data-testid选择器
- 添加适当的等待和错误消息匹配
2026-04-04 21:26:17 +08:00
张翔 46fd18a708 docs: 完善测试框架文档
- 创建详细的README文档
- 包含快速开始指南
- 包含测试场景说明
- 包含最佳实践和故障排查
- 包含CI/CD集成示例
- 包含维护指南和统计信息

测试验证:
- 单元测试:172个测试用例全部通过
- E2E测试:26个测试场景
- 角色定义:3个角色
- 测试覆盖率:核心功能100%
2026-04-04 21:01:03 +08:00
张翔 345211a860 feat: 实现用户管理场景测试
- 创建管理员创建用户测试(5个测试用例)
  - 管理员可以创建新用户
  - 管理员可以编辑用户信息
  - 管理员可以删除用户
  - 创建用户时用户名重复验证
  - 创建用户时邮箱格式验证
- 创建权限边界验证测试(11个测试用例)
  - 管理员权限验证(5个)
  - 普通用户权限验证(4个)
  - 测试用户权限验证(2个)
  - 跨角色权限对比测试
2026-04-04 20:59:45 +08:00
张翔 98276e0ffb feat: 实现认证场景测试
- 创建登录流程测试(6个测试用例)
  - 管理员用户登录成功
  - 普通用户登录成功
  - 错误密码登录失败
  - 空用户名登录失败
  - 空密码登录失败
  - Token注入登录
- 创建登出流程测试(4个测试用例)
  - 用户登出成功
  - 登出后无法访问受保护页面
  - 登出后Token被清除
  - 多角色登出测试
2026-04-04 20:58:30 +08:00
张翔 76d8afa264 feat: 配置环境变量和Playwright配置
- 创建 .env.test 测试环境配置文件
- 更新 playwright.config.ts 添加角色测试项目
- 配置测试用户密码为 Test@123
- 添加独立的角色测试项目配置
2026-04-04 20:57:27 +08:00
张翔 89ccb4e52f feat: 实现权限验证工具
- 创建 PermissionHelper 类
- 支持验证页面访问权限
- 支持验证CRUD操作权限
- 支持验证角色权限边界
- 添加基础单元测试(5个测试用例全部通过)
2026-04-04 20:56:35 +08:00
张翔 bf2ebab9aa feat: 实现测试数据管理器
- 创建 TestDataManager 单例类
- 支持创建用户、角色等测试数据
- 实现测试数据跟踪机制
- 支持自动清理测试数据
- 添加完整的单元测试(6个测试用例全部通过)
2026-04-04 20:55:20 +08:00
张翔 68070886d9 feat: 实现认证辅助工具
- 创建 Token 管理器 RoleAuthManager
- 创建认证辅助类 AuthHelper
- 支持 Token 注入和真实登录两种模式
- 实现 Token 缓存机制
- 添加完整的单元测试(5个测试用例全部通过)
2026-04-04 20:54:03 +08:00
张翔 54ea704f27 feat: 实现角色定义系统
- 创建角色定义基类 RoleDefinition
- 实现管理员角色 AdminRole
- 实现普通用户角色 UserRole
- 实现测试用户角色 TestRole
- 实现角色工厂 RoleFactory
- 添加完整的单元测试
- 更新 vitest 配置以包含角色定义测试

所有角色统一使用密码: Test@123
2026-04-04 20:43:25 +08:00
张翔 4732b9ef02 fix: 统一H2数据库密码配置为Test@123
- 统一主应用和测试环境的密码配置
- 使用BCrypt $2a$版本hash
- 添加密码验证测试确保一致性

影响范围:
- novalon-manage-api/manage-app/src/main/resources/data-h2.sql
- novalon-manage-api/manage-sys/src/test/java/cn/novalon/manage/sys/util/PasswordHashGenerator.java
2026-04-04 20:39:01 +08:00
张翔 49ba18e827 chore: 添加 .worktrees/ 到 .gitignore
为 git worktree 隔离工作区做准备
2026-04-04 20:34:31 +08:00