@jterrats/smart-deployment 1.0.5 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -2
- package/lib/ai/wave-validation-prompt.d.ts +2 -0
- package/lib/ai/wave-validation-prompt.js +56 -0
- package/lib/ai/wave-validation-prompt.js.map +1 -0
- package/lib/ai/wave-validation-report.d.ts +2 -0
- package/lib/ai/wave-validation-report.js +96 -0
- package/lib/ai/wave-validation-report.js.map +1 -0
- package/lib/ai/wave-validation-response-parser.d.ts +8 -0
- package/lib/ai/wave-validation-response-parser.js +112 -0
- package/lib/ai/wave-validation-response-parser.js.map +1 -0
- package/lib/ai/wave-validation-result-synthesis.d.ts +6 -0
- package/lib/ai/wave-validation-result-synthesis.js +49 -0
- package/lib/ai/wave-validation-result-synthesis.js.map +1 -0
- package/lib/ai/wave-validation-service.d.ts +1 -55
- package/lib/ai/wave-validation-service.js +11 -359
- package/lib/ai/wave-validation-service.js.map +1 -1
- package/lib/ai/wave-validation-transport.d.ts +7 -0
- package/lib/ai/wave-validation-transport.js +10 -0
- package/lib/ai/wave-validation-transport.js.map +1 -0
- package/lib/analysis/analysis-reporter.d.ts +29 -0
- package/lib/analysis/analysis-reporter.js +84 -1
- package/lib/analysis/analysis-reporter.js.map +1 -1
- package/lib/analysis/analyze-context-service.d.ts +1 -1
- package/lib/analysis/analyze-context-service.js +2 -0
- package/lib/analysis/analyze-context-service.js.map +1 -1
- package/lib/analysis/project-analysis-service.d.ts +2 -0
- package/lib/analysis/project-analysis-service.js +2 -0
- package/lib/analysis/project-analysis-service.js.map +1 -1
- package/lib/commands/start.d.ts +1 -0
- package/lib/commands/start.js +14 -1
- package/lib/commands/start.js.map +1 -1
- package/lib/commands/status.d.ts +2 -0
- package/lib/commands/status.js +1 -0
- package/lib/commands/status.js.map +1 -1
- package/lib/commands/validate.d.ts +3 -3
- package/lib/commands/validate.js +4 -4
- package/lib/commands/validate.js.map +1 -1
- package/lib/constants/api-version.d.ts +2 -2
- package/lib/constants/api-version.js +2 -2
- package/lib/constants/deployment-order.js +11 -8
- package/lib/constants/deployment-order.js.map +1 -1
- package/lib/dependencies/circular-dependency-detector.d.ts +1 -31
- package/lib/dependencies/circular-dependency-detector.js +7 -156
- package/lib/dependencies/circular-dependency-detector.js.map +1 -1
- package/lib/dependencies/cycle-break-suggestions.d.ts +3 -0
- package/lib/dependencies/cycle-break-suggestions.js +63 -0
- package/lib/dependencies/cycle-break-suggestions.js.map +1 -0
- package/lib/dependencies/cycle-discovery.d.ts +16 -0
- package/lib/dependencies/cycle-discovery.js +70 -0
- package/lib/dependencies/cycle-discovery.js.map +1 -0
- package/lib/dependencies/dependency-graph-builder.d.ts +0 -65
- package/lib/dependencies/dependency-graph-builder.js +19 -233
- package/lib/dependencies/dependency-graph-builder.js.map +1 -1
- package/lib/dependencies/dependency-graph-intake.d.ts +17 -0
- package/lib/dependencies/dependency-graph-intake.js +20 -0
- package/lib/dependencies/dependency-graph-intake.js.map +1 -0
- package/lib/dependencies/dependency-graph-stats.d.ts +4 -0
- package/lib/dependencies/dependency-graph-stats.js +82 -0
- package/lib/dependencies/dependency-graph-stats.js.map +1 -0
- package/lib/dependencies/dependency-graph-validation.d.ts +16 -0
- package/lib/dependencies/dependency-graph-validation.js +78 -0
- package/lib/dependencies/dependency-graph-validation.js.map +1 -0
- package/lib/dependencies/dependency-impact-analyzer.d.ts +1 -22
- package/lib/dependencies/dependency-impact-analyzer.js +12 -110
- package/lib/dependencies/dependency-impact-analyzer.js.map +1 -1
- package/lib/dependencies/dependency-impact-scoring.d.ts +5 -0
- package/lib/dependencies/dependency-impact-scoring.js +24 -0
- package/lib/dependencies/dependency-impact-scoring.js.map +1 -0
- package/lib/dependencies/dependency-impact-traversal.d.ts +18 -0
- package/lib/dependencies/dependency-impact-traversal.js +74 -0
- package/lib/dependencies/dependency-impact-traversal.js.map +1 -0
- package/lib/dependencies/dependency-resolution-classifier.d.ts +19 -0
- package/lib/dependencies/dependency-resolution-classifier.js +67 -0
- package/lib/dependencies/dependency-resolution-classifier.js.map +1 -0
- package/lib/dependencies/dependency-resolver.d.ts +1 -48
- package/lib/dependencies/dependency-resolver.js +12 -181
- package/lib/dependencies/dependency-resolver.js.map +1 -1
- package/lib/dependencies/dynamic-query-dependency-references.d.ts +3 -0
- package/lib/dependencies/dynamic-query-dependency-references.js +41 -0
- package/lib/dependencies/dynamic-query-dependency-references.js.map +1 -0
- package/lib/dependencies/topological-dependency-sorter.d.ts +10 -0
- package/lib/dependencies/topological-dependency-sorter.js +84 -0
- package/lib/dependencies/topological-dependency-sorter.js.map +1 -0
- package/lib/deployment/cycle-remediation-runner.d.ts +1 -0
- package/lib/deployment/cycle-remediation-runner.js +5 -1
- package/lib/deployment/cycle-remediation-runner.js.map +1 -1
- package/lib/deployment/deployment-runner.d.ts +3 -1
- package/lib/deployment/deployment-runner.js +6 -1
- package/lib/deployment/deployment-runner.js.map +1 -1
- package/lib/deployment/deployment-status-service.d.ts +2 -0
- package/lib/deployment/deployment-status-service.js +2 -0
- package/lib/deployment/deployment-status-service.js.map +1 -1
- package/lib/deployment/deployment-validation-service.js +1 -1
- package/lib/deployment/deployment-validation-service.js.map +1 -1
- package/lib/deployment/dynamic-query-target-validator.d.ts +24 -0
- package/lib/deployment/dynamic-query-target-validator.js +65 -0
- package/lib/deployment/dynamic-query-target-validator.js.map +1 -0
- package/lib/deployment/sf-cli-integration.d.ts +1 -0
- package/lib/deployment/sf-cli-integration.js +1 -1
- package/lib/deployment/sf-cli-integration.js.map +1 -1
- package/lib/deployment/sf-cli-metadata-lookup.d.ts +4 -0
- package/lib/deployment/sf-cli-metadata-lookup.js +26 -0
- package/lib/deployment/sf-cli-metadata-lookup.js.map +1 -0
- package/lib/deployment/start-execution-service.d.ts +5 -0
- package/lib/deployment/start-execution-service.js +26 -6
- package/lib/deployment/start-execution-service.js.map +1 -1
- package/lib/deployment/wave-graph-state.d.ts +6 -0
- package/lib/deployment/wave-graph-state.js +89 -0
- package/lib/deployment/wave-graph-state.js.map +1 -0
- package/lib/deployment/wave-manifest-service.d.ts +1 -0
- package/lib/deployment/wave-manifest-service.js +1 -1
- package/lib/deployment/wave-manifest-service.js.map +1 -1
- package/lib/errors/deployment-error.js +1 -1
- package/lib/errors/deployment-error.js.map +1 -1
- package/lib/parsers/apex-class-dependencies.d.ts +4 -0
- package/lib/parsers/apex-class-dependencies.js +122 -0
- package/lib/parsers/apex-class-dependencies.js.map +1 -0
- package/lib/parsers/apex-class-lexical.d.ts +3 -0
- package/lib/parsers/apex-class-lexical.js +101 -0
- package/lib/parsers/apex-class-lexical.js.map +1 -0
- package/lib/parsers/apex-class-names.d.ts +18 -0
- package/lib/parsers/apex-class-names.js +93 -0
- package/lib/parsers/apex-class-names.js.map +1 -0
- package/lib/parsers/apex-class-parser-model.d.ts +59 -0
- package/lib/parsers/apex-class-parser-model.js +2 -0
- package/lib/parsers/apex-class-parser-model.js.map +1 -0
- package/lib/parsers/apex-class-parser.d.ts +3 -29
- package/lib/parsers/apex-class-parser.js +10 -395
- package/lib/parsers/apex-class-parser.js.map +1 -1
- package/lib/parsers/apex-class-symbols.d.ts +2 -0
- package/lib/parsers/apex-class-symbols.js +61 -0
- package/lib/parsers/apex-class-symbols.js.map +1 -0
- package/lib/parsers/apex-dynamic-query-analysis.d.ts +2 -0
- package/lib/parsers/apex-dynamic-query-analysis.js +150 -0
- package/lib/parsers/apex-dynamic-query-analysis.js.map +1 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.d.ts +2 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.js +50 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.js.map +1 -0
- package/lib/parsers/custom-metadata-parser.d.ts +2 -0
- package/lib/parsers/custom-metadata-parser.js +3 -0
- package/lib/parsers/custom-metadata-parser.js.map +1 -1
- package/lib/parsers/custom-object-dependency-builder.d.ts +3 -0
- package/lib/parsers/custom-object-dependency-builder.js +103 -0
- package/lib/parsers/custom-object-dependency-builder.js.map +1 -0
- package/lib/parsers/custom-object-parser.js +1 -208
- package/lib/parsers/custom-object-parser.js.map +1 -1
- package/lib/parsers/custom-object-reference-helpers.d.ts +4 -0
- package/lib/parsers/custom-object-reference-helpers.js +92 -0
- package/lib/parsers/custom-object-reference-helpers.js.map +1 -0
- package/lib/parsers/dynamic-query-reference.d.ts +16 -0
- package/lib/parsers/dynamic-query-reference.js +65 -0
- package/lib/parsers/dynamic-query-reference.js.map +1 -0
- package/lib/parsers/layout-action-analysis.d.ts +6 -0
- package/lib/parsers/layout-action-analysis.js +36 -0
- package/lib/parsers/layout-action-analysis.js.map +1 -0
- package/lib/parsers/layout-parser.js +4 -272
- package/lib/parsers/layout-parser.js.map +1 -1
- package/lib/parsers/layout-reference-analysis.d.ts +9 -0
- package/lib/parsers/layout-reference-analysis.js +70 -0
- package/lib/parsers/layout-reference-analysis.js.map +1 -0
- package/lib/parsers/layout-result-assembly.d.ts +5 -0
- package/lib/parsers/layout-result-assembly.js +35 -0
- package/lib/parsers/layout-result-assembly.js.map +1 -0
- package/lib/parsers/layout-section-analysis.d.ts +7 -0
- package/lib/parsers/layout-section-analysis.js +9 -0
- package/lib/parsers/layout-section-analysis.js.map +1 -0
- package/lib/parsers/lwc-code-analysis.d.ts +10 -0
- package/lib/parsers/lwc-code-analysis.js +161 -0
- package/lib/parsers/lwc-code-analysis.js.map +1 -0
- package/lib/parsers/lwc-metadata-analysis.d.ts +6 -0
- package/lib/parsers/lwc-metadata-analysis.js +112 -0
- package/lib/parsers/lwc-metadata-analysis.js.map +1 -0
- package/lib/parsers/lwc-parser.d.ts +3 -27
- package/lib/parsers/lwc-parser.js +6 -377
- package/lib/parsers/lwc-parser.js.map +1 -1
- package/lib/parsers/lwc-result-assembly.d.ts +4 -0
- package/lib/parsers/lwc-result-assembly.js +47 -0
- package/lib/parsers/lwc-result-assembly.js.map +1 -0
- package/lib/presentation/status-command-presenter.d.ts +1 -0
- package/lib/presentation/status-command-presenter.js +20 -0
- package/lib/presentation/status-command-presenter.js.map +1 -1
- package/lib/scanner/forceignore-parser.d.ts +1 -0
- package/lib/scanner/forceignore-parser.js +14 -3
- package/lib/scanner/forceignore-parser.js.map +1 -1
- package/lib/scanner/structure-validator.js +1 -1
- package/lib/services/metadata-scanner-service.d.ts +2 -0
- package/lib/services/metadata-scanner-service.js +9 -2
- package/lib/services/metadata-scanner-service.js.map +1 -1
- package/lib/services/scanners/additional-metadata-scanner.d.ts +2 -0
- package/lib/services/scanners/additional-metadata-scanner.js +183 -0
- package/lib/services/scanners/additional-metadata-scanner.js.map +1 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.d.ts +1 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.js +11 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.js.map +1 -1
- package/lib/services/scanners/code-metadata-scanner.js +14 -1
- package/lib/services/scanners/code-metadata-scanner.js.map +1 -1
- package/lib/services/scanners/data-metadata-scanner.js +24 -8
- package/lib/services/scanners/data-metadata-scanner.js.map +1 -1
- package/lib/types/metadata.d.ts +1 -1
- package/lib/utils/cache-entry-serializer.d.ts +7 -0
- package/lib/utils/cache-entry-serializer.js +15 -0
- package/lib/utils/cache-entry-serializer.js.map +1 -0
- package/lib/utils/cache-expiry-policy.d.ts +7 -0
- package/lib/utils/cache-expiry-policy.js +34 -0
- package/lib/utils/cache-expiry-policy.js.map +1 -0
- package/lib/utils/cache-key-derivation.d.ts +11 -0
- package/lib/utils/cache-key-derivation.js +28 -0
- package/lib/utils/cache-key-derivation.js.map +1 -0
- package/lib/utils/cache-lock-lifecycle.d.ts +15 -0
- package/lib/utils/cache-lock-lifecycle.js +84 -0
- package/lib/utils/cache-lock-lifecycle.js.map +1 -0
- package/lib/utils/cache-logger.d.ts +8 -0
- package/lib/utils/cache-logger.js +19 -0
- package/lib/utils/cache-logger.js.map +1 -0
- package/lib/utils/cache-manager.d.ts +1 -2
- package/lib/utils/cache-manager.js +7 -253
- package/lib/utils/cache-manager.js.map +1 -1
- package/lib/utils/cache-storage.d.ts +20 -0
- package/lib/utils/cache-storage.js +83 -0
- package/lib/utils/cache-storage.js.map +1 -0
- package/lib/validators/xml-metadata-validator.js +1 -1
- package/lib/waves/priority-wave-generator.js +8 -2
- package/lib/waves/priority-wave-generator.js.map +1 -1
- package/lib/waves/test-optimizer-discovery.d.ts +12 -0
- package/lib/waves/test-optimizer-discovery.js +46 -0
- package/lib/waves/test-optimizer-discovery.js.map +1 -0
- package/lib/waves/test-optimizer-matching.d.ts +6 -0
- package/lib/waves/test-optimizer-matching.js +43 -0
- package/lib/waves/test-optimizer-matching.js.map +1 -0
- package/lib/waves/test-optimizer-model.d.ts +92 -0
- package/lib/waves/test-optimizer-model.js +2 -0
- package/lib/waves/test-optimizer-model.js.map +1 -0
- package/lib/waves/test-optimizer-scoring.d.ts +11 -0
- package/lib/waves/test-optimizer-scoring.js +53 -0
- package/lib/waves/test-optimizer-scoring.js.map +1 -0
- package/lib/waves/test-optimizer.d.ts +2 -102
- package/lib/waves/test-optimizer.js +9 -154
- package/lib/waves/test-optimizer.js.map +1 -1
- package/lib/waves/wave-builder.d.ts +0 -11
- package/lib/waves/wave-builder.js +19 -193
- package/lib/waves/wave-builder.js.map +1 -1
- package/lib/waves/wave-graph.d.ts +25 -0
- package/lib/waves/wave-graph.js +138 -0
- package/lib/waves/wave-graph.js.map +1 -0
- package/lib/waves/wave-metadata.d.ts +4 -0
- package/lib/waves/wave-metadata.js +36 -0
- package/lib/waves/wave-metadata.js.map +1 -0
- package/lib/waves/wave-priority-policy.d.ts +5 -0
- package/lib/waves/wave-priority-policy.js +83 -0
- package/lib/waves/wave-priority-policy.js.map +1 -0
- package/lib/waves/wave-topology.d.ts +28 -0
- package/lib/waves/wave-topology.js +65 -0
- package/lib/waves/wave-topology.js.map +1 -0
- package/messages/start.json +5 -5
- package/messages/validate.json +1 -1
- package/npm-shrinkwrap.json +342 -751
- package/oclif.lock +83 -262
- package/oclif.manifest.json +7 -7
- package/package.json +6 -2
|
@@ -12,91 +12,10 @@
|
|
|
12
12
|
* @issue #38
|
|
13
13
|
*/
|
|
14
14
|
import { getLogger } from '../utils/logger.js';
|
|
15
|
+
import { assembleWaveMetadata, calculateWaveStats } from './wave-metadata.js';
|
|
16
|
+
import { buildEdgeTypesByFrom, compareWavePriority } from './wave-priority-policy.js';
|
|
17
|
+
import { calculateInDegree, collectRemainingNodes, planTopologyStage, updateInDegreeForPlacedCandidates, } from './wave-topology.js';
|
|
15
18
|
const logger = getLogger('WaveBuilder');
|
|
16
|
-
/**
|
|
17
|
-
* Metadata type deployment order (Salesforce recommended)
|
|
18
|
-
*/
|
|
19
|
-
const TYPE_DEPLOYMENT_ORDER = [
|
|
20
|
-
'CustomObject',
|
|
21
|
-
'CustomField',
|
|
22
|
-
'RecordType',
|
|
23
|
-
'BusinessProcess',
|
|
24
|
-
'CompactLayout',
|
|
25
|
-
'Layout',
|
|
26
|
-
'Profile',
|
|
27
|
-
'PermissionSet',
|
|
28
|
-
'ApexClass',
|
|
29
|
-
'ApexTrigger',
|
|
30
|
-
'Flow',
|
|
31
|
-
'ValidationRule',
|
|
32
|
-
'WorkflowRule',
|
|
33
|
-
'EmailTemplate',
|
|
34
|
-
'FlexiPage',
|
|
35
|
-
];
|
|
36
|
-
function calculateInDegree(graph) {
|
|
37
|
-
const inDegree = new Map();
|
|
38
|
-
for (const [nodeId, deps] of graph.entries()) {
|
|
39
|
-
inDegree.set(nodeId, deps.size);
|
|
40
|
-
}
|
|
41
|
-
return inDegree;
|
|
42
|
-
}
|
|
43
|
-
function collectWaveCandidates(inDegree, processed) {
|
|
44
|
-
const candidates = [];
|
|
45
|
-
for (const [nodeId, degree] of inDegree.entries()) {
|
|
46
|
-
if (degree === 0 && !processed.has(nodeId)) {
|
|
47
|
-
candidates.push(nodeId);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
return candidates;
|
|
51
|
-
}
|
|
52
|
-
function collectRemainingNodes(graph, processed) {
|
|
53
|
-
const remaining = [];
|
|
54
|
-
for (const nodeId of graph.keys()) {
|
|
55
|
-
if (!processed.has(nodeId)) {
|
|
56
|
-
remaining.push(nodeId);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
return remaining;
|
|
60
|
-
}
|
|
61
|
-
function chunkArray(array, chunkSize) {
|
|
62
|
-
const chunks = [];
|
|
63
|
-
for (let i = 0; i < array.length; i += chunkSize) {
|
|
64
|
-
chunks.push(array.slice(i, i + chunkSize));
|
|
65
|
-
}
|
|
66
|
-
return chunks;
|
|
67
|
-
}
|
|
68
|
-
function getMetadataTypeDeploymentOrder(type) {
|
|
69
|
-
const order = TYPE_DEPLOYMENT_ORDER.indexOf(type);
|
|
70
|
-
return order === -1 ? 9999 : order;
|
|
71
|
-
}
|
|
72
|
-
function extractMetadataType(nodeId) {
|
|
73
|
-
return nodeId.split(':')[0];
|
|
74
|
-
}
|
|
75
|
-
function compareTypedDependencyRisk(left, right) {
|
|
76
|
-
if (left.inferred !== right.inferred) {
|
|
77
|
-
return left.inferred - right.inferred;
|
|
78
|
-
}
|
|
79
|
-
if (left.soft !== right.soft) {
|
|
80
|
-
return left.soft - right.soft;
|
|
81
|
-
}
|
|
82
|
-
if (left.hard !== right.hard) {
|
|
83
|
-
return right.hard - left.hard;
|
|
84
|
-
}
|
|
85
|
-
return 0;
|
|
86
|
-
}
|
|
87
|
-
function assembleWaveMetadata(components, hasCircularDeps) {
|
|
88
|
-
const types = new Set();
|
|
89
|
-
for (const component of components) {
|
|
90
|
-
types.add(extractMetadataType(component));
|
|
91
|
-
}
|
|
92
|
-
return {
|
|
93
|
-
componentCount: components.length,
|
|
94
|
-
types: Array.from(types),
|
|
95
|
-
maxDepth: 0,
|
|
96
|
-
hasCircularDeps,
|
|
97
|
-
estimatedTime: Math.ceil(components.length * 0.1),
|
|
98
|
-
};
|
|
99
|
-
}
|
|
100
19
|
/**
|
|
101
20
|
* Wave Builder
|
|
102
21
|
*
|
|
@@ -130,12 +49,7 @@ export class WaveBuilder {
|
|
|
130
49
|
handleCircularDeps: options.handleCircularDeps ?? true,
|
|
131
50
|
dependencyEdges: options.dependencyEdges ?? [],
|
|
132
51
|
};
|
|
133
|
-
this.edgeTypesByFrom =
|
|
134
|
-
for (const edge of this.options.dependencyEdges) {
|
|
135
|
-
const existing = this.edgeTypesByFrom.get(edge.from) ?? [];
|
|
136
|
-
existing.push(edge.type);
|
|
137
|
-
this.edgeTypesByFrom.set(edge.from, existing);
|
|
138
|
-
}
|
|
52
|
+
this.edgeTypesByFrom = buildEdgeTypesByFrom(this.options.dependencyEdges);
|
|
139
53
|
logger.debug('Initialized WaveBuilder', {
|
|
140
54
|
maxComponentsPerWave: this.options.maxComponentsPerWave,
|
|
141
55
|
respectTypeOrder: this.options.respectTypeOrder,
|
|
@@ -151,7 +65,12 @@ export class WaveBuilder {
|
|
|
151
65
|
const policy = this.getPlacementPolicy();
|
|
152
66
|
const state = this.createPlacementState(graph);
|
|
153
67
|
while (state.processed.size < graph.size) {
|
|
154
|
-
const topologyStage =
|
|
68
|
+
const topologyStage = planTopologyStage({
|
|
69
|
+
inDegree: state.inDegree,
|
|
70
|
+
processed: state.processed,
|
|
71
|
+
policy,
|
|
72
|
+
comparePriority: (left, right) => this.compareWavePriority(left, right),
|
|
73
|
+
});
|
|
155
74
|
if (topologyStage.orderedCandidates.length === 0) {
|
|
156
75
|
const circularResolution = this.resolveCircularWave(graph, state.processed, state.nextWaveNumber, policy);
|
|
157
76
|
state.unplacedComponents.push(...circularResolution.remaining);
|
|
@@ -165,9 +84,14 @@ export class WaveBuilder {
|
|
|
165
84
|
state.nextWaveNumber += 1;
|
|
166
85
|
this.markProcessed(state.processed, chunk);
|
|
167
86
|
}
|
|
168
|
-
|
|
87
|
+
updateInDegreeForPlacedCandidates({
|
|
88
|
+
graph,
|
|
89
|
+
inDegree: state.inDegree,
|
|
90
|
+
processed: state.processed,
|
|
91
|
+
placedCandidates: topologyStage.orderedCandidates,
|
|
92
|
+
});
|
|
169
93
|
}
|
|
170
|
-
const stats =
|
|
94
|
+
const stats = calculateWaveStats(state.waves);
|
|
171
95
|
const duration = Date.now() - startTime;
|
|
172
96
|
logger.info('Wave generation completed', {
|
|
173
97
|
waves: state.waves.length,
|
|
@@ -200,31 +124,11 @@ export class WaveBuilder {
|
|
|
200
124
|
handleCircularDeps: this.options.handleCircularDeps,
|
|
201
125
|
};
|
|
202
126
|
}
|
|
203
|
-
selectWaveCandidates(inDegree, processed, policy) {
|
|
204
|
-
const candidates = collectWaveCandidates(inDegree, processed);
|
|
205
|
-
if (policy.respectTypeOrder) {
|
|
206
|
-
candidates.sort((left, right) => this.compareWavePriority(left, right));
|
|
207
|
-
}
|
|
208
|
-
return candidates;
|
|
209
|
-
}
|
|
210
|
-
planTopologyStage(state, policy) {
|
|
211
|
-
const orderedCandidates = this.selectWaveCandidates(state.inDegree, state.processed, policy);
|
|
212
|
-
return {
|
|
213
|
-
orderedCandidates,
|
|
214
|
-
chunks: this.createWaveChunks(orderedCandidates, policy.maxComponentsPerWave),
|
|
215
|
-
};
|
|
216
|
-
}
|
|
217
|
-
createWaveChunks(candidates, maxComponentsPerWave) {
|
|
218
|
-
if (maxComponentsPerWave > 0 && candidates.length > maxComponentsPerWave) {
|
|
219
|
-
return chunkArray(candidates, maxComponentsPerWave);
|
|
220
|
-
}
|
|
221
|
-
return [candidates];
|
|
222
|
-
}
|
|
223
127
|
createWave(components, waveNumber, hasCircularDeps) {
|
|
224
128
|
return {
|
|
225
129
|
number: waveNumber,
|
|
226
130
|
components,
|
|
227
|
-
metadata:
|
|
131
|
+
metadata: assembleWaveMetadata(components, hasCircularDeps),
|
|
228
132
|
};
|
|
229
133
|
}
|
|
230
134
|
markProcessed(processed, components) {
|
|
@@ -232,22 +136,6 @@ export class WaveBuilder {
|
|
|
232
136
|
processed.add(nodeId);
|
|
233
137
|
}
|
|
234
138
|
}
|
|
235
|
-
updateInDegreeForPlacedCandidates(graph, inDegree, processed, placedCandidates) {
|
|
236
|
-
for (const [nodeId, deps] of graph.entries()) {
|
|
237
|
-
if (processed.has(nodeId)) {
|
|
238
|
-
continue;
|
|
239
|
-
}
|
|
240
|
-
let removedDeps = 0;
|
|
241
|
-
for (const dep of deps) {
|
|
242
|
-
if (placedCandidates.includes(dep)) {
|
|
243
|
-
removedDeps += 1;
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
if (removedDeps > 0) {
|
|
247
|
-
inDegree.set(nodeId, (inDegree.get(nodeId) ?? 0) - removedDeps);
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
139
|
resolveCircularWave(graph, processed, waveNumber, policy) {
|
|
252
140
|
const remaining = collectRemainingNodes(graph, processed);
|
|
253
141
|
logger.warn('Circular dependencies detected', {
|
|
@@ -265,69 +153,7 @@ export class WaveBuilder {
|
|
|
265
153
|
return { remaining };
|
|
266
154
|
}
|
|
267
155
|
compareWavePriority(a, b) {
|
|
268
|
-
|
|
269
|
-
const priorityB = this.createWavePriorityProfile(b);
|
|
270
|
-
const typeOrderComparison = priorityA.typeOrder - priorityB.typeOrder;
|
|
271
|
-
if (typeOrderComparison !== 0) {
|
|
272
|
-
return typeOrderComparison;
|
|
273
|
-
}
|
|
274
|
-
const riskComparison = compareTypedDependencyRisk(priorityA.riskProfile, priorityB.riskProfile);
|
|
275
|
-
if (riskComparison !== 0) {
|
|
276
|
-
return riskComparison;
|
|
277
|
-
}
|
|
278
|
-
return a.localeCompare(b);
|
|
279
|
-
}
|
|
280
|
-
createWavePriorityProfile(nodeId) {
|
|
281
|
-
const metadataType = extractMetadataType(nodeId);
|
|
282
|
-
return {
|
|
283
|
-
typeOrder: getMetadataTypeDeploymentOrder(metadataType),
|
|
284
|
-
riskProfile: this.getDependencyRiskProfile(nodeId),
|
|
285
|
-
};
|
|
286
|
-
}
|
|
287
|
-
getDependencyRiskProfile(nodeId) {
|
|
288
|
-
const edgeTypes = this.edgeTypesByFrom.get(nodeId) ?? [];
|
|
289
|
-
return edgeTypes.reduce((accumulator, type) => ({
|
|
290
|
-
...accumulator,
|
|
291
|
-
[type]: accumulator[type] + 1,
|
|
292
|
-
}), {
|
|
293
|
-
hard: 0,
|
|
294
|
-
soft: 0,
|
|
295
|
-
inferred: 0,
|
|
296
|
-
});
|
|
297
|
-
}
|
|
298
|
-
assembleWaveMetadata(components, hasCircularDeps) {
|
|
299
|
-
const assembly = assembleWaveMetadata(components, hasCircularDeps);
|
|
300
|
-
return {
|
|
301
|
-
componentCount: assembly.componentCount,
|
|
302
|
-
types: assembly.types,
|
|
303
|
-
maxDepth: assembly.maxDepth,
|
|
304
|
-
hasCircularDeps: assembly.hasCircularDeps,
|
|
305
|
-
estimatedTime: assembly.estimatedTime,
|
|
306
|
-
};
|
|
307
|
-
}
|
|
308
|
-
/**
|
|
309
|
-
* Calculate wave statistics
|
|
310
|
-
*/
|
|
311
|
-
calculateStats(waves) {
|
|
312
|
-
if (waves.length === 0) {
|
|
313
|
-
return {
|
|
314
|
-
totalWaves: 0,
|
|
315
|
-
avgComponentsPerWave: 0,
|
|
316
|
-
largestWaveSize: 0,
|
|
317
|
-
smallestWaveSize: 0,
|
|
318
|
-
totalEstimatedTime: 0,
|
|
319
|
-
};
|
|
320
|
-
}
|
|
321
|
-
const sizes = waves.map((w) => w.components.length);
|
|
322
|
-
const totalComponents = sizes.reduce((sum, size) => sum + size, 0);
|
|
323
|
-
const totalTime = waves.reduce((sum, w) => sum + w.metadata.estimatedTime, 0);
|
|
324
|
-
return {
|
|
325
|
-
totalWaves: waves.length,
|
|
326
|
-
avgComponentsPerWave: Math.round(totalComponents / waves.length),
|
|
327
|
-
largestWaveSize: Math.max(...sizes),
|
|
328
|
-
smallestWaveSize: Math.min(...sizes),
|
|
329
|
-
totalEstimatedTime: totalTime,
|
|
330
|
-
};
|
|
156
|
+
return compareWavePriority(this.edgeTypesByFrom, a, b);
|
|
331
157
|
}
|
|
332
158
|
/**
|
|
333
159
|
* Get wave by number
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wave-builder.js","sourceRoot":"","sources":["../../src/waves/wave-builder.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"wave-builder.js","sourceRoot":"","sources":["../../src/waves/wave-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { DeploymentState } from '../deployment/state-manager.js';
|
|
2
|
+
import type { DependencyGraph, NodeId } from '../types/dependency.js';
|
|
3
|
+
import type { Wave } from './wave-builder.js';
|
|
4
|
+
export type WaveGraphStatus = 'pending' | 'current' | 'completed' | 'failed';
|
|
5
|
+
export type WaveGraphNode = {
|
|
6
|
+
waveNumber: number;
|
|
7
|
+
componentCount: number;
|
|
8
|
+
components: NodeId[];
|
|
9
|
+
status: WaveGraphStatus;
|
|
10
|
+
};
|
|
11
|
+
export type WaveGraphEdge = {
|
|
12
|
+
fromWave: number;
|
|
13
|
+
toWave: number;
|
|
14
|
+
kind: 'sequence' | 'dependency';
|
|
15
|
+
dependencyCount?: number;
|
|
16
|
+
};
|
|
17
|
+
export type WaveGraph = {
|
|
18
|
+
nodes: WaveGraphNode[];
|
|
19
|
+
edges: WaveGraphEdge[];
|
|
20
|
+
visualizations: {
|
|
21
|
+
mermaid: string;
|
|
22
|
+
dot: string;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export declare function buildWaveGraph(waves: readonly Wave[], dependencyGraph: DependencyGraph, state?: DeploymentState | null): WaveGraph;
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
export function buildWaveGraph(waves, dependencyGraph, state) {
|
|
2
|
+
const sortedWaves = [...waves].sort((left, right) => left.number - right.number);
|
|
3
|
+
const componentWaveLookup = buildComponentWaveLookup(sortedWaves);
|
|
4
|
+
const nodes = sortedWaves.map((wave) => ({
|
|
5
|
+
waveNumber: wave.number,
|
|
6
|
+
componentCount: wave.components.length,
|
|
7
|
+
components: [...wave.components],
|
|
8
|
+
status: resolveWaveStatus(wave.number, state),
|
|
9
|
+
}));
|
|
10
|
+
const edges = [...buildSequenceEdges(sortedWaves), ...buildDependencyEdges(dependencyGraph, componentWaveLookup)];
|
|
11
|
+
const visualizations = {
|
|
12
|
+
mermaid: renderWaveGraphMermaid(nodes, edges),
|
|
13
|
+
dot: renderWaveGraphDot(nodes, edges),
|
|
14
|
+
};
|
|
15
|
+
return {
|
|
16
|
+
nodes,
|
|
17
|
+
edges,
|
|
18
|
+
visualizations,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
function buildComponentWaveLookup(waves) {
|
|
22
|
+
const lookup = new Map();
|
|
23
|
+
for (const wave of waves) {
|
|
24
|
+
for (const component of wave.components) {
|
|
25
|
+
lookup.set(component, wave.number);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return lookup;
|
|
29
|
+
}
|
|
30
|
+
function resolveWaveStatus(waveNumber, state) {
|
|
31
|
+
if (!state) {
|
|
32
|
+
return 'pending';
|
|
33
|
+
}
|
|
34
|
+
if (state.failedWave?.waveNumber === waveNumber) {
|
|
35
|
+
return 'failed';
|
|
36
|
+
}
|
|
37
|
+
if (state.completedWaves.includes(waveNumber)) {
|
|
38
|
+
return 'completed';
|
|
39
|
+
}
|
|
40
|
+
if (state.currentWave === waveNumber) {
|
|
41
|
+
return 'current';
|
|
42
|
+
}
|
|
43
|
+
return 'pending';
|
|
44
|
+
}
|
|
45
|
+
function buildSequenceEdges(waves) {
|
|
46
|
+
const edges = [];
|
|
47
|
+
for (let index = 0; index < waves.length - 1; index += 1) {
|
|
48
|
+
edges.push({
|
|
49
|
+
fromWave: waves[index].number,
|
|
50
|
+
toWave: waves[index + 1].number,
|
|
51
|
+
kind: 'sequence',
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
return edges;
|
|
55
|
+
}
|
|
56
|
+
function buildDependencyEdges(dependencyGraph, componentWaveLookup) {
|
|
57
|
+
const dependencyCounts = new Map();
|
|
58
|
+
for (const [dependent, dependencies] of dependencyGraph.entries()) {
|
|
59
|
+
const dependentWave = componentWaveLookup.get(dependent);
|
|
60
|
+
if (dependentWave === undefined) {
|
|
61
|
+
continue;
|
|
62
|
+
}
|
|
63
|
+
for (const dependency of dependencies) {
|
|
64
|
+
const dependencyWave = componentWaveLookup.get(dependency);
|
|
65
|
+
if (dependencyWave === undefined || dependencyWave === dependentWave) {
|
|
66
|
+
continue;
|
|
67
|
+
}
|
|
68
|
+
const key = `${dependencyWave}->${dependentWave}`;
|
|
69
|
+
const existing = dependencyCounts.get(key);
|
|
70
|
+
if (existing) {
|
|
71
|
+
existing.dependencyCount = (existing.dependencyCount ?? 0) + 1;
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
dependencyCounts.set(key, {
|
|
75
|
+
fromWave: dependencyWave,
|
|
76
|
+
toWave: dependentWave,
|
|
77
|
+
kind: 'dependency',
|
|
78
|
+
dependencyCount: 1,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return [...dependencyCounts.values()].sort((left, right) => left.fromWave - right.fromWave || left.toWave - right.toWave || left.kind.localeCompare(right.kind));
|
|
84
|
+
}
|
|
85
|
+
function renderWaveGraphMermaid(nodes, edges) {
|
|
86
|
+
const lines = ['graph LR'];
|
|
87
|
+
for (const node of nodes) {
|
|
88
|
+
lines.push(` W${node.waveNumber}["Wave ${node.waveNumber}<br/>${node.status}<br/>${node.componentCount} components"]`);
|
|
89
|
+
}
|
|
90
|
+
for (const edge of edges) {
|
|
91
|
+
const label = edge.kind === 'dependency'
|
|
92
|
+
? `${edge.dependencyCount ?? 0} dependenc${edge.dependencyCount === 1 ? 'y' : 'ies'}`
|
|
93
|
+
: 'next';
|
|
94
|
+
const connector = edge.kind === 'dependency' ? '==>' : '-->';
|
|
95
|
+
lines.push(` W${edge.fromWave} ${connector}|${label}| W${edge.toWave}`);
|
|
96
|
+
}
|
|
97
|
+
lines.push('');
|
|
98
|
+
lines.push(' classDef pending fill:#f3f4f6,stroke:#6b7280,color:#111827');
|
|
99
|
+
lines.push(' classDef current fill:#dbeafe,stroke:#2563eb,color:#1e3a8a,stroke-width:2px');
|
|
100
|
+
lines.push(' classDef completed fill:#dcfce7,stroke:#16a34a,color:#14532d');
|
|
101
|
+
lines.push(' classDef failed fill:#fee2e2,stroke:#dc2626,color:#7f1d1d,stroke-width:2px');
|
|
102
|
+
for (const node of nodes) {
|
|
103
|
+
lines.push(` class W${node.waveNumber} ${node.status}`);
|
|
104
|
+
}
|
|
105
|
+
return lines.join('\n');
|
|
106
|
+
}
|
|
107
|
+
function renderWaveGraphDot(nodes, edges) {
|
|
108
|
+
const lines = ['digraph WaveGraph {'];
|
|
109
|
+
lines.push(' rankdir=LR;');
|
|
110
|
+
lines.push(' node [shape=box, style="filled,rounded"];');
|
|
111
|
+
lines.push('');
|
|
112
|
+
for (const node of nodes) {
|
|
113
|
+
lines.push(` "W${node.waveNumber}" [label="Wave ${node.waveNumber}\\n${node.status}\\n${node.componentCount} components", fillcolor="${getDotStatusColor(node.status)}"];`);
|
|
114
|
+
}
|
|
115
|
+
lines.push('');
|
|
116
|
+
for (const edge of edges) {
|
|
117
|
+
const label = edge.kind === 'dependency'
|
|
118
|
+
? `${edge.dependencyCount ?? 0} dependenc${edge.dependencyCount === 1 ? 'y' : 'ies'}`
|
|
119
|
+
: 'next';
|
|
120
|
+
const attributes = edge.kind === 'dependency' ? `label="${label}", penwidth=2.0` : `label="${label}", style=dashed`;
|
|
121
|
+
lines.push(` "W${edge.fromWave}" -> "W${edge.toWave}" [${attributes}];`);
|
|
122
|
+
}
|
|
123
|
+
lines.push('}');
|
|
124
|
+
return lines.join('\n');
|
|
125
|
+
}
|
|
126
|
+
function getDotStatusColor(status) {
|
|
127
|
+
switch (status) {
|
|
128
|
+
case 'completed':
|
|
129
|
+
return '#dcfce7';
|
|
130
|
+
case 'current':
|
|
131
|
+
return '#dbeafe';
|
|
132
|
+
case 'failed':
|
|
133
|
+
return '#fee2e2';
|
|
134
|
+
case 'pending':
|
|
135
|
+
return '#f3f4f6';
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=wave-graph.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wave-graph.js","sourceRoot":"","sources":["../../src/waves/wave-graph.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeId } from '../types/dependency.js';
|
|
2
|
+
import type { Wave, WaveMetadata, WaveStats } from './wave-builder.js';
|
|
3
|
+
export declare function assembleWaveMetadata(components: NodeId[], hasCircularDeps: boolean): WaveMetadata;
|
|
4
|
+
export declare function calculateWaveStats(waves: Wave[]): WaveStats;
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { extractMetadataType } from './wave-priority-policy.js';
|
|
2
|
+
export function assembleWaveMetadata(components, hasCircularDeps) {
|
|
3
|
+
const types = new Set();
|
|
4
|
+
for (const component of components) {
|
|
5
|
+
types.add(extractMetadataType(component));
|
|
6
|
+
}
|
|
7
|
+
return {
|
|
8
|
+
componentCount: components.length,
|
|
9
|
+
types: Array.from(types),
|
|
10
|
+
maxDepth: 0,
|
|
11
|
+
hasCircularDeps,
|
|
12
|
+
estimatedTime: Math.ceil(components.length * 0.1),
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export function calculateWaveStats(waves) {
|
|
16
|
+
if (waves.length === 0) {
|
|
17
|
+
return {
|
|
18
|
+
totalWaves: 0,
|
|
19
|
+
avgComponentsPerWave: 0,
|
|
20
|
+
largestWaveSize: 0,
|
|
21
|
+
smallestWaveSize: 0,
|
|
22
|
+
totalEstimatedTime: 0,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
const sizes = waves.map((w) => w.components.length);
|
|
26
|
+
const totalComponents = sizes.reduce((sum, size) => sum + size, 0);
|
|
27
|
+
const totalTime = waves.reduce((sum, w) => sum + w.metadata.estimatedTime, 0);
|
|
28
|
+
return {
|
|
29
|
+
totalWaves: waves.length,
|
|
30
|
+
avgComponentsPerWave: Math.round(totalComponents / waves.length),
|
|
31
|
+
largestWaveSize: Math.max(...sizes),
|
|
32
|
+
smallestWaveSize: Math.min(...sizes),
|
|
33
|
+
totalEstimatedTime: totalTime,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=wave-metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wave-metadata.js","sourceRoot":"","sources":["../../src/waves/wave-metadata.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAEhE,MAAM,UAAU,oBAAoB,CAAC,UAAoB,EAAE,eAAwB;IACjF,MAAM,KAAK,GAAG,IAAI,GAAG,EAAgB,CAAC;IAEtC,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO;QACL,cAAc,EAAE,UAAU,CAAC,MAAM;QACjC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;QACxB,QAAQ,EAAE,CAAC;QACX,eAAe;QACf,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,GAAG,CAAC;KAClD,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAa;IAC9C,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,OAAO;YACL,UAAU,EAAE,CAAC;YACb,oBAAoB,EAAE,CAAC;YACvB,eAAe,EAAE,CAAC;YAClB,gBAAgB,EAAE,CAAC;YACnB,kBAAkB,EAAE,CAAC;SACtB,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACpD,MAAM,eAAe,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;IACnE,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IAE9E,OAAO;QACL,UAAU,EAAE,KAAK,CAAC,MAAM;QACxB,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC,MAAM,CAAC;QAChE,eAAe,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACnC,gBAAgB,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACpC,kBAAkB,EAAE,SAAS;KAC9B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { NodeId, DependencyEdge } from '../types/dependency.js';
|
|
2
|
+
import type { MetadataType } from '../types/metadata.js';
|
|
3
|
+
export declare function buildEdgeTypesByFrom(dependencyEdges: readonly DependencyEdge[]): Map<NodeId, Array<DependencyEdge['type']>>;
|
|
4
|
+
export declare function compareWavePriority(edgeTypesByFrom: ReadonlyMap<NodeId, Array<DependencyEdge['type']>>, a: NodeId, b: NodeId): number;
|
|
5
|
+
export declare function extractMetadataType(nodeId: NodeId): MetadataType;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
const TYPE_DEPLOYMENT_ORDER = [
|
|
2
|
+
'CustomObject',
|
|
3
|
+
'CustomField',
|
|
4
|
+
'RecordType',
|
|
5
|
+
'BusinessProcess',
|
|
6
|
+
'Queue',
|
|
7
|
+
'CompactLayout',
|
|
8
|
+
'Layout',
|
|
9
|
+
'ApexClass',
|
|
10
|
+
'ApexTrigger',
|
|
11
|
+
'Flow',
|
|
12
|
+
'ValidationRule',
|
|
13
|
+
'WorkflowRule',
|
|
14
|
+
'EmailTemplate',
|
|
15
|
+
'BrandingSet',
|
|
16
|
+
'CustomSite',
|
|
17
|
+
'Network',
|
|
18
|
+
'DigitalExperienceBundle',
|
|
19
|
+
'EmbeddedServiceConfig',
|
|
20
|
+
'FlexiPage',
|
|
21
|
+
'Profile',
|
|
22
|
+
'PermissionSet',
|
|
23
|
+
];
|
|
24
|
+
export function buildEdgeTypesByFrom(dependencyEdges) {
|
|
25
|
+
const edgeTypesByFrom = new Map();
|
|
26
|
+
for (const edge of dependencyEdges) {
|
|
27
|
+
const existing = edgeTypesByFrom.get(edge.from) ?? [];
|
|
28
|
+
existing.push(edge.type);
|
|
29
|
+
edgeTypesByFrom.set(edge.from, existing);
|
|
30
|
+
}
|
|
31
|
+
return edgeTypesByFrom;
|
|
32
|
+
}
|
|
33
|
+
export function compareWavePriority(edgeTypesByFrom, a, b) {
|
|
34
|
+
const priorityA = createWavePriorityProfile(edgeTypesByFrom, a);
|
|
35
|
+
const priorityB = createWavePriorityProfile(edgeTypesByFrom, b);
|
|
36
|
+
const typeOrderComparison = priorityA.typeOrder - priorityB.typeOrder;
|
|
37
|
+
if (typeOrderComparison !== 0) {
|
|
38
|
+
return typeOrderComparison;
|
|
39
|
+
}
|
|
40
|
+
const riskComparison = compareTypedDependencyRisk(priorityA.riskProfile, priorityB.riskProfile);
|
|
41
|
+
if (riskComparison !== 0) {
|
|
42
|
+
return riskComparison;
|
|
43
|
+
}
|
|
44
|
+
return a.localeCompare(b);
|
|
45
|
+
}
|
|
46
|
+
export function extractMetadataType(nodeId) {
|
|
47
|
+
return nodeId.split(':')[0];
|
|
48
|
+
}
|
|
49
|
+
function createWavePriorityProfile(edgeTypesByFrom, nodeId) {
|
|
50
|
+
const metadataType = extractMetadataType(nodeId);
|
|
51
|
+
return {
|
|
52
|
+
typeOrder: getMetadataTypeDeploymentOrder(metadataType),
|
|
53
|
+
riskProfile: getDependencyRiskProfile(edgeTypesByFrom, nodeId),
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function getMetadataTypeDeploymentOrder(type) {
|
|
57
|
+
const order = TYPE_DEPLOYMENT_ORDER.indexOf(type);
|
|
58
|
+
return order === -1 ? 9999 : order;
|
|
59
|
+
}
|
|
60
|
+
function getDependencyRiskProfile(edgeTypesByFrom, nodeId) {
|
|
61
|
+
const edgeTypes = edgeTypesByFrom.get(nodeId) ?? [];
|
|
62
|
+
return edgeTypes.reduce((accumulator, type) => ({
|
|
63
|
+
...accumulator,
|
|
64
|
+
[type]: accumulator[type] + 1,
|
|
65
|
+
}), {
|
|
66
|
+
hard: 0,
|
|
67
|
+
soft: 0,
|
|
68
|
+
inferred: 0,
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
function compareTypedDependencyRisk(left, right) {
|
|
72
|
+
if (left.inferred !== right.inferred) {
|
|
73
|
+
return left.inferred - right.inferred;
|
|
74
|
+
}
|
|
75
|
+
if (left.soft !== right.soft) {
|
|
76
|
+
return left.soft - right.soft;
|
|
77
|
+
}
|
|
78
|
+
if (left.hard !== right.hard) {
|
|
79
|
+
return right.hard - left.hard;
|
|
80
|
+
}
|
|
81
|
+
return 0;
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=wave-priority-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wave-priority-policy.js","sourceRoot":"","sources":["../../src/waves/wave-priority-policy.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { NodeId, DependencyGraph } from '../types/dependency.js';
|
|
2
|
+
export type WavePlacementPolicy = {
|
|
3
|
+
maxComponentsPerWave: number;
|
|
4
|
+
respectTypeOrder: boolean;
|
|
5
|
+
handleCircularDeps: boolean;
|
|
6
|
+
};
|
|
7
|
+
export type WaveTopologyStage = {
|
|
8
|
+
orderedCandidates: NodeId[];
|
|
9
|
+
chunks: NodeId[][];
|
|
10
|
+
};
|
|
11
|
+
export type CircularWaveResolutionInput = {
|
|
12
|
+
graph: DependencyGraph;
|
|
13
|
+
processed: ReadonlySet<NodeId>;
|
|
14
|
+
};
|
|
15
|
+
export declare function calculateInDegree(graph: DependencyGraph): Map<NodeId, number>;
|
|
16
|
+
export declare function planTopologyStage({ inDegree, processed, policy, comparePriority, }: {
|
|
17
|
+
inDegree: ReadonlyMap<NodeId, number>;
|
|
18
|
+
processed: ReadonlySet<NodeId>;
|
|
19
|
+
policy: WavePlacementPolicy;
|
|
20
|
+
comparePriority: (left: NodeId, right: NodeId) => number;
|
|
21
|
+
}): WaveTopologyStage;
|
|
22
|
+
export declare function collectRemainingNodes(graph: DependencyGraph, processed: ReadonlySet<NodeId>): NodeId[];
|
|
23
|
+
export declare function updateInDegreeForPlacedCandidates({ graph, inDegree, processed, placedCandidates, }: {
|
|
24
|
+
graph: DependencyGraph;
|
|
25
|
+
inDegree: Map<NodeId, number>;
|
|
26
|
+
processed: ReadonlySet<NodeId>;
|
|
27
|
+
placedCandidates: readonly NodeId[];
|
|
28
|
+
}): void;
|