Commit Graph

447 Commits

Author SHA1 Message Date
digua 6103255815 feat: 重构模型配置逻辑 2026-04-08 23:07:48 +08:00
digua 12941c4a1e chore: 升级到node24 2026-04-08 09:40:58 +08:00
digua 53208de60e feat: 实验室新增基础工具用于调试 2026-04-07 23:43:01 +08:00
digua fa3282f625 feat: 移除旧版提示词 2026-04-07 23:43:01 +08:00
digua a0155b5f68 chore: 支持Linux打包 2026-04-07 23:43:01 +08:00
digua 4929b49135 docs: update 2026-04-07 23:43:01 +08:00
digua 7919929b94 feat: 增加查询缓存以加速访问 2026-04-07 23:43:01 +08:00
digua b8a3823cef fix: 补全工具调用显示名称的 i18n 翻译 2026-04-07 23:43:01 +08:00
digua d49a094164 feat: 搜索工具自动携带上下文消息 2026-04-07 23:43:01 +08:00
digua e86df09371 release: v0.14.2 v0.14.2 2026-04-07 00:19:38 +08:00
digua f1cfc4c864 feat: 新增 7天内记住助手选择功能 2026-04-07 00:13:33 +08:00
digua 84284a4e01 docs: update intro images 2026-04-06 23:23:01 +08:00
digua fbd3155991 feat: toast样式优化 2026-04-06 22:24:49 +08:00
digua e74af1a8b6 feat: AI对话支持复制 2026-04-06 22:24:49 +08:00
digua 72c0d40f4d feat: AI对话样式优化 2026-04-06 22:24:49 +08:00
digua 3189de3a6e style: 代码格式优化 2026-04-06 22:24:49 +08:00
digua bfc96a723d fix: 完善AI对话报错信息 2026-04-06 22:24:49 +08:00
digua f66826ba73 feat: 优化对话UI 2026-04-06 22:24:49 +08:00
digua d641772d79 refactor: AI对话代码整理 2026-04-06 22:24:49 +08:00
digua a8c3b032a7 test: add reusable e2e launcher smoke framework and scripts 2026-04-06 22:24:49 +08:00
l17728 b532eeef42 feat: add E2E test framework for Electron applications with robust port management, instance isolation, and safety guards
## 功能
添加 Electron 应用的 E2E 测试启动框架,支持并行实例运行、CDP 调试、独立数据隔离、完善的故障检测和数据保护。

### 核心特性

#### 1. 可靠的端口扫描和预留机制
- 自动查找可用的 TCP 端口(默认从 9222 开始)
- **新增**:保持端口预留直到进程启动,防止 TOCTTOU 竞态
- 修复:递归逻辑中的 null + 1 bug
- 添加最大重试限制(100 次),防止无限递归
- 100ms 超时保护,快速检测端口占用
- 并发安全的 completed 标志和资源清理

#### 2. 正确的 CDP 端口配置
- 使用 --remote-debugging-port=<port> 命令行参数
- 移除无效的 REMOTE_DEBUGGING_PORT 环境变量
- 确保 E2E 客户端能正确连接调试器

#### 3. 完善的启动检测和错误处理
- 验证应用目录和 Electron 可执行文件存在性
- 捕获 spawn 错误事件并提供清晰错误信息
- 检测启动期间的早期退出(非零退出码)
- 检测信号终止的启动失败(SIGKILL、SIGTERM 等)
- 启动后立即抛出错误而不仅记录日志
- 避免连接到死进程,失败诊断清晰

#### 4. 并行实例隔离和数据保护
- 为每个 E2E 实例创建独立的用户数据目录
- 基于端口号生成唯一路径:`/tmp/chatlab-e2e-{port}`
- 通过环境变量 CHATLAB_E2E_USER_DATA_DIR 传递给主进程
- 主进程自动调用 app.setPath('userData', dir) 隔离存储
- **新增**:E2E 模式下跳过遗留数据迁移,保护用户真实数据
- 防止并发进程的状态泄漏、死锁、数据库冲突

#### 5. 优雅且高效的进程管理
- 防止多次调用 close() 导致的事件监听器泄漏
- 检查 proc.exitCode 和 proc.signalCode
- 已退出进程立即返回(无 5s 延迟)
- 使用 SIGTERM 允许进程正常清理资源
- 5 秒超时后强制 SIGKILL 防止僵尸进程
- 使用活力检查(proc.kill(0))替代 proc.killed
- 使用正确的 Node.js API signalCode(不是 signalDescription)
- 强制 SIGKILL 路径对 stubborn 进程有效
- 进程退出时立即清除超时定时器

#### 6. 并行实例支持
- 在主进程添加 TEST_MODE 环境变量检查
- 绕过单实例锁允许多个 Electron 实例
- 跳过遗留迁移保护用户数据
- 每个实例自动分配不同的 CDP 端口和数据目录

### 文件变更
- `electron/main/index.ts`:
  * 添加 TEST_MODE 检查,绕过单实例锁
  * 添加 CHATLAB_E2E_USER_DATA_DIR 读取和隔离
  * **新增**:跳过 E2E 模式下的遗留迁移
- `tests/e2e/helpers/app-launcher.js`: 完整的应用启动管理模块(260+ 行)
  * **新增**:port 预留机制,防止 TOCTTOU 竞态

### 使用示例
```javascript
const { launchApp } = require('./tests/e2e/helpers/app-launcher')

// 启动应用(自动查找可用端口和独立数据目录)
const app = await launchApp()
console.log('CDP 端口:', app.port)

// 运行测试...

// 关闭应用(已退出进程快速返回)
await app.close()
```

### 可配置选项
```javascript
await launchApp({
  port: 9222,                    // 指定端口,默认自动查找(带预留)
  userDataDir: '/custom/path',   // 自定义用户数据目录
  startupWaitTime: 2000          // 启动等待时间(毫秒),默认 2000
})
```

### 并行测试场景
 多个实例同时运行(每个实例独立端口和数据目录)
 自动端口分配(9222, 9223, 9224...)
 **端口预留防止竞态**(同时启动无冲突)
 自动数据隔离(/tmp/chatlab-e2e-9222, /tmp/chatlab-e2e-9223...)
 资源正确清理(无泄漏)
 启动失败快速失败(清晰诊断)
 进程强制清理(防止僵尸进程)
 慢速 CI 环境中不挂起
 Stubborn 进程能被正确杀死
 已退出进程快速检测和返回
 信号退出的进程也能快速返回
 无共享状态,支持真正的并行测试
 用户数据受保护,不会被测试污染

### 修复的关键问题
**P1 问题:**
- 端口扫描超时导致的无限挂起
- 进程强制杀死被 proc.killed 误导的竞态条件
- 启动期间的早期退出未被检测
- 并行 E2E 实例共享 userData 导致冲突
- **新增**:遗留迁移在 E2E 模式下可能删除用户数据
- **新增**:端口分配 TOCTTOU 竞态导致启动冲突

**P2 问题:**
- 慢速 CI 中的 listen 回调延迟
- close() 对已退出进程的 5 秒不必要延迟
- signalCode API 错误
- 信号终止的启动失败未被检测

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-04-06 17:37:33 +08:00
digua 59e6bdb9cb feat: 精简部分工具的搜索参数以节省token 2026-04-06 14:04:31 +08:00
digua 0a81238a0a feat: 支持 FTS5 全文搜索,并新增快速搜索工具 2026-04-06 14:04:31 +08:00
digua 3a4d722645 refactor: 抽取会话分析页公共逻辑并统一头部文案 2026-04-06 14:04:31 +08:00
digua a8e404244f release: v0.14.1 v0.14.1 2026-04-02 23:36:11 +08:00
digua 88f1af08dd feat: 优化SQL对话模块交互逻辑 2026-04-02 23:29:06 +08:00
digua 75183db517 feat: 迁移成员Tab内的模块到其他Tab 2026-04-02 23:29:06 +08:00
digua 4599ce44a0 feat: 成员管理迁移到首页 2026-04-02 23:29:06 +08:00
digua da3d7bccb4 feat: 新增部分AI工具 2026-04-02 23:29:06 +08:00
digua 346a38da5a feat: 重构 AI 工具分类体系 2026-04-02 23:29:06 +08:00
digua e099dde435 feat: 新增获取聊天概览工具 2026-04-02 23:29:06 +08:00
digua 211a8110b0 feat: 新增对话数据缓存管理模块,优化统计数据读取性能 2026-04-02 23:29:06 +08:00
digua bfca7ff133 fix: SQL Lab 和摘要生成的 AI 错误静默吞没问题
- llm:chatStream:正确处理 error/done 事件,防止终态重复发送
- llmComplete:检测 completeSimple 返回的 error stopReason 并抛出异常
- SessionTimeline:摘要生成失败时显示 toast 提示替代 console.log

Made-with: Cursor
2026-04-02 23:29:06 +08:00
digua b3d1171f71 feat: 废弃部分AI工具 2026-04-02 23:29:06 +08:00
digua fdd970701b feat: 总览页样式优化 2026-04-02 23:29:06 +08:00
digua 462ea14092 feat: 版本日志弹窗完善类型 2026-04-02 23:29:06 +08:00
digua 48c88aa6d5 release: v0.14.0 v0.14.0 2026-03-28 00:18:49 +08:00
digua c688d68282 feat: 总览样式优化 2026-03-28 00:10:29 +08:00
digua 4355344e35 docs: 新增AGENTS.md 2026-03-28 00:10:29 +08:00
digua 64b52e40f4 feat: 样式优化 2026-03-28 00:10:29 +08:00
digua 073c6bece5 feat: 点击预设问题自动提问 2026-03-28 00:10:29 +08:00
digua 4ea4df7480 feat: 设置支持选择选择会话默认进入的标签页 2026-03-28 00:10:29 +08:00
digua d1d817718f feat: 优化身份卡片样式 2026-03-28 00:10:29 +08:00
digua 792cb0e1ee feat: API服务 UI优化 2026-03-28 00:10:29 +08:00
digua 7ce50eab7c feat: 支持API导入 2026-03-28 00:10:29 +08:00
digua 6d5e6f6e7a feat: 支持API导出 2026-03-28 00:10:29 +08:00
xind 6d90552b9b fix: 修复消息去重误判并统一空字符串去重语义 2026-03-27 14:28:36 +08:00
digua 31c212d131 feat: 优化助手选择UI 2026-03-25 23:58:20 +08:00
digua 7eaba396ec refactor: 清理 parser worker rag merger 的历史类型问题 2026-03-25 22:43:12 +08:00
digua b6fdc3887e fix: 修复 AI 会话链路与前端 type-check 错误 2026-03-25 22:42:31 +08:00