130 lines
7.4 KiB
Markdown
130 lines
7.4 KiB
Markdown
# 性能与稳定性检查记录
|
|
|
|
本文档用于记录可重复的阶段性性能与稳定性检查。采样脚本和本记录只面向开发与回归测试,不进入普通用户发布包。
|
|
|
|
## 测试环境
|
|
|
|
| 项目 | 内容 |
|
|
| --- | --- |
|
|
| 测试日期 | TODO |
|
|
| Git commit | TODO |
|
|
| 构建类型 | TODO: Debug / Release |
|
|
| 操作系统 | TODO |
|
|
| CPU | TODO |
|
|
| 内存 | TODO |
|
|
| 显示器 / DPI | TODO |
|
|
| Qt 版本 | TODO |
|
|
| 角色包 | `resources/characters/shiroko` |
|
|
| AppConfig 关键项 | characterId=TODO, scale=TODO, performanceMode=TODO, pauseWhenHidden=TODO, enableLazyLoad=TODO, enableAnimationPrewarm=TODO, animationCacheLimitMb=TODO, unloadAnimationsWhenHidden=TODO |
|
|
|
|
## 采样脚本
|
|
|
|
默认采样当前 `QtDesktopPet` 进程 5 分钟,每 5 秒一条:
|
|
|
|
```powershell
|
|
powershell -NoProfile -ExecutionPolicy Bypass -File tools/perf_sample.ps1
|
|
```
|
|
|
|
指定 PID 采样:
|
|
|
|
```powershell
|
|
powershell -NoProfile -ExecutionPolicy Bypass -File tools/perf_sample.ps1 -Pid 12345 -DurationSeconds 600
|
|
```
|
|
|
|
输出目录默认是:
|
|
|
|
```text
|
|
reports/perf/
|
|
```
|
|
|
|
`reports/perf/` 已加入 `.gitignore`。需要沉淀结论时,只把摘要写入本文档,不提交原始采样 CSV。
|
|
|
|
## 检查项
|
|
|
|
| 场景 | 步骤 | 采样命令 | 预期结果 | 实际结果 | 结论 | 备注 |
|
|
| --- | --- | --- | --- | --- | --- | --- |
|
|
| 启动后静置 | 启动程序后不操作 5 分钟 | `tools/perf_sample.ps1` 默认参数 | CPU 保持低占用,内存无持续上涨 | TODO | TODO | TODO |
|
|
| idle 连续播放 | 保持桌宠可见并播放 idle 10 分钟 | `tools/perf_sample.ps1 -DurationSeconds 600` | 动画持续播放,内存曲线稳定 | TODO | TODO | TODO |
|
|
| 隐藏到托盘 | 可见采样 3 分钟,隐藏后再采样 3 分钟 | 两次采样分别记录 | 隐藏后 CPU 下降或保持低占用 | TODO | TODO | TODO |
|
|
| 重复显示 / 隐藏 | 连续显示/隐藏 10 次 | `tools/perf_sample.ps1 -DurationSeconds 300` | 无崩溃,句柄数和内存无异常增长 | TODO | TODO | TODO |
|
|
| 重复启动 / 单实例 | 已运行时连续双击 exe 多次;隐藏到托盘后再双击 exe | 任务管理器或 `Get-Process QtDesktopPet` | 始终只有一个进程;隐藏状态可被重复启动唤醒 | TODO | TODO | 检查 QLocalServer 激活路径 |
|
|
| 设置页居中 / 置前 | 从托盘打开设置页;多屏环境重复打开;设置页已打开时再次启动 exe | 手工观察 | 设置页位于当前屏幕可用区域中心;重复启动时设置页置前 | TODO | TODO | 优先按宠物所在屏幕计算 |
|
|
| 重复切换状态 | 通过右键状态测试切换 `idle/think/talk/error/drag` | `tools/perf_sample.ps1 -DurationSeconds 300` | 首次切换状态允许加载资源,缓存达到上限后按 LRU 卸载非保护状态 | TODO | TODO | 结合日志确认加载/卸载记录 |
|
|
| 动画预热与卸载 | 默认配置启动后静置,随后隐藏到托盘再显示 | `tools/perf_sample.ps1 -DurationSeconds 600` | 日志出现有限次分批预热;隐藏后非保护动画缓存释放;显示后不会反复预热刚被卸载的状态 | TODO | TODO | 不应影响当前播放状态恢复 |
|
|
| 缩放 / 置顶切换 | 设置页切换缩放,右键切换置顶 | `tools/perf_sample.ps1 -DurationSeconds 300` | 窗口尺寸和状态稳定,无崩溃 | TODO | TODO | TODO |
|
|
| AI 对话 | 连续发送 20 轮短消息 | `tools/perf_sample.ps1 -DurationSeconds 900` | 请求期间 UI 不阻塞,内存不持续上涨;日志不包含完整消息正文、API Key 或完整错误响应正文 | TODO | TODO | 使用错误 Key/Base URL 时检查脱敏摘要 |
|
|
| 提醒触发 | 创建 2 条同时间提醒并等待触发 | `tools/perf_sample.ps1 -DurationSeconds 300` | 可见时队列逐条显示;隐藏或 AI 忙时只发系统通知;内存和句柄无异常增长 | TODO | TODO | 检查音效播放和 5 分钟稍后提醒 |
|
|
| 天气查询 | 连续查询当前/明天/未来三天天气 | `tools/perf_sample.ps1 -DurationSeconds 300` | 网络请求异步执行,UI 不阻塞;失败时明确提示;日志不记录完整用户原文 | TODO | TODO | 覆盖默认城市、IP fallback、多候选提示 |
|
|
| 联网模式 | 使用支持联网的 OpenAI/Gemini Provider 连续发起 5 次联网对话,并覆盖 DeepSeek/Custom 不支持提示 | `tools/perf_sample.ps1 -DurationSeconds 300` | 请求异步执行,来源展示不阻塞 UI;不支持 Provider 不发起伪联网;日志不记录完整用户问题或 API Key | TODO | TODO | 输入框打开联网开关;不再测试旧多搜索源/SearXNG 路径 |
|
|
| 应用启动 | 登记一个测试 exe,聊天触发启动并取消/确认各一次 | 手工观察 + 采样 | 启动前始终二次确认;取消时不启动;确认后 UI 可继续响应;不执行脚本或聊天参数 | TODO | TODO | 使用无副作用测试程序,例如记事本或临时测试 exe |
|
|
| 本地文件操作 | 读取文本、列目录、复制、备份、重命名 | 手工观察 + 采样 | 写操作有确认;不覆盖、不删除、不访问系统目录;操作后 UI 可继续响应 | TODO | TODO | 使用临时测试目录,不操作真实重要文件 |
|
|
| 配置损坏兜底 | 备份后分别破坏 app 配置、AI 配置或本地聊天记录再启动 | 启动后采样 3 分钟 | 程序恢复默认配置或忽略损坏历史,并生成带时间戳的 broken 备份,不覆盖旧备份 | TODO | TODO | 使用备份副本测试 |
|
|
| 角色包损坏兜底 | 使用临时复制的损坏角色包测试 | 启动后采样 3 分钟 | 程序不崩溃,回退 preview 或默认显示 | TODO | TODO | 不直接破坏仓库内默认角色包 |
|
|
|
|
## 懒加载现状
|
|
|
|
当前实现是状态级懒加载、主线程分批预热和 LRU 卸载:
|
|
|
|
```text
|
|
1. enableLazyLoad=true 时,构建 AnimationClip 只保存帧路径
|
|
2. 某个状态首次播放时调用 ensureLoaded() 加载该状态帧
|
|
3. enableAnimationPrewarm=true 时,启动后在主线程按批次预热常用状态
|
|
4. 已加载状态按状态级 LRU 策略管理,超过 animationCacheLimitMb 时卸载非保护状态
|
|
5. 单轮预热记录会避免反复重新加载刚被 LRU 卸载的状态
|
|
6. unloadAnimationsWhenHidden=true 时,隐藏到托盘会释放非保护动画缓存
|
|
7. enableLazyLoad=false 时,仍保持启动阶段加载全部状态帧的兼容行为
|
|
```
|
|
|
|
尚未实现:
|
|
|
|
```text
|
|
1. 后台线程预热
|
|
2. 单帧级缓存
|
|
3. 自动化长期压测记录
|
|
```
|
|
|
|
## 发布包说明
|
|
|
|
普通用户发布包不包含:
|
|
|
|
```text
|
|
tools/
|
|
docs/
|
|
reports/
|
|
build/
|
|
dist/
|
|
release_packages/
|
|
.git/
|
|
```
|
|
|
|
普通用户发布包应包含运行必需内容:
|
|
|
|
```text
|
|
QtDesktopPet.exe
|
|
Qt 运行时依赖
|
|
resources/characters/
|
|
resources/icons/
|
|
resources/sounds/
|
|
LICENSE
|
|
README.md
|
|
```
|
|
|
|
安装器卸载验证:
|
|
|
|
```text
|
|
1. 正常卸载时程序文件应删除
|
|
2. 选择不删除用户数据时,配置、导入角色、聊天记录和日志应保留
|
|
3. 选择删除用户数据时,卸载完成阶段应删除当前用户下的 QtDesktopPet 数据目录
|
|
```
|
|
|
|
安装器最终文件默认放在项目根目录。Inno Setup 编译阶段使用当前盘符下的纯 ASCII 临时目录,例如 `D:\QtDesktopPetInstallerOutput`,再复制最终安装包回项目根目录,用于规避中文项目路径下可能出现的 `EndUpdateResource failed (5)`。
|
|
|
|
如果需要把本地安装包集中保存,可通过 `-InstallerOutputDir release_packages` 输出到 `release_packages/`。该目录属于本地发布产物,不进入 Git。
|
|
|
|
运行时资源查找顺序:
|
|
|
|
```text
|
|
1. QtDesktopPet.exe 同级 resources/
|
|
2. 开发源码目录 resources/
|
|
```
|