@jterrats/smart-deployment 1.0.3
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 +193 -0
- package/lib/ai/agentforce-error-handler.d.ts +81 -0
- package/lib/ai/agentforce-error-handler.js +196 -0
- package/lib/ai/agentforce-error-handler.js.map +1 -0
- package/lib/ai/agentforce-priority-service.d.ts +82 -0
- package/lib/ai/agentforce-priority-service.js +257 -0
- package/lib/ai/agentforce-priority-service.js.map +1 -0
- package/lib/ai/agentforce-service.d.ts +99 -0
- package/lib/ai/agentforce-service.js +300 -0
- package/lib/ai/agentforce-service.js.map +1 -0
- package/lib/ai/circuit-breaker.d.ts +115 -0
- package/lib/ai/circuit-breaker.js +277 -0
- package/lib/ai/circuit-breaker.js.map +1 -0
- package/lib/ai/dependency-inference-service.d.ts +76 -0
- package/lib/ai/dependency-inference-service.js +220 -0
- package/lib/ai/dependency-inference-service.js.map +1 -0
- package/lib/ai/llm-provider-factory.d.ts +15 -0
- package/lib/ai/llm-provider-factory.js +36 -0
- package/lib/ai/llm-provider-factory.js.map +1 -0
- package/lib/ai/llm-provider.d.ts +27 -0
- package/lib/ai/llm-provider.js +2 -0
- package/lib/ai/llm-provider.js.map +1 -0
- package/lib/ai/openai-service.d.ts +20 -0
- package/lib/ai/openai-service.js +89 -0
- package/lib/ai/openai-service.js.map +1 -0
- package/lib/ai/prompt-builder.d.ts +79 -0
- package/lib/ai/prompt-builder.js +180 -0
- package/lib/ai/prompt-builder.js.map +1 -0
- package/lib/ai/response-parser.d.ts +67 -0
- package/lib/ai/response-parser.js +234 -0
- package/lib/ai/response-parser.js.map +1 -0
- package/lib/ai/wave-validation-service.d.ts +111 -0
- package/lib/ai/wave-validation-service.js +381 -0
- package/lib/ai/wave-validation-service.js.map +1 -0
- package/lib/analysis/analysis-reporter.d.ts +56 -0
- package/lib/analysis/analysis-reporter.js +170 -0
- package/lib/analysis/analysis-reporter.js.map +1 -0
- package/lib/analytics/error-analytics.d.ts +80 -0
- package/lib/analytics/error-analytics.js +162 -0
- package/lib/analytics/error-analytics.js.map +1 -0
- package/lib/commands/analyze.d.ts +49 -0
- package/lib/commands/analyze.js +232 -0
- package/lib/commands/analyze.js.map +1 -0
- package/lib/commands/config.d.ts +42 -0
- package/lib/commands/config.js +219 -0
- package/lib/commands/config.js.map +1 -0
- package/lib/commands/resume.d.ts +26 -0
- package/lib/commands/resume.js +69 -0
- package/lib/commands/resume.js.map +1 -0
- package/lib/commands/start.d.ts +70 -0
- package/lib/commands/start.js +659 -0
- package/lib/commands/start.js.map +1 -0
- package/lib/commands/status.d.ts +37 -0
- package/lib/commands/status.js +69 -0
- package/lib/commands/status.js.map +1 -0
- package/lib/commands/validate.d.ts +33 -0
- package/lib/commands/validate.js +66 -0
- package/lib/commands/validate.js.map +1 -0
- package/lib/config/repo-config.d.ts +22 -0
- package/lib/config/repo-config.js +31 -0
- package/lib/config/repo-config.js.map +1 -0
- package/lib/constants/agentforce-limits.d.ts +174 -0
- package/lib/constants/agentforce-limits.js +262 -0
- package/lib/constants/agentforce-limits.js.map +1 -0
- package/lib/constants/api-version.d.ts +70 -0
- package/lib/constants/api-version.js +122 -0
- package/lib/constants/api-version.js.map +1 -0
- package/lib/constants/deployment-order.d.ts +68 -0
- package/lib/constants/deployment-order.js +162 -0
- package/lib/constants/deployment-order.js.map +1 -0
- package/lib/constants/salesforce-limits.d.ts +107 -0
- package/lib/constants/salesforce-limits.js +104 -0
- package/lib/constants/salesforce-limits.js.map +1 -0
- package/lib/dependencies/circular-dependency-detector.d.ts +137 -0
- package/lib/dependencies/circular-dependency-detector.js +329 -0
- package/lib/dependencies/circular-dependency-detector.js.map +1 -0
- package/lib/dependencies/cycle-remediation-planner.d.ts +50 -0
- package/lib/dependencies/cycle-remediation-planner.js +192 -0
- package/lib/dependencies/cycle-remediation-planner.js.map +1 -0
- package/lib/dependencies/dependency-cache.d.ts +134 -0
- package/lib/dependencies/dependency-cache.js +303 -0
- package/lib/dependencies/dependency-cache.js.map +1 -0
- package/lib/dependencies/dependency-depth-calculator.d.ts +145 -0
- package/lib/dependencies/dependency-depth-calculator.js +368 -0
- package/lib/dependencies/dependency-depth-calculator.js.map +1 -0
- package/lib/dependencies/dependency-graph-builder.d.ts +151 -0
- package/lib/dependencies/dependency-graph-builder.js +411 -0
- package/lib/dependencies/dependency-graph-builder.js.map +1 -0
- package/lib/dependencies/dependency-impact-analyzer.d.ts +145 -0
- package/lib/dependencies/dependency-impact-analyzer.js +330 -0
- package/lib/dependencies/dependency-impact-analyzer.js.map +1 -0
- package/lib/dependencies/dependency-merger.d.ts +122 -0
- package/lib/dependencies/dependency-merger.js +245 -0
- package/lib/dependencies/dependency-merger.js.map +1 -0
- package/lib/dependencies/dependency-resolver.d.ts +157 -0
- package/lib/dependencies/dependency-resolver.js +298 -0
- package/lib/dependencies/dependency-resolver.js.map +1 -0
- package/lib/dependencies/dependency-validator.d.ts +123 -0
- package/lib/dependencies/dependency-validator.js +291 -0
- package/lib/dependencies/dependency-validator.js.map +1 -0
- package/lib/dependencies/graph-visualizer.d.ts +110 -0
- package/lib/dependencies/graph-visualizer.js +262 -0
- package/lib/dependencies/graph-visualizer.js.map +1 -0
- package/lib/dependencies/heuristic-inference.d.ts +136 -0
- package/lib/dependencies/heuristic-inference.js +430 -0
- package/lib/dependencies/heuristic-inference.js.map +1 -0
- package/lib/deployment/cycle-source-editor.d.ts +34 -0
- package/lib/deployment/cycle-source-editor.js +121 -0
- package/lib/deployment/cycle-source-editor.js.map +1 -0
- package/lib/deployment/deployment-error-handler.d.ts +38 -0
- package/lib/deployment/deployment-error-handler.js +79 -0
- package/lib/deployment/deployment-error-handler.js.map +1 -0
- package/lib/deployment/deployment-reporter.d.ts +63 -0
- package/lib/deployment/deployment-reporter.js +150 -0
- package/lib/deployment/deployment-reporter.js.map +1 -0
- package/lib/deployment/deployment-state-summary.d.ts +38 -0
- package/lib/deployment/deployment-state-summary.js +209 -0
- package/lib/deployment/deployment-state-summary.js.map +1 -0
- package/lib/deployment/deployment-status-service.d.ts +36 -0
- package/lib/deployment/deployment-status-service.js +128 -0
- package/lib/deployment/deployment-status-service.js.map +1 -0
- package/lib/deployment/deployment-tracker.d.ts +42 -0
- package/lib/deployment/deployment-tracker.js +79 -0
- package/lib/deployment/deployment-tracker.js.map +1 -0
- package/lib/deployment/deployment-validation-service.d.ts +28 -0
- package/lib/deployment/deployment-validation-service.js +161 -0
- package/lib/deployment/deployment-validation-service.js.map +1 -0
- package/lib/deployment/retry-handler.d.ts +37 -0
- package/lib/deployment/retry-handler.js +86 -0
- package/lib/deployment/retry-handler.js.map +1 -0
- package/lib/deployment/sf-cli-integration.d.ts +42 -0
- package/lib/deployment/sf-cli-integration.js +105 -0
- package/lib/deployment/sf-cli-integration.js.map +1 -0
- package/lib/deployment/state-manager.d.ts +61 -0
- package/lib/deployment/state-manager.js +83 -0
- package/lib/deployment/state-manager.js.map +1 -0
- package/lib/deployment/test-executor.d.ts +41 -0
- package/lib/deployment/test-executor.js +87 -0
- package/lib/deployment/test-executor.js.map +1 -0
- package/lib/errors/base-error.d.ts +24 -0
- package/lib/errors/base-error.js +66 -0
- package/lib/errors/base-error.js.map +1 -0
- package/lib/errors/dependency-error.d.ts +37 -0
- package/lib/errors/dependency-error.js +76 -0
- package/lib/errors/dependency-error.js.map +1 -0
- package/lib/errors/deployment-error.d.ts +55 -0
- package/lib/errors/deployment-error.js +132 -0
- package/lib/errors/deployment-error.js.map +1 -0
- package/lib/errors/index.d.ts +45 -0
- package/lib/errors/index.js +71 -0
- package/lib/errors/index.js.map +1 -0
- package/lib/errors/network-error.d.ts +53 -0
- package/lib/errors/network-error.js +111 -0
- package/lib/errors/network-error.js.map +1 -0
- package/lib/errors/parsing-error.d.ts +41 -0
- package/lib/errors/parsing-error.js +69 -0
- package/lib/errors/parsing-error.js.map +1 -0
- package/lib/errors/validation-error-reporter.d.ts +34 -0
- package/lib/errors/validation-error-reporter.js +99 -0
- package/lib/errors/validation-error-reporter.js.map +1 -0
- package/lib/errors/validation-error.d.ts +58 -0
- package/lib/errors/validation-error.js +131 -0
- package/lib/errors/validation-error.js.map +1 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -0
- package/lib/monitoring/performance-monitor.d.ts +98 -0
- package/lib/monitoring/performance-monitor.js +260 -0
- package/lib/monitoring/performance-monitor.js.map +1 -0
- package/lib/parsers/apex-class-parser.d.ts +47 -0
- package/lib/parsers/apex-class-parser.js +368 -0
- package/lib/parsers/apex-class-parser.js.map +1 -0
- package/lib/parsers/apex-trigger-parser.d.ts +48 -0
- package/lib/parsers/apex-trigger-parser.js +229 -0
- package/lib/parsers/apex-trigger-parser.js.map +1 -0
- package/lib/parsers/aura-parser.d.ts +55 -0
- package/lib/parsers/aura-parser.js +229 -0
- package/lib/parsers/aura-parser.js.map +1 -0
- package/lib/parsers/bot-parser.d.ts +65 -0
- package/lib/parsers/bot-parser.js +225 -0
- package/lib/parsers/bot-parser.js.map +1 -0
- package/lib/parsers/custom-metadata-parser.d.ts +94 -0
- package/lib/parsers/custom-metadata-parser.js +199 -0
- package/lib/parsers/custom-metadata-parser.js.map +1 -0
- package/lib/parsers/custom-object-parser.d.ts +62 -0
- package/lib/parsers/custom-object-parser.js +297 -0
- package/lib/parsers/custom-object-parser.js.map +1 -0
- package/lib/parsers/email-template-parser.d.ts +64 -0
- package/lib/parsers/email-template-parser.js +238 -0
- package/lib/parsers/email-template-parser.js.map +1 -0
- package/lib/parsers/error-resilient-parser.d.ts +110 -0
- package/lib/parsers/error-resilient-parser.js +277 -0
- package/lib/parsers/error-resilient-parser.js.map +1 -0
- package/lib/parsers/flexipage-parser.d.ts +64 -0
- package/lib/parsers/flexipage-parser.js +196 -0
- package/lib/parsers/flexipage-parser.js.map +1 -0
- package/lib/parsers/flow-parser.d.ts +54 -0
- package/lib/parsers/flow-parser.js +287 -0
- package/lib/parsers/flow-parser.js.map +1 -0
- package/lib/parsers/genai-prompt-parser.d.ts +67 -0
- package/lib/parsers/genai-prompt-parser.js +160 -0
- package/lib/parsers/genai-prompt-parser.js.map +1 -0
- package/lib/parsers/layout-parser.d.ts +64 -0
- package/lib/parsers/layout-parser.js +267 -0
- package/lib/parsers/layout-parser.js.map +1 -0
- package/lib/parsers/lwc-parser.d.ts +60 -0
- package/lib/parsers/lwc-parser.js +264 -0
- package/lib/parsers/lwc-parser.js.map +1 -0
- package/lib/parsers/permission-set-parser.d.ts +86 -0
- package/lib/parsers/permission-set-parser.js +152 -0
- package/lib/parsers/permission-set-parser.js.map +1 -0
- package/lib/parsers/profile-parser.d.ts +81 -0
- package/lib/parsers/profile-parser.js +141 -0
- package/lib/parsers/profile-parser.js.map +1 -0
- package/lib/parsers/visualforce-parser.d.ts +47 -0
- package/lib/parsers/visualforce-parser.js +180 -0
- package/lib/parsers/visualforce-parser.js.map +1 -0
- package/lib/provisioning/data-provisioner.d.ts +88 -0
- package/lib/provisioning/data-provisioner.js +257 -0
- package/lib/provisioning/data-provisioner.js.map +1 -0
- package/lib/scanner/custom-structure-scanner.d.ts +66 -0
- package/lib/scanner/custom-structure-scanner.js +229 -0
- package/lib/scanner/custom-structure-scanner.js.map +1 -0
- package/lib/scanner/forceignore-parser.d.ts +69 -0
- package/lib/scanner/forceignore-parser.js +195 -0
- package/lib/scanner/forceignore-parser.js.map +1 -0
- package/lib/scanner/metadata-format-scanner.d.ts +77 -0
- package/lib/scanner/metadata-format-scanner.js +282 -0
- package/lib/scanner/metadata-format-scanner.js.map +1 -0
- package/lib/scanner/monorepo-scanner.d.ts +71 -0
- package/lib/scanner/monorepo-scanner.js +225 -0
- package/lib/scanner/monorepo-scanner.js.map +1 -0
- package/lib/scanner/project-validator.d.ts +55 -0
- package/lib/scanner/project-validator.js +235 -0
- package/lib/scanner/project-validator.js.map +1 -0
- package/lib/scanner/sfdx-project-detector.d.ts +86 -0
- package/lib/scanner/sfdx-project-detector.js +240 -0
- package/lib/scanner/sfdx-project-detector.js.map +1 -0
- package/lib/scanner/structure-validator.d.ts +64 -0
- package/lib/scanner/structure-validator.js +296 -0
- package/lib/scanner/structure-validator.js.map +1 -0
- package/lib/services/metadata-scanner-service.d.ts +64 -0
- package/lib/services/metadata-scanner-service.js +651 -0
- package/lib/services/metadata-scanner-service.js.map +1 -0
- package/lib/types/agentforce.d.ts +157 -0
- package/lib/types/agentforce.js +2 -0
- package/lib/types/agentforce.js.map +1 -0
- package/lib/types/dependency.d.ts +98 -0
- package/lib/types/dependency.js +5 -0
- package/lib/types/dependency.js.map +1 -0
- package/lib/types/deployment-plan.d.ts +81 -0
- package/lib/types/deployment-plan.js +6 -0
- package/lib/types/deployment-plan.js.map +1 -0
- package/lib/types/deployment.d.ts +88 -0
- package/lib/types/deployment.js +5 -0
- package/lib/types/deployment.js.map +1 -0
- package/lib/types/graph.d.ts +35 -0
- package/lib/types/graph.js +5 -0
- package/lib/types/graph.js.map +1 -0
- package/lib/types/index.d.ts +12 -0
- package/lib/types/index.js +17 -0
- package/lib/types/index.js.map +1 -0
- package/lib/types/metadata.d.ts +101 -0
- package/lib/types/metadata.js +13 -0
- package/lib/types/metadata.js.map +1 -0
- package/lib/types/project.d.ts +156 -0
- package/lib/types/project.js +56 -0
- package/lib/types/project.js.map +1 -0
- package/lib/types/salesforce/apex.d.ts +94 -0
- package/lib/types/salesforce/apex.js +6 -0
- package/lib/types/salesforce/apex.js.map +1 -0
- package/lib/types/salesforce/aura.d.ts +150 -0
- package/lib/types/salesforce/aura.js +6 -0
- package/lib/types/salesforce/aura.js.map +1 -0
- package/lib/types/salesforce/bot.d.ts +293 -0
- package/lib/types/salesforce/bot.js +6 -0
- package/lib/types/salesforce/bot.js.map +1 -0
- package/lib/types/salesforce/common.d.ts +15 -0
- package/lib/types/salesforce/common.js +5 -0
- package/lib/types/salesforce/common.js.map +1 -0
- package/lib/types/salesforce/custom-metadata.d.ts +92 -0
- package/lib/types/salesforce/custom-metadata.js +6 -0
- package/lib/types/salesforce/custom-metadata.js.map +1 -0
- package/lib/types/salesforce/email.d.ts +56 -0
- package/lib/types/salesforce/email.js +6 -0
- package/lib/types/salesforce/email.js.map +1 -0
- package/lib/types/salesforce/flexipage.d.ts +149 -0
- package/lib/types/salesforce/flexipage.js +6 -0
- package/lib/types/salesforce/flexipage.js.map +1 -0
- package/lib/types/salesforce/flow.d.ts +516 -0
- package/lib/types/salesforce/flow.js +6 -0
- package/lib/types/salesforce/flow.js.map +1 -0
- package/lib/types/salesforce/genai.d.ts +67 -0
- package/lib/types/salesforce/genai.js +6 -0
- package/lib/types/salesforce/genai.js.map +1 -0
- package/lib/types/salesforce/index.d.ts +27 -0
- package/lib/types/salesforce/index.js +43 -0
- package/lib/types/salesforce/index.js.map +1 -0
- package/lib/types/salesforce/layout.d.ts +236 -0
- package/lib/types/salesforce/layout.js +6 -0
- package/lib/types/salesforce/layout.js.map +1 -0
- package/lib/types/salesforce/lwc.d.ts +123 -0
- package/lib/types/salesforce/lwc.js +6 -0
- package/lib/types/salesforce/lwc.js.map +1 -0
- package/lib/types/salesforce/object.d.ts +427 -0
- package/lib/types/salesforce/object.js +6 -0
- package/lib/types/salesforce/object.js.map +1 -0
- package/lib/types/salesforce/parser-types.d.ts +79 -0
- package/lib/types/salesforce/parser-types.js +80 -0
- package/lib/types/salesforce/parser-types.js.map +1 -0
- package/lib/types/salesforce/permission.d.ts +289 -0
- package/lib/types/salesforce/permission.js +6 -0
- package/lib/types/salesforce/permission.js.map +1 -0
- package/lib/types/salesforce/resource.d.ts +93 -0
- package/lib/types/salesforce/resource.js +6 -0
- package/lib/types/salesforce/resource.js.map +1 -0
- package/lib/types/salesforce/visualforce.d.ts +70 -0
- package/lib/types/salesforce/visualforce.js +6 -0
- package/lib/types/salesforce/visualforce.js.map +1 -0
- package/lib/utils/cache-manager.d.ts +158 -0
- package/lib/utils/cache-manager.js +429 -0
- package/lib/utils/cache-manager.js.map +1 -0
- package/lib/utils/deployment-plan-manager.d.ts +40 -0
- package/lib/utils/deployment-plan-manager.js +183 -0
- package/lib/utils/deployment-plan-manager.js.map +1 -0
- package/lib/utils/error-aggregator.d.ts +117 -0
- package/lib/utils/error-aggregator.js +268 -0
- package/lib/utils/error-aggregator.js.map +1 -0
- package/lib/utils/file-system.d.ts +62 -0
- package/lib/utils/file-system.js +167 -0
- package/lib/utils/file-system.js.map +1 -0
- package/lib/utils/functional.d.ts +52 -0
- package/lib/utils/functional.js +61 -0
- package/lib/utils/functional.js.map +1 -0
- package/lib/utils/graph-algorithms.d.ts +53 -0
- package/lib/utils/graph-algorithms.js +177 -0
- package/lib/utils/graph-algorithms.js.map +1 -0
- package/lib/utils/logger.d.ts +154 -0
- package/lib/utils/logger.js +327 -0
- package/lib/utils/logger.js.map +1 -0
- package/lib/utils/network-handler.d.ts +64 -0
- package/lib/utils/network-handler.js +147 -0
- package/lib/utils/network-handler.js.map +1 -0
- package/lib/utils/performance.d.ts +148 -0
- package/lib/utils/performance.js +294 -0
- package/lib/utils/performance.js.map +1 -0
- package/lib/utils/string.d.ts +197 -0
- package/lib/utils/string.js +331 -0
- package/lib/utils/string.js.map +1 -0
- package/lib/utils/xml.d.ts +97 -0
- package/lib/utils/xml.js +227 -0
- package/lib/utils/xml.js.map +1 -0
- package/lib/validators/xml-metadata-validator.d.ts +106 -0
- package/lib/validators/xml-metadata-validator.js +509 -0
- package/lib/validators/xml-metadata-validator.js.map +1 -0
- package/lib/waves/priority-wave-generator-ai.d.ts +85 -0
- package/lib/waves/priority-wave-generator-ai.js +191 -0
- package/lib/waves/priority-wave-generator-ai.js.map +1 -0
- package/lib/waves/priority-wave-generator.d.ts +47 -0
- package/lib/waves/priority-wave-generator.js +88 -0
- package/lib/waves/priority-wave-generator.js.map +1 -0
- package/lib/waves/test-optimizer.d.ts +155 -0
- package/lib/waves/test-optimizer.js +290 -0
- package/lib/waves/test-optimizer.js.map +1 -0
- package/lib/waves/wave-builder.d.ts +147 -0
- package/lib/waves/wave-builder.js +286 -0
- package/lib/waves/wave-builder.js.map +1 -0
- package/lib/waves/wave-diff-generator.d.ts +17 -0
- package/lib/waves/wave-diff-generator.js +6 -0
- package/lib/waves/wave-diff-generator.js.map +1 -0
- package/lib/waves/wave-executor.d.ts +33 -0
- package/lib/waves/wave-executor.js +50 -0
- package/lib/waves/wave-executor.js.map +1 -0
- package/lib/waves/wave-merger.d.ts +96 -0
- package/lib/waves/wave-merger.js +181 -0
- package/lib/waves/wave-merger.js.map +1 -0
- package/lib/waves/wave-metadata-generator.d.ts +13 -0
- package/lib/waves/wave-metadata-generator.js +12 -0
- package/lib/waves/wave-metadata-generator.js.map +1 -0
- package/lib/waves/wave-splitter.d.ts +154 -0
- package/lib/waves/wave-splitter.js +307 -0
- package/lib/waves/wave-splitter.js.map +1 -0
- package/lib/waves/wave-validator.d.ts +17 -0
- package/lib/waves/wave-validator.js +15 -0
- package/lib/waves/wave-validator.js.map +1 -0
- package/messages/analyze.json +18 -0
- package/messages/config.json +29 -0
- package/messages/resume.json +9 -0
- package/messages/start.json +24 -0
- package/messages/status.json +8 -0
- package/messages/validate.json +9 -0
- package/npm-shrinkwrap.json +25676 -0
- package/oclif.lock +11988 -0
- package/oclif.manifest.json +589 -0
- package/package.json +224 -0
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
import { access, readFile, unlink, writeFile } from 'node:fs/promises';
|
|
3
|
+
import { constants as fsConstants } from 'node:fs';
|
|
4
|
+
function createBackupPath(filePath) {
|
|
5
|
+
return `${filePath}.cycle-remediation.bak`;
|
|
6
|
+
}
|
|
7
|
+
function hashContent(content) {
|
|
8
|
+
return createHash('sha256').update(content, 'utf8').digest('hex');
|
|
9
|
+
}
|
|
10
|
+
function countOccurrences(content, snippet) {
|
|
11
|
+
if (snippet.length === 0) {
|
|
12
|
+
return 0;
|
|
13
|
+
}
|
|
14
|
+
let count = 0;
|
|
15
|
+
let index = 0;
|
|
16
|
+
while (index <= content.length - snippet.length) {
|
|
17
|
+
const nextIndex = content.indexOf(snippet, index);
|
|
18
|
+
if (nextIndex === -1) {
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
count += 1;
|
|
22
|
+
index = nextIndex + snippet.length;
|
|
23
|
+
}
|
|
24
|
+
return count;
|
|
25
|
+
}
|
|
26
|
+
function createReplacementSnippet(request) {
|
|
27
|
+
const header = `// cycle-remediation: comment-reference ${request.targetDependency}` + ` | ${request.targetDescription}`;
|
|
28
|
+
const commentedSnippet = request.sourceSnippet
|
|
29
|
+
.split('\n')
|
|
30
|
+
.map((line) => (line.length === 0 ? '//' : `// ${line}`))
|
|
31
|
+
.join('\n');
|
|
32
|
+
return `${header}\n${commentedSnippet}\n// cycle-remediation: end`;
|
|
33
|
+
}
|
|
34
|
+
async function fileExists(filePath) {
|
|
35
|
+
try {
|
|
36
|
+
await access(filePath, fsConstants.F_OK);
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
export class CycleSourceEditor {
|
|
44
|
+
async createBackup(filePath) {
|
|
45
|
+
const originalContent = await readFile(filePath, 'utf8');
|
|
46
|
+
const originalHash = hashContent(originalContent);
|
|
47
|
+
const backupPath = createBackupPath(filePath);
|
|
48
|
+
if (!(await fileExists(backupPath))) {
|
|
49
|
+
await writeFile(backupPath, originalContent, 'utf8');
|
|
50
|
+
return {
|
|
51
|
+
filePath,
|
|
52
|
+
backupPath,
|
|
53
|
+
originalHash,
|
|
54
|
+
created: true,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const backupContent = await readFile(backupPath, 'utf8');
|
|
58
|
+
const backupHash = hashContent(backupContent);
|
|
59
|
+
if (backupHash !== originalHash) {
|
|
60
|
+
throw new Error(`Backup mismatch for ${filePath}; refusing to overwrite ${backupPath} with different source content.`);
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
filePath,
|
|
64
|
+
backupPath,
|
|
65
|
+
originalHash,
|
|
66
|
+
created: false,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
async applyEdit(request) {
|
|
70
|
+
if (request.sourceSnippet.trim().length === 0) {
|
|
71
|
+
throw new Error(`Cycle remediation edit for ${request.filePath} requires a non-empty sourceSnippet.`);
|
|
72
|
+
}
|
|
73
|
+
const originalContent = await readFile(request.filePath, 'utf8');
|
|
74
|
+
const matchCount = countOccurrences(originalContent, request.sourceSnippet);
|
|
75
|
+
if (matchCount !== 1) {
|
|
76
|
+
throw new Error(`Cycle remediation edit for ${request.filePath} requires exactly one sourceSnippet match; found ${matchCount}.`);
|
|
77
|
+
}
|
|
78
|
+
const backupRecord = await this.createBackup(request.filePath);
|
|
79
|
+
const replacementSnippet = createReplacementSnippet(request);
|
|
80
|
+
const editedContent = originalContent.replace(request.sourceSnippet, replacementSnippet);
|
|
81
|
+
const editedHash = hashContent(editedContent);
|
|
82
|
+
await writeFile(request.filePath, editedContent, 'utf8');
|
|
83
|
+
return {
|
|
84
|
+
operation: 'comment-reference',
|
|
85
|
+
filePath: request.filePath,
|
|
86
|
+
backupPath: backupRecord.backupPath,
|
|
87
|
+
targetDescription: request.targetDescription,
|
|
88
|
+
targetDependency: request.targetDependency,
|
|
89
|
+
sourceSnippet: request.sourceSnippet,
|
|
90
|
+
replacementSnippet,
|
|
91
|
+
originalHash: backupRecord.originalHash,
|
|
92
|
+
editedHash,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
async restoreEdit(record) {
|
|
96
|
+
if (!(await fileExists(record.backupPath))) {
|
|
97
|
+
return {
|
|
98
|
+
restored: false,
|
|
99
|
+
reason: 'backup-missing',
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
const currentContent = await readFile(record.filePath, 'utf8');
|
|
103
|
+
const currentHash = hashContent(currentContent);
|
|
104
|
+
if (currentHash !== record.editedHash) {
|
|
105
|
+
return {
|
|
106
|
+
restored: false,
|
|
107
|
+
reason: 'hash-mismatch',
|
|
108
|
+
currentHash,
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
const backupContent = await readFile(record.backupPath, 'utf8');
|
|
112
|
+
const restoredHash = hashContent(backupContent);
|
|
113
|
+
await writeFile(record.filePath, backupContent, 'utf8');
|
|
114
|
+
await unlink(record.backupPath);
|
|
115
|
+
return {
|
|
116
|
+
restored: true,
|
|
117
|
+
restoredHash,
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=cycle-source-editor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cycle-source-editor.js","sourceRoot":"","sources":["../../src/deployment/cycle-source-editor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deployment Error Handler - US-074
|
|
3
|
+
* Enhanced deployment error recovery
|
|
4
|
+
*
|
|
5
|
+
* @ac US-074-AC-1: Catch deployment errors
|
|
6
|
+
* @ac US-074-AC-2: Save deployment state
|
|
7
|
+
* @ac US-074-AC-3: Enable resume from failure
|
|
8
|
+
* @ac US-074-AC-4: Retry with different strategies
|
|
9
|
+
* @ac US-074-AC-5: Report error details
|
|
10
|
+
* @ac US-074-AC-6: Suggest fixes
|
|
11
|
+
* @issue #74
|
|
12
|
+
*/
|
|
13
|
+
export type DeploymentErrorContext = {
|
|
14
|
+
wave: number;
|
|
15
|
+
components: string[];
|
|
16
|
+
strategy: 'standard' | 'quick' | 'validate-only';
|
|
17
|
+
retryCount: number;
|
|
18
|
+
};
|
|
19
|
+
export declare class DeploymentErrorHandler {
|
|
20
|
+
private readonly stateManager;
|
|
21
|
+
constructor();
|
|
22
|
+
/**
|
|
23
|
+
* @ac US-074-AC-1: Catch deployment errors
|
|
24
|
+
* @ac US-074-AC-2: Save deployment state
|
|
25
|
+
* Handle deployment error with state persistence
|
|
26
|
+
*/
|
|
27
|
+
handleError(error: Error, context: DeploymentErrorContext): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* @ac US-074-AC-6: Suggest fixes
|
|
30
|
+
* Get error fix suggestions
|
|
31
|
+
*/
|
|
32
|
+
private getSuggestions;
|
|
33
|
+
/**
|
|
34
|
+
* @ac US-074-AC-3: Enable resume from failure
|
|
35
|
+
* Check if can resume
|
|
36
|
+
*/
|
|
37
|
+
canResume(): Promise<boolean>;
|
|
38
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deployment Error Handler - US-074
|
|
3
|
+
* Enhanced deployment error recovery
|
|
4
|
+
*
|
|
5
|
+
* @ac US-074-AC-1: Catch deployment errors
|
|
6
|
+
* @ac US-074-AC-2: Save deployment state
|
|
7
|
+
* @ac US-074-AC-3: Enable resume from failure
|
|
8
|
+
* @ac US-074-AC-4: Retry with different strategies
|
|
9
|
+
* @ac US-074-AC-5: Report error details
|
|
10
|
+
* @ac US-074-AC-6: Suggest fixes
|
|
11
|
+
* @issue #74
|
|
12
|
+
*/
|
|
13
|
+
import { getLogger } from '../utils/logger.js';
|
|
14
|
+
import { StateManager } from './state-manager.js';
|
|
15
|
+
const logger = getLogger('DeploymentErrorHandler');
|
|
16
|
+
export class DeploymentErrorHandler {
|
|
17
|
+
stateManager;
|
|
18
|
+
constructor() {
|
|
19
|
+
this.stateManager = new StateManager();
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* @ac US-074-AC-1: Catch deployment errors
|
|
23
|
+
* @ac US-074-AC-2: Save deployment state
|
|
24
|
+
* Handle deployment error with state persistence
|
|
25
|
+
*/
|
|
26
|
+
async handleError(error, context) {
|
|
27
|
+
logger.error('Deployment error occurred', {
|
|
28
|
+
wave: context.wave,
|
|
29
|
+
components: context.components.length,
|
|
30
|
+
error: error.message,
|
|
31
|
+
});
|
|
32
|
+
// Save state for resume
|
|
33
|
+
await this.stateManager.saveState({
|
|
34
|
+
deploymentId: `deploy-${Date.now()}`,
|
|
35
|
+
targetOrg: 'unknown',
|
|
36
|
+
timestamp: new Date().toISOString(),
|
|
37
|
+
totalWaves: context.wave + 1,
|
|
38
|
+
completedWaves: [],
|
|
39
|
+
currentWave: context.wave,
|
|
40
|
+
failedWave: {
|
|
41
|
+
waveNumber: context.wave,
|
|
42
|
+
error: error.message,
|
|
43
|
+
timestamp: new Date().toISOString(),
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
// Suggest fixes
|
|
47
|
+
const suggestions = this.getSuggestions(error);
|
|
48
|
+
logger.info('Suggested fixes', { suggestions });
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* @ac US-074-AC-6: Suggest fixes
|
|
52
|
+
* Get error fix suggestions
|
|
53
|
+
*/
|
|
54
|
+
getSuggestions(error) {
|
|
55
|
+
const suggestions = [];
|
|
56
|
+
if (error.message.includes('UNABLE_TO_LOCK_ROW')) {
|
|
57
|
+
suggestions.push('Retry deployment - this is usually temporary');
|
|
58
|
+
suggestions.push('Check for concurrent deployments');
|
|
59
|
+
}
|
|
60
|
+
else if (error.message.includes('INVALID_CROSS_REFERENCE_KEY')) {
|
|
61
|
+
suggestions.push('Check dependency order');
|
|
62
|
+
suggestions.push('Ensure all referenced components are included');
|
|
63
|
+
}
|
|
64
|
+
else if (error.message.includes('FIELD_INTEGRITY_EXCEPTION')) {
|
|
65
|
+
suggestions.push('Check required fields');
|
|
66
|
+
suggestions.push('Verify picklist values');
|
|
67
|
+
}
|
|
68
|
+
return suggestions;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* @ac US-074-AC-3: Enable resume from failure
|
|
72
|
+
* Check if can resume
|
|
73
|
+
*/
|
|
74
|
+
async canResume() {
|
|
75
|
+
const state = await this.stateManager.loadState();
|
|
76
|
+
return state !== null;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=deployment-error-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deployment-error-handler.js","sourceRoot":"","sources":["../../src/deployment/deployment-error-handler.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,MAAM,MAAM,GAAG,SAAS,CAAC,wBAAwB,CAAC,CAAC;AASnD,MAAM,OAAO,sBAAsB;IAChB,YAAY,CAAe;IAE5C;QACE,IAAI,CAAC,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;IACzC,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,WAAW,CAAC,KAAY,EAAE,OAA+B;QACpE,MAAM,CAAC,KAAK,CAAC,2BAA2B,EAAE;YACxC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,MAAM;YACrC,KAAK,EAAE,KAAK,CAAC,OAAO;SACrB,CAAC,CAAC;QAEH,wBAAwB;QACxB,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;YAChC,YAAY,EAAE,UAAU,IAAI,CAAC,GAAG,EAAE,EAAE;YACpC,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,UAAU,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC;YAC5B,cAAc,EAAE,EAAE;YAClB,WAAW,EAAE,OAAO,CAAC,IAAI;YACzB,UAAU,EAAE;gBACV,UAAU,EAAE,OAAO,CAAC,IAAI;gBACxB,KAAK,EAAE,KAAK,CAAC,OAAO;gBACpB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACpC;SACF,CAAC,CAAC;QAEH,gBAAgB;QAChB,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IAClD,CAAC;IAED;;;OAGG;IACK,cAAc,CAAC,KAAY;QACjC,MAAM,WAAW,GAAa,EAAE,CAAC;QAEjC,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACjD,WAAW,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAC;YACjE,WAAW,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;QACvD,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAE,CAAC;YACjE,WAAW,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;YAC3C,WAAW,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;QACpE,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,2BAA2B,CAAC,EAAE,CAAC;YAC/D,WAAW,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;YAC1C,WAAW,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QAC7C,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,SAAS;QACpB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;QAClD,OAAO,KAAK,KAAK,IAAI,CAAC;IACxB,CAAC;CACF"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deployment Reporting - US-090
|
|
3
|
+
* Generates comprehensive deployment reports
|
|
4
|
+
*
|
|
5
|
+
* @ac US-090-AC-1: Generate deployment summary
|
|
6
|
+
* @ac US-090-AC-2: Include wave-by-wave breakdown
|
|
7
|
+
* @ac US-090-AC-3: Include test results
|
|
8
|
+
* @ac US-090-AC-4: Include timing information
|
|
9
|
+
* @ac US-090-AC-5: Include error details
|
|
10
|
+
* @ac US-090-AC-6: Export as JSON
|
|
11
|
+
* @ac US-090-AC-7: Export as HTML
|
|
12
|
+
* @ac US-090-AC-8: Save to file
|
|
13
|
+
* @issue #90
|
|
14
|
+
*/
|
|
15
|
+
export type WaveReport = {
|
|
16
|
+
waveNumber: number;
|
|
17
|
+
components: number;
|
|
18
|
+
startTime: string;
|
|
19
|
+
endTime: string;
|
|
20
|
+
duration: number;
|
|
21
|
+
success: boolean;
|
|
22
|
+
testsRun?: number;
|
|
23
|
+
testFailures?: number;
|
|
24
|
+
error?: string;
|
|
25
|
+
};
|
|
26
|
+
export type DeploymentReport = {
|
|
27
|
+
deploymentId: string;
|
|
28
|
+
targetOrg: string;
|
|
29
|
+
startTime: string;
|
|
30
|
+
endTime: string;
|
|
31
|
+
totalDuration: number;
|
|
32
|
+
success: boolean;
|
|
33
|
+
totalWaves: number;
|
|
34
|
+
completedWaves: number;
|
|
35
|
+
totalComponents: number;
|
|
36
|
+
totalTests: number;
|
|
37
|
+
waves: WaveReport[];
|
|
38
|
+
errors: string[];
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* @ac US-090-AC-1: Generate deployment summary
|
|
42
|
+
* @ac US-090-AC-2: Include wave-by-wave breakdown
|
|
43
|
+
*/
|
|
44
|
+
export declare class DeploymentReporter {
|
|
45
|
+
/**
|
|
46
|
+
* @ac US-090-AC-3: Include test results
|
|
47
|
+
* @ac US-090-AC-4: Include timing information
|
|
48
|
+
* @ac US-090-AC-5: Include error details
|
|
49
|
+
*/
|
|
50
|
+
generateReport(report: DeploymentReport): string;
|
|
51
|
+
/**
|
|
52
|
+
* @ac US-090-AC-6: Export as JSON
|
|
53
|
+
*/
|
|
54
|
+
toJSON(report: DeploymentReport): string;
|
|
55
|
+
/**
|
|
56
|
+
* @ac US-090-AC-7: Export as HTML
|
|
57
|
+
*/
|
|
58
|
+
toHTML(report: DeploymentReport): string;
|
|
59
|
+
/**
|
|
60
|
+
* @ac US-090-AC-8: Save to file
|
|
61
|
+
*/
|
|
62
|
+
saveReport(report: DeploymentReport, format: 'json' | 'html' | 'text'): Promise<string>;
|
|
63
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deployment Reporting - US-090
|
|
3
|
+
* Generates comprehensive deployment reports
|
|
4
|
+
*
|
|
5
|
+
* @ac US-090-AC-1: Generate deployment summary
|
|
6
|
+
* @ac US-090-AC-2: Include wave-by-wave breakdown
|
|
7
|
+
* @ac US-090-AC-3: Include test results
|
|
8
|
+
* @ac US-090-AC-4: Include timing information
|
|
9
|
+
* @ac US-090-AC-5: Include error details
|
|
10
|
+
* @ac US-090-AC-6: Export as JSON
|
|
11
|
+
* @ac US-090-AC-7: Export as HTML
|
|
12
|
+
* @ac US-090-AC-8: Save to file
|
|
13
|
+
* @issue #90
|
|
14
|
+
*/
|
|
15
|
+
import * as fs from 'node:fs/promises';
|
|
16
|
+
import { getLogger } from '../utils/logger.js';
|
|
17
|
+
const logger = getLogger('DeploymentReporter');
|
|
18
|
+
/**
|
|
19
|
+
* @ac US-090-AC-1: Generate deployment summary
|
|
20
|
+
* @ac US-090-AC-2: Include wave-by-wave breakdown
|
|
21
|
+
*/
|
|
22
|
+
export class DeploymentReporter {
|
|
23
|
+
/**
|
|
24
|
+
* @ac US-090-AC-3: Include test results
|
|
25
|
+
* @ac US-090-AC-4: Include timing information
|
|
26
|
+
* @ac US-090-AC-5: Include error details
|
|
27
|
+
*/
|
|
28
|
+
generateReport(report) {
|
|
29
|
+
const lines = [
|
|
30
|
+
'═'.repeat(60),
|
|
31
|
+
'📊 DEPLOYMENT REPORT',
|
|
32
|
+
'═'.repeat(60),
|
|
33
|
+
'',
|
|
34
|
+
`Deployment ID: ${report.deploymentId}`,
|
|
35
|
+
`Target Org: ${report.targetOrg}`,
|
|
36
|
+
`Status: ${report.success ? '✅ SUCCESS' : '❌ FAILED'}`,
|
|
37
|
+
`Duration: ${report.totalDuration}s`,
|
|
38
|
+
'',
|
|
39
|
+
`Waves: ${report.completedWaves}/${report.totalWaves}`,
|
|
40
|
+
`Components: ${report.totalComponents}`,
|
|
41
|
+
`Tests: ${report.totalTests}`,
|
|
42
|
+
'',
|
|
43
|
+
'─'.repeat(60),
|
|
44
|
+
'Wave Breakdown:',
|
|
45
|
+
'─'.repeat(60),
|
|
46
|
+
];
|
|
47
|
+
for (const wave of report.waves) {
|
|
48
|
+
lines.push('');
|
|
49
|
+
lines.push(`Wave ${wave.waveNumber}:`);
|
|
50
|
+
lines.push(` Components: ${wave.components}`);
|
|
51
|
+
lines.push(` Duration: ${wave.duration}s`);
|
|
52
|
+
lines.push(` Status: ${wave.success ? '✅' : '❌'}`);
|
|
53
|
+
if (wave.testsRun !== undefined) {
|
|
54
|
+
lines.push(` Tests: ${wave.testsRun} (${wave.testFailures ?? 0} failures)`);
|
|
55
|
+
}
|
|
56
|
+
if (wave.error) {
|
|
57
|
+
lines.push(` Error: ${wave.error}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (report.errors.length > 0) {
|
|
61
|
+
lines.push('');
|
|
62
|
+
lines.push('─'.repeat(60));
|
|
63
|
+
lines.push('Errors:');
|
|
64
|
+
lines.push('─'.repeat(60));
|
|
65
|
+
for (const error of report.errors) {
|
|
66
|
+
lines.push(` • ${error}`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
lines.push('');
|
|
70
|
+
lines.push('═'.repeat(60));
|
|
71
|
+
return lines.join('\n');
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* @ac US-090-AC-6: Export as JSON
|
|
75
|
+
*/
|
|
76
|
+
toJSON(report) {
|
|
77
|
+
return JSON.stringify(report, null, 2);
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* @ac US-090-AC-7: Export as HTML
|
|
81
|
+
*/
|
|
82
|
+
toHTML(report) {
|
|
83
|
+
return `
|
|
84
|
+
<!DOCTYPE html>
|
|
85
|
+
<html>
|
|
86
|
+
<head>
|
|
87
|
+
<title>Deployment Report</title>
|
|
88
|
+
<style>
|
|
89
|
+
body { font-family: Arial, sans-serif; margin: 20px; }
|
|
90
|
+
.success { color: green; }
|
|
91
|
+
.failure { color: red; }
|
|
92
|
+
table { border-collapse: collapse; width: 100%; }
|
|
93
|
+
th, td { border: 1px solid #ddd; padding: 8px; text-align: left; }
|
|
94
|
+
th { background-color: #4CAF50; color: white; }
|
|
95
|
+
</style>
|
|
96
|
+
</head>
|
|
97
|
+
<body>
|
|
98
|
+
<h1>Deployment Report</h1>
|
|
99
|
+
<p><strong>Status:</strong> <span class="${report.success ? 'success' : 'failure'}">${report.success ? 'SUCCESS' : 'FAILED'}</span></p>
|
|
100
|
+
<p><strong>Target:</strong> ${report.targetOrg}</p>
|
|
101
|
+
<p><strong>Duration:</strong> ${report.totalDuration}s</p>
|
|
102
|
+
|
|
103
|
+
<h2>Wave Breakdown</h2>
|
|
104
|
+
<table>
|
|
105
|
+
<tr>
|
|
106
|
+
<th>Wave</th>
|
|
107
|
+
<th>Components</th>
|
|
108
|
+
<th>Duration</th>
|
|
109
|
+
<th>Tests</th>
|
|
110
|
+
<th>Status</th>
|
|
111
|
+
</tr>
|
|
112
|
+
${report.waves
|
|
113
|
+
.map((w) => `
|
|
114
|
+
<tr>
|
|
115
|
+
<td>${w.waveNumber}</td>
|
|
116
|
+
<td>${w.components}</td>
|
|
117
|
+
<td>${w.duration}s</td>
|
|
118
|
+
<td>${w.testsRun ?? 0}</td>
|
|
119
|
+
<td class="${w.success ? 'success' : 'failure'}">${w.success ? '✅' : '❌'}</td>
|
|
120
|
+
</tr>
|
|
121
|
+
`)
|
|
122
|
+
.join('')}
|
|
123
|
+
</table>
|
|
124
|
+
</body>
|
|
125
|
+
</html>
|
|
126
|
+
`.trim();
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* @ac US-090-AC-8: Save to file
|
|
130
|
+
*/
|
|
131
|
+
async saveReport(report, format) {
|
|
132
|
+
const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
|
|
133
|
+
const filename = `deployment-report-${timestamp}.${format}`;
|
|
134
|
+
let content;
|
|
135
|
+
switch (format) {
|
|
136
|
+
case 'json':
|
|
137
|
+
content = this.toJSON(report);
|
|
138
|
+
break;
|
|
139
|
+
case 'html':
|
|
140
|
+
content = this.toHTML(report);
|
|
141
|
+
break;
|
|
142
|
+
default:
|
|
143
|
+
content = this.generateReport(report);
|
|
144
|
+
}
|
|
145
|
+
await fs.writeFile(filename, content, 'utf-8');
|
|
146
|
+
logger.info('Report saved', { filename });
|
|
147
|
+
return filename;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=deployment-reporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deployment-reporter.js","sourceRoot":"","sources":["../../src/deployment/deployment-reporter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { DeploymentState } from './state-manager.js';
|
|
2
|
+
export type CycleRemediationStatusSummary = {
|
|
3
|
+
cycleId: string;
|
|
4
|
+
strategy: 'comment-reference' | 'manual';
|
|
5
|
+
activePhase: 1 | 2;
|
|
6
|
+
completedPhases: Array<1 | 2>;
|
|
7
|
+
startedAt: string;
|
|
8
|
+
editCount: number;
|
|
9
|
+
statusText: string;
|
|
10
|
+
};
|
|
11
|
+
export type DeploymentStatusSummary = {
|
|
12
|
+
deploymentId: string;
|
|
13
|
+
targetOrg: string;
|
|
14
|
+
status: 'Not Started' | 'In Progress' | 'Failed' | 'Completed';
|
|
15
|
+
currentWave: number;
|
|
16
|
+
totalWaves: number;
|
|
17
|
+
completedWaves: number[];
|
|
18
|
+
remainingWaves: number;
|
|
19
|
+
canResume: boolean;
|
|
20
|
+
etaSeconds: number;
|
|
21
|
+
testStatus: string;
|
|
22
|
+
lastUpdated: string;
|
|
23
|
+
failedWaveNumber?: number;
|
|
24
|
+
failureReason?: string;
|
|
25
|
+
cycleRemediation?: CycleRemediationStatusSummary;
|
|
26
|
+
ai?: {
|
|
27
|
+
provider?: string;
|
|
28
|
+
model?: string;
|
|
29
|
+
fallback?: boolean;
|
|
30
|
+
aiAdjustments?: number;
|
|
31
|
+
unknownTypes?: string[];
|
|
32
|
+
inferenceFallback?: boolean;
|
|
33
|
+
inferredDependencies?: number;
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
export declare function summarizeDeploymentState(state: DeploymentState, nowTimestamp?: number): DeploymentStatusSummary;
|
|
37
|
+
export declare function createResumedState(state: DeploymentState, retryStrategy: 'standard' | 'quick' | 'validate-only', resumedAt?: string): DeploymentState;
|
|
38
|
+
export declare function formatDeploymentStatus(summary: DeploymentStatusSummary): string[];
|