vaspera 2.11.0 → 2.13.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 +46 -0
- package/dist/__tests__/audit-trail.test.d.ts +7 -0
- package/dist/__tests__/audit-trail.test.d.ts.map +1 -0
- package/dist/__tests__/audit-trail.test.js +336 -0
- package/dist/__tests__/audit-trail.test.js.map +1 -0
- package/dist/__tests__/property-test-helpers.d.ts +1 -1
- package/dist/__tests__/siem-integration.test.d.ts +7 -0
- package/dist/__tests__/siem-integration.test.d.ts.map +1 -0
- package/dist/__tests__/siem-integration.test.js +285 -0
- package/dist/__tests__/siem-integration.test.js.map +1 -0
- package/dist/action/pr-comment.test.js +1 -0
- package/dist/action/pr-comment.test.js.map +1 -1
- package/dist/action/sarif-upload.test.js +1 -0
- package/dist/action/sarif-upload.test.js.map +1 -1
- package/dist/autofix/ast/__tests__/typescript.test.d.ts +5 -0
- package/dist/autofix/ast/__tests__/typescript.test.d.ts.map +1 -0
- package/dist/autofix/ast/__tests__/typescript.test.js +210 -0
- package/dist/autofix/ast/__tests__/typescript.test.js.map +1 -0
- package/dist/autofix/ast/index.d.ts +11 -0
- package/dist/autofix/ast/index.d.ts.map +1 -0
- package/dist/autofix/ast/index.js +11 -0
- package/dist/autofix/ast/index.js.map +1 -0
- package/dist/autofix/ast/types.d.ts +77 -0
- package/dist/autofix/ast/types.d.ts.map +1 -0
- package/dist/autofix/ast/types.js +9 -0
- package/dist/autofix/ast/types.js.map +1 -0
- package/dist/autofix/ast/typescript.d.ts +17 -0
- package/dist/autofix/ast/typescript.d.ts.map +1 -0
- package/dist/autofix/ast/typescript.js +427 -0
- package/dist/autofix/ast/typescript.js.map +1 -0
- package/dist/autofix/constitution.schema.d.ts +21 -21
- package/dist/autofix/index.d.ts +1 -0
- package/dist/autofix/index.d.ts.map +1 -1
- package/dist/autofix/index.js +2 -0
- package/dist/autofix/index.js.map +1 -1
- package/dist/config/flags.d.ts +6 -6
- package/dist/history/store.d.ts +55 -1
- package/dist/history/store.d.ts.map +1 -1
- package/dist/history/store.js +152 -4
- package/dist/history/store.js.map +1 -1
- package/dist/history/types.d.ts +9 -5
- package/dist/history/types.d.ts.map +1 -1
- package/dist/history/verify.d.ts.map +1 -1
- package/dist/history/verify.js +5 -3
- package/dist/history/verify.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +923 -16
- package/dist/index.js.map +1 -1
- package/dist/integrations/siem/datadog.d.ts +44 -0
- package/dist/integrations/siem/datadog.d.ts.map +1 -0
- package/dist/integrations/siem/datadog.js +211 -0
- package/dist/integrations/siem/datadog.js.map +1 -0
- package/dist/integrations/siem/format.d.ts +59 -0
- package/dist/integrations/siem/format.d.ts.map +1 -0
- package/dist/integrations/siem/format.js +360 -0
- package/dist/integrations/siem/format.js.map +1 -0
- package/dist/integrations/siem/index.d.ts +56 -0
- package/dist/integrations/siem/index.d.ts.map +1 -0
- package/dist/integrations/siem/index.js +117 -0
- package/dist/integrations/siem/index.js.map +1 -0
- package/dist/integrations/siem/sentinel.d.ts +53 -0
- package/dist/integrations/siem/sentinel.d.ts.map +1 -0
- package/dist/integrations/siem/sentinel.js +231 -0
- package/dist/integrations/siem/sentinel.js.map +1 -0
- package/dist/integrations/siem/splunk.d.ts +46 -0
- package/dist/integrations/siem/splunk.d.ts.map +1 -0
- package/dist/integrations/siem/splunk.js +210 -0
- package/dist/integrations/siem/splunk.js.map +1 -0
- package/dist/integrations/siem/types.d.ts +210 -0
- package/dist/integrations/siem/types.d.ts.map +1 -0
- package/dist/integrations/siem/types.js +9 -0
- package/dist/integrations/siem/types.js.map +1 -0
- package/dist/persistence/__tests__/json-fallback.test.d.ts +5 -0
- package/dist/persistence/__tests__/json-fallback.test.d.ts.map +1 -0
- package/dist/persistence/__tests__/json-fallback.test.js +249 -0
- package/dist/persistence/__tests__/json-fallback.test.js.map +1 -0
- package/dist/persistence/__tests__/persistence.test.d.ts +5 -0
- package/dist/persistence/__tests__/persistence.test.d.ts.map +1 -0
- package/dist/persistence/__tests__/persistence.test.js +369 -0
- package/dist/persistence/__tests__/persistence.test.js.map +1 -0
- package/dist/persistence/db.d.ts +30 -0
- package/dist/persistence/db.d.ts.map +1 -0
- package/dist/persistence/db.js +128 -0
- package/dist/persistence/db.js.map +1 -0
- package/dist/persistence/index.d.ts +75 -0
- package/dist/persistence/index.d.ts.map +1 -0
- package/dist/persistence/index.js +268 -0
- package/dist/persistence/index.js.map +1 -0
- package/dist/persistence/json-fallback.d.ts +52 -0
- package/dist/persistence/json-fallback.d.ts.map +1 -0
- package/dist/persistence/json-fallback.js +283 -0
- package/dist/persistence/json-fallback.js.map +1 -0
- package/dist/persistence/migrations/index.d.ts +10 -0
- package/dist/persistence/migrations/index.d.ts.map +1 -0
- package/dist/persistence/migrations/index.js +125 -0
- package/dist/persistence/migrations/index.js.map +1 -0
- package/dist/persistence/repositories/findings.d.ts +41 -0
- package/dist/persistence/repositories/findings.d.ts.map +1 -0
- package/dist/persistence/repositories/findings.js +238 -0
- package/dist/persistence/repositories/findings.js.map +1 -0
- package/dist/persistence/repositories/projects.d.ts +22 -0
- package/dist/persistence/repositories/projects.d.ts.map +1 -0
- package/dist/persistence/repositories/projects.js +71 -0
- package/dist/persistence/repositories/projects.js.map +1 -0
- package/dist/persistence/repositories/scans.d.ts +30 -0
- package/dist/persistence/repositories/scans.d.ts.map +1 -0
- package/dist/persistence/repositories/scans.js +107 -0
- package/dist/persistence/repositories/scans.js.map +1 -0
- package/dist/persistence/repositories/trends.d.ts +42 -0
- package/dist/persistence/repositories/trends.d.ts.map +1 -0
- package/dist/persistence/repositories/trends.js +178 -0
- package/dist/persistence/repositories/trends.js.map +1 -0
- package/dist/persistence/types.d.ts +105 -0
- package/dist/persistence/types.d.ts.map +1 -0
- package/dist/persistence/types.js +13 -0
- package/dist/persistence/types.js.map +1 -0
- package/dist/plugins/types.d.ts +2 -2
- package/dist/scanners/ai-code/index.d.ts.map +1 -1
- package/dist/scanners/ai-code/index.js +90 -2
- package/dist/scanners/ai-code/index.js.map +1 -1
- package/dist/scanners/ai-code/types.d.ts +24 -12
- package/dist/scanners/ai-code/types.d.ts.map +1 -1
- package/dist/scanners/cache.d.ts.map +1 -1
- package/dist/scanners/cache.js +1 -0
- package/dist/scanners/cache.js.map +1 -1
- package/dist/scanners/deploy/types.d.ts +13 -13
- package/dist/scanners/detection/__tests__/detection.test.d.ts +5 -0
- package/dist/scanners/detection/__tests__/detection.test.d.ts.map +1 -0
- package/dist/scanners/detection/__tests__/detection.test.js +265 -0
- package/dist/scanners/detection/__tests__/detection.test.js.map +1 -0
- package/dist/scanners/detection/engines/ast-query.d.ts +23 -0
- package/dist/scanners/detection/engines/ast-query.d.ts.map +1 -0
- package/dist/scanners/detection/engines/ast-query.js +232 -0
- package/dist/scanners/detection/engines/ast-query.js.map +1 -0
- package/dist/scanners/detection/engines/data-flow.d.ts +12 -0
- package/dist/scanners/detection/engines/data-flow.d.ts.map +1 -0
- package/dist/scanners/detection/engines/data-flow.js +269 -0
- package/dist/scanners/detection/engines/data-flow.js.map +1 -0
- package/dist/scanners/detection/index.d.ts +29 -0
- package/dist/scanners/detection/index.d.ts.map +1 -0
- package/dist/scanners/detection/index.js +140 -0
- package/dist/scanners/detection/index.js.map +1 -0
- package/dist/scanners/detection/rules/builtin.d.ts +14 -0
- package/dist/scanners/detection/rules/builtin.d.ts.map +1 -0
- package/dist/scanners/detection/rules/builtin.js +307 -0
- package/dist/scanners/detection/rules/builtin.js.map +1 -0
- package/dist/scanners/detection/rules/loader.d.ts +19 -0
- package/dist/scanners/detection/rules/loader.d.ts.map +1 -0
- package/dist/scanners/detection/rules/loader.js +111 -0
- package/dist/scanners/detection/rules/loader.js.map +1 -0
- package/dist/scanners/detection/types.d.ts +171 -0
- package/dist/scanners/detection/types.d.ts.map +1 -0
- package/dist/scanners/detection/types.js +36 -0
- package/dist/scanners/detection/types.js.map +1 -0
- package/dist/scanners/eslint.d.ts.map +1 -1
- package/dist/scanners/eslint.js +45 -3
- package/dist/scanners/eslint.js.map +1 -1
- package/dist/scanners/index.d.ts +9 -1
- package/dist/scanners/index.d.ts.map +1 -1
- package/dist/scanners/index.js +64 -0
- package/dist/scanners/index.js.map +1 -1
- package/dist/scanners/index.test.js +6 -6
- package/dist/scanners/index.test.js.map +1 -1
- package/dist/scanners/scale/bottleneck-detector.d.ts +13 -2
- package/dist/scanners/scale/bottleneck-detector.d.ts.map +1 -1
- package/dist/scanners/scale/bottleneck-detector.js +199 -72
- package/dist/scanners/scale/bottleneck-detector.js.map +1 -1
- package/dist/scanners/scale/types.d.ts +3 -3
- package/dist/scanners/types.d.ts +19 -2
- package/dist/scanners/types.d.ts.map +1 -1
- package/dist/scanners/types.js +1 -0
- package/dist/scanners/types.js.map +1 -1
- package/dist/scanners/typescript.d.ts.map +1 -1
- package/dist/scanners/typescript.js +36 -4
- package/dist/scanners/typescript.js.map +1 -1
- package/package.json +5 -1
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
* Bottleneck Detector
|
|
3
3
|
*
|
|
4
4
|
* Analyzes load test results and code patterns to identify performance bottlenecks.
|
|
5
|
+
* Uses semantic analysis to reduce false positives on intentional patterns.
|
|
5
6
|
*
|
|
6
7
|
* @module scanners/scale/bottleneck-detector
|
|
7
8
|
*/
|
|
@@ -9,19 +10,36 @@ import { readFile, readdir } from "fs/promises";
|
|
|
9
10
|
import { join } from "path";
|
|
10
11
|
import { logger } from "../../logger.js";
|
|
11
12
|
/**
|
|
12
|
-
*
|
|
13
|
+
* Patterns that indicate intentional sequential processing (workflow orchestration)
|
|
13
14
|
*/
|
|
15
|
+
const WORKFLOW_CONTEXT_PATTERNS = [
|
|
16
|
+
/(?:workflow|pipeline|sequential|steps|phases|orchestrat|saga)/i,
|
|
17
|
+
/await\s+Promise\.all/,
|
|
18
|
+
/for\s+await\s+\(/,
|
|
19
|
+
/\.reduce\(\s*async/,
|
|
20
|
+
/runInSequence|runSequentially|executeInOrder/i,
|
|
21
|
+
/step\d+|phase\d+|stage\d+/i,
|
|
22
|
+
];
|
|
23
|
+
/**
|
|
24
|
+
* File patterns that are low-risk for N+1 issues
|
|
25
|
+
*/
|
|
26
|
+
const LOW_RISK_FILE_PATTERNS = [
|
|
27
|
+
/\.test\.(ts|js|tsx|jsx)$/,
|
|
28
|
+
/\.spec\.(ts|js|tsx|jsx)$/,
|
|
29
|
+
/__tests__\//,
|
|
30
|
+
/\.config\.(ts|js)$/,
|
|
31
|
+
/migrations?\//,
|
|
32
|
+
/seeds?\//,
|
|
33
|
+
/scripts?\//,
|
|
34
|
+
/fixtures?\//,
|
|
35
|
+
];
|
|
14
36
|
const N_PLUS_ONE_PATTERNS = [
|
|
15
|
-
|
|
16
|
-
/\.
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
/\.
|
|
21
|
-
// Raw SQL in loop
|
|
22
|
-
/for\s*\([^)]*\)\s*\{[^}]*(?:SELECT|INSERT|UPDATE|DELETE)/gi,
|
|
23
|
-
// forEach with await
|
|
24
|
-
/\.forEach\(\s*async/g,
|
|
37
|
+
{ pattern: /\.findMany\(\s*\{[^}]*include\s*:\s*\{/g, name: "Prisma nested include", baseConfidence: 85 },
|
|
38
|
+
{ pattern: /\.findAll\(\s*\{[^}]*include\s*:\s*\[/g, name: "Sequelize nested include", baseConfidence: 85 },
|
|
39
|
+
{ pattern: /\.find\(\s*\{[^}]*relations\s*:\s*\[/g, name: "TypeORM relations", baseConfidence: 85 },
|
|
40
|
+
{ pattern: /for\s*\([^)]*\)\s*\{[^}]*(?:SELECT|INSERT|UPDATE|DELETE)/gi, name: "SQL in loop", baseConfidence: 90 },
|
|
41
|
+
{ pattern: /\.forEach\(\s*async/g, name: "forEach async", baseConfidence: 60 },
|
|
42
|
+
{ pattern: /\.map\(\s*async[^)]*=>\s*\{[^}]*(?:findOne|findById|query)/gi, name: "async map with query", baseConfidence: 80 },
|
|
25
43
|
];
|
|
26
44
|
/**
|
|
27
45
|
* Memory leak patterns
|
|
@@ -45,6 +63,56 @@ const BLOCKING_PATTERNS = [
|
|
|
45
63
|
// Large JSON parsing
|
|
46
64
|
/JSON\.parse\([^)]*\.length\s*>\s*\d{6}/g,
|
|
47
65
|
];
|
|
66
|
+
/**
|
|
67
|
+
* Check if a file is low-risk based on its path
|
|
68
|
+
*/
|
|
69
|
+
function isLowRiskFile(filePath) {
|
|
70
|
+
return LOW_RISK_FILE_PATTERNS.some((pattern) => pattern.test(filePath));
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Check if the pattern match is in a workflow/orchestration context
|
|
74
|
+
*/
|
|
75
|
+
function isWorkflowContext(content, matchIndex) {
|
|
76
|
+
const contextStart = Math.max(0, matchIndex - 500);
|
|
77
|
+
const contextEnd = Math.min(content.length, matchIndex + 500);
|
|
78
|
+
const context = content.slice(contextStart, contextEnd);
|
|
79
|
+
return WORKFLOW_CONTEXT_PATTERNS.some((pattern) => pattern.test(context));
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Check if the loop has a small fixed iteration count
|
|
83
|
+
*/
|
|
84
|
+
function hasSmallFixedIteration(content, matchIndex) {
|
|
85
|
+
const lineStart = content.lastIndexOf("\n", matchIndex) + 1;
|
|
86
|
+
const lineEnd = content.indexOf("\n", matchIndex);
|
|
87
|
+
const line = content.slice(lineStart, lineEnd === -1 ? undefined : lineEnd);
|
|
88
|
+
const smallArrayPatterns = [
|
|
89
|
+
/\.length\s*[<>]=?\s*[0-9]{1,2}\)/,
|
|
90
|
+
/\[\s*['"][^'"]+['"]\s*(?:,\s*['"][^'"]+['"]\s*){0,5}\]/,
|
|
91
|
+
/(?:steps|phases|stages|config|options)\s*\./i,
|
|
92
|
+
];
|
|
93
|
+
return smallArrayPatterns.some((p) => p.test(line));
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Calculate adjusted confidence for a pattern match
|
|
97
|
+
*/
|
|
98
|
+
function calculateConfidence(baseConfidence, content, matchIndex, filePath) {
|
|
99
|
+
let confidence = baseConfidence;
|
|
100
|
+
let reason;
|
|
101
|
+
if (isLowRiskFile(filePath)) {
|
|
102
|
+
confidence -= 30;
|
|
103
|
+
reason = "Low-risk file (test/config/migration)";
|
|
104
|
+
}
|
|
105
|
+
if (isWorkflowContext(content, matchIndex)) {
|
|
106
|
+
confidence -= 25;
|
|
107
|
+
reason = reason ? `${reason}, workflow context` : "Workflow/orchestration context";
|
|
108
|
+
}
|
|
109
|
+
if (hasSmallFixedIteration(content, matchIndex)) {
|
|
110
|
+
confidence -= 20;
|
|
111
|
+
reason = reason ? `${reason}, small iteration` : "Small fixed iteration count";
|
|
112
|
+
}
|
|
113
|
+
const isLikelyFalsePositive = confidence < 50;
|
|
114
|
+
return { confidence: Math.max(10, confidence), isLikelyFalsePositive, reason };
|
|
115
|
+
}
|
|
48
116
|
/**
|
|
49
117
|
* Analyze source code for potential bottlenecks
|
|
50
118
|
*/
|
|
@@ -62,59 +130,81 @@ async function analyzeSourceCode(projectPath) {
|
|
|
62
130
|
continue;
|
|
63
131
|
try {
|
|
64
132
|
const filePath = join(dirPath, file);
|
|
133
|
+
const fullPath = `${dir}/${file}`;
|
|
65
134
|
const content = await readFile(filePath, "utf-8");
|
|
66
|
-
// Check for N+1 patterns
|
|
67
|
-
for (const pattern of N_PLUS_ONE_PATTERNS) {
|
|
68
|
-
const
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
135
|
+
// Check for N+1 patterns with semantic analysis
|
|
136
|
+
for (const { pattern, name, baseConfidence } of N_PLUS_ONE_PATTERNS) {
|
|
137
|
+
const regex = new RegExp(pattern.source, pattern.flags);
|
|
138
|
+
let match;
|
|
139
|
+
while ((match = regex.exec(content)) !== null) {
|
|
140
|
+
const { confidence, isLikelyFalsePositive, reason } = calculateConfidence(baseConfidence, content, match.index, fullPath);
|
|
141
|
+
if (confidence >= 50) {
|
|
142
|
+
bottlenecks.push({
|
|
143
|
+
type: "database",
|
|
144
|
+
location: fullPath,
|
|
145
|
+
severity: confidence >= 80 ? "high" : "medium",
|
|
146
|
+
description: `Potential N+1 query pattern: ${name}`,
|
|
147
|
+
metrics: {
|
|
148
|
+
current: 1,
|
|
149
|
+
threshold: 0,
|
|
150
|
+
unit: "patterns",
|
|
151
|
+
},
|
|
152
|
+
recommendation: "Consider using eager loading or batching queries",
|
|
153
|
+
confidence,
|
|
154
|
+
isLikelyFalsePositive,
|
|
155
|
+
falsePositiveReason: reason,
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
else if (!isLikelyFalsePositive) {
|
|
159
|
+
logger.debug("scale.bottleneck_low_confidence", {
|
|
160
|
+
file: fullPath,
|
|
161
|
+
pattern: name,
|
|
162
|
+
confidence,
|
|
163
|
+
reason,
|
|
164
|
+
});
|
|
165
|
+
}
|
|
82
166
|
}
|
|
83
167
|
}
|
|
84
|
-
// Check for memory leak patterns
|
|
85
|
-
|
|
86
|
-
const
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
168
|
+
// Check for memory leak patterns (skip in test files)
|
|
169
|
+
if (!isLowRiskFile(fullPath)) {
|
|
170
|
+
for (const pattern of MEMORY_LEAK_PATTERNS) {
|
|
171
|
+
const matches = content.match(pattern);
|
|
172
|
+
if (matches && matches.length > 0) {
|
|
173
|
+
bottlenecks.push({
|
|
174
|
+
type: "memory",
|
|
175
|
+
location: fullPath,
|
|
176
|
+
severity: "medium",
|
|
177
|
+
description: `Potential memory leak pattern detected`,
|
|
178
|
+
metrics: {
|
|
179
|
+
current: matches.length,
|
|
180
|
+
threshold: 0,
|
|
181
|
+
unit: "patterns",
|
|
182
|
+
},
|
|
183
|
+
recommendation: "Ensure proper cleanup of resources and event listeners",
|
|
184
|
+
confidence: 75,
|
|
185
|
+
isLikelyFalsePositive: false,
|
|
186
|
+
});
|
|
187
|
+
}
|
|
100
188
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
189
|
+
// Check for blocking patterns
|
|
190
|
+
for (const pattern of BLOCKING_PATTERNS) {
|
|
191
|
+
const matches = content.match(pattern);
|
|
192
|
+
if (matches && matches.length > 0) {
|
|
193
|
+
bottlenecks.push({
|
|
194
|
+
type: "cpu",
|
|
195
|
+
location: fullPath,
|
|
196
|
+
severity: "medium",
|
|
197
|
+
description: `Blocking operation detected: ${matches[0]}`,
|
|
198
|
+
metrics: {
|
|
199
|
+
current: matches.length,
|
|
200
|
+
threshold: 0,
|
|
201
|
+
unit: "occurrences",
|
|
202
|
+
},
|
|
203
|
+
recommendation: "Use async alternatives to avoid blocking the event loop",
|
|
204
|
+
confidence: 85,
|
|
205
|
+
isLikelyFalsePositive: false,
|
|
206
|
+
});
|
|
207
|
+
}
|
|
118
208
|
}
|
|
119
209
|
}
|
|
120
210
|
}
|
|
@@ -127,7 +217,16 @@ async function analyzeSourceCode(projectPath) {
|
|
|
127
217
|
// Directory doesn't exist
|
|
128
218
|
}
|
|
129
219
|
}
|
|
130
|
-
|
|
220
|
+
// Deduplicate bottlenecks by location + type
|
|
221
|
+
const seen = new Set();
|
|
222
|
+
const deduped = bottlenecks.filter((b) => {
|
|
223
|
+
const key = `${b.type}:${b.location}:${b.description}`;
|
|
224
|
+
if (seen.has(key))
|
|
225
|
+
return false;
|
|
226
|
+
seen.add(key);
|
|
227
|
+
return true;
|
|
228
|
+
});
|
|
229
|
+
return deduped;
|
|
131
230
|
}
|
|
132
231
|
/**
|
|
133
232
|
* Analyze load test results for bottlenecks
|
|
@@ -203,22 +302,40 @@ function analyzeLoadTestResults(results) {
|
|
|
203
302
|
/**
|
|
204
303
|
* Detect bottlenecks in a project
|
|
205
304
|
*/
|
|
206
|
-
export async function detectBottlenecks(projectPath, loadTestResults) {
|
|
305
|
+
export async function detectBottlenecks(projectPath, loadTestResults, options = {}) {
|
|
306
|
+
const { includeAllConfidence = false, minConfidence = 50 } = options;
|
|
207
307
|
const bottlenecks = [];
|
|
208
|
-
logger.info("scale.bottleneck_detection_started", { projectPath });
|
|
308
|
+
logger.info("scale.bottleneck_detection_started", { projectPath, minConfidence });
|
|
209
309
|
// Analyze source code
|
|
210
310
|
const codeBottlenecks = await analyzeSourceCode(projectPath);
|
|
211
|
-
|
|
311
|
+
// Filter by confidence unless includeAllConfidence is true
|
|
312
|
+
const filteredCodeBottlenecks = includeAllConfidence
|
|
313
|
+
? codeBottlenecks
|
|
314
|
+
: codeBottlenecks.filter((b) => b.confidence >= minConfidence);
|
|
315
|
+
bottlenecks.push(...filteredCodeBottlenecks);
|
|
212
316
|
// Analyze load test results if available
|
|
213
317
|
if (loadTestResults) {
|
|
214
318
|
const loadBottlenecks = analyzeLoadTestResults(loadTestResults);
|
|
215
|
-
bottlenecks.push(...loadBottlenecks)
|
|
319
|
+
bottlenecks.push(...loadBottlenecks.map((b) => ({
|
|
320
|
+
...b,
|
|
321
|
+
confidence: 100,
|
|
322
|
+
isLikelyFalsePositive: false,
|
|
323
|
+
})));
|
|
216
324
|
}
|
|
217
|
-
// Sort by severity
|
|
325
|
+
// Sort by severity, then by confidence
|
|
218
326
|
const severityOrder = { critical: 0, high: 1, medium: 2, low: 3 };
|
|
219
|
-
bottlenecks.sort((a, b) =>
|
|
327
|
+
bottlenecks.sort((a, b) => {
|
|
328
|
+
const severityDiff = severityOrder[a.severity] - severityOrder[b.severity];
|
|
329
|
+
if (severityDiff !== 0)
|
|
330
|
+
return severityDiff;
|
|
331
|
+
return b.confidence - a.confidence;
|
|
332
|
+
});
|
|
333
|
+
const highConfidenceCount = bottlenecks.filter((b) => b.confidence >= 80).length;
|
|
334
|
+
const likelyFpCount = bottlenecks.filter((b) => b.isLikelyFalsePositive).length;
|
|
220
335
|
logger.info("scale.bottleneck_detection_completed", {
|
|
221
336
|
total: bottlenecks.length,
|
|
337
|
+
highConfidence: highConfidenceCount,
|
|
338
|
+
likelyFalsePositives: likelyFpCount,
|
|
222
339
|
critical: bottlenecks.filter((b) => b.severity === "critical").length,
|
|
223
340
|
high: bottlenecks.filter((b) => b.severity === "high").length,
|
|
224
341
|
});
|
|
@@ -226,25 +343,35 @@ export async function detectBottlenecks(projectPath, loadTestResults) {
|
|
|
226
343
|
}
|
|
227
344
|
/**
|
|
228
345
|
* Calculate bottleneck score (100 = no bottlenecks)
|
|
346
|
+
* Now factors in confidence - low confidence findings have less impact
|
|
229
347
|
*/
|
|
230
348
|
export function calculateBottleneckScore(bottlenecks) {
|
|
231
349
|
let score = 100;
|
|
232
350
|
for (const bottleneck of bottlenecks) {
|
|
351
|
+
const extended = bottleneck;
|
|
352
|
+
const confidenceMultiplier = extended.confidence !== undefined ? extended.confidence / 100 : 1;
|
|
353
|
+
if (extended.isLikelyFalsePositive) {
|
|
354
|
+
continue;
|
|
355
|
+
}
|
|
356
|
+
let penalty;
|
|
233
357
|
switch (bottleneck.severity) {
|
|
234
358
|
case "critical":
|
|
235
|
-
|
|
359
|
+
penalty = 25;
|
|
236
360
|
break;
|
|
237
361
|
case "high":
|
|
238
|
-
|
|
362
|
+
penalty = 15;
|
|
239
363
|
break;
|
|
240
364
|
case "medium":
|
|
241
|
-
|
|
365
|
+
penalty = 8;
|
|
242
366
|
break;
|
|
243
367
|
case "low":
|
|
244
|
-
|
|
368
|
+
penalty = 3;
|
|
245
369
|
break;
|
|
370
|
+
default:
|
|
371
|
+
penalty = 0;
|
|
246
372
|
}
|
|
373
|
+
score -= penalty * confidenceMultiplier;
|
|
247
374
|
}
|
|
248
|
-
return Math.max(0, score);
|
|
375
|
+
return Math.max(0, Math.round(score));
|
|
249
376
|
}
|
|
250
377
|
//# sourceMappingURL=bottleneck-detector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bottleneck-detector.js","sourceRoot":"","sources":["../../../src/scanners/scale/bottleneck-detector.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"bottleneck-detector.js","sourceRoot":"","sources":["../../../src/scanners/scale/bottleneck-detector.ts"],"names":[],"mappings":"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"}
|
|
@@ -121,8 +121,8 @@ export declare const ScenarioSchema: z.ZodObject<{
|
|
|
121
121
|
}>, "many">>;
|
|
122
122
|
}, "strip", z.ZodTypeAny, {
|
|
123
123
|
name: string;
|
|
124
|
-
duration: string;
|
|
125
124
|
type: "ramp" | "spike" | "soak" | "stress" | "breakpoint";
|
|
125
|
+
duration: string;
|
|
126
126
|
vus: number | {
|
|
127
127
|
end: number;
|
|
128
128
|
start: number;
|
|
@@ -227,8 +227,8 @@ export declare const LoadProfileSchema: z.ZodObject<{
|
|
|
227
227
|
}>, "many">>;
|
|
228
228
|
}, "strip", z.ZodTypeAny, {
|
|
229
229
|
name: string;
|
|
230
|
-
duration: string;
|
|
231
230
|
type: "ramp" | "spike" | "soak" | "stress" | "breakpoint";
|
|
231
|
+
duration: string;
|
|
232
232
|
vus: number | {
|
|
233
233
|
end: number;
|
|
234
234
|
start: number;
|
|
@@ -329,8 +329,8 @@ export declare const LoadProfileSchema: z.ZodObject<{
|
|
|
329
329
|
tool: "k6" | "artillery" | "autocannon" | "wrk";
|
|
330
330
|
scenarios: {
|
|
331
331
|
name: string;
|
|
332
|
-
duration: string;
|
|
333
332
|
type: "ramp" | "spike" | "soak" | "stress" | "breakpoint";
|
|
333
|
+
duration: string;
|
|
334
334
|
vus: number | {
|
|
335
335
|
end: number;
|
|
336
336
|
start: number;
|
package/dist/scanners/types.d.ts
CHANGED
|
@@ -13,7 +13,7 @@ export type { Severity };
|
|
|
13
13
|
/**
|
|
14
14
|
* Supported scanner types
|
|
15
15
|
*/
|
|
16
|
-
export type ScannerType = "semgrep" | "npm-audit" | "gitleaks" | "tsc" | "eslint" | "bandit" | "gosec" | "brakeman" | "trivy" | "binary-analysis" | "memory-safety" | "race-condition" | "healthcare" | "logic" | "dast" | "zap" | "nuclei" | "terraform" | "tfsec" | "checkov" | "openapi" | "spectral" | "rust" | "cargo-audit" | "clippy" | "plugin";
|
|
16
|
+
export type ScannerType = "semgrep" | "npm-audit" | "gitleaks" | "tsc" | "eslint" | "bandit" | "gosec" | "brakeman" | "trivy" | "binary-analysis" | "memory-safety" | "race-condition" | "healthcare" | "logic" | "dast" | "zap" | "nuclei" | "terraform" | "tfsec" | "checkov" | "openapi" | "spectral" | "rust" | "cargo-audit" | "clippy" | "detection" | "plugin";
|
|
17
17
|
/**
|
|
18
18
|
* A finding from a deterministic scanner.
|
|
19
19
|
*
|
|
@@ -56,6 +56,21 @@ export interface DeterministicFinding {
|
|
|
56
56
|
/** Additional metadata from the scanner */
|
|
57
57
|
metadata?: Record<string, unknown>;
|
|
58
58
|
}
|
|
59
|
+
/**
|
|
60
|
+
* Detailed error information for scanner failures
|
|
61
|
+
*/
|
|
62
|
+
export interface ScannerErrorDetails {
|
|
63
|
+
/** Full error message */
|
|
64
|
+
message: string;
|
|
65
|
+
/** Full output (stdout/stderr combined) */
|
|
66
|
+
fullOutput?: string;
|
|
67
|
+
/** Actionable suggestions to fix the issue */
|
|
68
|
+
suggestions?: string[];
|
|
69
|
+
/** Which phase failed */
|
|
70
|
+
phase?: "init" | "scan" | "parse";
|
|
71
|
+
/** File that caused the error (if applicable) */
|
|
72
|
+
file?: string;
|
|
73
|
+
}
|
|
59
74
|
/**
|
|
60
75
|
* Result from running a single scanner
|
|
61
76
|
*/
|
|
@@ -68,8 +83,10 @@ export interface ScannerResult {
|
|
|
68
83
|
duration: number;
|
|
69
84
|
/** Whether the scan completed successfully */
|
|
70
85
|
success: boolean;
|
|
71
|
-
/** Error message if scan failed */
|
|
86
|
+
/** Error message if scan failed (truncated) */
|
|
72
87
|
error?: string;
|
|
88
|
+
/** Detailed error information with suggestions */
|
|
89
|
+
errorDetails?: ScannerErrorDetails;
|
|
73
90
|
/** Exit code from the scanner process */
|
|
74
91
|
exitCode?: number;
|
|
75
92
|
/** Scanner version used */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/scanners/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAG1D,YAAY,EAAE,QAAQ,EAAE,CAAC;AAEzB;;GAEG;AACH,MAAM,MAAM,WAAW,GACnB,SAAS,GACT,WAAW,GACX,UAAU,GACV,KAAK,GACL,QAAQ,GACR,QAAQ,GACR,OAAO,GACP,UAAU,GACV,OAAO,GACP,iBAAiB,GACjB,eAAe,GACf,gBAAgB,GAChB,YAAY,GACZ,OAAO,GACP,MAAM,GACN,KAAK,GACL,QAAQ,GACR,WAAW,GACX,OAAO,GACP,SAAS,GACT,SAAS,GACT,UAAU,GACV,MAAM,GACN,aAAa,GACb,QAAQ,GACR,QAAQ,CAAC;AAEb;;;;;GAKG;AACH,MAAM,WAAW,oBAAoB;IACnC,qCAAqC;IACrC,OAAO,EAAE,WAAW,CAAC;IAErB,+EAA+E;IAC/E,MAAM,EAAE,MAAM,CAAC;IAEf,mDAAmD;IACnD,IAAI,EAAE,MAAM,CAAC;IAEb,8BAA8B;IAC9B,IAAI,EAAE,MAAM,CAAC;IAEb,0CAA0C;IAC1C,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,qCAAqC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,uCAAuC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,8CAA8C;IAC9C,OAAO,EAAE,MAAM,CAAC;IAEhB,qBAAqB;IACrB,QAAQ,EAAE,QAAQ,CAAC;IAEnB,wEAAwE;IACxE,UAAU,EAAE,MAAM,CAAC;IAEnB,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,0DAA0D;IAC1D,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB,4CAA4C;IAC5C,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvB,iCAAiC;IACjC,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,iDAAiD;IACjD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,2CAA2C;IAC3C,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,4BAA4B;IAC5B,OAAO,EAAE,WAAW,CAAC;IAErB,0CAA0C;IAC1C,QAAQ,EAAE,oBAAoB,EAAE,CAAC;IAEjC,6CAA6C;IAC7C,QAAQ,EAAE,MAAM,CAAC;IAEjB,8CAA8C;IAC9C,OAAO,EAAE,OAAO,CAAC;IAEjB
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/scanners/types.ts"],"names":[],"mappings":"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"}
|
package/dist/scanners/types.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/scanners/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/scanners/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAiPH;;GAEG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAA8E;IAChH,OAAO,EAAE,IAAI;IACb,YAAY,EAAE,IAAI;IAClB,OAAO,EAAE,IAAI;IACb,UAAU,EAAE,IAAI;IAChB,MAAM,EAAE,KAAK,EAAU,mCAAmC;IAC1D,MAAM,EAAE,KAAK,EAAU,kCAAkC;IACzD,KAAK,EAAE,KAAK,EAAW,8BAA8B;IACrD,QAAQ,EAAE,KAAK,EAAQ,gCAAgC;IACvD,KAAK,EAAE,KAAK,EAAW,kCAAkC;IACzD,cAAc,EAAE,IAAI,EAAG,6CAA6C;IACpE,YAAY,EAAE,KAAK,EAAI,sCAAsC;IAC7D,aAAa,EAAE,IAAI,EAAI,qBAAqB;IAC5C,OAAO,EAAE,MAAM,EAAQ,wBAAwB;CAChD,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,0BAA0B;IAC1B,GAAG,EAAE;QACH,QAAQ,EAAE,UAAsB;QAChC,IAAI,EAAE,MAAkB;QACxB,QAAQ,EAAE,QAAoB;QAC9B,GAAG,EAAE,KAAiB;QACtB,IAAI,EAAE,MAAkB;KACzB;IAED,UAAU;IACV,OAAO,EAAE;QACP,KAAK,EAAE,MAAkB;QACzB,OAAO,EAAE,QAAoB;QAC7B,IAAI,EAAE,KAAiB;KACxB;IAED,sCAAsC;IACtC,QAAQ,EAAE;QACR,OAAO,EAAE,UAAsB;KAChC;IAED,sBAAsB;IACtB,UAAU,EAAE;QACV,KAAK,EAAE,MAAkB;QACzB,OAAO,EAAE,QAAoB;QAC7B,UAAU,EAAE,KAAiB;QAC7B,OAAO,EAAE,MAAkB;KAC5B;IAED,kBAAkB;IAClB,MAAM,EAAE;QACN,IAAI,EAAE,MAAkB;QACxB,MAAM,EAAE,QAAoB;QAC5B,GAAG,EAAE,KAAiB;KACvB;IAED,aAAa;IACb,KAAK,EAAE;QACL,IAAI,EAAE,MAAkB;QACxB,MAAM,EAAE,QAAoB;QAC5B,GAAG,EAAE,KAAiB;KACvB;IAED,kBAAkB;IAClB,QAAQ,EAAE;QACR,IAAI,EAAE,MAAkB;QACxB,MAAM,EAAE,QAAoB;QAC5B,IAAI,EAAE,KAAiB;KACxB;IAED,QAAQ;IACR,KAAK,EAAE;QACL,QAAQ,EAAE,UAAsB;QAChC,IAAI,EAAE,MAAkB;QACxB,MAAM,EAAE,QAAoB;QAC5B,GAAG,EAAE,KAAiB;QACtB,OAAO,EAAE,MAAkB;KAC5B;CACF,CAAC;AAaF;;GAEG;AACH,MAAM,UAAU,WAAW,CAAC,OAAoB,EAAE,MAAc,EAAE,KAAa;IAC7E,MAAM,MAAM,GAAgC;QAC1C,OAAO,EAAE,KAAK;QACd,WAAW,EAAE,KAAK;QAClB,QAAQ,EAAE,KAAK;QACf,GAAG,EAAE,IAAI;QACT,MAAM,EAAE,MAAM;QACd,MAAM,EAAE,IAAI;QACZ,KAAK,EAAE,IAAI;QACX,QAAQ,EAAE,IAAI;QACd,KAAK,EAAE,KAAK;QACZ,iBAAiB,EAAE,KAAK;QACxB,eAAe,EAAE,KAAK;QACtB,gBAAgB,EAAE,KAAK;QACvB,UAAU,EAAE,IAAI;QAChB,KAAK,EAAE,KAAK;QACZ,IAAI,EAAE,KAAK;QACX,GAAG,EAAE,KAAK;QACV,MAAM,EAAE,KAAK;QACb,SAAS,EAAE,IAAI;QACf,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,KAAK;QACd,OAAO,EAAE,KAAK;QACd,QAAQ,EAAE,KAAK;QACf,IAAI,EAAE,IAAI;QACV,aAAa,EAAE,KAAK;QACpB,MAAM,EAAE,KAAK;QACb,SAAS,EAAE,KAAK;QAChB,MAAM,EAAE,KAAK;KACd,CAAC;IAEF,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AACpE,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"typescript.d.ts","sourceRoot":"","sources":["../../src/scanners/typescript.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAwB,aAAa,
|
|
1
|
+
{"version":3,"file":"typescript.d.ts","sourceRoot":"","sources":["../../src/scanners/typescript.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,KAAK,EAAwB,aAAa,EAAuB,MAAM,YAAY,CAAC;AAgB3F;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;CACzB;AAED;;GAEG;AACH,wBAAsB,qBAAqB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAwJvF;AAuID;;GAEG;AACH,wBAAsB,qBAAqB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,CA8DlG"}
|
|
@@ -14,6 +14,13 @@ import ts from "typescript";
|
|
|
14
14
|
import { access } from "fs/promises";
|
|
15
15
|
import { join, relative } from "path";
|
|
16
16
|
import { logger } from "../logger.js";
|
|
17
|
+
function buildErrorDetails(phase, message, suggestions = []) {
|
|
18
|
+
return {
|
|
19
|
+
message,
|
|
20
|
+
phase,
|
|
21
|
+
suggestions,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
17
24
|
/**
|
|
18
25
|
* Run TypeScript analysis and return findings
|
|
19
26
|
*/
|
|
@@ -26,12 +33,18 @@ export async function runTypeScriptAnalysis(projectPath) {
|
|
|
26
33
|
await access(tsconfigPath);
|
|
27
34
|
}
|
|
28
35
|
catch {
|
|
36
|
+
logger.debug("scanners.typescript_no_config", { projectPath });
|
|
29
37
|
return {
|
|
30
38
|
scanner: "tsc",
|
|
31
39
|
findings: [],
|
|
32
40
|
duration: Date.now() - startTime,
|
|
33
|
-
success:
|
|
34
|
-
error: "No tsconfig.json found
|
|
41
|
+
success: false,
|
|
42
|
+
error: "No tsconfig.json found",
|
|
43
|
+
errorDetails: buildErrorDetails("init", "No tsconfig.json found in project root", [
|
|
44
|
+
"Create a tsconfig.json: npx tsc --init",
|
|
45
|
+
"Or specify a custom path in scanner options",
|
|
46
|
+
"If this is not a TypeScript project, disable the tsc scanner",
|
|
47
|
+
]),
|
|
35
48
|
};
|
|
36
49
|
}
|
|
37
50
|
try {
|
|
@@ -47,12 +60,18 @@ export async function runTypeScriptAnalysis(projectPath) {
|
|
|
47
60
|
}
|
|
48
61
|
});
|
|
49
62
|
if (configFile.error) {
|
|
63
|
+
const errorText = ts.flattenDiagnosticMessageText(configFile.error.messageText, "\n");
|
|
50
64
|
return {
|
|
51
65
|
scanner: "tsc",
|
|
52
66
|
findings: [],
|
|
53
67
|
duration: Date.now() - startTime,
|
|
54
68
|
success: false,
|
|
55
|
-
error: `Failed to parse tsconfig.json: ${
|
|
69
|
+
error: `Failed to parse tsconfig.json: ${errorText}`,
|
|
70
|
+
errorDetails: buildErrorDetails("parse", errorText, [
|
|
71
|
+
"Check tsconfig.json for JSON syntax errors",
|
|
72
|
+
"Validate extends path if using a base config",
|
|
73
|
+
"Run: npx tsc --showConfig to diagnose",
|
|
74
|
+
]),
|
|
56
75
|
};
|
|
57
76
|
}
|
|
58
77
|
const parsedConfig = ts.parseJsonConfigFileContent(configFile.config, ts.sys, projectPath);
|
|
@@ -116,13 +135,26 @@ export async function runTypeScriptAnalysis(projectPath) {
|
|
|
116
135
|
}
|
|
117
136
|
catch (error) {
|
|
118
137
|
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
119
|
-
|
|
138
|
+
const errorStack = error instanceof Error ? error.stack : undefined;
|
|
139
|
+
logger.error("scanners.typescript_failed", { error: errorMessage, stack: errorStack });
|
|
140
|
+
const suggestions = [];
|
|
141
|
+
if (errorMessage.includes("Cannot find module")) {
|
|
142
|
+
suggestions.push("Run: npm install to install dependencies");
|
|
143
|
+
}
|
|
144
|
+
if (errorMessage.includes("memory")) {
|
|
145
|
+
suggestions.push("Try increasing Node.js heap: NODE_OPTIONS=--max-old-space-size=4096");
|
|
146
|
+
}
|
|
147
|
+
if (suggestions.length === 0) {
|
|
148
|
+
suggestions.push("Check that TypeScript is installed: npm install typescript");
|
|
149
|
+
suggestions.push("Validate tsconfig.json is correct");
|
|
150
|
+
}
|
|
120
151
|
return {
|
|
121
152
|
scanner: "tsc",
|
|
122
153
|
findings: [],
|
|
123
154
|
duration: Date.now() - startTime,
|
|
124
155
|
success: false,
|
|
125
156
|
error: errorMessage,
|
|
157
|
+
errorDetails: buildErrorDetails("scan", errorMessage, suggestions),
|
|
126
158
|
};
|
|
127
159
|
}
|
|
128
160
|
}
|