@mycodemap/mycodemap 0.1.0 → 0.2.0
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/CHANGELOG.md +164 -6
- package/README.md +407 -141
- package/dist/cli/commands/ci.d.ts +7 -1
- package/dist/cli/commands/ci.d.ts.map +1 -1
- package/dist/cli/commands/ci.js +38 -0
- package/dist/cli/commands/ci.js.map +1 -1
- package/dist/cli/commands/cycles.d.ts.map +1 -1
- package/dist/cli/commands/cycles.js +2 -0
- package/dist/cli/commands/cycles.js.map +1 -1
- package/dist/cli/commands/export.d.ts +6 -0
- package/dist/cli/commands/export.d.ts.map +1 -0
- package/dist/cli/commands/export.js +108 -0
- package/dist/cli/commands/export.js.map +1 -0
- package/dist/cli/commands/generate.d.ts.map +1 -1
- package/dist/cli/commands/generate.js +96 -0
- package/dist/cli/commands/generate.js.map +1 -1
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +3 -1
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/logs.d.ts +5 -0
- package/dist/cli/commands/logs.d.ts.map +1 -0
- package/dist/cli/commands/logs.js +189 -0
- package/dist/cli/commands/logs.js.map +1 -0
- package/dist/cli/commands/report.d.ts +12 -0
- package/dist/cli/commands/report.d.ts.map +1 -0
- package/dist/cli/commands/report.js +158 -0
- package/dist/cli/commands/report.js.map +1 -0
- package/dist/cli/commands/server.d.ts +9 -0
- package/dist/cli/commands/server.d.ts.map +1 -0
- package/dist/cli/commands/server.js +68 -0
- package/dist/cli/commands/server.js.map +1 -0
- package/dist/cli/commands/watch-foreground.d.ts.map +1 -1
- package/dist/cli/commands/watch-foreground.js +2 -0
- package/dist/cli/commands/watch-foreground.js.map +1 -1
- package/dist/cli/commands/watch.d.ts.map +1 -1
- package/dist/cli/commands/watch.js +2 -0
- package/dist/cli/commands/watch.js.map +1 -1
- package/dist/cli/first-run-guide.d.ts +23 -0
- package/dist/cli/first-run-guide.d.ts.map +1 -0
- package/dist/cli/first-run-guide.js +83 -0
- package/dist/cli/first-run-guide.js.map +1 -0
- package/dist/cli/index.js +85 -1
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/platform-check.d.ts +21 -0
- package/dist/cli/platform-check.d.ts.map +1 -0
- package/dist/cli/platform-check.js +94 -0
- package/dist/cli/platform-check.js.map +1 -0
- package/dist/cli/tree-sitter-check.d.ts +35 -0
- package/dist/cli/tree-sitter-check.d.ts.map +1 -0
- package/dist/cli/tree-sitter-check.js +133 -0
- package/dist/cli/tree-sitter-check.js.map +1 -0
- package/dist/cli/utils/sanitize.d.ts +54 -0
- package/dist/cli/utils/sanitize.d.ts.map +1 -0
- package/dist/cli/utils/sanitize.js +131 -0
- package/dist/cli/utils/sanitize.js.map +1 -0
- package/dist/cli-new/commands/export.d.ts +15 -0
- package/dist/cli-new/commands/export.d.ts.map +1 -0
- package/dist/cli-new/commands/export.js +107 -0
- package/dist/cli-new/commands/export.js.map +1 -0
- package/dist/cli-new/commands/query.d.ts +14 -0
- package/dist/cli-new/commands/query.d.ts.map +1 -0
- package/dist/cli-new/commands/query.js +120 -0
- package/dist/cli-new/commands/query.js.map +1 -0
- package/dist/cli-new/commands/server.d.ts +13 -0
- package/dist/cli-new/commands/server.d.ts.map +1 -0
- package/dist/cli-new/commands/server.js +94 -0
- package/dist/cli-new/commands/server.js.map +1 -0
- package/dist/cli-new/index.d.ts +11 -0
- package/dist/cli-new/index.d.ts.map +1 -0
- package/dist/cli-new/index.js +63 -0
- package/dist/cli-new/index.js.map +1 -0
- package/dist/cli-new/types/index.d.ts +88 -0
- package/dist/cli-new/types/index.d.ts.map +1 -0
- package/dist/cli-new/types/index.js +7 -0
- package/dist/cli-new/types/index.js.map +1 -0
- package/dist/domain/entities/CodeGraph.d.ts +134 -0
- package/dist/domain/entities/CodeGraph.d.ts.map +1 -0
- package/dist/domain/entities/CodeGraph.js +316 -0
- package/dist/domain/entities/CodeGraph.js.map +1 -0
- package/dist/domain/entities/Dependency.d.ts +78 -0
- package/dist/domain/entities/Dependency.d.ts.map +1 -0
- package/dist/domain/entities/Dependency.js +132 -0
- package/dist/domain/entities/Dependency.js.map +1 -0
- package/dist/domain/entities/Module.d.ts +75 -0
- package/dist/domain/entities/Module.d.ts.map +1 -0
- package/dist/domain/entities/Module.js +151 -0
- package/dist/domain/entities/Module.js.map +1 -0
- package/dist/domain/entities/Project.d.ts +50 -0
- package/dist/domain/entities/Project.d.ts.map +1 -0
- package/dist/domain/entities/Project.js +99 -0
- package/dist/domain/entities/Project.js.map +1 -0
- package/dist/domain/entities/Symbol.d.ts +75 -0
- package/dist/domain/entities/Symbol.d.ts.map +1 -0
- package/dist/domain/entities/Symbol.js +130 -0
- package/dist/domain/entities/Symbol.js.map +1 -0
- package/dist/domain/events/DomainEvent.d.ts +76 -0
- package/dist/domain/events/DomainEvent.d.ts.map +1 -0
- package/dist/domain/events/DomainEvent.js +153 -0
- package/dist/domain/events/DomainEvent.js.map +1 -0
- package/dist/domain/index.d.ts +10 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +18 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/repositories/CodeGraphRepository.d.ts +58 -0
- package/dist/domain/repositories/CodeGraphRepository.d.ts.map +1 -0
- package/dist/domain/repositories/CodeGraphRepository.js +37 -0
- package/dist/domain/repositories/CodeGraphRepository.js.map +1 -0
- package/dist/domain/services/CodeGraphBuilder.d.ts +50 -0
- package/dist/domain/services/CodeGraphBuilder.d.ts.map +1 -0
- package/dist/domain/services/CodeGraphBuilder.js +121 -0
- package/dist/domain/services/CodeGraphBuilder.js.map +1 -0
- package/dist/infrastructure/parser/implementations/GoParser.d.ts +25 -0
- package/dist/infrastructure/parser/implementations/GoParser.d.ts.map +1 -0
- package/dist/infrastructure/parser/implementations/GoParser.js +158 -0
- package/dist/infrastructure/parser/implementations/GoParser.js.map +1 -0
- package/dist/infrastructure/parser/implementations/PythonParser.d.ts +30 -0
- package/dist/infrastructure/parser/implementations/PythonParser.d.ts.map +1 -0
- package/dist/infrastructure/parser/implementations/PythonParser.js +201 -0
- package/dist/infrastructure/parser/implementations/PythonParser.js.map +1 -0
- package/dist/infrastructure/parser/implementations/TypeScriptParser.d.ts +63 -0
- package/dist/infrastructure/parser/implementations/TypeScriptParser.d.ts.map +1 -0
- package/dist/infrastructure/parser/implementations/TypeScriptParser.js +420 -0
- package/dist/infrastructure/parser/implementations/TypeScriptParser.js.map +1 -0
- package/dist/infrastructure/parser/index.d.ts +13 -0
- package/dist/infrastructure/parser/index.d.ts.map +1 -0
- package/dist/infrastructure/parser/index.js +32 -0
- package/dist/infrastructure/parser/index.js.map +1 -0
- package/dist/infrastructure/parser/interfaces/ParserBase.d.ts +124 -0
- package/dist/infrastructure/parser/interfaces/ParserBase.d.ts.map +1 -0
- package/dist/infrastructure/parser/interfaces/ParserBase.js +200 -0
- package/dist/infrastructure/parser/interfaces/ParserBase.js.map +1 -0
- package/dist/infrastructure/parser/registry/ParserRegistry.d.ts +68 -0
- package/dist/infrastructure/parser/registry/ParserRegistry.d.ts.map +1 -0
- package/dist/infrastructure/parser/registry/ParserRegistry.js +116 -0
- package/dist/infrastructure/parser/registry/ParserRegistry.js.map +1 -0
- package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.d.ts +44 -0
- package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.d.ts.map +1 -0
- package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.js +129 -0
- package/dist/infrastructure/repositories/CodeGraphRepositoryImpl.js.map +1 -0
- package/dist/infrastructure/repositories/index.d.ts +3 -0
- package/dist/infrastructure/repositories/index.d.ts.map +1 -0
- package/dist/infrastructure/repositories/index.js +7 -0
- package/dist/infrastructure/repositories/index.js.map +1 -0
- package/dist/infrastructure/storage/StorageFactory.d.ts +53 -0
- package/dist/infrastructure/storage/StorageFactory.d.ts.map +1 -0
- package/dist/infrastructure/storage/StorageFactory.js +150 -0
- package/dist/infrastructure/storage/StorageFactory.js.map +1 -0
- package/dist/infrastructure/storage/adapters/FileSystemStorage.d.ts +52 -0
- package/dist/infrastructure/storage/adapters/FileSystemStorage.d.ts.map +1 -0
- package/dist/infrastructure/storage/adapters/FileSystemStorage.js +315 -0
- package/dist/infrastructure/storage/adapters/FileSystemStorage.js.map +1 -0
- package/dist/infrastructure/storage/adapters/KuzuDBStorage.d.ts +52 -0
- package/dist/infrastructure/storage/adapters/KuzuDBStorage.d.ts.map +1 -0
- package/dist/infrastructure/storage/adapters/KuzuDBStorage.js +235 -0
- package/dist/infrastructure/storage/adapters/KuzuDBStorage.js.map +1 -0
- package/dist/infrastructure/storage/adapters/MemoryStorage.d.ts +37 -0
- package/dist/infrastructure/storage/adapters/MemoryStorage.d.ts.map +1 -0
- package/dist/infrastructure/storage/adapters/MemoryStorage.js +229 -0
- package/dist/infrastructure/storage/adapters/MemoryStorage.js.map +1 -0
- package/dist/infrastructure/storage/adapters/Neo4jStorage.d.ts +49 -0
- package/dist/infrastructure/storage/adapters/Neo4jStorage.d.ts.map +1 -0
- package/dist/infrastructure/storage/adapters/Neo4jStorage.js +222 -0
- package/dist/infrastructure/storage/adapters/Neo4jStorage.js.map +1 -0
- package/dist/infrastructure/storage/index.d.ts +6 -0
- package/dist/infrastructure/storage/index.d.ts.map +1 -0
- package/dist/infrastructure/storage/index.js +13 -0
- package/dist/infrastructure/storage/index.js.map +1 -0
- package/dist/infrastructure/storage/interfaces/StorageBase.d.ts +76 -0
- package/dist/infrastructure/storage/interfaces/StorageBase.d.ts.map +1 -0
- package/dist/infrastructure/storage/interfaces/StorageBase.js +116 -0
- package/dist/infrastructure/storage/interfaces/StorageBase.js.map +1 -0
- package/dist/interface/config/index.d.ts +102 -0
- package/dist/interface/config/index.d.ts.map +1 -0
- package/dist/interface/config/index.js +7 -0
- package/dist/interface/config/index.js.map +1 -0
- package/dist/interface/types/index.d.ts +425 -0
- package/dist/interface/types/index.d.ts.map +1 -0
- package/dist/interface/types/index.js +8 -0
- package/dist/interface/types/index.js.map +1 -0
- package/dist/interface/types/parser.d.ts +103 -0
- package/dist/interface/types/parser.d.ts.map +1 -0
- package/dist/interface/types/parser.js +7 -0
- package/dist/interface/types/parser.js.map +1 -0
- package/dist/interface/types/storage.d.ts +98 -0
- package/dist/interface/types/storage.d.ts.map +1 -0
- package/dist/interface/types/storage.js +7 -0
- package/dist/interface/types/storage.js.map +1 -0
- package/dist/orchestrator/test-linker.js +1 -1
- package/dist/orchestrator/test-linker.js.map +1 -1
- package/dist/server/CodeMapServer.d.ts +51 -0
- package/dist/server/CodeMapServer.d.ts.map +1 -0
- package/dist/server/CodeMapServer.js +146 -0
- package/dist/server/CodeMapServer.js.map +1 -0
- package/dist/server/handlers/AnalysisHandler.d.ts +82 -0
- package/dist/server/handlers/AnalysisHandler.d.ts.map +1 -0
- package/dist/server/handlers/AnalysisHandler.js +196 -0
- package/dist/server/handlers/AnalysisHandler.js.map +1 -0
- package/dist/server/handlers/QueryHandler.d.ts +57 -0
- package/dist/server/handlers/QueryHandler.d.ts.map +1 -0
- package/dist/server/handlers/QueryHandler.js +260 -0
- package/dist/server/handlers/QueryHandler.js.map +1 -0
- package/dist/server/index.d.ts +7 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +13 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/routes/api.d.ts +8 -0
- package/dist/server/routes/api.d.ts.map +1 -0
- package/dist/server/routes/api.js +372 -0
- package/dist/server/routes/api.js.map +1 -0
- package/dist/server/types/index.d.ts +171 -0
- package/dist/server/types/index.d.ts.map +1 -0
- package/dist/server/types/index.js +7 -0
- package/dist/server/types/index.js.map +1 -0
- package/dist/types/index.d.ts +6 -372
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +9 -3
- package/dist/types/index.js.map +1 -1
- package/docs/AI_ASSISTANT_SETUP.md +811 -0
- package/docs/PUBLISHING.md +162 -0
- package/docs/README.md +37 -0
- package/docs/SETUP_GUIDE.md +493 -0
- package/docs/ai-guide/COMMANDS.md +369 -0
- package/docs/ai-guide/INTEGRATION.md +513 -0
- package/docs/ai-guide/OUTPUT.md +465 -0
- package/docs/ai-guide/PATTERNS.md +409 -0
- package/docs/ai-guide/PROMPTS.md +414 -0
- package/docs/ai-guide/QUICKSTART.md +114 -0
- package/docs/ai-guide/README.md +66 -0
- package/docs/archive/AI_INTEGRATION_GUIDE_ARCHIVED.md +391 -0
- package/docs/archive/ARCHIVE.md +39 -0
- package/docs/archive/MYCLAUDE_GUIDE.md +305 -0
- package/docs/archive/PUBLISH_NPM_DESIGN_V1.md +1699 -0
- package/docs/archive/PUBLISH_NPM_DESIGN_V2.md +396 -0
- package/docs/archive/README.md +29 -0
- package/docs/archive/TASK_DESIGN_COVERAGE_REPORT.md +320 -0
- package/docs/archive/TEST_SUMMARY.md +140 -0
- package/docs/archive/comprehensive_test_report.md +337 -0
- package/docs/archive/design-docs/CI_GATEWAY_DESIGN.md +790 -0
- package/docs/archive/design-docs/PUBLISH_NPM_DESIGN_FINAL.md +491 -0
- package/docs/archive/design-docs/REFACTOR_ARCHITECTURE_OVERVIEW.md +558 -0
- package/docs/archive/design-docs/REFACTOR_CONFIDENCE_DESIGN.md +250 -0
- package/docs/archive/design-docs/REFACTOR_GIT_ANALYZER_DESIGN.md +791 -0
- package/docs/archive/design-docs/REFACTOR_ORCHESTRATOR_DESIGN.md +1071 -0
- package/docs/archive/design-docs/REFACTOR_RESULT_FUSION_DESIGN.md +321 -0
- package/docs/archive/design-docs/REFACTOR_TEST_LINKER_DESIGN.md +317 -0
- package/docs/archive/myclaude.md +1084 -0
- package/docs/archive/plans/2026-03-14-go-language-support-design.md +92 -0
- package/docs/archive/product-specs/REFACTOR_REQUIREMENTS.md +976 -0
- package/docs/archive/scenario-2-deps-analysis.md +353 -0
- package/docs/archive/test-report-symbol-search.md +384 -0
- package/docs/archive/test-scenario-4-complexity-analysis.md +460 -0
- package/docs/archive/test_report_scenario5.md +615 -0
- package/docs/archive/test_scenario_3_impact_analysis_report.md +520 -0
- package/docs/design-docs/README.md +26 -0
- package/docs/exec-plans/MVP3-IMPLEMENTATION-ROADMAP.md +524 -0
- package/docs/exec-plans/README.md +29 -0
- package/docs/exec-plans/active/.gitkeep +0 -0
- package/docs/exec-plans/completed/.gitkeep +0 -0
- package/docs/exec-plans/completed/2026-03-03-deps-path-extension-fix.md +186 -0
- package/docs/exec-plans/completed/2026-03-03-post-task-plan.md +135 -0
- package/docs/exec-plans/completed/harness-engineering-rollout.md +184 -0
- package/docs/exec-plans/tech-debt/.gitkeep +0 -0
- package/docs/exec-plans/tech-debt/2026-03-15-lint-guardrail-gap.md +30 -0
- package/docs/generated/README.md +19 -0
- package/docs/product-specs/MVP3-ARCHITECTURE-COMPARISON.md +504 -0
- package/docs/product-specs/MVP3-ARCHITECTURE-REDESIGN-PRD.md +322 -0
- package/docs/product-specs/MVP3-ARCHITECTURE-REDESIGN-TECH-PRD.md +1374 -0
- package/docs/product-specs/README.md +22 -0
- package/docs/references/README.md +15 -0
- package/docs/references/tmp.md +527 -0
- package/docs/rules/README.md +16 -0
- package/docs/rules/architecture-guardrails.md +349 -0
- package/docs/rules/code-quality-redlines.md +321 -0
- package/docs/rules/deployment.md +23 -0
- package/docs/rules/engineering-with-codex-openai.md +202 -0
- package/docs/rules/testing.md +73 -0
- package/docs/rules/validation.md +39 -0
- package/examples/README.md +61 -0
- package/examples/claude/codemap-skill.md +94 -0
- package/examples/codex/codemap-agent.md +66 -0
- package/examples/copilot/copilot-instructions.md +24 -0
- package/examples/kimi/codemap-skill.md +92 -0
- package/package.json +22 -7
|
@@ -0,0 +1,321 @@
|
|
|
1
|
+
# 多工具结果融合详细设计
|
|
2
|
+
|
|
3
|
+
> 归档时间:2026-03-15
|
|
4
|
+
> 归档原因:历史结果融合设计稿,统一结果结构与当前实现不再完全一致。
|
|
5
|
+
> 当前依据:`ARCHITECTURE.md`、`src/orchestrator/result-fusion.ts`、`src/orchestrator/types.ts`
|
|
6
|
+
> 状态:仅供历史对照,不作为当前执行依据。
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
> 版本: 2.6
|
|
10
|
+
> 所属模块: 编排层 - 结果融合
|
|
11
|
+
> 更新日期: 2026-03-03
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## 1. 设计目标
|
|
16
|
+
|
|
17
|
+
所有工具的结果都转换为统一的中间格式,然后按统一规则处理(加权合并、去重、排序)。
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
## 2. 数据结构设计
|
|
22
|
+
|
|
23
|
+
### 2.1 统一结果格式
|
|
24
|
+
|
|
25
|
+
```typescript
|
|
26
|
+
// src/orchestrator/types.ts
|
|
27
|
+
|
|
28
|
+
interface UnifiedResult {
|
|
29
|
+
// 唯一标识
|
|
30
|
+
id: string;
|
|
31
|
+
|
|
32
|
+
// 来源信息
|
|
33
|
+
source: 'codemap' | 'ast-grep' | 'rg-internal';
|
|
34
|
+
toolScore: number; // 工具返回的原始分数
|
|
35
|
+
|
|
36
|
+
// 内容信息
|
|
37
|
+
type: 'file' | 'symbol' | 'code' | 'documentation';
|
|
38
|
+
file: string;
|
|
39
|
+
line?: number;
|
|
40
|
+
content: string; // 截断后的内容
|
|
41
|
+
preview?: string; // 上下文预览
|
|
42
|
+
|
|
43
|
+
// 语义信息
|
|
44
|
+
relevance: number; // 0-1 归一化相关度
|
|
45
|
+
keywords: string[]; // 匹配的关键词
|
|
46
|
+
|
|
47
|
+
// 元数据
|
|
48
|
+
metadata?: {
|
|
49
|
+
symbolType?: 'class' | 'function' | 'interface' | 'variable';
|
|
50
|
+
dependencies?: string[];
|
|
51
|
+
testFile?: string;
|
|
52
|
+
commitCount?: number;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
---
|
|
58
|
+
|
|
59
|
+
## 3. 接口设计
|
|
60
|
+
|
|
61
|
+
### 3.1 结果融合类
|
|
62
|
+
|
|
63
|
+
```typescript
|
|
64
|
+
// src/orchestrator/result-fusion.ts
|
|
65
|
+
|
|
66
|
+
class ResultFusion {
|
|
67
|
+
/**
|
|
68
|
+
* 多工具结果融合
|
|
69
|
+
* 策略:加权合并 → 去重 → 排序
|
|
70
|
+
*/
|
|
71
|
+
fuse(
|
|
72
|
+
resultsByTool: Map<string, UnifiedResult[]>,
|
|
73
|
+
options: { topK: number; keywordWeights: Record<string, number> }
|
|
74
|
+
): UnifiedResult[] {
|
|
75
|
+
// 1. 加权合并
|
|
76
|
+
let allResults: UnifiedResult[] = [];
|
|
77
|
+
for (const [tool, results] of resultsByTool) {
|
|
78
|
+
const toolWeight = this.getToolWeight(tool);
|
|
79
|
+
const weighted = results.map(r => ({
|
|
80
|
+
...r,
|
|
81
|
+
relevance: r.relevance * toolWeight
|
|
82
|
+
}));
|
|
83
|
+
allResults = allResults.concat(weighted);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// 2. 去重(基于文件+行号)
|
|
87
|
+
const seen = new Map<string, UnifiedResult>();
|
|
88
|
+
for (const result of allResults) {
|
|
89
|
+
const key = `${result.file}:${result.line || ''}`;
|
|
90
|
+
if (!seen.has(key)) {
|
|
91
|
+
seen.set(key, result);
|
|
92
|
+
} else {
|
|
93
|
+
// 保留分数更高的
|
|
94
|
+
const existing = seen.get(key)!;
|
|
95
|
+
if (result.relevance > existing.relevance) {
|
|
96
|
+
seen.set(key, result);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
// 3. 按相关度排序
|
|
102
|
+
const sorted = Array.from(seen.values())
|
|
103
|
+
.sort((a, b) => b.relevance - a.relevance);
|
|
104
|
+
|
|
105
|
+
// 4. 关键词加权
|
|
106
|
+
const keywordBoosted = this.applyKeywordBoost(sorted, options.keywordWeights);
|
|
107
|
+
|
|
108
|
+
return keywordBoosted.slice(0, options.topK);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
private getToolWeight(tool: string): number {
|
|
112
|
+
const weights: Record<string, number> = {
|
|
113
|
+
'ast-grep': 1.0, // AST 分析最准确
|
|
114
|
+
'codemap': 0.9, // 结构分析次之
|
|
115
|
+
'rg-internal': 0.7 // 文本搜索兜底(仅内部调试用)
|
|
116
|
+
};
|
|
117
|
+
return weights[tool] || 0.5;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
* 应用关键词加权
|
|
122
|
+
*/
|
|
123
|
+
private applyKeywordBoost(
|
|
124
|
+
results: UnifiedResult[],
|
|
125
|
+
keywordWeights: Record<string, number>
|
|
126
|
+
): UnifiedResult[] {
|
|
127
|
+
if (Object.keys(keywordWeights).length === 0) {
|
|
128
|
+
return results;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return results.map(r => {
|
|
132
|
+
let boost = 0;
|
|
133
|
+
for (const keyword of r.keywords) {
|
|
134
|
+
boost += keywordWeights[keyword] || 0;
|
|
135
|
+
}
|
|
136
|
+
return {
|
|
137
|
+
...r,
|
|
138
|
+
relevance: r.relevance + boost
|
|
139
|
+
};
|
|
140
|
+
}).sort((a, b) => b.relevance - a.relevance);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
---
|
|
146
|
+
|
|
147
|
+
## 4. Token 截断
|
|
148
|
+
|
|
149
|
+
### 4.1 按 token 数量截断内容
|
|
150
|
+
|
|
151
|
+
```typescript
|
|
152
|
+
/**
|
|
153
|
+
* 按 token 数量截断内容(而非字符数)
|
|
154
|
+
* 简单估算:英文约 4 字符 = 1 token,中文约 1 字符 = 1-2 token
|
|
155
|
+
*/
|
|
156
|
+
function truncateByToken(content: string, maxTokens: number): string {
|
|
157
|
+
const tokens = content.split(/[\s\u4e00-\u9fa5]/).filter(Boolean);
|
|
158
|
+
if (tokens.length <= maxTokens) return content;
|
|
159
|
+
return tokens.slice(0, maxTokens).join(' ') + '...';
|
|
160
|
+
}
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
---
|
|
164
|
+
|
|
165
|
+
## 5. 模块依赖
|
|
166
|
+
|
|
167
|
+
```
|
|
168
|
+
结果融合模块 (result-fusion.ts)
|
|
169
|
+
│
|
|
170
|
+
├── 依赖类型: UnifiedResult (输入/输出)
|
|
171
|
+
│
|
|
172
|
+
└── 被以下模块使用:
|
|
173
|
+
└── ToolOrchestrator (tool-orchestrator.ts)
|
|
174
|
+
└── AnalyzeCommand (analyze.ts)
|
|
175
|
+
└── CIGateway (ci-gateway.ts)
|
|
176
|
+
└── WorkflowOrchestrator (workflow-orchestrator.ts) (v2.5)
|
|
177
|
+
```
|
|
178
|
+
|
|
179
|
+
---
|
|
180
|
+
|
|
181
|
+
## 6. 工作流上下文融合 (v2.5)
|
|
182
|
+
|
|
183
|
+
### 6.1 跨阶段结果传递
|
|
184
|
+
|
|
185
|
+
在工作流中,每个阶段的分析结果需要传递给下一阶段:
|
|
186
|
+
|
|
187
|
+
```typescript
|
|
188
|
+
// 工作流上下文中的结果缓存
|
|
189
|
+
|
|
190
|
+
interface WorkflowFusionContext {
|
|
191
|
+
phaseResults: Map<WorkflowPhase, UnifiedResult[]>;
|
|
192
|
+
accumulatedContext: Map<string, UnifiedResult>;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
// 跨阶段结果合并策略
|
|
196
|
+
class WorkflowResultFusion {
|
|
197
|
+
/**
|
|
198
|
+
* 将新阶段结果与已有上下文合并
|
|
199
|
+
*/
|
|
200
|
+
mergeWithContext(
|
|
201
|
+
newResults: UnifiedResult[],
|
|
202
|
+
context: WorkflowFusionContext
|
|
203
|
+
): UnifiedResult[] {
|
|
204
|
+
// 1. 合并所有历史结果
|
|
205
|
+
const allResults = [
|
|
206
|
+
...Array.from(context.phaseResults.values()).flat(),
|
|
207
|
+
...newResults
|
|
208
|
+
];
|
|
209
|
+
|
|
210
|
+
// 2. 应用工作流特定的加权
|
|
211
|
+
const workflowWeighted = this.applyWorkflowWeights(allResults, context);
|
|
212
|
+
|
|
213
|
+
// 3. 按工作流阶段优先级排序
|
|
214
|
+
return this.sortByWorkflowPriority(workflowWeighted);
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* 工作流阶段权重
|
|
219
|
+
* 越近期的阶段权重越高
|
|
220
|
+
*/
|
|
221
|
+
private applyWorkflowWeights(
|
|
222
|
+
results: UnifiedResult[],
|
|
223
|
+
context: WorkflowFusionContext
|
|
224
|
+
): UnifiedResult[] {
|
|
225
|
+
const phaseWeights: Record<WorkflowPhase, number> = {
|
|
226
|
+
'reference': 0.8,
|
|
227
|
+
'impact': 0.9,
|
|
228
|
+
'risk': 1.0,
|
|
229
|
+
'implementation': 0.7,
|
|
230
|
+
'commit': 0.6,
|
|
231
|
+
'ci': 0.5
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
return results.map(r => {
|
|
235
|
+
// 根据结果来源确定阶段权重
|
|
236
|
+
const sourcePhase = this.inferPhase(r.source);
|
|
237
|
+
const weight = phaseWeights[sourcePhase] || 0.5;
|
|
238
|
+
|
|
239
|
+
return {
|
|
240
|
+
...r,
|
|
241
|
+
relevance: r.relevance * weight
|
|
242
|
+
};
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
### 6.2 阶段间结果继承
|
|
249
|
+
|
|
250
|
+
```typescript
|
|
251
|
+
// 阶段间的结果继承逻辑
|
|
252
|
+
|
|
253
|
+
class PhaseInheritance {
|
|
254
|
+
/**
|
|
255
|
+
* 获取下一阶段应该继承的结果
|
|
256
|
+
*/
|
|
257
|
+
getInheritedResults(
|
|
258
|
+
currentPhase: WorkflowPhase,
|
|
259
|
+
allResults: UnifiedResult[]
|
|
260
|
+
): UnifiedResult[] {
|
|
261
|
+
switch (currentPhase) {
|
|
262
|
+
case 'reference':
|
|
263
|
+
// 影响分析继承参考搜索的结果
|
|
264
|
+
return allResults.filter(r =>
|
|
265
|
+
r.source === 'ast-grep' || r.source === 'codemap'
|
|
266
|
+
);
|
|
267
|
+
|
|
268
|
+
case 'impact':
|
|
269
|
+
// 风险评估继承影响分析 + 参考搜索
|
|
270
|
+
return allResults;
|
|
271
|
+
|
|
272
|
+
case 'risk':
|
|
273
|
+
// 代码实现继承所有分析结果
|
|
274
|
+
return allResults;
|
|
275
|
+
|
|
276
|
+
default:
|
|
277
|
+
return allResults;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
---
|
|
284
|
+
|
|
285
|
+
## 7. 融合策略总结
|
|
286
|
+
|
|
287
|
+
| 阶段 | 策略 | 说明 |
|
|
288
|
+
|------|------|------|
|
|
289
|
+
| 1 | 加权合并 | 按工具权重调整 relevance |
|
|
290
|
+
| 2 | 去重 | 基于 file:line 作为 key |
|
|
291
|
+
| 3 | 排序 | 按 relevance 降序 |
|
|
292
|
+
| 4 | 关键词加权 | 提升匹配关键词的结果 |
|
|
293
|
+
| 5 | 截断 | Top-K + Token 限制 |
|
|
294
|
+
|
|
295
|
+
**示例输出**:
|
|
296
|
+
```
|
|
297
|
+
[SEARCH RESULTS] - Sorted by Relevance
|
|
298
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
299
|
+
|
|
300
|
+
1. src/auth/jwt.ts (relevance: 92%)
|
|
301
|
+
Type: function | Line: 45
|
|
302
|
+
Content: export function verifyToken(token: string): Payload {...}
|
|
303
|
+
|
|
304
|
+
2. src/cache/lru-cache.ts (relevance: 85%)
|
|
305
|
+
Type: class | Line: 12
|
|
306
|
+
Content: export class LRUCache<K, V> {...}
|
|
307
|
+
|
|
308
|
+
3. src/utils/date.ts (relevance: 45%)
|
|
309
|
+
Type: function | Line: 8
|
|
310
|
+
Content: export function formatDate(d: Date): string {...}
|
|
311
|
+
```
|
|
312
|
+
|
|
313
|
+
---
|
|
314
|
+
|
|
315
|
+
## 附录:版本历史
|
|
316
|
+
|
|
317
|
+
| 版本 | 日期 | 变更 |
|
|
318
|
+
|------|------|------|
|
|
319
|
+
| 2.4 | 2026-02-28 | 添加 AI 饲料融合、风险加权 |
|
|
320
|
+
| 2.5 | 2026-03-01 | 添加工作流上下文融合 |
|
|
321
|
+
| 2.6 | 2026-03-03 | 移除 AI 饲料相关功能,简化融合策略 |
|
|
@@ -0,0 +1,317 @@
|
|
|
1
|
+
# 测试关联器详细设计
|
|
2
|
+
|
|
3
|
+
> 归档时间:2026-03-15
|
|
4
|
+
> 归档原因:历史测试关联设计稿,已被当前测试规则和实现替代。
|
|
5
|
+
> 当前依据:`docs/rules/testing.md`、`src/orchestrator/test-linker.ts`
|
|
6
|
+
> 状态:仅供历史对照,不作为当前执行依据。
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
> 版本: 2.4
|
|
10
|
+
> 所属模块: 编排层 - 测试关联器
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## 1. 功能定位
|
|
15
|
+
|
|
16
|
+
在影响分析场景中,根据源代码文件自动关联相关的测试文件。
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
## 2. 数据结构设计
|
|
21
|
+
|
|
22
|
+
### 2.1 测试配置
|
|
23
|
+
|
|
24
|
+
```typescript
|
|
25
|
+
// src/orchestrator/test-linker.ts
|
|
26
|
+
|
|
27
|
+
interface TestConfig {
|
|
28
|
+
framework: 'jest' | 'vitest' | 'none';
|
|
29
|
+
patterns: {
|
|
30
|
+
testFile: string[]; // 测试文件匹配模式
|
|
31
|
+
testDir: string[]; // 测试目录
|
|
32
|
+
};
|
|
33
|
+
sourceToTestMap: Map<string, string[]>; // 源文件 → 测试文件映射
|
|
34
|
+
}
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## 3. 接口设计
|
|
40
|
+
|
|
41
|
+
### 3.1 测试关联器类
|
|
42
|
+
|
|
43
|
+
```typescript
|
|
44
|
+
class TestLinker {
|
|
45
|
+
private config: TestConfig | null = null;
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* 加载测试配置
|
|
49
|
+
* 读取 jest.config.js / vitest.config.ts
|
|
50
|
+
*/
|
|
51
|
+
async loadConfig(projectRoot: string): Promise<TestConfig> {
|
|
52
|
+
const fsPromises = require('fs').promises;
|
|
53
|
+
|
|
54
|
+
// 1. 尝试读取 vitest.config.ts
|
|
55
|
+
const vitestPath = path.join(projectRoot, 'vitest.config.ts');
|
|
56
|
+
if (await this.pathExists(vitestPath)) {
|
|
57
|
+
return this.parseVitestConfig(vitestPath);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// 2. 尝试读取 jest.config.js
|
|
61
|
+
const jestPath = path.join(projectRoot, 'jest.config.js');
|
|
62
|
+
if (await this.pathExists(jestPath)) {
|
|
63
|
+
return this.parseJestConfig(jestPath);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// 3. 使用默认模式
|
|
67
|
+
const defaultConfig: TestConfig = {
|
|
68
|
+
framework: 'vitest',
|
|
69
|
+
patterns: {
|
|
70
|
+
testFile: ['**/*.test.ts', '**/*.spec.ts'],
|
|
71
|
+
testDir: ['__tests__', 'test', 'tests']
|
|
72
|
+
},
|
|
73
|
+
sourceToTestMap: new Map()
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
// 赋值到实例变量
|
|
77
|
+
this.config = defaultConfig;
|
|
78
|
+
return this.config;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* 检查文件是否存在
|
|
83
|
+
* 使用 fsPromises.access 替代已废弃的 fs.exists
|
|
84
|
+
*/
|
|
85
|
+
private async pathExists(filePath: string): Promise<boolean> {
|
|
86
|
+
try {
|
|
87
|
+
await require('fs').promises.access(filePath);
|
|
88
|
+
return true;
|
|
89
|
+
} catch {
|
|
90
|
+
return false;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* 确保配置已加载
|
|
96
|
+
* 在使用 this.config 前调用
|
|
97
|
+
*/
|
|
98
|
+
private assertConfig(): void {
|
|
99
|
+
if (!this.config) {
|
|
100
|
+
throw new Error('TestLinker 配置未初始化,请先调用 loadConfig');
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
### 3.2 构建映射
|
|
107
|
+
|
|
108
|
+
```typescript
|
|
109
|
+
/**
|
|
110
|
+
* 构建源文件 → 测试文件 映射
|
|
111
|
+
* 基于测试框架的匹配规则
|
|
112
|
+
*/
|
|
113
|
+
async buildMapping(projectRoot: string, codemap: CodemapData): Promise<void> {
|
|
114
|
+
// 确保配置已加载
|
|
115
|
+
if (!this.config) {
|
|
116
|
+
throw new Error('请先调用 loadConfig 加载测试配置');
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
const testFiles = await this.findTestFiles(projectRoot);
|
|
120
|
+
|
|
121
|
+
for (const testFile of testFiles) {
|
|
122
|
+
// 从测试文件名推断源文件
|
|
123
|
+
// 例如: lru-cache.test.ts → lru-cache.ts
|
|
124
|
+
const sourceFile = this.inferSourceFile(testFile);
|
|
125
|
+
|
|
126
|
+
if (sourceFile) {
|
|
127
|
+
const existing = this.config.sourceToTestMap.get(sourceFile) || [];
|
|
128
|
+
existing.push(testFile);
|
|
129
|
+
this.config.sourceToTestMap.set(sourceFile, existing);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// 扫描测试文件内容,找出 import 的源文件
|
|
133
|
+
const imports = await this.scanTestImports(testFile);
|
|
134
|
+
for (const imported of imports) {
|
|
135
|
+
const existing = this.config.sourceToTestMap.get(imported) || [];
|
|
136
|
+
if (!existing.includes(testFile)) {
|
|
137
|
+
existing.push(testFile);
|
|
138
|
+
this.config.sourceToTestMap.set(imported, existing);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
### 3.3 查找相关测试
|
|
146
|
+
|
|
147
|
+
```typescript
|
|
148
|
+
/**
|
|
149
|
+
* 查找相关测试文件
|
|
150
|
+
*/
|
|
151
|
+
findRelatedTests(sourceFiles: string[]): string[] {
|
|
152
|
+
// 确保配置已加载
|
|
153
|
+
if (!this.config) {
|
|
154
|
+
throw new Error('请先调用 loadConfig 加载测试配置');
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
const relatedTests = new Set<string>();
|
|
158
|
+
|
|
159
|
+
for (const sourceFile of sourceFiles) {
|
|
160
|
+
// 直接映射
|
|
161
|
+
const direct = this.config.sourceToTestMap.get(sourceFile) || [];
|
|
162
|
+
direct.forEach(t => relatedTests.add(t));
|
|
163
|
+
|
|
164
|
+
// 目录级别匹配
|
|
165
|
+
// src/cache/lru-cache.ts → src/cache/__tests__/
|
|
166
|
+
const dirTests = this.findDirLevelTests(sourceFile);
|
|
167
|
+
dirTests.forEach(t => relatedTests.add(t));
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
return Array.from(relatedTests);
|
|
171
|
+
}
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
### 3.4 源文件推断
|
|
175
|
+
|
|
176
|
+
```typescript
|
|
177
|
+
private inferSourceFile(testFile: string): string | null {
|
|
178
|
+
// lru-cache.test.ts → lru-cache.ts
|
|
179
|
+
// src/cache/__tests__/lru-cache.test.ts → src/cache/lru-cache.ts
|
|
180
|
+
const normalized = testFile.replace(/\\/g, '/');
|
|
181
|
+
const baseMatch = normalized.match(/^(.+?)\.(test|spec)\.ts$/);
|
|
182
|
+
if (!baseMatch) return null;
|
|
183
|
+
|
|
184
|
+
const base = baseMatch[1];
|
|
185
|
+
// 处理任意层级的 __tests__ 目录
|
|
186
|
+
if (base.includes('/__tests__/')) {
|
|
187
|
+
return base.replace('/__tests__/', '/') + '.ts';
|
|
188
|
+
}
|
|
189
|
+
return base + '.ts';
|
|
190
|
+
}
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
---
|
|
194
|
+
|
|
195
|
+
## 4. 测试关联策略
|
|
196
|
+
|
|
197
|
+
| 策略 | 示例 | 优先级 |
|
|
198
|
+
|------|------|--------|
|
|
199
|
+
| **文件名匹配** | `lru-cache.ts` → `lru-cache.test.ts` | 高 |
|
|
200
|
+
| **目录匹配** | `src/cache/file.ts` → `src/cache/__tests__/*.test.ts` | 高 |
|
|
201
|
+
| **import 扫描** | 测试 import 了源文件 | 中 |
|
|
202
|
+
| **反向覆盖** | 哪些测试覆盖了目标代码 | 低(可选) |
|
|
203
|
+
|
|
204
|
+
---
|
|
205
|
+
|
|
206
|
+
## 5. 模块依赖
|
|
207
|
+
|
|
208
|
+
```
|
|
209
|
+
测试关联器 (test-linker.ts)
|
|
210
|
+
│
|
|
211
|
+
├── 依赖: fs.promises (文件系统)
|
|
212
|
+
│
|
|
213
|
+
└── 被以下模块使用:
|
|
214
|
+
└── AnalyzeCommand (analyze.ts)
|
|
215
|
+
└── WorkflowOrchestrator (workflow-orchestrator.ts) (v2.5 新增)
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
---
|
|
219
|
+
|
|
220
|
+
## 7. 工作流阶段的测试关联 (v2.5 规划)
|
|
221
|
+
|
|
222
|
+
### 7.1 阶段特定的测试策略
|
|
223
|
+
|
|
224
|
+
```typescript
|
|
225
|
+
// 工作流阶段与测试关联的映射
|
|
226
|
+
|
|
227
|
+
const PHASE_TEST_STRATEGY: Record<WorkflowPhase, TestStrategy> = {
|
|
228
|
+
reference: {
|
|
229
|
+
// 参考搜索阶段:查找相关测试作为参考
|
|
230
|
+
mode: 'find-similar',
|
|
231
|
+
includePatterns: ['**/*.test.ts', '**/*.spec.ts'],
|
|
232
|
+
excludePatterns: []
|
|
233
|
+
},
|
|
234
|
+
impact: {
|
|
235
|
+
// 影响分析阶段:查找所有可能受影响的测试
|
|
236
|
+
mode: 'find-affected',
|
|
237
|
+
includePatterns: ['**/*.test.ts', '**/*.spec.ts'],
|
|
238
|
+
excludePatterns: []
|
|
239
|
+
},
|
|
240
|
+
risk: {
|
|
241
|
+
// 风险评估阶段:关注高风险模块的测试
|
|
242
|
+
mode: 'focus-high-risk',
|
|
243
|
+
includePatterns: ['**/*.test.ts'],
|
|
244
|
+
excludePatterns: [],
|
|
245
|
+
priority: 'high-risk-first'
|
|
246
|
+
},
|
|
247
|
+
implementation: {
|
|
248
|
+
// 代码实现阶段:需要通过的测试
|
|
249
|
+
mode: 'required-tests',
|
|
250
|
+
includePatterns: ['**/*.test.ts', '**/*.spec.ts'],
|
|
251
|
+
excludePatterns: []
|
|
252
|
+
},
|
|
253
|
+
commit: {
|
|
254
|
+
// 提交阶段:验证测试通过
|
|
255
|
+
mode: 'verify',
|
|
256
|
+
includePatterns: ['**/*.test.ts', '**/*.spec.ts'],
|
|
257
|
+
excludePatterns: []
|
|
258
|
+
},
|
|
259
|
+
ci: {
|
|
260
|
+
// CI 阶段:完整测试套件
|
|
261
|
+
mode: 'full-suite',
|
|
262
|
+
includePatterns: ['**/*.test.ts', '**/*.spec.ts', '**/*.test.js'],
|
|
263
|
+
excludePatterns: []
|
|
264
|
+
}
|
|
265
|
+
};
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
### 7.2 工作流测试建议生成
|
|
269
|
+
|
|
270
|
+
```typescript
|
|
271
|
+
class WorkflowTestLinker {
|
|
272
|
+
/**
|
|
273
|
+
* 根据当前工作流阶段生成测试建议
|
|
274
|
+
*/
|
|
275
|
+
getTestSuggestions(
|
|
276
|
+
phase: WorkflowPhase,
|
|
277
|
+
sourceFiles: string[],
|
|
278
|
+
context: WorkflowContext
|
|
279
|
+
): TestSuggestion[] {
|
|
280
|
+
const strategy = PHASE_TEST_STRATEGY[phase];
|
|
281
|
+
const testFiles = this.findRelatedTests(sourceFiles, strategy);
|
|
282
|
+
|
|
283
|
+
return testFiles.map(testFile => ({
|
|
284
|
+
file: testFile,
|
|
285
|
+
relevance: this.calculateRelevance(testFile, sourceFiles),
|
|
286
|
+
action: this.getSuggestedAction(phase, testFile),
|
|
287
|
+
priority: this.getPriority(phase, testFile, context)
|
|
288
|
+
}));
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
private getSuggestedAction(phase: WorkflowPhase, testFile: string): string {
|
|
292
|
+
switch (phase) {
|
|
293
|
+
case 'reference':
|
|
294
|
+
return '参考此测试的实现模式';
|
|
295
|
+
case 'impact':
|
|
296
|
+
return '修改后需运行此测试';
|
|
297
|
+
case 'risk':
|
|
298
|
+
return '重点关注此测试,确保通过';
|
|
299
|
+
case 'implementation':
|
|
300
|
+
return '实现完成后运行此测试';
|
|
301
|
+
case 'commit':
|
|
302
|
+
return '提交前确保此测试通过';
|
|
303
|
+
case 'ci':
|
|
304
|
+
return 'CI 会自动运行此测试';
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
```
|
|
309
|
+
|
|
310
|
+
---
|
|
311
|
+
|
|
312
|
+
## 6. 风险与缓解
|
|
313
|
+
|
|
314
|
+
| 风险 | 影响 | 缓解措施 |
|
|
315
|
+
|------|------|----------|
|
|
316
|
+
| 测试框架配置解析失败 | 无法关联测试 | 使用默认模式 |
|
|
317
|
+
| 复杂 import 关系 | 关联不准确 | 多种策略组合 |
|