@trigger.dev/core 4.0.2 → 4.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/dist/commonjs/v3/errors.d.ts +1 -0
  2. package/dist/commonjs/v3/errors.js +35 -2
  3. package/dist/commonjs/v3/errors.js.map +1 -1
  4. package/dist/commonjs/v3/heartbeats/api.d.ts +14 -0
  5. package/dist/commonjs/v3/heartbeats/api.js +58 -0
  6. package/dist/commonjs/v3/heartbeats/api.js.map +1 -0
  7. package/dist/commonjs/v3/heartbeats/manager.d.ts +16 -0
  8. package/dist/commonjs/v3/heartbeats/manager.js +72 -0
  9. package/dist/commonjs/v3/heartbeats/manager.js.map +1 -0
  10. package/dist/commonjs/v3/heartbeats/types.d.ts +7 -0
  11. package/dist/commonjs/v3/heartbeats/types.js +3 -0
  12. package/dist/commonjs/v3/heartbeats/types.js.map +1 -0
  13. package/dist/commonjs/v3/heartbeats-api.d.ts +3 -0
  14. package/dist/commonjs/v3/heartbeats-api.js +9 -0
  15. package/dist/commonjs/v3/heartbeats-api.js.map +1 -0
  16. package/dist/commonjs/v3/index.d.ts +1 -0
  17. package/dist/commonjs/v3/index.js +1 -0
  18. package/dist/commonjs/v3/index.js.map +1 -1
  19. package/dist/commonjs/v3/links.d.ts +1 -0
  20. package/dist/commonjs/v3/links.js +1 -0
  21. package/dist/commonjs/v3/links.js.map +1 -1
  22. package/dist/commonjs/v3/runEngineWorker/index.d.ts +1 -0
  23. package/dist/commonjs/v3/runEngineWorker/index.js +1 -0
  24. package/dist/commonjs/v3/runEngineWorker/index.js.map +1 -1
  25. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.d.ts +71 -0
  26. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.js +316 -0
  27. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.js.map +1 -0
  28. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.test.d.ts +1 -0
  29. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.test.js +589 -0
  30. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPool.test.js.map +1 -0
  31. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPoolMetrics.d.ts +43 -0
  32. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPoolMetrics.js +131 -0
  33. package/dist/commonjs/v3/runEngineWorker/supervisor/consumerPoolMetrics.js.map +1 -0
  34. package/dist/commonjs/v3/runEngineWorker/supervisor/queueConsumer.d.ts +7 -4
  35. package/dist/commonjs/v3/runEngineWorker/supervisor/queueConsumer.js.map +1 -1
  36. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.d.ts +76 -0
  37. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.js +161 -0
  38. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.js.map +1 -0
  39. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.d.ts +1 -0
  40. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.js +293 -0
  41. package/dist/commonjs/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.js.map +1 -0
  42. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.d.ts +67 -0
  43. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.js +153 -0
  44. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.js.map +1 -0
  45. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.test.d.ts +1 -0
  46. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.test.js +235 -0
  47. package/dist/commonjs/v3/runEngineWorker/supervisor/scalingStrategies.test.js.map +1 -0
  48. package/dist/commonjs/v3/runEngineWorker/supervisor/session.d.ts +5 -2
  49. package/dist/commonjs/v3/runEngineWorker/supervisor/session.js +14 -8
  50. package/dist/commonjs/v3/runEngineWorker/supervisor/session.js.map +1 -1
  51. package/dist/commonjs/v3/runEngineWorker/workload/http.d.ts +80 -111
  52. package/dist/commonjs/v3/runEngineWorker/workload/http.js +36 -14
  53. package/dist/commonjs/v3/runEngineWorker/workload/http.js.map +1 -1
  54. package/dist/commonjs/v3/schemas/api.d.ts +139 -0
  55. package/dist/commonjs/v3/schemas/api.js +11 -3
  56. package/dist/commonjs/v3/schemas/api.js.map +1 -1
  57. package/dist/commonjs/v3/utils/globals.d.ts +2 -0
  58. package/dist/commonjs/v3/utils/globals.js.map +1 -1
  59. package/dist/commonjs/v3/utils/ioSerialization.d.ts +1 -0
  60. package/dist/commonjs/v3/utils/ioSerialization.js +92 -3
  61. package/dist/commonjs/v3/utils/ioSerialization.js.map +1 -1
  62. package/dist/commonjs/v3/workers/index.d.ts +1 -0
  63. package/dist/commonjs/v3/workers/index.js +3 -1
  64. package/dist/commonjs/v3/workers/index.js.map +1 -1
  65. package/dist/commonjs/version.js +1 -1
  66. package/dist/esm/v3/errors.d.ts +1 -0
  67. package/dist/esm/v3/errors.js +34 -2
  68. package/dist/esm/v3/errors.js.map +1 -1
  69. package/dist/esm/v3/heartbeats/api.d.ts +14 -0
  70. package/dist/esm/v3/heartbeats/api.js +54 -0
  71. package/dist/esm/v3/heartbeats/api.js.map +1 -0
  72. package/dist/esm/v3/heartbeats/manager.d.ts +16 -0
  73. package/dist/esm/v3/heartbeats/manager.js +68 -0
  74. package/dist/esm/v3/heartbeats/manager.js.map +1 -0
  75. package/dist/esm/v3/heartbeats/types.d.ts +7 -0
  76. package/dist/esm/v3/heartbeats/types.js +2 -0
  77. package/dist/esm/v3/heartbeats/types.js.map +1 -0
  78. package/dist/esm/v3/heartbeats-api.d.ts +3 -0
  79. package/dist/esm/v3/heartbeats-api.js +6 -0
  80. package/dist/esm/v3/heartbeats-api.js.map +1 -0
  81. package/dist/esm/v3/index.d.ts +1 -0
  82. package/dist/esm/v3/index.js +1 -0
  83. package/dist/esm/v3/index.js.map +1 -1
  84. package/dist/esm/v3/links.d.ts +1 -0
  85. package/dist/esm/v3/links.js +1 -0
  86. package/dist/esm/v3/links.js.map +1 -1
  87. package/dist/esm/v3/runEngineWorker/index.d.ts +1 -0
  88. package/dist/esm/v3/runEngineWorker/index.js +1 -0
  89. package/dist/esm/v3/runEngineWorker/index.js.map +1 -1
  90. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.d.ts +71 -0
  91. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.js +312 -0
  92. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.js.map +1 -0
  93. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.test.d.ts +1 -0
  94. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.test.js +587 -0
  95. package/dist/esm/v3/runEngineWorker/supervisor/consumerPool.test.js.map +1 -0
  96. package/dist/esm/v3/runEngineWorker/supervisor/consumerPoolMetrics.d.ts +43 -0
  97. package/dist/esm/v3/runEngineWorker/supervisor/consumerPoolMetrics.js +127 -0
  98. package/dist/esm/v3/runEngineWorker/supervisor/consumerPoolMetrics.js.map +1 -0
  99. package/dist/esm/v3/runEngineWorker/supervisor/queueConsumer.d.ts +7 -4
  100. package/dist/esm/v3/runEngineWorker/supervisor/queueConsumer.js.map +1 -1
  101. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.d.ts +76 -0
  102. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.js +157 -0
  103. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.js.map +1 -0
  104. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.d.ts +1 -0
  105. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.js +291 -0
  106. package/dist/esm/v3/runEngineWorker/supervisor/queueMetricsProcessor.test.js.map +1 -0
  107. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.d.ts +67 -0
  108. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.js +146 -0
  109. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.js.map +1 -0
  110. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.test.d.ts +1 -0
  111. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.test.js +233 -0
  112. package/dist/esm/v3/runEngineWorker/supervisor/scalingStrategies.test.js.map +1 -0
  113. package/dist/esm/v3/runEngineWorker/supervisor/session.d.ts +5 -2
  114. package/dist/esm/v3/runEngineWorker/supervisor/session.js +14 -8
  115. package/dist/esm/v3/runEngineWorker/supervisor/session.js.map +1 -1
  116. package/dist/esm/v3/runEngineWorker/workload/http.d.ts +80 -111
  117. package/dist/esm/v3/runEngineWorker/workload/http.js +37 -15
  118. package/dist/esm/v3/runEngineWorker/workload/http.js.map +1 -1
  119. package/dist/esm/v3/schemas/api.d.ts +139 -0
  120. package/dist/esm/v3/schemas/api.js +8 -0
  121. package/dist/esm/v3/schemas/api.js.map +1 -1
  122. package/dist/esm/v3/utils/globals.d.ts +2 -0
  123. package/dist/esm/v3/utils/globals.js.map +1 -1
  124. package/dist/esm/v3/utils/ioSerialization.d.ts +1 -0
  125. package/dist/esm/v3/utils/ioSerialization.js +92 -3
  126. package/dist/esm/v3/utils/ioSerialization.js.map +1 -1
  127. package/dist/esm/v3/workers/index.d.ts +1 -0
  128. package/dist/esm/v3/workers/index.js +1 -0
  129. package/dist/esm/v3/workers/index.js.map +1 -1
  130. package/dist/esm/version.js +1 -1
  131. package/package.json +1 -1
@@ -0,0 +1,127 @@
1
+ import { Counter, Gauge, Registry } from "prom-client";
2
+ export class ConsumerPoolMetrics {
3
+ register;
4
+ prefix;
5
+ // Current state metrics
6
+ consumerCount;
7
+ queueLength;
8
+ smoothedQueueLength;
9
+ targetConsumerCount;
10
+ scalingStrategy;
11
+ // Scaling operation metrics
12
+ scalingOperationsTotal;
13
+ consumersAddedTotal;
14
+ consumersRemovedTotal;
15
+ scalingCooldownsApplied;
16
+ // Performance metrics
17
+ queueLengthUpdatesTotal;
18
+ batchesProcessedTotal;
19
+ constructor(opts = {}) {
20
+ this.register = opts.register ?? new Registry();
21
+ this.prefix = opts.prefix ?? "queue_consumer_pool";
22
+ // Current state metrics
23
+ this.consumerCount = new Gauge({
24
+ name: `${this.prefix}_consumer_count`,
25
+ help: "Current number of active queue consumers",
26
+ labelNames: ["strategy"],
27
+ registers: [this.register],
28
+ });
29
+ this.queueLength = new Gauge({
30
+ name: `${this.prefix}_queue_length`,
31
+ help: "Current queue length (median of recent samples)",
32
+ registers: [this.register],
33
+ });
34
+ this.smoothedQueueLength = new Gauge({
35
+ name: `${this.prefix}_smoothed_queue_length`,
36
+ help: "EWMA smoothed queue length",
37
+ registers: [this.register],
38
+ });
39
+ this.targetConsumerCount = new Gauge({
40
+ name: `${this.prefix}_target_consumer_count`,
41
+ help: "Target number of consumers calculated by scaling strategy",
42
+ labelNames: ["strategy"],
43
+ registers: [this.register],
44
+ });
45
+ this.scalingStrategy = new Gauge({
46
+ name: `${this.prefix}_scaling_strategy_info`,
47
+ help: "Information about the active scaling strategy (1 = active, 0 = inactive)",
48
+ labelNames: ["strategy"],
49
+ registers: [this.register],
50
+ });
51
+ // Scaling operation metrics
52
+ this.scalingOperationsTotal = new Counter({
53
+ name: `${this.prefix}_scaling_operations_total`,
54
+ help: "Total number of scaling operations performed",
55
+ labelNames: ["direction", "strategy"],
56
+ registers: [this.register],
57
+ });
58
+ this.consumersAddedTotal = new Counter({
59
+ name: `${this.prefix}_consumers_added_total`,
60
+ help: "Total number of consumers added",
61
+ registers: [this.register],
62
+ });
63
+ this.consumersRemovedTotal = new Counter({
64
+ name: `${this.prefix}_consumers_removed_total`,
65
+ help: "Total number of consumers removed",
66
+ registers: [this.register],
67
+ });
68
+ this.scalingCooldownsApplied = new Counter({
69
+ name: `${this.prefix}_scaling_cooldowns_applied_total`,
70
+ help: "Number of times scaling was prevented due to cooldown",
71
+ labelNames: ["direction"],
72
+ registers: [this.register],
73
+ });
74
+ this.queueLengthUpdatesTotal = new Counter({
75
+ name: `${this.prefix}_queue_length_updates_total`,
76
+ help: "Total number of queue length updates received",
77
+ registers: [this.register],
78
+ });
79
+ this.batchesProcessedTotal = new Counter({
80
+ name: `${this.prefix}_batches_processed_total`,
81
+ help: "Total number of metric batches processed",
82
+ registers: [this.register],
83
+ });
84
+ }
85
+ /**
86
+ * Update all gauge metrics with current state
87
+ */
88
+ updateState(state) {
89
+ this.consumerCount.set({ strategy: state.strategy }, state.consumerCount);
90
+ if (state.queueLength !== undefined) {
91
+ this.queueLength.set(state.queueLength);
92
+ }
93
+ this.smoothedQueueLength.set(state.smoothedQueueLength);
94
+ this.targetConsumerCount.set({ strategy: state.strategy }, state.targetConsumerCount);
95
+ // Set strategy info (1 for active strategy, 0 for others)
96
+ ["none", "smooth", "aggressive"].forEach((s) => {
97
+ this.scalingStrategy.set({ strategy: s }, s === state.strategy ? 1 : 0);
98
+ });
99
+ }
100
+ /**
101
+ * Record a scaling operation
102
+ */
103
+ recordScalingOperation(direction, strategy, count) {
104
+ if (direction !== "none") {
105
+ this.scalingOperationsTotal.inc({ direction, strategy });
106
+ if (direction === "up") {
107
+ this.consumersAddedTotal.inc(count);
108
+ }
109
+ else {
110
+ this.consumersRemovedTotal.inc(count);
111
+ }
112
+ }
113
+ }
114
+ /**
115
+ * Record that scaling was prevented by cooldown
116
+ */
117
+ recordCooldownApplied(direction) {
118
+ this.scalingCooldownsApplied.inc({ direction });
119
+ }
120
+ /**
121
+ * Record a queue length update
122
+ */
123
+ recordQueueLengthUpdate() {
124
+ this.queueLengthUpdatesTotal.inc();
125
+ }
126
+ }
127
+ //# sourceMappingURL=consumerPoolMetrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consumerPoolMetrics.js","sourceRoot":"","sources":["../../../../../src/v3/runEngineWorker/supervisor/consumerPoolMetrics.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,11 @@
1
1
  import { SupervisorHttpClient } from "./http.js";
2
2
  import { WorkerApiDequeueResponseBody } from "./schemas.js";
3
3
  import { PreDequeueFn, PreSkipFn } from "./types.js";
4
- type RunQueueConsumerOptions = {
4
+ export interface QueueConsumer {
5
+ start(): void;
6
+ stop(): void;
7
+ }
8
+ export type RunQueueConsumerOptions = {
5
9
  client: SupervisorHttpClient;
6
10
  intervalMs: number;
7
11
  idleIntervalMs: number;
@@ -10,7 +14,7 @@ type RunQueueConsumerOptions = {
10
14
  maxRunCount?: number;
11
15
  onDequeue: (messages: WorkerApiDequeueResponseBody) => Promise<void>;
12
16
  };
13
- export declare class RunQueueConsumer {
17
+ export declare class RunQueueConsumer implements QueueConsumer {
14
18
  private readonly client;
15
19
  private readonly preDequeue?;
16
20
  private readonly preSkip?;
@@ -24,6 +28,5 @@ export declare class RunQueueConsumer {
24
28
  start(): void;
25
29
  stop(): void;
26
30
  private dequeue;
27
- scheduleNextDequeue(delayMs: number): void;
31
+ private scheduleNextDequeue;
28
32
  }
29
- export {};
@@ -1 +1 @@
1
- {"version":3,"file":"queueConsumer.js","sourceRoot":"","sources":["../../../../../src/v3/runEngineWorker/supervisor/queueConsumer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"queueConsumer.js","sourceRoot":"","sources":["../../../../../src/v3/runEngineWorker/supervisor/queueConsumer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,76 @@
1
+ export interface QueueMetricsProcessorOptions {
2
+ /**
3
+ * EWMA smoothing factor (0-1)
4
+ * Lower values = more smoothing, less reactive
5
+ * Higher values = more responsive to recent changes
6
+ */
7
+ ewmaAlpha: number;
8
+ /**
9
+ * Batch window duration in milliseconds
10
+ * Samples within this window are collected and processed together
11
+ */
12
+ batchWindowMs: number;
13
+ }
14
+ export interface BatchProcessingResult {
15
+ /** Median of samples in the batch */
16
+ median: number;
17
+ /** EWMA-smoothed value after processing this batch */
18
+ smoothedValue: number;
19
+ /** Number of samples processed in this batch */
20
+ sampleCount: number;
21
+ /** Raw samples that were processed */
22
+ samples: readonly number[];
23
+ }
24
+ /**
25
+ * Processes queue length samples using exponential weighted moving average (EWMA)
26
+ * for smoothing and median filtering for outlier resistance.
27
+ *
28
+ * Collects samples within a batch window, calculates median to filter outliers,
29
+ * then applies EWMA smoothing for stable trend tracking.
30
+ */
31
+ export declare class QueueMetricsProcessor {
32
+ private readonly ewmaAlpha;
33
+ private readonly batchWindowMs;
34
+ private readonly logger;
35
+ private samples;
36
+ private smoothedValue;
37
+ private lastBatchTime;
38
+ private isInitialized;
39
+ constructor(options: QueueMetricsProcessorOptions);
40
+ /**
41
+ * Adds a sample to the current batch
42
+ */
43
+ addSample(value: number, timestamp?: number): void;
44
+ /**
45
+ * Checks if enough time has passed to process the current batch
46
+ */
47
+ shouldProcessBatch(currentTime?: number): boolean;
48
+ private calculateMedian;
49
+ /**
50
+ * Processes the current batch of samples and returns the result.
51
+ * Clears the samples array and updates the smoothed value.
52
+ *
53
+ * Returns null if there are no samples to process.
54
+ */
55
+ processBatch(currentTime?: number): BatchProcessingResult | null;
56
+ /**
57
+ * Gets the current smoothed value without processing a batch
58
+ */
59
+ getSmoothedValue(): number;
60
+ /**
61
+ * Gets the number of samples in the current batch
62
+ */
63
+ getCurrentSampleCount(): number;
64
+ /**
65
+ * Gets the current samples (for testing/debugging)
66
+ */
67
+ getCurrentSamples(): readonly number[];
68
+ /**
69
+ * Resets the processor state
70
+ */
71
+ reset(): void;
72
+ /**
73
+ * Gets processor configuration
74
+ */
75
+ getConfig(): Readonly<QueueMetricsProcessorOptions>;
76
+ }
@@ -0,0 +1,157 @@
1
+ import { SimpleStructuredLogger } from "../../utils/structuredLogger.js";
2
+ /**
3
+ * Processes queue length samples using exponential weighted moving average (EWMA)
4
+ * for smoothing and median filtering for outlier resistance.
5
+ *
6
+ * Collects samples within a batch window, calculates median to filter outliers,
7
+ * then applies EWMA smoothing for stable trend tracking.
8
+ */
9
+ export class QueueMetricsProcessor {
10
+ ewmaAlpha;
11
+ batchWindowMs;
12
+ logger = new SimpleStructuredLogger("queue-metrics-processor");
13
+ samples = [];
14
+ smoothedValue = 0;
15
+ lastBatchTime = 0;
16
+ isInitialized = false;
17
+ constructor(options) {
18
+ if (options.ewmaAlpha < 0 || options.ewmaAlpha > 1) {
19
+ throw new Error("ewmaAlpha must be between 0 and 1");
20
+ }
21
+ if (options.batchWindowMs <= 0) {
22
+ throw new Error("batchWindowMs must be positive");
23
+ }
24
+ this.ewmaAlpha = options.ewmaAlpha;
25
+ this.batchWindowMs = options.batchWindowMs;
26
+ }
27
+ /**
28
+ * Adds a sample to the current batch
29
+ */
30
+ addSample(value, timestamp = Date.now()) {
31
+ if (value < 0) {
32
+ throw new Error("Queue length cannot be negative");
33
+ }
34
+ this.samples.push(value);
35
+ // Update last batch time on first sample
36
+ if (this.samples.length === 1) {
37
+ this.lastBatchTime = timestamp;
38
+ }
39
+ }
40
+ /**
41
+ * Checks if enough time has passed to process the current batch
42
+ */
43
+ shouldProcessBatch(currentTime = Date.now()) {
44
+ if (this.samples.length === 0) {
45
+ return false;
46
+ }
47
+ return currentTime - this.lastBatchTime >= this.batchWindowMs;
48
+ }
49
+ calculateMedian(samples) {
50
+ const sortedSamples = [...samples].sort((a, b) => a - b);
51
+ const mid = Math.floor(sortedSamples.length / 2);
52
+ if (sortedSamples.length % 2 === 1) {
53
+ // Odd length: use middle value
54
+ const median = sortedSamples[mid];
55
+ if (median === undefined) {
56
+ this.logger.error("Invalid median calculated from odd samples", {
57
+ sortedSamples,
58
+ mid,
59
+ median,
60
+ });
61
+ return null;
62
+ }
63
+ return median;
64
+ }
65
+ else {
66
+ // Even length: average two middle values
67
+ const lowMid = sortedSamples[mid - 1];
68
+ const highMid = sortedSamples[mid];
69
+ if (lowMid === undefined || highMid === undefined) {
70
+ this.logger.error("Invalid median calculated from even samples", {
71
+ sortedSamples,
72
+ mid,
73
+ lowMid,
74
+ highMid,
75
+ });
76
+ return null;
77
+ }
78
+ const median = (lowMid + highMid) / 2;
79
+ return median;
80
+ }
81
+ }
82
+ /**
83
+ * Processes the current batch of samples and returns the result.
84
+ * Clears the samples array and updates the smoothed value.
85
+ *
86
+ * Returns null if there are no samples to process.
87
+ */
88
+ processBatch(currentTime = Date.now()) {
89
+ if (this.samples.length === 0) {
90
+ // No samples to process
91
+ return null;
92
+ }
93
+ // Calculate median of samples to filter outliers
94
+ const median = this.calculateMedian(this.samples);
95
+ if (median === null) {
96
+ // We already logged a more specific error message
97
+ return null;
98
+ }
99
+ // Update EWMA smoothed value
100
+ if (!this.isInitialized) {
101
+ // First value - initialize with median
102
+ this.smoothedValue = median;
103
+ this.isInitialized = true;
104
+ }
105
+ else {
106
+ // Apply EWMA: s_t = α * x_t + (1 - α) * s_(t-1)
107
+ this.smoothedValue = this.ewmaAlpha * median + (1 - this.ewmaAlpha) * this.smoothedValue;
108
+ }
109
+ const result = {
110
+ median,
111
+ smoothedValue: this.smoothedValue,
112
+ sampleCount: this.samples.length,
113
+ samples: Object.freeze([...this.samples]),
114
+ };
115
+ // Clear samples for next batch
116
+ this.samples = [];
117
+ this.lastBatchTime = currentTime;
118
+ return result;
119
+ }
120
+ /**
121
+ * Gets the current smoothed value without processing a batch
122
+ */
123
+ getSmoothedValue() {
124
+ return this.smoothedValue;
125
+ }
126
+ /**
127
+ * Gets the number of samples in the current batch
128
+ */
129
+ getCurrentSampleCount() {
130
+ return this.samples.length;
131
+ }
132
+ /**
133
+ * Gets the current samples (for testing/debugging)
134
+ */
135
+ getCurrentSamples() {
136
+ return Object.freeze([...this.samples]);
137
+ }
138
+ /**
139
+ * Resets the processor state
140
+ */
141
+ reset() {
142
+ this.samples = [];
143
+ this.smoothedValue = 0;
144
+ this.lastBatchTime = 0;
145
+ this.isInitialized = false;
146
+ }
147
+ /**
148
+ * Gets processor configuration
149
+ */
150
+ getConfig() {
151
+ return {
152
+ ewmaAlpha: this.ewmaAlpha,
153
+ batchWindowMs: this.batchWindowMs,
154
+ };
155
+ }
156
+ }
157
+ //# sourceMappingURL=queueMetricsProcessor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queueMetricsProcessor.js","sourceRoot":"","sources":["../../../../../src/v3/runEngineWorker/supervisor/queueMetricsProcessor.ts"],"names":[],"mappings":"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"}