# 课程包三端全链路测试记录 **测试日期**: 2026-03-13 **测试人员**: Claude **测试类型**: 功能测试 --- ## 测试概述 本次测试针对课程包业务从超管端创建到学校端查看、教师端备课授课的完整链路进行功能验证。 --- ## 测试结果汇总 ### 整体进度 | 阶段 | 测试项 | 状态 | |------|--------|------| | 超管端 | 登录功能 | ✅ 通过 | | 超管端 | 套餐列表页 | ✅ 通过 | | 超管端 | 创建套餐页 | ✅ 通过 | | 超管端 | 表单字段填写 | ❌ 失败 - 选择器问题 | | 超管端 | 保存套餐 | ⚠️ 部分成功 - 列表为空 | | 学校端 | 登录功能 | ✅ 通过 | | 学校端 | 课程包页面 | ✅ 通过 | | 学校端 | 课程包数据 | ❌ 显示"暂无数据" | | 教师端 | 登录功能 | ❌ 失败 - 页面跳转问题 | | 教师端 | 课程查看 | ❌ 未测试 | --- ## 详细测试结果 ### 第一阶段:超管端 #### ✅ 1.1 登录功能 - **测试步骤**: 访问登录页 → 选择超管角色 → 输入账号密码 → 点击登录 - **测试结果**: ✅ 通过 - **API调用**: - `POST /api/v1/auth/login` ✅ - **截图**: `pkg_01_admin_login_1773378047.png` #### ✅ 1.2 套餐列表页 - **测试步骤**: 访问 `/admin/packages` - **测试结果**: ✅ 通过 - 页面正常加载 - **截图**: `pkg_02_admin_package_list_1773378048.png` #### ✅ 1.3 创建套餐页 - **测试步骤**: 点击"创建套餐"按钮 - **测试结果**: ✅ 通过 - 创建表单正常加载 - **截图**: `pkg_03_admin_create_page_1773378055.png` #### ❌ 1.4 表单字段填写 - **测试步骤**: 填写套餐名称、描述、价格、优惠类型、适用年级 - **测试结果**: ❌ 失败 - 所有字段选择器无法定位 - **错误信息**: - 填写套餐名称失败 - 填写价格失败 - 选择年级失败 - **原因分析**: - Ant Design Vue 的表单组件结构与选择器不匹配 - `a-input-number` 组件没有 placeholder 属性 - label 与输入框的关联方式需要调整 - **截图**: `pkg_04_admin_form_filled_1773378237.png` #### ⚠️ 1.5 保存套餐 - **测试步骤**: 点击保存按钮 - **测试结果**: ⚠️ 部分成功 - 保存按钮点击成功,但返回列表为空 - **截图**: `pkg_05_admin_saved_1773378238.png`, `pkg_06_admin_list_again_1773378239.png` --- ### 第二阶段:学校端 #### ✅ 2.1 登录功能 - **测试步骤**: 访问登录页 → 选择学校角色 → 输入账号密码 → 点击登录 - **测试结果**: ✅ 通过 - **API调用**: - `POST /api/v1/auth/login` ✅ - `GET /api/v1/school/stats` ✅ - `GET /api/v1/school/stats/*` ✅ (多个统计接口) - **截图**: `pkg_07_school_login_1773378243.png` #### ✅ 2.2 课程包页面 - **测试步骤**: 访问 `/school/packages` - **测试结果**: ✅ 通过 - 页面正常加载 - **数据状态**: ❌ 显示"暂无数据" - **原因分析**: 超管端套餐未成功保存或未发布到租户 - **截图**: `pkg_08_school_packages_1773378244.png` --- ### 第三阶段:教师端 #### ❌ 3.1 登录功能 - **测试步骤**: 从学校端切换到教师端,访问登录页 - **测试结果**: ❌ 失败 - 页面未正确跳转到登录页 - **错误信息**: `TimeoutError: Page.click: Timeout 30000ms exceeded. waiting for locator(".role-btn:has-text(\"教师\")")` - **原因分析**: 页面可能仍停留在学校端 Dashboard,未跳转到登录页 - **截图**: 无(测试异常终止) --- ## 发现的问题 ### 高优先级问题 1. **超管端 - 表单输入框选择器问题** - **位置**: `/admin/packages/create` - **问题**: 无法定位到 Ant Design Vue 表单的输入框 - **影响**: 无法自动化测试套餐创建功能 - **修复方案**: 调整选择器策略,使用更精确的 CSS 选择器或属性选择器 2. **学校端 - 课程包数据为空** - **位置**: `/school/packages` - **问题**: 显示"暂无数据" - **影响**: 无法测试学校端查看课程包功能 - **可能原因**: - 超管端套餐创建未成功 - 套餐未审核/发布 - 租户未关联套餐 - **修复方案**: - 先手动测试套餐创建 API - 检查套餐审核发布流程 - 检查租户套餐关联逻辑 3. **教师端 - 登录页跳转问题** - **问题**: 从学校端切换到教师端时,页面未跳转到登录页 - **影响**: 无法测试教师端功能 - **修复方案**: 添加明确的登出逻辑或等待页面加载 ### 中优先级问题 4. **套餐保存后列表为空** - **问题**: 保存后返回列表,但列表显示空数据 - **可能原因**: - 保存 API 调用失败 - 前端状态更新问题 - 数据库写入失败 - **修复方案**: 检查后端日志和前端 console --- ## 待办事项 1. **修复自动化测试选择器问题** - 调研 Ant Design Vue 表单组件的实际 DOM 结构 - 更新选择器以匹配实际 DOM - 或考虑使用 playwright 的 `getByPlaceholder` 和 `getByLabel` 方法 2. **手动测试套餐创建 API** - 使用 curl 或 Postman 直接测试后端 API - 验证套餐是否成功保存到数据库 3. **检查套餐审核发布流程** - 确认套餐审核、发布状态流转 - 确认租户套餐关联逻辑 4. **完善测试脚本** - 添加更健壮的等待和重试逻辑 - 添加错误恢复机制 - 添加更详细的日志输出 --- ## 截图索引 | 序号 | 截图文件 | 说明 | |------|----------|------| | 1 | pkg_01_admin_login_1773378047.png | 超管登录成功 | | 2 | pkg_02_admin_package_list_1773378048.png | 超管套餐列表(空) | | 3 | pkg_03_admin_create_page_1773378055.png | 创建套餐页面 | | 4 | pkg_04_admin_form_filled_1773378237.png | 表单页面(字段未填充) | | 5 | pkg_05_admin_saved_1773378238.png | 保存后跳转 | | 6 | pkg_06_admin_list_again_1773378239.png | 套餐列表(仍为空) | | 7 | pkg_07_school_login_1773378243.png | 学校登录成功 | | 8 | pkg_08_school_packages_1773378244.png | 学校课程包(暂无数据) | --- ## 下一步计划 1. **调试套餐创建问题** - 手动通过浏览器创建一个测试套餐 - 检查浏览器开发者工具中的网络请求 - 确认 API 调用是否成功 2. **完善自动化测试** - 修复表单输入框选择器 - 添加登出逻辑 - 添加更详细的错误日志 3. **继续教师端测试** - 修复登录跳转问题 - 测试备课功能 - 测试授课功能 --- **测试结论**: 课程包三端基础框架运行正常,但套餐创建和数据流转环节存在问题,需要进一步调试和修复。