job51-gitlab-cr-node-jt-1 2.9.2 → 2.9.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/settings.json +9 -9
- package/docs/GITLAB_CR_NODE_TECHNICAL_DOCS.md +148 -17
- package/package.json +1 -1
- package/log +0 -4630
package/.claude/settings.json
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
{
|
|
2
|
-
"env": {
|
|
3
|
-
"ANTHROPIC_AUTH_TOKEN": "sk-436f005eeece4cf7b339bd18162c8a76",
|
|
4
|
-
"ANTHROPIC_BASE_URL": "https://dashscope.aliyuncs.com/apps/anthropic",
|
|
5
|
-
"API_TIMEOUT_MS": "3000000",
|
|
6
|
-
"ANTHROPIC_MODEL": "qwen3.5-plus",
|
|
7
|
-
"ANTHROPIC_SMALL_FAST_MODEL":"qwen3.5-plus",
|
|
8
|
-
"SLASH_COMMAND_TOOL_CHAR_BUDGET": "50000"
|
|
9
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"env": {
|
|
3
|
+
"ANTHROPIC_AUTH_TOKEN": "sk-436f005eeece4cf7b339bd18162c8a76",
|
|
4
|
+
"ANTHROPIC_BASE_URL": "https://dashscope.aliyuncs.com/apps/anthropic",
|
|
5
|
+
"API_TIMEOUT_MS": "3000000",
|
|
6
|
+
"ANTHROPIC_MODEL": "qwen3.5-plus",
|
|
7
|
+
"ANTHROPIC_SMALL_FAST_MODEL":"qwen3.5-plus",
|
|
8
|
+
"SLASH_COMMAND_TOOL_CHAR_BUDGET": "50000"
|
|
9
|
+
}
|
|
10
10
|
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
# GitLab Code Review AI Tool 技术文档
|
|
2
2
|
|
|
3
|
-
**项目名称**: job51-gitlab-cr-node
|
|
4
|
-
**当前版本**: 2.8.
|
|
5
|
-
**作者**: tao.jing
|
|
6
|
-
**最后更新**: 2026-
|
|
3
|
+
**项目名称**: job51-gitlab-cr-node
|
|
4
|
+
**当前版本**: 2.8.8
|
|
5
|
+
**作者**: tao.jing
|
|
6
|
+
**最后更新**: 2026-05-09
|
|
7
7
|
**项目地址**: https://gitdev.51job.com/51jobweb/ai-agent
|
|
8
8
|
|
|
9
9
|
---
|
|
@@ -27,6 +27,56 @@
|
|
|
27
27
|
|
|
28
28
|
## 版本历史
|
|
29
29
|
|
|
30
|
+
### v2.8.8 (2026-05-09)
|
|
31
|
+
|
|
32
|
+
**当前版本**: 幻觉检测增强 - 部分幻觉问题过滤机制
|
|
33
|
+
|
|
34
|
+
**新增功能**:
|
|
35
|
+
- **部分幻觉问题过滤机制**:在汇总报告中只显示正常发布的问题,不包含幻觉问题内容
|
|
36
|
+
- 问题现象:当一个diff块有多个问题时,部分问题被检测为幻觉(如文件路径不匹配),但汇总报告中仍包含所有问题的完整内容,包括幻觉问题的内容
|
|
37
|
+
- 根本原因:
|
|
38
|
+
- 幻觉检测逻辑只判断是否跳过评论发布
|
|
39
|
+
- 但审查结果的 `reportContent` 包含所有问题的完整报告
|
|
40
|
+
- 汇总报告直接使用原始 `reportContent`,导致幻觉问题内容也被显示
|
|
41
|
+
- 影响分析:
|
|
42
|
+
- 用户在汇总报告中看到幻觉问题的内容,但这些问题的评论并未发布到GitLab
|
|
43
|
+
- 产生信息不一致,降低汇总报告的可信度
|
|
44
|
+
- 解决方案:
|
|
45
|
+
- **统计机制**:记录每个问题的发布状态(幻觉/正常)
|
|
46
|
+
- **过滤机制**:根据实际发布的问题索引重新生成过滤后的报告内容
|
|
47
|
+
- **传递机制**:通过返回值将过滤后的内容传递给汇总报告生成流程
|
|
48
|
+
- 实现细节:
|
|
49
|
+
- 新增 `publishedProblemIndexes` 数组:记录正常发布的问题索引(从1开始)
|
|
50
|
+
- 新增 `generateFilteredReport` 方法:根据问题索引生成过滤后的报告内容
|
|
51
|
+
- 修改 `postSingleCommentToGitLab` 方法:
|
|
52
|
+
- 统计幻觉问题数量和正常发布数量
|
|
53
|
+
- 根据统计结果返回不同状态:
|
|
54
|
+
- 所有问题都是幻觉:返回 `{ hallucination_detected: true, filtered_report_content: '' }`
|
|
55
|
+
- 部分问题正常:返回 `{ hallucination_detected: false, filtered_report_content: '过滤后的报告' }`
|
|
56
|
+
- 所有问题正常:返回 `{ hallucination_detected: false, filtered_report_content: '完整报告' }`
|
|
57
|
+
- 修改 `processBlock` 方法:接收过滤后的报告内容并更新 `blockObj.review_result.reportContent`
|
|
58
|
+
- 修改 `collectAllReviewReports` 方法:过滤掉完全幻觉的结果
|
|
59
|
+
- 处理场景:
|
|
60
|
+
- **场景1:所有问题都是幻觉**
|
|
61
|
+
- 示例:问题1、2、3文件路径都不匹配
|
|
62
|
+
- 行为:标记为幻觉,过滤掉整个结果,不出现在汇总报告中
|
|
63
|
+
- **场景2:部分问题正常**
|
|
64
|
+
- 示例:问题1幻觉(文件路径不匹配),问题2、3正常发布
|
|
65
|
+
- 行为:不标记为幻觉,但汇总报告只显示问题2、3的内容(过滤掉问题1)
|
|
66
|
+
- 实现:调用 `generateFilteredReport` 提取问题2、3内容
|
|
67
|
+
- **场景3:所有问题都正常**
|
|
68
|
+
- 示例:问题1、2、3都正常发布
|
|
69
|
+
- 行为:汇总报告显示完整内容
|
|
70
|
+
- 效果:
|
|
71
|
+
- 汇总报告与GitLab发布的评论保持一致
|
|
72
|
+
- 用户看到的汇总报告内容都是实际发布的评论内容
|
|
73
|
+
- 提高汇总报告的准确性和可信度
|
|
74
|
+
- 修复文件:
|
|
75
|
+
- `index.js:863-966`:统计机制和返回值增强
|
|
76
|
+
- `index.js:125-147`:接收过滤后的内容并更新报告
|
|
77
|
+
- `index.js:201-223`:汇总报告过滤逻辑
|
|
78
|
+
- `index.js:775-807`:新增 `generateFilteredReport` 方法
|
|
79
|
+
|
|
30
80
|
### v2.8.7 (2026-04-29)
|
|
31
81
|
|
|
32
82
|
**当前版本**: 审查规则增强 - 文件路径格式保留与上下文行限制
|
|
@@ -1300,7 +1350,9 @@ POST /projects/{projectId}/merge_requests/{iid}/notes
|
|
|
1300
1350
|
|
|
1301
1351
|
## 10. 错误处理与容错机制
|
|
1302
1352
|
|
|
1303
|
-
### 10.1 AI 幻觉检测与过滤
|
|
1353
|
+
### 10.1 AI 幻觉检测与过滤
|
|
1354
|
+
|
|
1355
|
+
#### 10.1.1 文件路径幻觉检测 (v2.8.4)
|
|
1304
1356
|
|
|
1305
1357
|
**幻觉问题表现**:
|
|
1306
1358
|
- AI 在生成审查报告时可能编造错误的文件路径
|
|
@@ -1317,18 +1369,97 @@ if (problemInfo.new_path && diff_info.new_path &&
|
|
|
1317
1369
|
}
|
|
1318
1370
|
```
|
|
1319
1371
|
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
1330
|
-
|
|
1331
|
-
|
|
1372
|
+
#### 10.1.2 部分幻觉过滤机制 (v2.8.8)
|
|
1373
|
+
|
|
1374
|
+
**新增问题**:
|
|
1375
|
+
- 一个diff块有多个问题时,部分问题被检测为幻觉,但汇总报告仍包含所有问题的完整内容
|
|
1376
|
+
- 用户在汇总报告中看到幻觉问题的内容,但这些评论并未发布到GitLab
|
|
1377
|
+
- 信息不一致,降低汇总报告的可信度
|
|
1378
|
+
|
|
1379
|
+
**解决方案**:
|
|
1380
|
+
|
|
1381
|
+
1. **统计机制**:记录每个问题的发布状态
|
|
1382
|
+
```javascript
|
|
1383
|
+
// 统计幻觉问题数量和正常发布数量
|
|
1384
|
+
let hallucinationCount = 0;
|
|
1385
|
+
let publishedCount = 0;
|
|
1386
|
+
const publishedProblemIndexes = []; // 记录正常发布的问题索引(从1开始)
|
|
1387
|
+
|
|
1388
|
+
for (let i = 0; i < allLineInfo.length; i++) {
|
|
1389
|
+
if (文件路径不匹配) {
|
|
1390
|
+
hallucinationCount++;
|
|
1391
|
+
continue; // 跳过发布
|
|
1392
|
+
}
|
|
1393
|
+
// 正常发布
|
|
1394
|
+
publishedProblemIndexes.push(i + 1);
|
|
1395
|
+
publishedCount++;
|
|
1396
|
+
}
|
|
1397
|
+
```
|
|
1398
|
+
|
|
1399
|
+
2. **过滤机制**:根据问题索引生成过滤后的报告
|
|
1400
|
+
```javascript
|
|
1401
|
+
// generateFilteredReport 方法:根据问题索引生成过滤后的报告
|
|
1402
|
+
generateFilteredReport(fullReport, publishedProblemIndexes) {
|
|
1403
|
+
// 提取报告标题(如 "## 🤖 AI 代码审查结果")
|
|
1404
|
+
// 提取指定索引的问题内容
|
|
1405
|
+
// 组合成过滤后的报告
|
|
1406
|
+
}
|
|
1407
|
+
```
|
|
1408
|
+
|
|
1409
|
+
3. **传递机制**:返回过滤后的内容
|
|
1410
|
+
```javascript
|
|
1411
|
+
// 只有问题都被检测为幻觉时,才标记整个结果为幻觉
|
|
1412
|
+
const isAllHallucination = hallucinationCount > 0 && hallucinationCount === allLineInfo.length;
|
|
1413
|
+
|
|
1414
|
+
if (isAllHallucination) {
|
|
1415
|
+
return { hallucination_detected: true, filtered_report_content: '' };
|
|
1416
|
+
}
|
|
1417
|
+
|
|
1418
|
+
// 如果部分问题正常发布,生成过滤后的报告内容
|
|
1419
|
+
let filteredReportContent = fullReportContent;
|
|
1420
|
+
if (publishedCount > 0 && publishedCount < allLineInfo.length) {
|
|
1421
|
+
filteredReportContent = this.generateFilteredReport(fullReportContent, publishedProblemIndexes);
|
|
1422
|
+
}
|
|
1423
|
+
|
|
1424
|
+
return {
|
|
1425
|
+
hallucination_detected: false,
|
|
1426
|
+
filtered_report_content: filteredReportContent
|
|
1427
|
+
};
|
|
1428
|
+
```
|
|
1429
|
+
|
|
1430
|
+
**处理策略** (v2.8.8更新):
|
|
1431
|
+
| 检测场景 | 处理动作 | 汇总报告显示 |
|
|
1432
|
+
|---------|----------|------------|
|
|
1433
|
+
| 所有问题都是幻觉 | 标记 `hallucination_detected=true` | **完全过滤**,不显示 |
|
|
1434
|
+
| 部分问题正常 | 生成过滤后的报告内容 | 只显示正常问题内容 |
|
|
1435
|
+
| 所有问题正常 | 返回完整报告内容 | 显示完整内容 |
|
|
1436
|
+
|
|
1437
|
+
**效果对比**:
|
|
1438
|
+
|
|
1439
|
+
| 版本 | 行为 | 效果 |
|
|
1440
|
+
|------|------|------|
|
|
1441
|
+
| v2.8.4-v2.8.7 | 所有问题都标记为幻觉 → 过滤整个结果 | ❌ 如果有正常问题,正常问题也被过滤 |
|
|
1442
|
+
| v2.8.8 | 只过滤幻觉问题内容,保留正常问题内容 | ✅ 汇总报告与GitLab评论一致 |
|
|
1443
|
+
|
|
1444
|
+
**示例**:
|
|
1445
|
+
|
|
1446
|
+
假设审查结果有3个问题:
|
|
1447
|
+
- 问题1:文件路径不匹配(幻觉)
|
|
1448
|
+
- 问题2:正常发布
|
|
1449
|
+
- 问题3:正常发布
|
|
1450
|
+
|
|
1451
|
+
**v2.8.7处理**:
|
|
1452
|
+
```
|
|
1453
|
+
hallucination_detected = true
|
|
1454
|
+
汇总报告:不显示该diff块
|
|
1455
|
+
```
|
|
1456
|
+
|
|
1457
|
+
**v2.8.8处理**:
|
|
1458
|
+
```
|
|
1459
|
+
hallucination_detected = false
|
|
1460
|
+
filtered_report_content = 只包含问题2和问题3的内容
|
|
1461
|
+
汇总报告:显示问题2和问题3
|
|
1462
|
+
```
|
|
1332
1463
|
|
|
1333
1464
|
### 10.2 AI 审查失败处理
|
|
1334
1465
|
|