flow-debugger 1.9.7 → 1.9.9
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/ENHANCED_OBSERVABILITY.md +835 -0
- package/IMPLEMENTATION_SUMMARY.md +466 -0
- package/README.md +147 -8
- package/bin/cli.js +1 -1
- package/dist/cjs/core/Alerting.js +310 -0
- package/dist/cjs/core/Alerting.js.map +1 -0
- package/dist/cjs/core/AnomalyDetection.js +223 -0
- package/dist/cjs/core/AnomalyDetection.js.map +1 -0
- package/dist/cjs/core/DependencyGraph.js +251 -0
- package/dist/cjs/core/DependencyGraph.js.map +1 -0
- package/dist/cjs/core/DistributedTracing.js +245 -0
- package/dist/cjs/core/DistributedTracing.js.map +1 -0
- package/dist/cjs/core/ErrorClustering.js +257 -0
- package/dist/cjs/core/ErrorClustering.js.map +1 -0
- package/dist/cjs/core/LogCorrelation.js +242 -0
- package/dist/cjs/core/LogCorrelation.js.map +1 -0
- package/dist/cjs/core/Metrics.js +301 -0
- package/dist/cjs/core/Metrics.js.map +1 -0
- package/dist/cjs/core/RootCause.js +107 -9
- package/dist/cjs/core/RootCause.js.map +1 -1
- package/dist/cjs/core/TrendAnalysis.js +254 -0
- package/dist/cjs/core/TrendAnalysis.js.map +1 -0
- package/dist/cjs/core/types.js +14 -0
- package/dist/cjs/core/types.js.map +1 -1
- package/dist/cjs/index.js +27 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/middleware/express.js +105 -4
- package/dist/cjs/middleware/express.js.map +1 -1
- package/dist/esm/core/Alerting.js +305 -0
- package/dist/esm/core/Alerting.js.map +1 -0
- package/dist/esm/core/AnomalyDetection.js +218 -0
- package/dist/esm/core/AnomalyDetection.js.map +1 -0
- package/dist/esm/core/DependencyGraph.js +246 -0
- package/dist/esm/core/DependencyGraph.js.map +1 -0
- package/dist/esm/core/DistributedTracing.js +240 -0
- package/dist/esm/core/DistributedTracing.js.map +1 -0
- package/dist/esm/core/ErrorClustering.js +252 -0
- package/dist/esm/core/ErrorClustering.js.map +1 -0
- package/dist/esm/core/LogCorrelation.js +236 -0
- package/dist/esm/core/LogCorrelation.js.map +1 -0
- package/dist/esm/core/Metrics.js +297 -0
- package/dist/esm/core/Metrics.js.map +1 -0
- package/dist/esm/core/RootCause.js +107 -9
- package/dist/esm/core/RootCause.js.map +1 -1
- package/dist/esm/core/TrendAnalysis.js +250 -0
- package/dist/esm/core/TrendAnalysis.js.map +1 -0
- package/dist/esm/core/types.js +14 -0
- package/dist/esm/core/types.js.map +1 -1
- package/dist/esm/index.js +10 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/middleware/express.js +105 -4
- package/dist/esm/middleware/express.js.map +1 -1
- package/dist/types/core/Alerting.d.ts +82 -0
- package/dist/types/core/Alerting.d.ts.map +1 -0
- package/dist/types/core/AnomalyDetection.d.ts +93 -0
- package/dist/types/core/AnomalyDetection.d.ts.map +1 -0
- package/dist/types/core/DependencyGraph.d.ts +65 -0
- package/dist/types/core/DependencyGraph.d.ts.map +1 -0
- package/dist/types/core/DistributedTracing.d.ts +92 -0
- package/dist/types/core/DistributedTracing.d.ts.map +1 -0
- package/dist/types/core/ErrorClustering.d.ts +70 -0
- package/dist/types/core/ErrorClustering.d.ts.map +1 -0
- package/dist/types/core/LogCorrelation.d.ts +73 -0
- package/dist/types/core/LogCorrelation.d.ts.map +1 -0
- package/dist/types/core/Metrics.d.ts +73 -0
- package/dist/types/core/Metrics.d.ts.map +1 -0
- package/dist/types/core/RootCause.d.ts +9 -5
- package/dist/types/core/RootCause.d.ts.map +1 -1
- package/dist/types/core/TrendAnalysis.d.ts +63 -0
- package/dist/types/core/TrendAnalysis.d.ts.map +1 -0
- package/dist/types/core/types.d.ts +200 -0
- package/dist/types/core/types.d.ts.map +1 -1
- package/dist/types/index.d.ts +9 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/middleware/express.d.ts +12 -0
- package/dist/types/middleware/express.d.ts.map +1 -1
- package/package.json +3 -3
- package/test-results.json +1 -0
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
// ─────────────────────────────────────────────────────────────
|
|
2
|
+
// flow-debugger — Metrics & Gauges System
|
|
3
|
+
// Custom metrics for business and performance tracking
|
|
4
|
+
// ─────────────────────────────────────────────────────────────
|
|
5
|
+
/**
|
|
6
|
+
* Metrics Registry - Central storage for all metrics
|
|
7
|
+
*/
|
|
8
|
+
export class MetricsRegistry {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.metrics = new Map();
|
|
11
|
+
this.timeSeries = new Map();
|
|
12
|
+
this.maxTimeSeriesPoints = 1000;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Create or get a counter metric
|
|
16
|
+
*/
|
|
17
|
+
counter(name, description, labels) {
|
|
18
|
+
const key = this.makeKey(name, labels);
|
|
19
|
+
const existing = this.metrics.get(key);
|
|
20
|
+
if (existing)
|
|
21
|
+
return existing;
|
|
22
|
+
const metric = {
|
|
23
|
+
name,
|
|
24
|
+
type: 'counter',
|
|
25
|
+
description,
|
|
26
|
+
labels,
|
|
27
|
+
value: 0,
|
|
28
|
+
createdAt: Date.now(),
|
|
29
|
+
updatedAt: Date.now(),
|
|
30
|
+
};
|
|
31
|
+
this.metrics.set(key, metric);
|
|
32
|
+
return metric;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Create or get a gauge metric
|
|
36
|
+
*/
|
|
37
|
+
gauge(name, description, labels) {
|
|
38
|
+
const key = this.makeKey(name, labels);
|
|
39
|
+
const existing = this.metrics.get(key);
|
|
40
|
+
if (existing)
|
|
41
|
+
return existing;
|
|
42
|
+
const metric = {
|
|
43
|
+
name,
|
|
44
|
+
type: 'gauge',
|
|
45
|
+
description,
|
|
46
|
+
labels,
|
|
47
|
+
value: 0,
|
|
48
|
+
createdAt: Date.now(),
|
|
49
|
+
updatedAt: Date.now(),
|
|
50
|
+
};
|
|
51
|
+
this.metrics.set(key, metric);
|
|
52
|
+
return metric;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Create or get a histogram metric
|
|
56
|
+
*/
|
|
57
|
+
histogram(name, buckets = [0.005, 0.01, 0.025, 0.05, 0.1, 0.25, 0.5, 1, 2.5, 5, 10], description, labels) {
|
|
58
|
+
const key = this.makeKey(name, labels);
|
|
59
|
+
const existing = this.metrics.get(key);
|
|
60
|
+
if (existing)
|
|
61
|
+
return existing;
|
|
62
|
+
const metric = {
|
|
63
|
+
name,
|
|
64
|
+
type: 'histogram',
|
|
65
|
+
description,
|
|
66
|
+
labels,
|
|
67
|
+
buckets: buckets.map(b => ({ upperBound: b, count: 0 })),
|
|
68
|
+
sum: 0,
|
|
69
|
+
count: 0,
|
|
70
|
+
createdAt: Date.now(),
|
|
71
|
+
updatedAt: Date.now(),
|
|
72
|
+
};
|
|
73
|
+
this.metrics.set(key, metric);
|
|
74
|
+
return metric;
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Create or get a summary metric
|
|
78
|
+
*/
|
|
79
|
+
summary(name, quantiles = [0.5, 0.9, 0.95, 0.99], description, labels) {
|
|
80
|
+
const key = this.makeKey(name, labels);
|
|
81
|
+
const existing = this.metrics.get(key);
|
|
82
|
+
if (existing)
|
|
83
|
+
return existing;
|
|
84
|
+
const metric = {
|
|
85
|
+
name,
|
|
86
|
+
type: 'summary',
|
|
87
|
+
description,
|
|
88
|
+
labels,
|
|
89
|
+
quantiles: quantiles.map(q => ({ quantile: q, value: 0 })),
|
|
90
|
+
sum: 0,
|
|
91
|
+
count: 0,
|
|
92
|
+
createdAt: Date.now(),
|
|
93
|
+
updatedAt: Date.now(),
|
|
94
|
+
};
|
|
95
|
+
this.metrics.set(key, metric);
|
|
96
|
+
return metric;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Increment a counter
|
|
100
|
+
*/
|
|
101
|
+
inc(name, value = 1, labels) {
|
|
102
|
+
const key = this.makeKey(name, labels);
|
|
103
|
+
const metric = this.metrics.get(key);
|
|
104
|
+
if (metric && metric.type === 'counter') {
|
|
105
|
+
metric.value += value;
|
|
106
|
+
metric.updatedAt = Date.now();
|
|
107
|
+
this.recordTimeSeries(name, metric.value, labels);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Set a gauge value
|
|
112
|
+
*/
|
|
113
|
+
set(name, value, labels) {
|
|
114
|
+
const key = this.makeKey(name, labels);
|
|
115
|
+
const metric = this.metrics.get(key);
|
|
116
|
+
if (metric && metric.type === 'gauge') {
|
|
117
|
+
metric.value = value;
|
|
118
|
+
metric.min = metric.min === undefined ? value : Math.min(metric.min, value);
|
|
119
|
+
metric.max = metric.max === undefined ? value : Math.max(metric.max, value);
|
|
120
|
+
metric.updatedAt = Date.now();
|
|
121
|
+
this.recordTimeSeries(name, value, labels);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Observe a value for histogram/summary
|
|
126
|
+
*/
|
|
127
|
+
observe(name, value, labels) {
|
|
128
|
+
const key = this.makeKey(name, labels);
|
|
129
|
+
const metric = this.metrics.get(key);
|
|
130
|
+
if (!metric)
|
|
131
|
+
return;
|
|
132
|
+
metric.updatedAt = Date.now();
|
|
133
|
+
if (metric.type === 'histogram') {
|
|
134
|
+
const h = metric;
|
|
135
|
+
h.count++;
|
|
136
|
+
h.sum += value;
|
|
137
|
+
h.buckets.forEach(bucket => {
|
|
138
|
+
if (value <= bucket.upperBound) {
|
|
139
|
+
bucket.count++;
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
else if (metric.type === 'summary') {
|
|
144
|
+
const s = metric;
|
|
145
|
+
s.count++;
|
|
146
|
+
s.sum += value;
|
|
147
|
+
// Update quantiles (simplified - uses reservoir sampling)
|
|
148
|
+
this.updateQuantiles(s, value);
|
|
149
|
+
}
|
|
150
|
+
this.recordTimeSeries(name, value, labels);
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Get metric by name
|
|
154
|
+
*/
|
|
155
|
+
get(name, labels) {
|
|
156
|
+
const key = this.makeKey(name, labels);
|
|
157
|
+
return this.metrics.get(key);
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Get all metrics
|
|
161
|
+
*/
|
|
162
|
+
getAll() {
|
|
163
|
+
return Array.from(this.metrics.values());
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Get metrics by type
|
|
167
|
+
*/
|
|
168
|
+
getByType(type) {
|
|
169
|
+
return Array.from(this.metrics.values()).filter(m => m.type === type);
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Reset a metric
|
|
173
|
+
*/
|
|
174
|
+
reset(name, labels) {
|
|
175
|
+
const key = this.makeKey(name, labels);
|
|
176
|
+
const metric = this.metrics.get(key);
|
|
177
|
+
if (!metric)
|
|
178
|
+
return;
|
|
179
|
+
if (metric.type === 'counter') {
|
|
180
|
+
const c = metric;
|
|
181
|
+
c.value = 0;
|
|
182
|
+
}
|
|
183
|
+
else if (metric.type === 'gauge') {
|
|
184
|
+
const g = metric;
|
|
185
|
+
g.value = 0;
|
|
186
|
+
g.min = undefined;
|
|
187
|
+
g.max = undefined;
|
|
188
|
+
}
|
|
189
|
+
else if (metric.type === 'histogram') {
|
|
190
|
+
const h = metric;
|
|
191
|
+
h.buckets.forEach((b) => (b.count = 0));
|
|
192
|
+
h.sum = 0;
|
|
193
|
+
h.count = 0;
|
|
194
|
+
}
|
|
195
|
+
else if (metric.type === 'summary') {
|
|
196
|
+
const s = metric;
|
|
197
|
+
s.quantiles.forEach((q) => (q.value = 0));
|
|
198
|
+
s.sum = 0;
|
|
199
|
+
s.count = 0;
|
|
200
|
+
}
|
|
201
|
+
metric.updatedAt = Date.now();
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Clear all metrics
|
|
205
|
+
*/
|
|
206
|
+
clear() {
|
|
207
|
+
this.metrics.clear();
|
|
208
|
+
this.timeSeries.clear();
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Get time series data for a metric
|
|
212
|
+
*/
|
|
213
|
+
getTimeSeries(name, labels) {
|
|
214
|
+
const key = this.makeKey(name, labels);
|
|
215
|
+
return this.timeSeries.get(key) || [];
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Export metrics in Prometheus format
|
|
219
|
+
*/
|
|
220
|
+
exportPrometheus() {
|
|
221
|
+
const lines = [];
|
|
222
|
+
this.metrics.forEach(metric => {
|
|
223
|
+
const labelStr = metric.labels
|
|
224
|
+
? `{${Object.entries(metric.labels).map(([k, v]) => `${k}="${v}"`).join(', ')}}`
|
|
225
|
+
: '';
|
|
226
|
+
if (metric.type === 'counter') {
|
|
227
|
+
const c = metric;
|
|
228
|
+
lines.push(`# HELP ${metric.name} ${metric.description || ''}`);
|
|
229
|
+
lines.push(`# TYPE ${metric.name} counter`);
|
|
230
|
+
lines.push(`${metric.name}${labelStr} ${c.value}`);
|
|
231
|
+
}
|
|
232
|
+
else if (metric.type === 'gauge') {
|
|
233
|
+
const g = metric;
|
|
234
|
+
lines.push(`# HELP ${metric.name} ${metric.description || ''}`);
|
|
235
|
+
lines.push(`# TYPE ${metric.name} gauge`);
|
|
236
|
+
lines.push(`${metric.name}${labelStr} ${g.value}`);
|
|
237
|
+
}
|
|
238
|
+
else if (metric.type === 'histogram') {
|
|
239
|
+
const h = metric;
|
|
240
|
+
lines.push(`# HELP ${metric.name}_bucket ${metric.description || ''}`);
|
|
241
|
+
lines.push(`# TYPE ${metric.name}_bucket histogram`);
|
|
242
|
+
h.buckets.forEach(bucket => {
|
|
243
|
+
lines.push(`${metric.name}_bucket${labelStr}{le="${bucket.upperBound}"} ${bucket.count}`);
|
|
244
|
+
});
|
|
245
|
+
lines.push(`${metric.name}_bucket${labelStr}{le="+Inf"} ${h.count}`);
|
|
246
|
+
lines.push(`# HELP ${metric.name}_sum ${metric.description || ''}`);
|
|
247
|
+
lines.push(`# TYPE ${metric.name}_sum summary`);
|
|
248
|
+
lines.push(`${metric.name}_sum${labelStr} ${h.sum}`);
|
|
249
|
+
lines.push(`# HELP ${metric.name}_count ${metric.description || ''}`);
|
|
250
|
+
lines.push(`# TYPE ${metric.name}_count summary`);
|
|
251
|
+
lines.push(`${metric.name}_count${labelStr} ${h.count}`);
|
|
252
|
+
}
|
|
253
|
+
});
|
|
254
|
+
return lines.join('\n');
|
|
255
|
+
}
|
|
256
|
+
makeKey(name, labels) {
|
|
257
|
+
if (!labels)
|
|
258
|
+
return name;
|
|
259
|
+
const labelStr = Object.entries(labels)
|
|
260
|
+
.sort(([a], [b]) => a.localeCompare(b))
|
|
261
|
+
.map(([k, v]) => `${k}=${v}`)
|
|
262
|
+
.join('|');
|
|
263
|
+
return `${name}|${labelStr}`;
|
|
264
|
+
}
|
|
265
|
+
recordTimeSeries(name, value, labels) {
|
|
266
|
+
const key = this.makeKey(name, labels);
|
|
267
|
+
let series = this.timeSeries.get(key);
|
|
268
|
+
if (!series) {
|
|
269
|
+
series = [];
|
|
270
|
+
this.timeSeries.set(key, series);
|
|
271
|
+
}
|
|
272
|
+
series.push({
|
|
273
|
+
timestamp: new Date(),
|
|
274
|
+
value,
|
|
275
|
+
labels,
|
|
276
|
+
});
|
|
277
|
+
// Limit time series points
|
|
278
|
+
if (series.length > this.maxTimeSeriesPoints) {
|
|
279
|
+
series.shift();
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
updateQuantiles(metric, value) {
|
|
283
|
+
// Simplified quantile estimation using sorted array
|
|
284
|
+
const values = metric.quantiles.map(q => q.value);
|
|
285
|
+
values.push(value);
|
|
286
|
+
values.sort((a, b) => a - b);
|
|
287
|
+
metric.quantiles.forEach((q, i) => {
|
|
288
|
+
const index = Math.floor(q.quantile * (values.length - 1));
|
|
289
|
+
q.value = values[index] || 0;
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
/**
|
|
294
|
+
* Global metrics registry instance
|
|
295
|
+
*/
|
|
296
|
+
export const globalMetrics = new MetricsRegistry();
|
|
297
|
+
//# sourceMappingURL=Metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Metrics.js","sourceRoot":"","sources":["../../../src/core/Metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,20 @@
|
|
|
1
1
|
// ─────────────────────────────────────────────────────────────
|
|
2
2
|
// flow-debugger — Root Cause Detection
|
|
3
3
|
// Analyzes trace steps to identify the most likely failure origin
|
|
4
|
+
// INCLUDING SILENT FAILURES (no console error)
|
|
4
5
|
// ─────────────────────────────────────────────────────────────
|
|
5
6
|
/**
|
|
6
7
|
* Enhanced root cause detection with suggestions and detailed analysis.
|
|
7
8
|
*
|
|
8
|
-
*
|
|
9
|
-
* 1.
|
|
10
|
-
* 2.
|
|
11
|
-
* 3.
|
|
12
|
-
* 4.
|
|
9
|
+
* DETECTS:
|
|
10
|
+
* 1. Error patterns (timeout, connection, validation, etc.)
|
|
11
|
+
* 2. Slow queries and bottlenecks
|
|
12
|
+
* 3. Memory/performance issues
|
|
13
|
+
* 4. SILENT FAILURES (no console error but status codes indicate problems)
|
|
14
|
+
* 5. Empty/null database results without errors
|
|
15
|
+
* 6. Performance degradation trends
|
|
16
|
+
*
|
|
17
|
+
* Provides actionable suggestions for each issue type.
|
|
13
18
|
*/
|
|
14
19
|
export function detectRootCause(steps, statusCode, config) {
|
|
15
20
|
if (steps.length === 0)
|
|
@@ -24,7 +29,83 @@ export function detectRootCause(steps, statusCode, config) {
|
|
|
24
29
|
suggestions: [],
|
|
25
30
|
contributingFactors: []
|
|
26
31
|
};
|
|
27
|
-
// 1.
|
|
32
|
+
// ✅ 1. SILENT FAILURE DETECTION - No console error but status indicates problem
|
|
33
|
+
if (statusCode && statusCode >= 400 && statusCode < 500) {
|
|
34
|
+
// Client errors - might not throw but indicate problems
|
|
35
|
+
if (statusCode === 404) {
|
|
36
|
+
result.cause = 'Resource not found (silent failure - no exception thrown)';
|
|
37
|
+
result.step = 'Request handling';
|
|
38
|
+
result.service = 'internal';
|
|
39
|
+
result.confidence = 90;
|
|
40
|
+
result.suggestions = [
|
|
41
|
+
'Check if the requested resource exists',
|
|
42
|
+
'Verify route parameters and IDs',
|
|
43
|
+
'Review database for missing records',
|
|
44
|
+
'Check if file/blob exists before accessing'
|
|
45
|
+
];
|
|
46
|
+
return result;
|
|
47
|
+
}
|
|
48
|
+
if (statusCode === 401 || statusCode === 403) {
|
|
49
|
+
result.cause = 'Authentication/Authorization failed (silent rejection)';
|
|
50
|
+
result.step = 'Auth middleware';
|
|
51
|
+
result.service = 'internal';
|
|
52
|
+
result.confidence = 95;
|
|
53
|
+
result.suggestions = [
|
|
54
|
+
'Verify user token/credentials',
|
|
55
|
+
'Check session expiration',
|
|
56
|
+
'Review permission/role configuration',
|
|
57
|
+
'Ensure CORS policy allows the request'
|
|
58
|
+
];
|
|
59
|
+
return result;
|
|
60
|
+
}
|
|
61
|
+
if (statusCode === 429) {
|
|
62
|
+
result.cause = 'Rate limit exceeded (throttled silently)';
|
|
63
|
+
result.step = 'Rate limiter';
|
|
64
|
+
result.service = 'internal';
|
|
65
|
+
result.confidence = 100;
|
|
66
|
+
result.suggestions = [
|
|
67
|
+
'Implement request throttling on client',
|
|
68
|
+
'Add exponential backoff',
|
|
69
|
+
'Cache frequently accessed data',
|
|
70
|
+
'Consider upgrading API plan'
|
|
71
|
+
];
|
|
72
|
+
return result;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
// ✅ 2. SILENT DATABASE ISSUES - Returns empty/null without error
|
|
76
|
+
const dbSteps = steps.filter(s => ['mongo', 'mysql', 'postgres', 'redis'].includes(s.service));
|
|
77
|
+
for (const dbStep of dbSteps) {
|
|
78
|
+
const metadata = dbStep.metadata;
|
|
79
|
+
// Check for empty results (might indicate problem)
|
|
80
|
+
if (metadata?.resultCount === 0 && dbStep.name.toLowerCase().includes('find')) {
|
|
81
|
+
result.cause = 'Database query returned empty result (no error thrown)';
|
|
82
|
+
result.step = dbStep.name;
|
|
83
|
+
result.service = dbStep.service;
|
|
84
|
+
result.confidence = 70;
|
|
85
|
+
result.suggestions = [
|
|
86
|
+
'Verify query conditions are correct',
|
|
87
|
+
'Check if data exists in database',
|
|
88
|
+
'Review filter/criteria logic',
|
|
89
|
+
'Consider if empty result is expected behavior'
|
|
90
|
+
];
|
|
91
|
+
return result;
|
|
92
|
+
}
|
|
93
|
+
// Check for null/undefined returns
|
|
94
|
+
if (metadata?.result === null || metadata?.result === undefined) {
|
|
95
|
+
result.cause = 'Database operation returned null (silent failure)';
|
|
96
|
+
result.step = dbStep.name;
|
|
97
|
+
result.service = dbStep.service;
|
|
98
|
+
result.confidence = 75;
|
|
99
|
+
result.suggestions = [
|
|
100
|
+
'Check if document/record exists',
|
|
101
|
+
'Verify query syntax and collection name',
|
|
102
|
+
'Review connection pool status',
|
|
103
|
+
'Check database logs for warnings'
|
|
104
|
+
];
|
|
105
|
+
return result;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
// 3. Look for timed-out steps (highest priority)
|
|
28
109
|
const timedOut = steps.find(s => s.status === 'timeout');
|
|
29
110
|
if (timedOut) {
|
|
30
111
|
result.cause = `${timedOut.name} timed out`;
|
|
@@ -33,13 +114,13 @@ export function detectRootCause(steps, statusCode, config) {
|
|
|
33
114
|
result.confidence = 100;
|
|
34
115
|
result.suggestions = [
|
|
35
116
|
`Increase timeout for ${getServiceLabel(timedOut.service)} operations`,
|
|
36
|
-
|
|
117
|
+
'Check service health and load',
|
|
37
118
|
'Add retry logic with exponential backoff',
|
|
38
119
|
'Consider implementing circuit breaker pattern'
|
|
39
120
|
];
|
|
40
121
|
return result;
|
|
41
122
|
}
|
|
42
|
-
//
|
|
123
|
+
// 4. Analyze failed steps with detailed error detection
|
|
43
124
|
const failedSteps = steps.filter(s => s.status === 'error');
|
|
44
125
|
if (failedSteps.length > 0) {
|
|
45
126
|
const firstFailed = failedSteps[0];
|
|
@@ -155,7 +236,7 @@ export function detectRootCause(steps, statusCode, config) {
|
|
|
155
236
|
];
|
|
156
237
|
return result;
|
|
157
238
|
}
|
|
158
|
-
//
|
|
239
|
+
// 5. Analyze slow requests (performance degradation)
|
|
159
240
|
const slowSteps = steps.filter(s => s.duration > slowThreshold);
|
|
160
241
|
if (slowSteps.length > 0) {
|
|
161
242
|
// Find the slowest step
|
|
@@ -230,6 +311,23 @@ export function detectRootCause(steps, statusCode, config) {
|
|
|
230
311
|
}
|
|
231
312
|
return result;
|
|
232
313
|
}
|
|
314
|
+
// ✅ 6. PERFORMANCE DEGRADATION DETECTION (no specific slow step but overall slow)
|
|
315
|
+
const totalDuration = steps.reduce((sum, s) => sum + s.duration, 0);
|
|
316
|
+
const avgDuration = totalDuration / steps.length;
|
|
317
|
+
if (avgDuration > slowThreshold * 0.8) {
|
|
318
|
+
result.cause = `Overall performance degradation (avg: ${Math.round(avgDuration)}ms per step)`;
|
|
319
|
+
result.step = 'Multiple steps';
|
|
320
|
+
result.service = 'internal';
|
|
321
|
+
result.confidence = 60;
|
|
322
|
+
result.suggestions = [
|
|
323
|
+
'Review overall request flow',
|
|
324
|
+
'Check server resource utilization (CPU, memory)',
|
|
325
|
+
'Monitor database connection pool',
|
|
326
|
+
'Consider horizontal scaling',
|
|
327
|
+
'Implement caching strategy'
|
|
328
|
+
];
|
|
329
|
+
return result;
|
|
330
|
+
}
|
|
233
331
|
return null;
|
|
234
332
|
}
|
|
235
333
|
function getServiceLabel(service) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RootCause.js","sourceRoot":"","sources":["../../../src/core/RootCause.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,uCAAuC;AACvC,kEAAkE;AAClE,gEAAgE;AAyBhE
|
|
1
|
+
{"version":3,"file":"RootCause.js","sourceRoot":"","sources":["../../../src/core/RootCause.ts"],"names":[],"mappings":"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"}
|