kindergarten_java/docs/test-logs/package/2026-03-13.md

203 lines
6.6 KiB
Markdown
Raw Permalink Normal View History

# 课程包三端全链路测试记录
**测试日期**: 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. **继续教师端测试**
- 修复登录跳转问题
- 测试备课功能
- 测试授课功能
---
**测试结论**: 课程包三端基础框架运行正常,但套餐创建和数据流转环节存在问题,需要进一步调试和修复。