@eldrforge/kodrdriv 1.2.24 → 1.2.26
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/MONOREPO-PUBLISH-IMPROVEMENTS.md +281 -0
- package/SUBMODULE-LOCK-FIX.md +132 -0
- package/dist/commands/tree.js +151 -45
- package/dist/commands/tree.js.map +1 -1
- package/dist/constants.js +1 -1
- package/dist/execution/DynamicTaskPool.js +112 -16
- package/dist/execution/DynamicTaskPool.js.map +1 -1
- package/dist/execution/RecoveryManager.js +6 -2
- package/dist/execution/RecoveryManager.js.map +1 -1
- package/dist/execution/TreeExecutionAdapter.js +45 -10
- package/dist/execution/TreeExecutionAdapter.js.map +1 -1
- package/dist/ui/ProgressFormatter.js +22 -2
- package/dist/ui/ProgressFormatter.js.map +1 -1
- package/dist/util/fileLock.js +40 -3
- package/dist/util/fileLock.js.map +1 -1
- package/package.json +1 -1
package/dist/constants.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import os__default from 'os';
|
|
2
2
|
import path__default from 'path';
|
|
3
3
|
|
|
4
|
-
const VERSION = '1.2.
|
|
4
|
+
const VERSION = '1.2.26 (HEAD/3f9cfd0 T:v1.2.26 2025-12-11 23:20:38 -0800) linux x64 v22.21.1';
|
|
5
5
|
const PROGRAM_NAME = 'kodrdriv';
|
|
6
6
|
const DEFAULT_OVERRIDES = false;
|
|
7
7
|
const DATE_FORMAT_YEAR_MONTH_DAY_HOURS_MINUTES_SECONDS_MILLISECONDS = 'YYYY-MM-DD-HHmmss.SSS';
|
|
@@ -65,7 +65,8 @@ function _define_property(obj, key, value) {
|
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
67
|
// Final checkpoint and cleanup
|
|
68
|
-
// Only cleanup if everything completed (no failures, no skipped packages)
|
|
68
|
+
// Only cleanup if everything completed (no failures, no skipped packages due to dependencies)
|
|
69
|
+
// Note: skippedNoChanges is OK - those packages successfully ran but had nothing to do
|
|
69
70
|
const allCompleted = this.state.failed.length === 0 && this.state.skipped.length === 0;
|
|
70
71
|
if (allCompleted) {
|
|
71
72
|
await this.checkpointManager.cleanup();
|
|
@@ -96,7 +97,8 @@ function _define_property(obj, key, value) {
|
|
|
96
97
|
running: [],
|
|
97
98
|
completed: [],
|
|
98
99
|
failed: [],
|
|
99
|
-
skipped: []
|
|
100
|
+
skipped: [],
|
|
101
|
+
skippedNoChanges: []
|
|
100
102
|
};
|
|
101
103
|
}
|
|
102
104
|
/**
|
|
@@ -179,20 +181,31 @@ function _define_property(obj, key, value) {
|
|
|
179
181
|
/**
|
|
180
182
|
* Handle successful package completion
|
|
181
183
|
*/ async handleSuccess(packageName, result) {
|
|
182
|
-
this
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
packageName
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
if (result.publishedVersion) {
|
|
191
|
-
this.publishedVersions.push({
|
|
192
|
-
name: packageName,
|
|
193
|
-
version: result.publishedVersion,
|
|
194
|
-
time: new Date()
|
|
184
|
+
// Check if this was skipped due to no changes
|
|
185
|
+
if (result.skippedNoChanges) {
|
|
186
|
+
this.state.skippedNoChanges.push(packageName);
|
|
187
|
+
const duration = this.packageDurations.get(packageName);
|
|
188
|
+
this.logger.info(`⊘ ${packageName} skipped - no code changes (${this.formatDuration(duration)})`);
|
|
189
|
+
this.emit('package:skipped-no-changes', {
|
|
190
|
+
packageName,
|
|
191
|
+
result
|
|
195
192
|
});
|
|
193
|
+
} else {
|
|
194
|
+
this.state.completed.push(packageName);
|
|
195
|
+
const duration = this.packageDurations.get(packageName);
|
|
196
|
+
this.logger.info(`✓ ${packageName} completed successfully (${this.formatDuration(duration)})`);
|
|
197
|
+
this.emit('package:completed', {
|
|
198
|
+
packageName,
|
|
199
|
+
result
|
|
200
|
+
});
|
|
201
|
+
// Track published version if applicable
|
|
202
|
+
if (result.publishedVersion) {
|
|
203
|
+
this.publishedVersions.push({
|
|
204
|
+
name: packageName,
|
|
205
|
+
version: result.publishedVersion,
|
|
206
|
+
time: new Date()
|
|
207
|
+
});
|
|
208
|
+
}
|
|
196
209
|
}
|
|
197
210
|
}
|
|
198
211
|
/**
|
|
@@ -218,6 +231,8 @@ function _define_property(obj, key, value) {
|
|
|
218
231
|
// Permanent failure
|
|
219
232
|
const dependencies = Array.from(this.graph.edges.get(packageName) || []);
|
|
220
233
|
const dependents = Array.from(findAllDependents(packageName, this.graph));
|
|
234
|
+
// Extract detailed error information
|
|
235
|
+
const errorDetails = this.extractErrorDetails(error, packageName);
|
|
221
236
|
const failureInfo = {
|
|
222
237
|
name: packageName,
|
|
223
238
|
error: error.message,
|
|
@@ -226,7 +241,8 @@ function _define_property(obj, key, value) {
|
|
|
226
241
|
attemptNumber,
|
|
227
242
|
failedAt: new Date().toISOString(),
|
|
228
243
|
dependencies,
|
|
229
|
-
dependents
|
|
244
|
+
dependents,
|
|
245
|
+
errorDetails
|
|
230
246
|
};
|
|
231
247
|
this.state.failed.push(failureInfo);
|
|
232
248
|
this.logger.error(`✗ ${packageName} failed permanently: ${error.message}`);
|
|
@@ -395,6 +411,7 @@ function _define_property(obj, key, value) {
|
|
|
395
411
|
completed: this.state.completed,
|
|
396
412
|
failed: this.state.failed,
|
|
397
413
|
skipped: this.state.skipped,
|
|
414
|
+
skippedNoChanges: this.state.skippedNoChanges,
|
|
398
415
|
metrics
|
|
399
416
|
};
|
|
400
417
|
}
|
|
@@ -434,6 +451,85 @@ function _define_property(obj, key, value) {
|
|
|
434
451
|
}
|
|
435
452
|
return `${seconds}s`;
|
|
436
453
|
}
|
|
454
|
+
/**
|
|
455
|
+
* Extract detailed error information from error message and stack
|
|
456
|
+
*/ extractErrorDetails(error, packageName) {
|
|
457
|
+
const errorMsg = error.message || '';
|
|
458
|
+
const errorStack = error.stack || '';
|
|
459
|
+
const fullText = `${errorMsg}\n${errorStack}`;
|
|
460
|
+
// Test coverage failure
|
|
461
|
+
if (fullText.match(/coverage.*below.*threshold|coverage.*insufficient/i)) {
|
|
462
|
+
const coverageMatch = fullText.match(/(\w+):\s*(\d+\.?\d*)%.*threshold:\s*(\d+\.?\d*)%/i);
|
|
463
|
+
return {
|
|
464
|
+
type: 'test_coverage',
|
|
465
|
+
context: coverageMatch ? `${coverageMatch[1]}: ${coverageMatch[2]}% (threshold: ${coverageMatch[3]}%)` : 'Coverage below threshold',
|
|
466
|
+
logFile: this.getLogFilePath(packageName),
|
|
467
|
+
suggestion: `cd ${this.getPackagePath(packageName)} && npm test -- --coverage`
|
|
468
|
+
};
|
|
469
|
+
}
|
|
470
|
+
// Build/compile errors
|
|
471
|
+
if (fullText.match(/compilation.*failed|build.*failed|tsc.*error/i)) {
|
|
472
|
+
return {
|
|
473
|
+
type: 'build_error',
|
|
474
|
+
context: this.extractFirstErrorLine(fullText),
|
|
475
|
+
logFile: this.getLogFilePath(packageName),
|
|
476
|
+
suggestion: `cd ${this.getPackagePath(packageName)} && npm run build`
|
|
477
|
+
};
|
|
478
|
+
}
|
|
479
|
+
// Merge conflicts
|
|
480
|
+
if (fullText.match(/merge.*conflict|conflict.*marker|<<<<<<<|>>>>>>>/i)) {
|
|
481
|
+
return {
|
|
482
|
+
type: 'merge_conflict',
|
|
483
|
+
context: 'Unresolved merge conflicts detected',
|
|
484
|
+
logFile: this.getLogFilePath(packageName),
|
|
485
|
+
suggestion: `cd ${this.getPackagePath(packageName)} && git status`
|
|
486
|
+
};
|
|
487
|
+
}
|
|
488
|
+
// Test failures
|
|
489
|
+
if (fullText.match(/test.*failed|tests.*failed|\d+\s+failing/i)) {
|
|
490
|
+
const failMatch = fullText.match(/(\d+)\s+failing/i);
|
|
491
|
+
return {
|
|
492
|
+
type: 'test_failure',
|
|
493
|
+
context: failMatch ? `${failMatch[1]} test(s) failing` : 'Tests failed',
|
|
494
|
+
logFile: this.getLogFilePath(packageName),
|
|
495
|
+
suggestion: `cd ${this.getPackagePath(packageName)} && npm test`
|
|
496
|
+
};
|
|
497
|
+
}
|
|
498
|
+
// Timeout errors
|
|
499
|
+
if (fullText.match(/timeout|timed.*out/i)) {
|
|
500
|
+
return {
|
|
501
|
+
type: 'timeout',
|
|
502
|
+
context: this.extractFirstErrorLine(fullText),
|
|
503
|
+
logFile: this.getLogFilePath(packageName),
|
|
504
|
+
suggestion: 'Consider increasing timeout or checking for stuck processes'
|
|
505
|
+
};
|
|
506
|
+
}
|
|
507
|
+
// Generic error with log file
|
|
508
|
+
return {
|
|
509
|
+
type: 'unknown',
|
|
510
|
+
context: errorMsg.split('\n')[0].substring(0, 200),
|
|
511
|
+
logFile: this.getLogFilePath(packageName)
|
|
512
|
+
};
|
|
513
|
+
}
|
|
514
|
+
extractFirstErrorLine(text) {
|
|
515
|
+
const lines = text.split('\n');
|
|
516
|
+
for (const line of lines){
|
|
517
|
+
if (line.match(/error|failed|exception/i) && line.trim().length > 10) {
|
|
518
|
+
return line.trim().substring(0, 200);
|
|
519
|
+
}
|
|
520
|
+
}
|
|
521
|
+
return text.split('\n')[0].substring(0, 200);
|
|
522
|
+
}
|
|
523
|
+
getPackagePath(packageName) {
|
|
524
|
+
const pkgInfo = this.graph.packages.get(packageName);
|
|
525
|
+
return (pkgInfo === null || pkgInfo === void 0 ? void 0 : pkgInfo.path) || '.';
|
|
526
|
+
}
|
|
527
|
+
getLogFilePath(packageName) {
|
|
528
|
+
const pkgPath = this.getPackagePath(packageName);
|
|
529
|
+
const outputDir = this.config.config.outputDirectory || 'output/kodrdriv';
|
|
530
|
+
// Try to find the most recent log file
|
|
531
|
+
return `${pkgPath}/${outputDir}/publish_*.log`;
|
|
532
|
+
}
|
|
437
533
|
constructor(config){
|
|
438
534
|
super(), _define_property(this, "config", void 0), _define_property(this, "graph", void 0), _define_property(this, "state", void 0), _define_property(this, "dependencyChecker", void 0), _define_property(this, "resourceMonitor", void 0), _define_property(this, "scheduler", void 0), _define_property(this, "checkpointManager", void 0), _define_property(this, "logger", getLogger()), // Execution tracking
|
|
439
535
|
_define_property(this, "executionId", void 0), _define_property(this, "startTime", void 0), _define_property(this, "runningTasks", new Map()), _define_property(this, "packageStartTimes", new Map()), _define_property(this, "packageEndTimes", new Map()), _define_property(this, "packageDurations", new Map()), _define_property(this, "retryAttempts", new Map()), _define_property(this, "publishedVersions", []);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicTaskPool.js","sources":["../../src/execution/DynamicTaskPool.ts"],"sourcesContent":["import { EventEmitter } from 'events';\nimport { randomUUID } from 'crypto';\nimport { getLogger } from '../logging';\nimport { Config } from '../types';\nimport {\n DependencyGraph,\n findAllDependents\n} from '../util/dependencyGraph';\nimport {\n ParallelExecutionCheckpoint,\n ExecutionState,\n ExecutionResult,\n PackageResult,\n ExecutionMetrics,\n FailedPackageSnapshot\n} from '../types/parallelExecution';\nimport { CheckpointManager } from '../util/checkpointManager';\nimport { DependencyChecker } from './DependencyChecker';\nimport { ResourceMonitor } from './ResourceMonitor';\nimport { Scheduler } from './Scheduler';\n\nexport interface PoolConfig {\n graph: DependencyGraph;\n maxConcurrency: number;\n command: string;\n config: Config;\n checkpointPath?: string;\n continue?: boolean;\n maxRetries?: number;\n initialRetryDelay?: number;\n maxRetryDelay?: number;\n backoffMultiplier?: number;\n}\n\ninterface CompletedTask {\n packageName: string;\n result: PackageResult | null;\n error: Error | null;\n}\n\ninterface RunningTask {\n packageName: string;\n startTime: Date;\n promise: Promise<PackageResult>;\n controller: AbortController;\n}\n\n/**\n * DynamicTaskPool manages parallel execution of packages with dependency awareness\n */\nexport class DynamicTaskPool extends EventEmitter {\n private config: PoolConfig;\n private graph: DependencyGraph;\n private state: ExecutionState;\n private dependencyChecker: DependencyChecker;\n private resourceMonitor: ResourceMonitor;\n private scheduler: Scheduler;\n private checkpointManager: CheckpointManager;\n private logger = getLogger();\n\n // Execution tracking\n private executionId: string;\n private startTime: Date;\n private runningTasks = new Map<string, RunningTask>();\n private packageStartTimes = new Map<string, Date>();\n private packageEndTimes = new Map<string, Date>();\n private packageDurations = new Map<string, number>();\n private retryAttempts = new Map<string, number>();\n private publishedVersions: Array<{name: string, version: string, time: Date}> = [];\n\n constructor(config: PoolConfig) {\n super();\n this.config = config;\n this.graph = config.graph;\n this.executionId = randomUUID();\n this.startTime = new Date();\n\n // Initialize components\n this.dependencyChecker = new DependencyChecker(this.graph);\n this.resourceMonitor = new ResourceMonitor(config.maxConcurrency);\n this.scheduler = new Scheduler(this.graph, this.dependencyChecker);\n this.checkpointManager = new CheckpointManager(\n config.checkpointPath || process.cwd()\n );\n\n // Initialize state\n this.state = this.initializeState();\n }\n\n /**\n * Main execution entry point\n */\n async execute(): Promise<ExecutionResult> {\n this.logger.info(`Starting parallel execution with max concurrency: ${this.config.maxConcurrency}`);\n this.emit('execution:started', { totalPackages: this.graph.packages.size });\n\n try {\n // Load checkpoint if continuing\n if (this.config.continue) {\n await this.loadCheckpoint();\n }\n\n // Initialize ready queue\n this.updateReadyQueue();\n\n // Main execution loop\n while (!this.isComplete()) {\n // Schedule as many packages as we can\n const availableSlots = this.resourceMonitor.getAvailableSlots();\n if (availableSlots > 0 && this.state.ready.length > 0) {\n const toSchedule = this.scheduler.getNext(availableSlots, this.state);\n\n for (const packageName of toSchedule) {\n await this.schedulePackage(packageName);\n }\n }\n\n // Check if we're stuck\n if (this.runningTasks.size === 0) {\n if (this.state.ready.length > 0) {\n throw new Error('Deadlock detected: packages ready but cannot execute');\n }\n break; // No more work to do\n }\n\n // Wait for next package to complete\n const completedTask = await this.waitForNext();\n await this.handleTaskCompletion(completedTask);\n\n // Update ready queue\n this.updateReadyQueue();\n\n // Save checkpoint periodically\n if (this.shouldCheckpoint()) {\n await this.saveCheckpoint();\n }\n }\n\n // Final checkpoint and cleanup\n // Only cleanup if everything completed (no failures, no skipped packages)\n const allCompleted = this.state.failed.length === 0 && this.state.skipped.length === 0;\n if (allCompleted) {\n await this.checkpointManager.cleanup();\n } else {\n await this.saveCheckpoint();\n }\n\n // Build and return result\n const result = this.buildExecutionResult();\n this.emit('execution:completed', { result });\n\n return result;\n } catch (error) {\n // Save checkpoint on error\n await this.saveCheckpoint();\n throw error;\n }\n }\n\n /**\n * Initialize execution state\n */\n private initializeState(): ExecutionState {\n const buildOrder = Array.from(this.graph.packages.keys());\n\n return {\n pending: [...buildOrder],\n ready: [],\n running: [],\n completed: [],\n failed: [],\n skipped: []\n };\n }\n\n /**\n * Schedule a package for execution\n */\n private async schedulePackage(packageName: string): Promise<void> {\n // Move from ready to running\n this.state.ready = this.state.ready.filter(p => p !== packageName);\n\n // Allocate resource\n if (!this.resourceMonitor.allocate()) {\n throw new Error(`Failed to allocate resource for ${packageName}`);\n }\n\n // Record start time\n this.packageStartTimes.set(packageName, new Date());\n\n // Create abort controller\n const controller = new AbortController();\n\n // Start execution\n const promise = this.executePackage(packageName, controller.signal);\n\n // Track running task\n const task: RunningTask = {\n packageName,\n startTime: new Date(),\n promise,\n controller\n };\n\n this.runningTasks.set(packageName, task);\n\n // Update state\n this.state.running.push({\n name: packageName,\n startTime: task.startTime.toISOString(),\n elapsedTime: 0\n });\n\n // Emit event\n this.emit('package:started', { packageName });\n\n this.logger.verbose(\n `Scheduled ${packageName} (${this.runningTasks.size}/${this.config.maxConcurrency} slots used)`\n );\n }\n\n /**\n * Execute a single package (placeholder - will be overridden or use callback)\n */\n private async executePackage(\n _packageName: string,\n _signal: AbortSignal\n ): Promise<PackageResult> {\n // This is a placeholder that will be replaced with actual execution logic\n // In the real implementation, this would call the tree.ts executePackage function\n throw new Error('executePackage must be implemented');\n }\n\n /**\n * Wait for next task to complete\n */\n private async waitForNext(): Promise<CompletedTask> {\n const runningTasks = Array.from(this.runningTasks.entries());\n\n const promises = runningTasks.map(([name, task]) =>\n task.promise\n .then(result => ({ packageName: name, result, error: null }))\n .catch(error => ({ packageName: name, result: null, error }))\n );\n\n return await Promise.race(promises);\n }\n\n /**\n * Handle task completion\n */\n private async handleTaskCompletion(task: CompletedTask): Promise<void> {\n const { packageName, result, error } = task;\n\n // Remove from running\n this.runningTasks.delete(packageName);\n this.state.running = this.state.running.filter(r => r.name !== packageName);\n this.resourceMonitor.release();\n\n // Record timing\n const endTime = new Date();\n this.packageEndTimes.set(packageName, endTime);\n\n const startTime = this.packageStartTimes.get(packageName)!;\n const duration = endTime.getTime() - startTime.getTime();\n this.packageDurations.set(packageName, duration);\n\n if (error) {\n await this.handleFailure(packageName, error);\n } else {\n await this.handleSuccess(packageName, result!);\n }\n }\n\n /**\n * Handle successful package completion\n */\n private async handleSuccess(packageName: string, result: PackageResult): Promise<void> {\n this.state.completed.push(packageName);\n\n const duration = this.packageDurations.get(packageName)!;\n this.logger.info(`✓ ${packageName} completed successfully (${this.formatDuration(duration)})`);\n\n this.emit('package:completed', { packageName, result });\n\n // Track published version if applicable\n if (result.publishedVersion) {\n this.publishedVersions.push({\n name: packageName,\n version: result.publishedVersion,\n time: new Date()\n });\n }\n }\n\n /**\n * Handle package failure\n */\n private async handleFailure(packageName: string, error: Error): Promise<void> {\n const attemptNumber = (this.retryAttempts.get(packageName) || 0) + 1;\n this.retryAttempts.set(packageName, attemptNumber);\n\n const isRetriable = this.isRetriableError(error);\n const maxRetries = this.config.maxRetries || 3;\n const canRetry = isRetriable && attemptNumber < maxRetries;\n\n if (canRetry) {\n // Schedule retry\n this.logger.warn(\n `⟳ ${packageName} failed (attempt ${attemptNumber}/${maxRetries}), will retry`\n );\n\n this.state.pending.push(packageName);\n this.emit('package:retrying', { packageName, attemptNumber });\n\n // Apply backoff delay\n const delay = this.calculateRetryDelay(attemptNumber);\n await new Promise(resolve => setTimeout(resolve, delay));\n } else {\n // Permanent failure\n const dependencies = Array.from(this.graph.edges.get(packageName) || []);\n const dependents = Array.from(findAllDependents(packageName, this.graph));\n\n const failureInfo: FailedPackageSnapshot = {\n name: packageName,\n error: error.message,\n stack: error.stack,\n isRetriable,\n attemptNumber,\n failedAt: new Date().toISOString(),\n dependencies,\n dependents\n };\n\n this.state.failed.push(failureInfo);\n\n this.logger.error(`✗ ${packageName} failed permanently: ${error.message}`);\n this.emit('package:failed', { packageName, error });\n\n // Cascade failure to dependents\n await this.cascadeFailure(packageName);\n }\n }\n\n /**\n * Cascade failure to dependent packages\n */\n private async cascadeFailure(failedPackage: string): Promise<void> {\n const toSkip = findAllDependents(failedPackage, this.graph);\n\n for (const dependent of toSkip) {\n // Remove from pending/ready\n this.state.pending = this.state.pending.filter(p => p !== dependent);\n this.state.ready = this.state.ready.filter(p => p !== dependent);\n\n // Add to skipped\n if (!this.state.skipped.includes(dependent)) {\n this.state.skipped.push(dependent);\n this.logger.warn(`⊘ Skipping ${dependent} (depends on failed ${failedPackage})`);\n this.emit('package:skipped', {\n packageName: dependent,\n reason: `Depends on failed ${failedPackage}`\n });\n }\n }\n }\n\n /**\n * Update ready queue\n */\n private updateReadyQueue(): void {\n const nowReady: string[] = [];\n\n for (const packageName of this.state.pending) {\n if (this.dependencyChecker.isReady(packageName, this.state)) {\n nowReady.push(packageName);\n }\n }\n\n for (const packageName of nowReady) {\n this.state.pending = this.state.pending.filter(p => p !== packageName);\n this.state.ready.push(packageName);\n }\n }\n\n /**\n * Check if execution is complete\n */\n private isComplete(): boolean {\n return (\n this.state.pending.length === 0 &&\n this.state.ready.length === 0 &&\n this.runningTasks.size === 0\n );\n }\n\n /**\n * Determine if should save checkpoint\n */\n private shouldCheckpoint(): boolean {\n // Checkpoint after each completion for now\n // Could be optimized to checkpoint less frequently\n return true;\n }\n\n /**\n * Save checkpoint\n */\n private async saveCheckpoint(): Promise<void> {\n const checkpoint: ParallelExecutionCheckpoint = {\n version: '1.0.0',\n executionId: this.executionId,\n createdAt: this.startTime.toISOString(),\n lastUpdated: new Date().toISOString(),\n command: this.config.command,\n originalConfig: this.config.config,\n dependencyGraph: {\n packages: Array.from(this.graph.packages.values()).map(pkg => ({\n name: pkg.name,\n version: pkg.version,\n path: pkg.path,\n dependencies: Array.from(pkg.dependencies)\n })),\n edges: Array.from(this.graph.edges.entries()).map(([pkg, deps]) => [\n pkg,\n Array.from(deps)\n ])\n },\n buildOrder: [\n ...this.state.pending,\n ...this.state.ready,\n ...this.state.running.map(r => r.name),\n ...this.state.completed,\n ...this.state.failed.map(f => f.name),\n ...this.state.skipped\n ],\n executionMode: 'parallel',\n maxConcurrency: this.config.maxConcurrency,\n state: this.state,\n publishedVersions: this.publishedVersions.map(pv => ({\n packageName: pv.name,\n version: pv.version,\n publishTime: pv.time.toISOString()\n })),\n retryAttempts: Object.fromEntries(this.retryAttempts),\n lastRetryTime: {},\n packageStartTimes: Object.fromEntries(\n Array.from(this.packageStartTimes.entries()).map(([k, v]) => [k, v.toISOString()])\n ),\n packageEndTimes: Object.fromEntries(\n Array.from(this.packageEndTimes.entries()).map(([k, v]) => [k, v.toISOString()])\n ),\n packageDurations: Object.fromEntries(this.packageDurations),\n totalStartTime: this.startTime.toISOString(),\n recoveryHints: [],\n canRecover: true\n };\n\n await this.checkpointManager.save(checkpoint);\n this.emit('checkpoint:saved', { timestamp: new Date() });\n }\n\n /**\n * Load checkpoint\n */\n private async loadCheckpoint(): Promise<void> {\n const checkpoint = await this.checkpointManager.load();\n\n if (!checkpoint) {\n this.logger.warn('No checkpoint found, starting fresh');\n return;\n }\n\n this.logger.info('Loading checkpoint...');\n this.logger.info(`Execution ID: ${checkpoint.executionId}`);\n this.logger.info(`Completed: ${checkpoint.state.completed.length} packages`);\n this.logger.info(`Failed: ${checkpoint.state.failed.length} packages`);\n\n // Restore state\n this.executionId = checkpoint.executionId;\n this.startTime = new Date(checkpoint.totalStartTime);\n this.state = checkpoint.state;\n\n // Restore timing data\n for (const [pkg, time] of Object.entries(checkpoint.packageStartTimes)) {\n this.packageStartTimes.set(pkg, new Date(time));\n }\n for (const [pkg, time] of Object.entries(checkpoint.packageEndTimes)) {\n this.packageEndTimes.set(pkg, new Date(time));\n }\n for (const [pkg, duration] of Object.entries(checkpoint.packageDurations)) {\n this.packageDurations.set(pkg, duration);\n }\n\n // Restore retry attempts\n for (const [pkg, attempts] of Object.entries(checkpoint.retryAttempts)) {\n this.retryAttempts.set(pkg, attempts);\n }\n\n // Clear running state (cannot resume mid-execution)\n for (const running of this.state.running) {\n this.state.pending.push(running.name);\n }\n this.state.running = [];\n }\n\n /**\n * Build execution result\n */\n private buildExecutionResult(): ExecutionResult {\n const totalDuration = Date.now() - this.startTime.getTime();\n const completedDurations = Array.from(this.packageDurations.values());\n const averageDuration = completedDurations.length > 0\n ? completedDurations.reduce((a, b) => a + b, 0) / completedDurations.length\n : 0;\n\n const metrics: ExecutionMetrics = {\n totalDuration,\n averagePackageDuration: averageDuration,\n peakConcurrency: this.resourceMonitor.getMetrics().peakConcurrency,\n averageConcurrency: this.resourceMonitor.getMetrics().averageConcurrency\n };\n\n return {\n success: this.state.failed.length === 0,\n totalPackages: this.graph.packages.size,\n completed: this.state.completed,\n failed: this.state.failed,\n skipped: this.state.skipped,\n metrics\n };\n }\n\n /**\n * Check if error is retriable\n */\n private isRetriableError(error: Error): boolean {\n const retriablePatterns = [\n /ETIMEDOUT/i,\n /ECONNRESET/i,\n /ENOTFOUND/i,\n /rate limit/i,\n /temporary failure/i,\n /try again/i,\n /gateway timeout/i,\n /service unavailable/i\n ];\n\n return retriablePatterns.some(pattern =>\n pattern.test(error.message || String(error))\n );\n }\n\n /**\n * Calculate retry delay with exponential backoff\n */\n private calculateRetryDelay(attemptNumber: number): number {\n const initialDelay = this.config.initialRetryDelay || 5000;\n const maxDelay = this.config.maxRetryDelay || 60000;\n const multiplier = this.config.backoffMultiplier || 2;\n\n const delay = Math.min(\n initialDelay * Math.pow(multiplier, attemptNumber - 1),\n maxDelay\n );\n\n // Add jitter\n const jitter = Math.random() * 0.1 * delay;\n\n return delay + jitter;\n }\n\n /**\n * Format duration in human-readable format\n */\n private formatDuration(ms: number): string {\n const seconds = Math.floor(ms / 1000);\n const minutes = Math.floor(seconds / 60);\n\n if (minutes > 0) {\n return `${minutes}m ${seconds % 60}s`;\n }\n return `${seconds}s`;\n }\n}\n"],"names":["DynamicTaskPool","EventEmitter","execute","logger","info","config","maxConcurrency","emit","totalPackages","graph","packages","size","continue","loadCheckpoint","updateReadyQueue","isComplete","availableSlots","resourceMonitor","getAvailableSlots","state","ready","length","toSchedule","scheduler","getNext","packageName","schedulePackage","runningTasks","Error","completedTask","waitForNext","handleTaskCompletion","shouldCheckpoint","saveCheckpoint","allCompleted","failed","skipped","checkpointManager","cleanup","result","buildExecutionResult","error","initializeState","buildOrder","Array","from","keys","pending","running","completed","filter","p","allocate","packageStartTimes","set","Date","controller","AbortController","promise","executePackage","signal","task","startTime","push","name","toISOString","elapsedTime","verbose","_packageName","_signal","entries","promises","map","then","catch","Promise","race","delete","r","release","endTime","packageEndTimes","get","duration","getTime","packageDurations","handleFailure","handleSuccess","formatDuration","publishedVersion","publishedVersions","version","time","attemptNumber","retryAttempts","isRetriable","isRetriableError","maxRetries","canRetry","warn","delay","calculateRetryDelay","resolve","setTimeout","dependencies","edges","dependents","findAllDependents","failureInfo","message","stack","failedAt","cascadeFailure","failedPackage","toSkip","dependent","includes","reason","nowReady","dependencyChecker","isReady","checkpoint","executionId","createdAt","lastUpdated","command","originalConfig","dependencyGraph","values","pkg","path","deps","f","executionMode","pv","publishTime","Object","fromEntries","lastRetryTime","k","v","totalStartTime","recoveryHints","canRecover","save","timestamp","load","attempts","totalDuration","now","completedDurations","averageDuration","reduce","a","b","metrics","averagePackageDuration","peakConcurrency","getMetrics","averageConcurrency","success","retriablePatterns","some","pattern","test","String","initialDelay","initialRetryDelay","maxDelay","maxRetryDelay","multiplier","backoffMultiplier","Math","min","pow","jitter","random","ms","seconds","floor","minutes","getLogger","Map","randomUUID","DependencyChecker","ResourceMonitor","Scheduler","CheckpointManager","checkpointPath","process","cwd"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DynamicTaskPool.js","sources":["../../src/execution/DynamicTaskPool.ts"],"sourcesContent":["import { EventEmitter } from 'events';\nimport { randomUUID } from 'crypto';\nimport { getLogger } from '../logging';\nimport { Config } from '../types';\nimport {\n DependencyGraph,\n findAllDependents\n} from '../util/dependencyGraph';\nimport {\n ParallelExecutionCheckpoint,\n ExecutionState,\n ExecutionResult,\n PackageResult,\n ExecutionMetrics,\n FailedPackageSnapshot\n} from '../types/parallelExecution';\nimport { CheckpointManager } from '../util/checkpointManager';\nimport { DependencyChecker } from './DependencyChecker';\nimport { ResourceMonitor } from './ResourceMonitor';\nimport { Scheduler } from './Scheduler';\n\nexport interface PoolConfig {\n graph: DependencyGraph;\n maxConcurrency: number;\n command: string;\n config: Config;\n checkpointPath?: string;\n continue?: boolean;\n maxRetries?: number;\n initialRetryDelay?: number;\n maxRetryDelay?: number;\n backoffMultiplier?: number;\n}\n\ninterface CompletedTask {\n packageName: string;\n result: PackageResult | null;\n error: Error | null;\n}\n\ninterface RunningTask {\n packageName: string;\n startTime: Date;\n promise: Promise<PackageResult>;\n controller: AbortController;\n}\n\n/**\n * DynamicTaskPool manages parallel execution of packages with dependency awareness\n */\nexport class DynamicTaskPool extends EventEmitter {\n private config: PoolConfig;\n private graph: DependencyGraph;\n private state: ExecutionState;\n private dependencyChecker: DependencyChecker;\n private resourceMonitor: ResourceMonitor;\n private scheduler: Scheduler;\n private checkpointManager: CheckpointManager;\n private logger = getLogger();\n\n // Execution tracking\n private executionId: string;\n private startTime: Date;\n private runningTasks = new Map<string, RunningTask>();\n private packageStartTimes = new Map<string, Date>();\n private packageEndTimes = new Map<string, Date>();\n private packageDurations = new Map<string, number>();\n private retryAttempts = new Map<string, number>();\n private publishedVersions: Array<{name: string, version: string, time: Date}> = [];\n\n constructor(config: PoolConfig) {\n super();\n this.config = config;\n this.graph = config.graph;\n this.executionId = randomUUID();\n this.startTime = new Date();\n\n // Initialize components\n this.dependencyChecker = new DependencyChecker(this.graph);\n this.resourceMonitor = new ResourceMonitor(config.maxConcurrency);\n this.scheduler = new Scheduler(this.graph, this.dependencyChecker);\n this.checkpointManager = new CheckpointManager(\n config.checkpointPath || process.cwd()\n );\n\n // Initialize state\n this.state = this.initializeState();\n }\n\n /**\n * Main execution entry point\n */\n async execute(): Promise<ExecutionResult> {\n this.logger.info(`Starting parallel execution with max concurrency: ${this.config.maxConcurrency}`);\n this.emit('execution:started', { totalPackages: this.graph.packages.size });\n\n try {\n // Load checkpoint if continuing\n if (this.config.continue) {\n await this.loadCheckpoint();\n }\n\n // Initialize ready queue\n this.updateReadyQueue();\n\n // Main execution loop\n while (!this.isComplete()) {\n // Schedule as many packages as we can\n const availableSlots = this.resourceMonitor.getAvailableSlots();\n if (availableSlots > 0 && this.state.ready.length > 0) {\n const toSchedule = this.scheduler.getNext(availableSlots, this.state);\n\n for (const packageName of toSchedule) {\n await this.schedulePackage(packageName);\n }\n }\n\n // Check if we're stuck\n if (this.runningTasks.size === 0) {\n if (this.state.ready.length > 0) {\n throw new Error('Deadlock detected: packages ready but cannot execute');\n }\n break; // No more work to do\n }\n\n // Wait for next package to complete\n const completedTask = await this.waitForNext();\n await this.handleTaskCompletion(completedTask);\n\n // Update ready queue\n this.updateReadyQueue();\n\n // Save checkpoint periodically\n if (this.shouldCheckpoint()) {\n await this.saveCheckpoint();\n }\n }\n\n // Final checkpoint and cleanup\n // Only cleanup if everything completed (no failures, no skipped packages due to dependencies)\n // Note: skippedNoChanges is OK - those packages successfully ran but had nothing to do\n const allCompleted = this.state.failed.length === 0 && this.state.skipped.length === 0;\n if (allCompleted) {\n await this.checkpointManager.cleanup();\n } else {\n await this.saveCheckpoint();\n }\n\n // Build and return result\n const result = this.buildExecutionResult();\n this.emit('execution:completed', { result });\n\n return result;\n } catch (error) {\n // Save checkpoint on error\n await this.saveCheckpoint();\n throw error;\n }\n }\n\n /**\n * Initialize execution state\n */\n private initializeState(): ExecutionState {\n const buildOrder = Array.from(this.graph.packages.keys());\n\n return {\n pending: [...buildOrder],\n ready: [],\n running: [],\n completed: [],\n failed: [],\n skipped: [],\n skippedNoChanges: []\n };\n }\n\n /**\n * Schedule a package for execution\n */\n private async schedulePackage(packageName: string): Promise<void> {\n // Move from ready to running\n this.state.ready = this.state.ready.filter(p => p !== packageName);\n\n // Allocate resource\n if (!this.resourceMonitor.allocate()) {\n throw new Error(`Failed to allocate resource for ${packageName}`);\n }\n\n // Record start time\n this.packageStartTimes.set(packageName, new Date());\n\n // Create abort controller\n const controller = new AbortController();\n\n // Start execution\n const promise = this.executePackage(packageName, controller.signal);\n\n // Track running task\n const task: RunningTask = {\n packageName,\n startTime: new Date(),\n promise,\n controller\n };\n\n this.runningTasks.set(packageName, task);\n\n // Update state\n this.state.running.push({\n name: packageName,\n startTime: task.startTime.toISOString(),\n elapsedTime: 0\n });\n\n // Emit event\n this.emit('package:started', { packageName });\n\n this.logger.verbose(\n `Scheduled ${packageName} (${this.runningTasks.size}/${this.config.maxConcurrency} slots used)`\n );\n }\n\n /**\n * Execute a single package (placeholder - will be overridden or use callback)\n */\n private async executePackage(\n _packageName: string,\n _signal: AbortSignal\n ): Promise<PackageResult> {\n // This is a placeholder that will be replaced with actual execution logic\n // In the real implementation, this would call the tree.ts executePackage function\n throw new Error('executePackage must be implemented');\n }\n\n /**\n * Wait for next task to complete\n */\n private async waitForNext(): Promise<CompletedTask> {\n const runningTasks = Array.from(this.runningTasks.entries());\n\n const promises = runningTasks.map(([name, task]) =>\n task.promise\n .then(result => ({ packageName: name, result, error: null }))\n .catch(error => ({ packageName: name, result: null, error }))\n );\n\n return await Promise.race(promises);\n }\n\n /**\n * Handle task completion\n */\n private async handleTaskCompletion(task: CompletedTask): Promise<void> {\n const { packageName, result, error } = task;\n\n // Remove from running\n this.runningTasks.delete(packageName);\n this.state.running = this.state.running.filter(r => r.name !== packageName);\n this.resourceMonitor.release();\n\n // Record timing\n const endTime = new Date();\n this.packageEndTimes.set(packageName, endTime);\n\n const startTime = this.packageStartTimes.get(packageName)!;\n const duration = endTime.getTime() - startTime.getTime();\n this.packageDurations.set(packageName, duration);\n\n if (error) {\n await this.handleFailure(packageName, error);\n } else {\n await this.handleSuccess(packageName, result!);\n }\n }\n\n /**\n * Handle successful package completion\n */\n private async handleSuccess(packageName: string, result: PackageResult): Promise<void> {\n // Check if this was skipped due to no changes\n if (result.skippedNoChanges) {\n this.state.skippedNoChanges.push(packageName);\n const duration = this.packageDurations.get(packageName)!;\n this.logger.info(`⊘ ${packageName} skipped - no code changes (${this.formatDuration(duration)})`);\n this.emit('package:skipped-no-changes', { packageName, result });\n } else {\n this.state.completed.push(packageName);\n const duration = this.packageDurations.get(packageName)!;\n this.logger.info(`✓ ${packageName} completed successfully (${this.formatDuration(duration)})`);\n this.emit('package:completed', { packageName, result });\n\n // Track published version if applicable\n if (result.publishedVersion) {\n this.publishedVersions.push({\n name: packageName,\n version: result.publishedVersion,\n time: new Date()\n });\n }\n }\n }\n\n /**\n * Handle package failure\n */\n private async handleFailure(packageName: string, error: Error): Promise<void> {\n const attemptNumber = (this.retryAttempts.get(packageName) || 0) + 1;\n this.retryAttempts.set(packageName, attemptNumber);\n\n const isRetriable = this.isRetriableError(error);\n const maxRetries = this.config.maxRetries || 3;\n const canRetry = isRetriable && attemptNumber < maxRetries;\n\n if (canRetry) {\n // Schedule retry\n this.logger.warn(\n `⟳ ${packageName} failed (attempt ${attemptNumber}/${maxRetries}), will retry`\n );\n\n this.state.pending.push(packageName);\n this.emit('package:retrying', { packageName, attemptNumber });\n\n // Apply backoff delay\n const delay = this.calculateRetryDelay(attemptNumber);\n await new Promise(resolve => setTimeout(resolve, delay));\n } else {\n // Permanent failure\n const dependencies = Array.from(this.graph.edges.get(packageName) || []);\n const dependents = Array.from(findAllDependents(packageName, this.graph));\n\n // Extract detailed error information\n const errorDetails = this.extractErrorDetails(error, packageName);\n\n const failureInfo: FailedPackageSnapshot = {\n name: packageName,\n error: error.message,\n stack: error.stack,\n isRetriable,\n attemptNumber,\n failedAt: new Date().toISOString(),\n dependencies,\n dependents,\n errorDetails\n };\n\n this.state.failed.push(failureInfo);\n\n this.logger.error(`✗ ${packageName} failed permanently: ${error.message}`);\n this.emit('package:failed', { packageName, error });\n\n // Cascade failure to dependents\n await this.cascadeFailure(packageName);\n }\n }\n\n /**\n * Cascade failure to dependent packages\n */\n private async cascadeFailure(failedPackage: string): Promise<void> {\n const toSkip = findAllDependents(failedPackage, this.graph);\n\n for (const dependent of toSkip) {\n // Remove from pending/ready\n this.state.pending = this.state.pending.filter(p => p !== dependent);\n this.state.ready = this.state.ready.filter(p => p !== dependent);\n\n // Add to skipped\n if (!this.state.skipped.includes(dependent)) {\n this.state.skipped.push(dependent);\n this.logger.warn(`⊘ Skipping ${dependent} (depends on failed ${failedPackage})`);\n this.emit('package:skipped', {\n packageName: dependent,\n reason: `Depends on failed ${failedPackage}`\n });\n }\n }\n }\n\n /**\n * Update ready queue\n */\n private updateReadyQueue(): void {\n const nowReady: string[] = [];\n\n for (const packageName of this.state.pending) {\n if (this.dependencyChecker.isReady(packageName, this.state)) {\n nowReady.push(packageName);\n }\n }\n\n for (const packageName of nowReady) {\n this.state.pending = this.state.pending.filter(p => p !== packageName);\n this.state.ready.push(packageName);\n }\n }\n\n /**\n * Check if execution is complete\n */\n private isComplete(): boolean {\n return (\n this.state.pending.length === 0 &&\n this.state.ready.length === 0 &&\n this.runningTasks.size === 0\n );\n }\n\n /**\n * Determine if should save checkpoint\n */\n private shouldCheckpoint(): boolean {\n // Checkpoint after each completion for now\n // Could be optimized to checkpoint less frequently\n return true;\n }\n\n /**\n * Save checkpoint\n */\n private async saveCheckpoint(): Promise<void> {\n const checkpoint: ParallelExecutionCheckpoint = {\n version: '1.0.0',\n executionId: this.executionId,\n createdAt: this.startTime.toISOString(),\n lastUpdated: new Date().toISOString(),\n command: this.config.command,\n originalConfig: this.config.config,\n dependencyGraph: {\n packages: Array.from(this.graph.packages.values()).map(pkg => ({\n name: pkg.name,\n version: pkg.version,\n path: pkg.path,\n dependencies: Array.from(pkg.dependencies)\n })),\n edges: Array.from(this.graph.edges.entries()).map(([pkg, deps]) => [\n pkg,\n Array.from(deps)\n ])\n },\n buildOrder: [\n ...this.state.pending,\n ...this.state.ready,\n ...this.state.running.map(r => r.name),\n ...this.state.completed,\n ...this.state.failed.map(f => f.name),\n ...this.state.skipped\n ],\n executionMode: 'parallel',\n maxConcurrency: this.config.maxConcurrency,\n state: this.state,\n publishedVersions: this.publishedVersions.map(pv => ({\n packageName: pv.name,\n version: pv.version,\n publishTime: pv.time.toISOString()\n })),\n retryAttempts: Object.fromEntries(this.retryAttempts),\n lastRetryTime: {},\n packageStartTimes: Object.fromEntries(\n Array.from(this.packageStartTimes.entries()).map(([k, v]) => [k, v.toISOString()])\n ),\n packageEndTimes: Object.fromEntries(\n Array.from(this.packageEndTimes.entries()).map(([k, v]) => [k, v.toISOString()])\n ),\n packageDurations: Object.fromEntries(this.packageDurations),\n totalStartTime: this.startTime.toISOString(),\n recoveryHints: [],\n canRecover: true\n };\n\n await this.checkpointManager.save(checkpoint);\n this.emit('checkpoint:saved', { timestamp: new Date() });\n }\n\n /**\n * Load checkpoint\n */\n private async loadCheckpoint(): Promise<void> {\n const checkpoint = await this.checkpointManager.load();\n\n if (!checkpoint) {\n this.logger.warn('No checkpoint found, starting fresh');\n return;\n }\n\n this.logger.info('Loading checkpoint...');\n this.logger.info(`Execution ID: ${checkpoint.executionId}`);\n this.logger.info(`Completed: ${checkpoint.state.completed.length} packages`);\n this.logger.info(`Failed: ${checkpoint.state.failed.length} packages`);\n\n // Restore state\n this.executionId = checkpoint.executionId;\n this.startTime = new Date(checkpoint.totalStartTime);\n this.state = checkpoint.state;\n\n // Restore timing data\n for (const [pkg, time] of Object.entries(checkpoint.packageStartTimes)) {\n this.packageStartTimes.set(pkg, new Date(time));\n }\n for (const [pkg, time] of Object.entries(checkpoint.packageEndTimes)) {\n this.packageEndTimes.set(pkg, new Date(time));\n }\n for (const [pkg, duration] of Object.entries(checkpoint.packageDurations)) {\n this.packageDurations.set(pkg, duration);\n }\n\n // Restore retry attempts\n for (const [pkg, attempts] of Object.entries(checkpoint.retryAttempts)) {\n this.retryAttempts.set(pkg, attempts);\n }\n\n // Clear running state (cannot resume mid-execution)\n for (const running of this.state.running) {\n this.state.pending.push(running.name);\n }\n this.state.running = [];\n }\n\n /**\n * Build execution result\n */\n private buildExecutionResult(): ExecutionResult {\n const totalDuration = Date.now() - this.startTime.getTime();\n const completedDurations = Array.from(this.packageDurations.values());\n const averageDuration = completedDurations.length > 0\n ? completedDurations.reduce((a, b) => a + b, 0) / completedDurations.length\n : 0;\n\n const metrics: ExecutionMetrics = {\n totalDuration,\n averagePackageDuration: averageDuration,\n peakConcurrency: this.resourceMonitor.getMetrics().peakConcurrency,\n averageConcurrency: this.resourceMonitor.getMetrics().averageConcurrency\n };\n\n return {\n success: this.state.failed.length === 0,\n totalPackages: this.graph.packages.size,\n completed: this.state.completed,\n failed: this.state.failed,\n skipped: this.state.skipped,\n skippedNoChanges: this.state.skippedNoChanges,\n metrics\n };\n }\n\n /**\n * Check if error is retriable\n */\n private isRetriableError(error: Error): boolean {\n const retriablePatterns = [\n /ETIMEDOUT/i,\n /ECONNRESET/i,\n /ENOTFOUND/i,\n /rate limit/i,\n /temporary failure/i,\n /try again/i,\n /gateway timeout/i,\n /service unavailable/i\n ];\n\n return retriablePatterns.some(pattern =>\n pattern.test(error.message || String(error))\n );\n }\n\n /**\n * Calculate retry delay with exponential backoff\n */\n private calculateRetryDelay(attemptNumber: number): number {\n const initialDelay = this.config.initialRetryDelay || 5000;\n const maxDelay = this.config.maxRetryDelay || 60000;\n const multiplier = this.config.backoffMultiplier || 2;\n\n const delay = Math.min(\n initialDelay * Math.pow(multiplier, attemptNumber - 1),\n maxDelay\n );\n\n // Add jitter\n const jitter = Math.random() * 0.1 * delay;\n\n return delay + jitter;\n }\n\n /**\n * Format duration in human-readable format\n */\n private formatDuration(ms: number): string {\n const seconds = Math.floor(ms / 1000);\n const minutes = Math.floor(seconds / 60);\n\n if (minutes > 0) {\n return `${minutes}m ${seconds % 60}s`;\n }\n return `${seconds}s`;\n }\n\n /**\n * Extract detailed error information from error message and stack\n */\n private extractErrorDetails(error: Error, packageName: string): { type?: string; context?: string; logFile?: string; suggestion?: string } | undefined {\n const errorMsg = error.message || '';\n const errorStack = error.stack || '';\n const fullText = `${errorMsg}\\n${errorStack}`;\n\n // Test coverage failure\n if (fullText.match(/coverage.*below.*threshold|coverage.*insufficient/i)) {\n const coverageMatch = fullText.match(/(\\w+):\\s*(\\d+\\.?\\d*)%.*threshold:\\s*(\\d+\\.?\\d*)%/i);\n return {\n type: 'test_coverage',\n context: coverageMatch\n ? `${coverageMatch[1]}: ${coverageMatch[2]}% (threshold: ${coverageMatch[3]}%)`\n : 'Coverage below threshold',\n logFile: this.getLogFilePath(packageName),\n suggestion: `cd ${this.getPackagePath(packageName)} && npm test -- --coverage`\n };\n }\n\n // Build/compile errors\n if (fullText.match(/compilation.*failed|build.*failed|tsc.*error/i)) {\n return {\n type: 'build_error',\n context: this.extractFirstErrorLine(fullText),\n logFile: this.getLogFilePath(packageName),\n suggestion: `cd ${this.getPackagePath(packageName)} && npm run build`\n };\n }\n\n // Merge conflicts\n if (fullText.match(/merge.*conflict|conflict.*marker|<<<<<<<|>>>>>>>/i)) {\n return {\n type: 'merge_conflict',\n context: 'Unresolved merge conflicts detected',\n logFile: this.getLogFilePath(packageName),\n suggestion: `cd ${this.getPackagePath(packageName)} && git status`\n };\n }\n\n // Test failures\n if (fullText.match(/test.*failed|tests.*failed|\\d+\\s+failing/i)) {\n const failMatch = fullText.match(/(\\d+)\\s+failing/i);\n return {\n type: 'test_failure',\n context: failMatch ? `${failMatch[1]} test(s) failing` : 'Tests failed',\n logFile: this.getLogFilePath(packageName),\n suggestion: `cd ${this.getPackagePath(packageName)} && npm test`\n };\n }\n\n // Timeout errors\n if (fullText.match(/timeout|timed.*out/i)) {\n return {\n type: 'timeout',\n context: this.extractFirstErrorLine(fullText),\n logFile: this.getLogFilePath(packageName),\n suggestion: 'Consider increasing timeout or checking for stuck processes'\n };\n }\n\n // Generic error with log file\n return {\n type: 'unknown',\n context: errorMsg.split('\\n')[0].substring(0, 200),\n logFile: this.getLogFilePath(packageName)\n };\n }\n\n private extractFirstErrorLine(text: string): string {\n const lines = text.split('\\n');\n for (const line of lines) {\n if (line.match(/error|failed|exception/i) && line.trim().length > 10) {\n return line.trim().substring(0, 200);\n }\n }\n return text.split('\\n')[0].substring(0, 200);\n }\n\n private getPackagePath(packageName: string): string {\n const pkgInfo = this.graph.packages.get(packageName);\n return pkgInfo?.path || '.';\n }\n\n private getLogFilePath(packageName: string): string {\n const pkgPath = this.getPackagePath(packageName);\n const outputDir = this.config.config.outputDirectory || 'output/kodrdriv';\n // Try to find the most recent log file\n return `${pkgPath}/${outputDir}/publish_*.log`;\n }\n}\n"],"names":["DynamicTaskPool","EventEmitter","execute","logger","info","config","maxConcurrency","emit","totalPackages","graph","packages","size","continue","loadCheckpoint","updateReadyQueue","isComplete","availableSlots","resourceMonitor","getAvailableSlots","state","ready","length","toSchedule","scheduler","getNext","packageName","schedulePackage","runningTasks","Error","completedTask","waitForNext","handleTaskCompletion","shouldCheckpoint","saveCheckpoint","allCompleted","failed","skipped","checkpointManager","cleanup","result","buildExecutionResult","error","initializeState","buildOrder","Array","from","keys","pending","running","completed","skippedNoChanges","filter","p","allocate","packageStartTimes","set","Date","controller","AbortController","promise","executePackage","signal","task","startTime","push","name","toISOString","elapsedTime","verbose","_packageName","_signal","entries","promises","map","then","catch","Promise","race","delete","r","release","endTime","packageEndTimes","get","duration","getTime","packageDurations","handleFailure","handleSuccess","formatDuration","publishedVersion","publishedVersions","version","time","attemptNumber","retryAttempts","isRetriable","isRetriableError","maxRetries","canRetry","warn","delay","calculateRetryDelay","resolve","setTimeout","dependencies","edges","dependents","findAllDependents","errorDetails","extractErrorDetails","failureInfo","message","stack","failedAt","cascadeFailure","failedPackage","toSkip","dependent","includes","reason","nowReady","dependencyChecker","isReady","checkpoint","executionId","createdAt","lastUpdated","command","originalConfig","dependencyGraph","values","pkg","path","deps","f","executionMode","pv","publishTime","Object","fromEntries","lastRetryTime","k","v","totalStartTime","recoveryHints","canRecover","save","timestamp","load","attempts","totalDuration","now","completedDurations","averageDuration","reduce","a","b","metrics","averagePackageDuration","peakConcurrency","getMetrics","averageConcurrency","success","retriablePatterns","some","pattern","test","String","initialDelay","initialRetryDelay","maxDelay","maxRetryDelay","multiplier","backoffMultiplier","Math","min","pow","jitter","random","ms","seconds","floor","minutes","errorMsg","errorStack","fullText","match","coverageMatch","type","context","logFile","getLogFilePath","suggestion","getPackagePath","extractFirstErrorLine","failMatch","split","substring","text","lines","line","trim","pkgInfo","pkgPath","outputDir","outputDirectory","getLogger","Map","randomUUID","DependencyChecker","ResourceMonitor","Scheduler","CheckpointManager","checkpointPath","process","cwd"],"mappings":"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"}
|
|
@@ -214,7 +214,8 @@ function _define_property(obj, key, value) {
|
|
|
214
214
|
...this.checkpoint.state.running.map((r)=>r.name),
|
|
215
215
|
...this.checkpoint.state.completed,
|
|
216
216
|
...this.checkpoint.state.failed.map((f)=>f.name),
|
|
217
|
-
...this.checkpoint.state.skipped
|
|
217
|
+
...this.checkpoint.state.skipped,
|
|
218
|
+
...this.checkpoint.state.skippedNoChanges
|
|
218
219
|
];
|
|
219
220
|
const duplicates = this.findDuplicates(allPackages);
|
|
220
221
|
if (duplicates.length > 0) {
|
|
@@ -320,16 +321,18 @@ function _define_property(obj, key, value) {
|
|
|
320
321
|
// Progress summary
|
|
321
322
|
const total = this.checkpoint.buildOrder.length;
|
|
322
323
|
const completed = this.checkpoint.state.completed.length;
|
|
324
|
+
const skippedNoChanges = this.checkpoint.state.skippedNoChanges.length;
|
|
323
325
|
const failed = this.checkpoint.state.failed.length;
|
|
324
326
|
const skipped = this.checkpoint.state.skipped.length;
|
|
325
327
|
const running = this.checkpoint.state.running.length;
|
|
326
328
|
const pending = this.checkpoint.state.pending.length + this.checkpoint.state.ready.length;
|
|
327
329
|
lines.push('📊 Progress:');
|
|
328
330
|
lines.push(` Completed: ${completed}/${total} (${Math.round(completed / total * 100)}%)`);
|
|
331
|
+
lines.push(` Skipped (no changes): ${skippedNoChanges}`);
|
|
329
332
|
lines.push(` Running: ${running}`);
|
|
330
333
|
lines.push(` Pending: ${pending}`);
|
|
331
334
|
lines.push(` Failed: ${failed}`);
|
|
332
|
-
lines.push(` Skipped: ${skipped}`);
|
|
335
|
+
lines.push(` Skipped (dependency failed): ${skipped}`);
|
|
333
336
|
lines.push('');
|
|
334
337
|
// Progress bar
|
|
335
338
|
const progressBar = this.createProgressBar(completed, total);
|
|
@@ -428,6 +431,7 @@ function _define_property(obj, key, value) {
|
|
|
428
431
|
this.checkpoint.state.completed = this.checkpoint.state.completed.filter((p)=>p !== packageName);
|
|
429
432
|
this.checkpoint.state.failed = this.checkpoint.state.failed.filter((f)=>f.name !== packageName);
|
|
430
433
|
this.checkpoint.state.skipped = this.checkpoint.state.skipped.filter((p)=>p !== packageName);
|
|
434
|
+
this.checkpoint.state.skippedNoChanges = this.checkpoint.state.skippedNoChanges.filter((p)=>p !== packageName);
|
|
431
435
|
}
|
|
432
436
|
updateReadyState() {
|
|
433
437
|
// Move packages from pending to ready if dependencies met
|