@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.
Files changed (259) hide show
  1. package/README.md +3 -2
  2. package/lib/ai/wave-validation-prompt.d.ts +2 -0
  3. package/lib/ai/wave-validation-prompt.js +56 -0
  4. package/lib/ai/wave-validation-prompt.js.map +1 -0
  5. package/lib/ai/wave-validation-report.d.ts +2 -0
  6. package/lib/ai/wave-validation-report.js +96 -0
  7. package/lib/ai/wave-validation-report.js.map +1 -0
  8. package/lib/ai/wave-validation-response-parser.d.ts +8 -0
  9. package/lib/ai/wave-validation-response-parser.js +112 -0
  10. package/lib/ai/wave-validation-response-parser.js.map +1 -0
  11. package/lib/ai/wave-validation-result-synthesis.d.ts +6 -0
  12. package/lib/ai/wave-validation-result-synthesis.js +49 -0
  13. package/lib/ai/wave-validation-result-synthesis.js.map +1 -0
  14. package/lib/ai/wave-validation-service.d.ts +1 -55
  15. package/lib/ai/wave-validation-service.js +11 -359
  16. package/lib/ai/wave-validation-service.js.map +1 -1
  17. package/lib/ai/wave-validation-transport.d.ts +7 -0
  18. package/lib/ai/wave-validation-transport.js +10 -0
  19. package/lib/ai/wave-validation-transport.js.map +1 -0
  20. package/lib/analysis/analysis-reporter.d.ts +29 -0
  21. package/lib/analysis/analysis-reporter.js +84 -1
  22. package/lib/analysis/analysis-reporter.js.map +1 -1
  23. package/lib/analysis/analyze-context-service.d.ts +1 -1
  24. package/lib/analysis/analyze-context-service.js +2 -0
  25. package/lib/analysis/analyze-context-service.js.map +1 -1
  26. package/lib/analysis/project-analysis-service.d.ts +2 -0
  27. package/lib/analysis/project-analysis-service.js +2 -0
  28. package/lib/analysis/project-analysis-service.js.map +1 -1
  29. package/lib/commands/start.d.ts +1 -0
  30. package/lib/commands/start.js +14 -1
  31. package/lib/commands/start.js.map +1 -1
  32. package/lib/commands/status.d.ts +2 -0
  33. package/lib/commands/status.js +1 -0
  34. package/lib/commands/status.js.map +1 -1
  35. package/lib/commands/validate.d.ts +3 -3
  36. package/lib/commands/validate.js +4 -4
  37. package/lib/commands/validate.js.map +1 -1
  38. package/lib/constants/api-version.d.ts +2 -2
  39. package/lib/constants/api-version.js +2 -2
  40. package/lib/constants/deployment-order.js +11 -8
  41. package/lib/constants/deployment-order.js.map +1 -1
  42. package/lib/dependencies/circular-dependency-detector.d.ts +1 -31
  43. package/lib/dependencies/circular-dependency-detector.js +7 -156
  44. package/lib/dependencies/circular-dependency-detector.js.map +1 -1
  45. package/lib/dependencies/cycle-break-suggestions.d.ts +3 -0
  46. package/lib/dependencies/cycle-break-suggestions.js +63 -0
  47. package/lib/dependencies/cycle-break-suggestions.js.map +1 -0
  48. package/lib/dependencies/cycle-discovery.d.ts +16 -0
  49. package/lib/dependencies/cycle-discovery.js +70 -0
  50. package/lib/dependencies/cycle-discovery.js.map +1 -0
  51. package/lib/dependencies/dependency-graph-builder.d.ts +0 -65
  52. package/lib/dependencies/dependency-graph-builder.js +19 -233
  53. package/lib/dependencies/dependency-graph-builder.js.map +1 -1
  54. package/lib/dependencies/dependency-graph-intake.d.ts +17 -0
  55. package/lib/dependencies/dependency-graph-intake.js +20 -0
  56. package/lib/dependencies/dependency-graph-intake.js.map +1 -0
  57. package/lib/dependencies/dependency-graph-stats.d.ts +4 -0
  58. package/lib/dependencies/dependency-graph-stats.js +82 -0
  59. package/lib/dependencies/dependency-graph-stats.js.map +1 -0
  60. package/lib/dependencies/dependency-graph-validation.d.ts +16 -0
  61. package/lib/dependencies/dependency-graph-validation.js +78 -0
  62. package/lib/dependencies/dependency-graph-validation.js.map +1 -0
  63. package/lib/dependencies/dependency-impact-analyzer.d.ts +1 -22
  64. package/lib/dependencies/dependency-impact-analyzer.js +12 -110
  65. package/lib/dependencies/dependency-impact-analyzer.js.map +1 -1
  66. package/lib/dependencies/dependency-impact-scoring.d.ts +5 -0
  67. package/lib/dependencies/dependency-impact-scoring.js +24 -0
  68. package/lib/dependencies/dependency-impact-scoring.js.map +1 -0
  69. package/lib/dependencies/dependency-impact-traversal.d.ts +18 -0
  70. package/lib/dependencies/dependency-impact-traversal.js +74 -0
  71. package/lib/dependencies/dependency-impact-traversal.js.map +1 -0
  72. package/lib/dependencies/dependency-resolution-classifier.d.ts +19 -0
  73. package/lib/dependencies/dependency-resolution-classifier.js +67 -0
  74. package/lib/dependencies/dependency-resolution-classifier.js.map +1 -0
  75. package/lib/dependencies/dependency-resolver.d.ts +1 -48
  76. package/lib/dependencies/dependency-resolver.js +12 -181
  77. package/lib/dependencies/dependency-resolver.js.map +1 -1
  78. package/lib/dependencies/dynamic-query-dependency-references.d.ts +3 -0
  79. package/lib/dependencies/dynamic-query-dependency-references.js +41 -0
  80. package/lib/dependencies/dynamic-query-dependency-references.js.map +1 -0
  81. package/lib/dependencies/topological-dependency-sorter.d.ts +10 -0
  82. package/lib/dependencies/topological-dependency-sorter.js +84 -0
  83. package/lib/dependencies/topological-dependency-sorter.js.map +1 -0
  84. package/lib/deployment/cycle-remediation-runner.d.ts +1 -0
  85. package/lib/deployment/cycle-remediation-runner.js +5 -1
  86. package/lib/deployment/cycle-remediation-runner.js.map +1 -1
  87. package/lib/deployment/deployment-runner.d.ts +3 -1
  88. package/lib/deployment/deployment-runner.js +6 -1
  89. package/lib/deployment/deployment-runner.js.map +1 -1
  90. package/lib/deployment/deployment-status-service.d.ts +2 -0
  91. package/lib/deployment/deployment-status-service.js +2 -0
  92. package/lib/deployment/deployment-status-service.js.map +1 -1
  93. package/lib/deployment/deployment-validation-service.js +1 -1
  94. package/lib/deployment/deployment-validation-service.js.map +1 -1
  95. package/lib/deployment/dynamic-query-target-validator.d.ts +24 -0
  96. package/lib/deployment/dynamic-query-target-validator.js +65 -0
  97. package/lib/deployment/dynamic-query-target-validator.js.map +1 -0
  98. package/lib/deployment/sf-cli-integration.d.ts +1 -0
  99. package/lib/deployment/sf-cli-integration.js +1 -1
  100. package/lib/deployment/sf-cli-integration.js.map +1 -1
  101. package/lib/deployment/sf-cli-metadata-lookup.d.ts +4 -0
  102. package/lib/deployment/sf-cli-metadata-lookup.js +26 -0
  103. package/lib/deployment/sf-cli-metadata-lookup.js.map +1 -0
  104. package/lib/deployment/start-execution-service.d.ts +5 -0
  105. package/lib/deployment/start-execution-service.js +26 -6
  106. package/lib/deployment/start-execution-service.js.map +1 -1
  107. package/lib/deployment/wave-graph-state.d.ts +6 -0
  108. package/lib/deployment/wave-graph-state.js +89 -0
  109. package/lib/deployment/wave-graph-state.js.map +1 -0
  110. package/lib/deployment/wave-manifest-service.d.ts +1 -0
  111. package/lib/deployment/wave-manifest-service.js +1 -1
  112. package/lib/deployment/wave-manifest-service.js.map +1 -1
  113. package/lib/errors/deployment-error.js +1 -1
  114. package/lib/errors/deployment-error.js.map +1 -1
  115. package/lib/parsers/apex-class-dependencies.d.ts +4 -0
  116. package/lib/parsers/apex-class-dependencies.js +122 -0
  117. package/lib/parsers/apex-class-dependencies.js.map +1 -0
  118. package/lib/parsers/apex-class-lexical.d.ts +3 -0
  119. package/lib/parsers/apex-class-lexical.js +101 -0
  120. package/lib/parsers/apex-class-lexical.js.map +1 -0
  121. package/lib/parsers/apex-class-names.d.ts +18 -0
  122. package/lib/parsers/apex-class-names.js +93 -0
  123. package/lib/parsers/apex-class-names.js.map +1 -0
  124. package/lib/parsers/apex-class-parser-model.d.ts +59 -0
  125. package/lib/parsers/apex-class-parser-model.js +2 -0
  126. package/lib/parsers/apex-class-parser-model.js.map +1 -0
  127. package/lib/parsers/apex-class-parser.d.ts +3 -29
  128. package/lib/parsers/apex-class-parser.js +10 -395
  129. package/lib/parsers/apex-class-parser.js.map +1 -1
  130. package/lib/parsers/apex-class-symbols.d.ts +2 -0
  131. package/lib/parsers/apex-class-symbols.js +61 -0
  132. package/lib/parsers/apex-class-symbols.js.map +1 -0
  133. package/lib/parsers/apex-dynamic-query-analysis.d.ts +2 -0
  134. package/lib/parsers/apex-dynamic-query-analysis.js +150 -0
  135. package/lib/parsers/apex-dynamic-query-analysis.js.map +1 -0
  136. package/lib/parsers/custom-metadata-dynamic-query-analysis.d.ts +2 -0
  137. package/lib/parsers/custom-metadata-dynamic-query-analysis.js +50 -0
  138. package/lib/parsers/custom-metadata-dynamic-query-analysis.js.map +1 -0
  139. package/lib/parsers/custom-metadata-parser.d.ts +2 -0
  140. package/lib/parsers/custom-metadata-parser.js +3 -0
  141. package/lib/parsers/custom-metadata-parser.js.map +1 -1
  142. package/lib/parsers/custom-object-dependency-builder.d.ts +3 -0
  143. package/lib/parsers/custom-object-dependency-builder.js +103 -0
  144. package/lib/parsers/custom-object-dependency-builder.js.map +1 -0
  145. package/lib/parsers/custom-object-parser.js +1 -208
  146. package/lib/parsers/custom-object-parser.js.map +1 -1
  147. package/lib/parsers/custom-object-reference-helpers.d.ts +4 -0
  148. package/lib/parsers/custom-object-reference-helpers.js +92 -0
  149. package/lib/parsers/custom-object-reference-helpers.js.map +1 -0
  150. package/lib/parsers/dynamic-query-reference.d.ts +16 -0
  151. package/lib/parsers/dynamic-query-reference.js +65 -0
  152. package/lib/parsers/dynamic-query-reference.js.map +1 -0
  153. package/lib/parsers/layout-action-analysis.d.ts +6 -0
  154. package/lib/parsers/layout-action-analysis.js +36 -0
  155. package/lib/parsers/layout-action-analysis.js.map +1 -0
  156. package/lib/parsers/layout-parser.js +4 -272
  157. package/lib/parsers/layout-parser.js.map +1 -1
  158. package/lib/parsers/layout-reference-analysis.d.ts +9 -0
  159. package/lib/parsers/layout-reference-analysis.js +70 -0
  160. package/lib/parsers/layout-reference-analysis.js.map +1 -0
  161. package/lib/parsers/layout-result-assembly.d.ts +5 -0
  162. package/lib/parsers/layout-result-assembly.js +35 -0
  163. package/lib/parsers/layout-result-assembly.js.map +1 -0
  164. package/lib/parsers/layout-section-analysis.d.ts +7 -0
  165. package/lib/parsers/layout-section-analysis.js +9 -0
  166. package/lib/parsers/layout-section-analysis.js.map +1 -0
  167. package/lib/parsers/lwc-code-analysis.d.ts +10 -0
  168. package/lib/parsers/lwc-code-analysis.js +161 -0
  169. package/lib/parsers/lwc-code-analysis.js.map +1 -0
  170. package/lib/parsers/lwc-metadata-analysis.d.ts +6 -0
  171. package/lib/parsers/lwc-metadata-analysis.js +112 -0
  172. package/lib/parsers/lwc-metadata-analysis.js.map +1 -0
  173. package/lib/parsers/lwc-parser.d.ts +3 -27
  174. package/lib/parsers/lwc-parser.js +6 -377
  175. package/lib/parsers/lwc-parser.js.map +1 -1
  176. package/lib/parsers/lwc-result-assembly.d.ts +4 -0
  177. package/lib/parsers/lwc-result-assembly.js +47 -0
  178. package/lib/parsers/lwc-result-assembly.js.map +1 -0
  179. package/lib/presentation/status-command-presenter.d.ts +1 -0
  180. package/lib/presentation/status-command-presenter.js +20 -0
  181. package/lib/presentation/status-command-presenter.js.map +1 -1
  182. package/lib/scanner/forceignore-parser.d.ts +1 -0
  183. package/lib/scanner/forceignore-parser.js +14 -3
  184. package/lib/scanner/forceignore-parser.js.map +1 -1
  185. package/lib/scanner/structure-validator.js +1 -1
  186. package/lib/services/metadata-scanner-service.d.ts +2 -0
  187. package/lib/services/metadata-scanner-service.js +9 -2
  188. package/lib/services/metadata-scanner-service.js.map +1 -1
  189. package/lib/services/scanners/additional-metadata-scanner.d.ts +2 -0
  190. package/lib/services/scanners/additional-metadata-scanner.js +183 -0
  191. package/lib/services/scanners/additional-metadata-scanner.js.map +1 -0
  192. package/lib/services/scanners/automation-ai-metadata-scanner.d.ts +1 -0
  193. package/lib/services/scanners/automation-ai-metadata-scanner.js +11 -0
  194. package/lib/services/scanners/automation-ai-metadata-scanner.js.map +1 -1
  195. package/lib/services/scanners/code-metadata-scanner.js +14 -1
  196. package/lib/services/scanners/code-metadata-scanner.js.map +1 -1
  197. package/lib/services/scanners/data-metadata-scanner.js +24 -8
  198. package/lib/services/scanners/data-metadata-scanner.js.map +1 -1
  199. package/lib/types/metadata.d.ts +1 -1
  200. package/lib/utils/cache-entry-serializer.d.ts +7 -0
  201. package/lib/utils/cache-entry-serializer.js +15 -0
  202. package/lib/utils/cache-entry-serializer.js.map +1 -0
  203. package/lib/utils/cache-expiry-policy.d.ts +7 -0
  204. package/lib/utils/cache-expiry-policy.js +34 -0
  205. package/lib/utils/cache-expiry-policy.js.map +1 -0
  206. package/lib/utils/cache-key-derivation.d.ts +11 -0
  207. package/lib/utils/cache-key-derivation.js +28 -0
  208. package/lib/utils/cache-key-derivation.js.map +1 -0
  209. package/lib/utils/cache-lock-lifecycle.d.ts +15 -0
  210. package/lib/utils/cache-lock-lifecycle.js +84 -0
  211. package/lib/utils/cache-lock-lifecycle.js.map +1 -0
  212. package/lib/utils/cache-logger.d.ts +8 -0
  213. package/lib/utils/cache-logger.js +19 -0
  214. package/lib/utils/cache-logger.js.map +1 -0
  215. package/lib/utils/cache-manager.d.ts +1 -2
  216. package/lib/utils/cache-manager.js +7 -253
  217. package/lib/utils/cache-manager.js.map +1 -1
  218. package/lib/utils/cache-storage.d.ts +20 -0
  219. package/lib/utils/cache-storage.js +83 -0
  220. package/lib/utils/cache-storage.js.map +1 -0
  221. package/lib/validators/xml-metadata-validator.js +1 -1
  222. package/lib/waves/priority-wave-generator.js +8 -2
  223. package/lib/waves/priority-wave-generator.js.map +1 -1
  224. package/lib/waves/test-optimizer-discovery.d.ts +12 -0
  225. package/lib/waves/test-optimizer-discovery.js +46 -0
  226. package/lib/waves/test-optimizer-discovery.js.map +1 -0
  227. package/lib/waves/test-optimizer-matching.d.ts +6 -0
  228. package/lib/waves/test-optimizer-matching.js +43 -0
  229. package/lib/waves/test-optimizer-matching.js.map +1 -0
  230. package/lib/waves/test-optimizer-model.d.ts +92 -0
  231. package/lib/waves/test-optimizer-model.js +2 -0
  232. package/lib/waves/test-optimizer-model.js.map +1 -0
  233. package/lib/waves/test-optimizer-scoring.d.ts +11 -0
  234. package/lib/waves/test-optimizer-scoring.js +53 -0
  235. package/lib/waves/test-optimizer-scoring.js.map +1 -0
  236. package/lib/waves/test-optimizer.d.ts +2 -102
  237. package/lib/waves/test-optimizer.js +9 -154
  238. package/lib/waves/test-optimizer.js.map +1 -1
  239. package/lib/waves/wave-builder.d.ts +0 -11
  240. package/lib/waves/wave-builder.js +19 -193
  241. package/lib/waves/wave-builder.js.map +1 -1
  242. package/lib/waves/wave-graph.d.ts +25 -0
  243. package/lib/waves/wave-graph.js +138 -0
  244. package/lib/waves/wave-graph.js.map +1 -0
  245. package/lib/waves/wave-metadata.d.ts +4 -0
  246. package/lib/waves/wave-metadata.js +36 -0
  247. package/lib/waves/wave-metadata.js.map +1 -0
  248. package/lib/waves/wave-priority-policy.d.ts +5 -0
  249. package/lib/waves/wave-priority-policy.js +83 -0
  250. package/lib/waves/wave-priority-policy.js.map +1 -0
  251. package/lib/waves/wave-topology.d.ts +28 -0
  252. package/lib/waves/wave-topology.js +65 -0
  253. package/lib/waves/wave-topology.js.map +1 -0
  254. package/messages/start.json +5 -5
  255. package/messages/validate.json +1 -1
  256. package/npm-shrinkwrap.json +342 -751
  257. package/oclif.lock +83 -262
  258. package/oclif.manifest.json +7 -7
  259. 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 = new Map();
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 = this.planTopologyStage(state, policy);
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
- this.updateInDegreeForPlacedCandidates(graph, state.inDegree, state.processed, topologyStage.orderedCandidates);
87
+ updateInDegreeForPlacedCandidates({
88
+ graph,
89
+ inDegree: state.inDegree,
90
+ processed: state.processed,
91
+ placedCandidates: topologyStage.orderedCandidates,
92
+ });
169
93
  }
170
- const stats = this.calculateStats(state.waves);
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: this.assembleWaveMetadata(components, hasCircularDeps),
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
- const priorityA = this.createWavePriorityProfile(a);
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;