@unispechq/unispec-core 0.3.2 → 0.3.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/dist/cjs/src/cache/cache-factory.js +1 -1
- package/dist/cjs/src/cache/cache-manager.js +2 -2
- package/dist/cjs/src/cache/hash-utils.js +1 -1
- package/dist/cjs/src/cache/hashing.js +1 -1
- package/dist/cjs/src/cache/index.js +5 -5
- package/dist/cjs/src/cache/lru-cache.js +1 -1
- package/dist/cjs/src/diff/core.js +2 -2
- package/dist/cjs/src/diff/enhanced-diff.js +5 -5
- package/dist/cjs/src/diff/index.js +8 -8
- package/dist/cjs/src/errors/config-error.js +1 -1
- package/dist/cjs/src/errors/error-factory.js +7 -7
- package/dist/cjs/src/errors/index.js +8 -8
- package/dist/cjs/src/errors/loader-error.js +1 -1
- package/dist/cjs/src/errors/reference-error.js +1 -1
- package/dist/cjs/src/errors/schema-error.js +1 -1
- package/dist/cjs/src/errors/security-error.js +1 -1
- package/dist/cjs/src/errors/semantic-error.js +1 -1
- package/dist/cjs/src/index.js +13 -13
- package/dist/cjs/src/loader/index.js +4 -4
- package/dist/cjs/src/loader/security-validator.js +1 -1
- package/dist/cjs/src/loader/unispec-loader.js +3 -3
- package/dist/cjs/src/loader/yaml-loader.js +1 -1
- package/dist/cjs/src/normalizer/core.js +4 -4
- package/dist/cjs/src/normalizer/index.js +1 -1
- package/dist/cjs/src/optimizer/core.js +2 -2
- package/dist/cjs/src/optimizer/index.js +3 -3
- package/dist/cjs/src/optimizer/optimization-functions.js +2 -2
- package/dist/cjs/src/schemas/dedupe.js +1 -1
- package/dist/cjs/src/schemas/index.js +3 -3
- package/dist/cjs/src/schemas/resolver.js +1 -1
- package/dist/cjs/src/validator/ajv-validator.js +1 -1
- package/dist/cjs/src/validator/config-validator-main.js +4 -4
- package/dist/cjs/src/validator/config-validator.js +1 -1
- package/dist/cjs/src/validator/index.js +7 -7
- package/dist/cjs/src/validator/reference-validator.js +1 -1
- package/dist/cjs/src/validator/tests-validator.js +2 -2
- package/dist/cjs/src/validator/unispec-validator.js +5 -5
- package/dist/cjs/src/validator/validator-factory.js +1 -1
- package/dist/cjs/tests/cache/cache.test.js +4 -4
- package/dist/cjs/tests/cache/utils.js +1 -1
- package/dist/cjs/tests/diff/diff-annotators.test.js +2 -2
- package/dist/cjs/tests/diff/diff-comprehensive.test.js +2 -2
- package/dist/cjs/tests/diff/diff-extended.test.js +2 -2
- package/dist/cjs/tests/diff/diff.test.js +2 -2
- package/dist/cjs/tests/diff/utils.js +1 -1
- package/dist/cjs/tests/errors/errors-integration.test.js +3 -3
- package/dist/cjs/tests/errors/errors.test.js +2 -2
- package/dist/cjs/tests/errors/utils.js +1 -1
- package/dist/cjs/tests/loader/integration.test.js +2 -2
- package/dist/cjs/tests/loader/loader.test.js +2 -2
- package/dist/cjs/tests/normalizer/normalizer-comprehensive.test.js +2 -2
- package/dist/cjs/tests/normalizer/normalizer-invalid.test.js +2 -2
- package/dist/cjs/tests/normalizer/normalizer-valid.test.js +2 -2
- package/dist/cjs/tests/normalizer/utils.js +1 -1
- package/dist/cjs/tests/optimizer/compress-references.test.js +2 -2
- package/dist/cjs/tests/optimizer/deduplication.test.js +2 -2
- package/dist/cjs/tests/optimizer/integration.test.js +3 -3
- package/dist/cjs/tests/optimizer/optimization-report.test.js +2 -2
- package/dist/cjs/tests/optimizer/optimize-document.test.js +2 -2
- package/dist/cjs/tests/optimizer/orphaned-schemas.test.js +2 -2
- package/dist/cjs/tests/optimizer/sort-schemas.test.js +2 -2
- package/dist/cjs/tests/optimizer/utils.js +1 -1
- package/dist/cjs/tests/schemas/schemas-edge-cases.test.js +3 -3
- package/dist/cjs/tests/schemas/schemas.test.js +3 -3
- package/dist/cjs/tests/schemas/utils.js +1 -1
- package/dist/cjs/tests/validator/config-validator.test.js +2 -2
- package/dist/cjs/tests/validator/unispec-validator.test.js +2 -2
- package/dist/cjs/tests/validator/utils.js +1 -1
- package/package.json +1 -1
- package/dist/cache/cache-factory.d.ts +0 -31
- package/dist/cache/cache-factory.js +0 -65
- package/dist/cache/cache-manager.d.ts +0 -62
- package/dist/cache/cache-manager.js +0 -122
- package/dist/cache/constants.d.ts +0 -21
- package/dist/cache/constants.js +0 -22
- package/dist/cache/hash-utils.d.ts +0 -21
- package/dist/cache/hash-utils.js +0 -35
- package/dist/cache/hashing.d.ts +0 -19
- package/dist/cache/hashing.js +0 -197
- package/dist/cache/index.d.ts +0 -6
- package/dist/cache/index.js +0 -10
- package/dist/cache/lru-cache.d.ts +0 -56
- package/dist/cache/lru-cache.js +0 -161
- package/dist/cache/types.d.ts +0 -24
- package/dist/cache/types.js +0 -4
- package/dist/cjs/cache/cache-factory.js +0 -72
- package/dist/cjs/cache/cache-manager.js +0 -126
- package/dist/cjs/cache/constants.js +0 -25
- package/dist/cjs/cache/hash-utils.js +0 -41
- package/dist/cjs/cache/hashing.js +0 -236
- package/dist/cjs/cache/index.js +0 -26
- package/dist/cjs/cache/lru-cache.js +0 -165
- package/dist/cjs/cache/types.js +0 -5
- package/dist/cjs/diff/annotators.js +0 -159
- package/dist/cjs/diff/change-reports.js +0 -369
- package/dist/cjs/diff/core.js +0 -158
- package/dist/cjs/diff/enhanced-diff.js +0 -79
- package/dist/cjs/diff/impact-strategies-refactored.js +0 -230
- package/dist/cjs/diff/impact-strategies.js +0 -219
- package/dist/cjs/diff/index.js +0 -27
- package/dist/cjs/diff/metrics-calculator.js +0 -69
- package/dist/cjs/diff/risk-calculator.js +0 -58
- package/dist/cjs/diff/suggestion-generator.js +0 -78
- package/dist/cjs/diff/types.js +0 -11
- package/dist/cjs/errors/base-error.js +0 -33
- package/dist/cjs/errors/config-error.js +0 -11
- package/dist/cjs/errors/error-factory.js +0 -48
- package/dist/cjs/errors/index.js +0 -19
- package/dist/cjs/errors/loader-error.js +0 -11
- package/dist/cjs/errors/reference-error.js +0 -11
- package/dist/cjs/errors/schema-error.js +0 -11
- package/dist/cjs/errors/security-error.js +0 -11
- package/dist/cjs/errors/semantic-error.js +0 -11
- package/dist/cjs/generated-schemas.js +0 -2100
- package/dist/cjs/index.js +0 -59
- package/dist/cjs/loader/index.js +0 -13
- package/dist/cjs/loader/security-validator.js +0 -53
- package/dist/cjs/loader/types.js +0 -11
- package/dist/cjs/loader/unispec-loader.js +0 -84
- package/dist/cjs/loader/yaml-loader.js +0 -76
- package/dist/cjs/normalizer/core.js +0 -32
- package/dist/cjs/normalizer/graphql-normalizer.js +0 -67
- package/dist/cjs/normalizer/index.js +0 -7
- package/dist/cjs/normalizer/rest-normalizer.js +0 -51
- package/dist/cjs/normalizer/types.js +0 -2
- package/dist/cjs/normalizer/utils.js +0 -33
- package/dist/cjs/normalizer/websocket-normalizer.js +0 -81
- package/dist/cjs/optimizer/core.js +0 -115
- package/dist/cjs/optimizer/index.js +0 -17
- package/dist/cjs/optimizer/optimization-functions.js +0 -185
- package/dist/cjs/optimizer/types.js +0 -2
- package/dist/cjs/optimizer/utils.js +0 -32
- package/dist/cjs/schemas/dedupe.js +0 -100
- package/dist/cjs/schemas/index.js +0 -14
- package/dist/cjs/schemas/resolver.js +0 -41
- package/dist/cjs/schemas/utils.js +0 -53
- package/dist/cjs/types/index.js +0 -2
- package/dist/cjs/validator/ajv-validator.js +0 -82
- package/dist/cjs/validator/config-validator-main.js +0 -34
- package/dist/cjs/validator/config-validator.js +0 -17
- package/dist/cjs/validator/index.js +0 -23
- package/dist/cjs/validator/object-traversal.js +0 -112
- package/dist/cjs/validator/reference-validator.js +0 -233
- package/dist/cjs/validator/schema-references.js +0 -116
- package/dist/cjs/validator/semantic-validator.js +0 -328
- package/dist/cjs/validator/tests-validator.js +0 -16
- package/dist/cjs/validator/types.js +0 -2
- package/dist/cjs/validator/unispec-validator.js +0 -84
- package/dist/cjs/validator/validator-factory.js +0 -77
- package/dist/cjs/versions.js +0 -147
- package/dist/diff/annotators.d.ts +0 -4
- package/dist/diff/annotators.js +0 -154
- package/dist/diff/change-reports.d.ts +0 -37
- package/dist/diff/change-reports.js +0 -366
- package/dist/diff/core.d.ts +0 -26
- package/dist/diff/core.js +0 -155
- package/dist/diff/enhanced-diff.d.ts +0 -51
- package/dist/diff/enhanced-diff.js +0 -76
- package/dist/diff/impact-strategies-refactored.d.ts +0 -69
- package/dist/diff/impact-strategies-refactored.js +0 -223
- package/dist/diff/impact-strategies.d.ts +0 -41
- package/dist/diff/impact-strategies.js +0 -212
- package/dist/diff/index.d.ts +0 -8
- package/dist/diff/index.js +0 -11
- package/dist/diff/metrics-calculator.d.ts +0 -23
- package/dist/diff/metrics-calculator.js +0 -65
- package/dist/diff/risk-calculator.d.ts +0 -23
- package/dist/diff/risk-calculator.js +0 -55
- package/dist/diff/suggestion-generator.d.ts +0 -18
- package/dist/diff/suggestion-generator.js +0 -74
- package/dist/diff/types.d.ts +0 -24
- package/dist/diff/types.js +0 -8
- package/dist/errors/base-error.d.ts +0 -20
- package/dist/errors/base-error.js +0 -29
- package/dist/errors/config-error.d.ts +0 -4
- package/dist/errors/config-error.js +0 -7
- package/dist/errors/error-factory.d.ts +0 -22
- package/dist/errors/error-factory.js +0 -45
- package/dist/errors/index.d.ts +0 -8
- package/dist/errors/index.js +0 -8
- package/dist/errors/loader-error.d.ts +0 -4
- package/dist/errors/loader-error.js +0 -7
- package/dist/errors/reference-error.d.ts +0 -4
- package/dist/errors/reference-error.js +0 -7
- package/dist/errors/schema-error.d.ts +0 -4
- package/dist/errors/schema-error.js +0 -7
- package/dist/errors/security-error.d.ts +0 -4
- package/dist/errors/security-error.js +0 -7
- package/dist/errors/semantic-error.d.ts +0 -4
- package/dist/errors/semantic-error.js +0 -7
- package/dist/generated-schemas.d.ts +0 -2073
- package/dist/generated-schemas.js +0 -2097
- package/dist/index.cjs +0 -59
- package/dist/index.d.ts +0 -13
- package/dist/index.js +0 -43
- package/dist/loader/index.d.ts +0 -5
- package/dist/loader/index.js +0 -5
- package/dist/loader/security-validator.d.ts +0 -5
- package/dist/loader/security-validator.js +0 -50
- package/dist/loader/types.d.ts +0 -30
- package/dist/loader/types.js +0 -8
- package/dist/loader/unispec-loader.d.ts +0 -10
- package/dist/loader/unispec-loader.js +0 -81
- package/dist/loader/yaml-loader.d.ts +0 -10
- package/dist/loader/yaml-loader.js +0 -39
- package/dist/normalizer/core.d.ts +0 -24
- package/dist/normalizer/core.js +0 -29
- package/dist/normalizer/graphql-normalizer.d.ts +0 -8
- package/dist/normalizer/graphql-normalizer.js +0 -64
- package/dist/normalizer/index.d.ts +0 -2
- package/dist/normalizer/index.js +0 -3
- package/dist/normalizer/rest-normalizer.d.ts +0 -8
- package/dist/normalizer/rest-normalizer.js +0 -48
- package/dist/normalizer/types.d.ts +0 -7
- package/dist/normalizer/types.js +0 -1
- package/dist/normalizer/utils.d.ts +0 -14
- package/dist/normalizer/utils.js +0 -29
- package/dist/normalizer/websocket-normalizer.d.ts +0 -8
- package/dist/normalizer/websocket-normalizer.js +0 -78
- package/dist/optimizer/core.d.ts +0 -17
- package/dist/optimizer/core.js +0 -111
- package/dist/optimizer/index.d.ts +0 -4
- package/dist/optimizer/index.js +0 -7
- package/dist/optimizer/optimization-functions.d.ts +0 -32
- package/dist/optimizer/optimization-functions.js +0 -179
- package/dist/optimizer/types.d.ts +0 -28
- package/dist/optimizer/types.js +0 -1
- package/dist/optimizer/utils.d.ts +0 -7
- package/dist/optimizer/utils.js +0 -29
- package/dist/schemas/dedupe.d.ts +0 -9
- package/dist/schemas/dedupe.js +0 -97
- package/dist/schemas/index.d.ts +0 -3
- package/dist/schemas/index.js +0 -6
- package/dist/schemas/resolver.d.ts +0 -19
- package/dist/schemas/resolver.js +0 -37
- package/dist/schemas/utils.d.ts +0 -20
- package/dist/schemas/utils.js +0 -49
- package/dist/types/index.d.ts +0 -433
- package/dist/types/index.js +0 -1
- package/dist/validator/ajv-validator.d.ts +0 -15
- package/dist/validator/ajv-validator.js +0 -75
- package/dist/validator/config-validator-main.d.ts +0 -10
- package/dist/validator/config-validator-main.js +0 -31
- package/dist/validator/config-validator.d.ts +0 -5
- package/dist/validator/config-validator.js +0 -14
- package/dist/validator/index.d.ts +0 -10
- package/dist/validator/index.js +0 -11
- package/dist/validator/object-traversal.d.ts +0 -52
- package/dist/validator/object-traversal.js +0 -104
- package/dist/validator/reference-validator.d.ts +0 -31
- package/dist/validator/reference-validator.js +0 -230
- package/dist/validator/schema-references.d.ts +0 -23
- package/dist/validator/schema-references.js +0 -111
- package/dist/validator/semantic-validator.d.ts +0 -26
- package/dist/validator/semantic-validator.js +0 -325
- package/dist/validator/tests-validator.d.ts +0 -9
- package/dist/validator/tests-validator.js +0 -13
- package/dist/validator/types.d.ts +0 -29
- package/dist/validator/types.js +0 -1
- package/dist/validator/unispec-validator.d.ts +0 -15
- package/dist/validator/unispec-validator.js +0 -81
- package/dist/validator/validator-factory.d.ts +0 -10
- package/dist/validator/validator-factory.js +0 -73
- package/dist/versions.d.ts +0 -10
- package/dist/versions.js +0 -143
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.diffUniSpecEnhanced = diffUniSpecEnhanced;
|
|
4
|
-
const core_1 = require("./core.js");
|
|
5
|
-
const impact_strategies_refactored_1 = require("./impact-strategies-refactored.js");
|
|
6
|
-
const metrics_calculator_1 = require("./metrics-calculator.js");
|
|
7
|
-
const risk_calculator_1 = require("./risk-calculator.js");
|
|
8
|
-
const suggestion_generator_1 = require("./suggestion-generator.js");
|
|
9
|
-
/**
|
|
10
|
-
* Service instances for better separation of concerns.
|
|
11
|
-
*/
|
|
12
|
-
const suggestionGenerator = new suggestion_generator_1.SuggestionGeneratorService();
|
|
13
|
-
const metricsCalculator = new metrics_calculator_1.MetricsCalculatorService();
|
|
14
|
-
/**
|
|
15
|
-
* Generate migration suggestions based on change impact.
|
|
16
|
-
* @deprecated Use SuggestionGeneratorService.generateSuggestions instead
|
|
17
|
-
*/
|
|
18
|
-
function generateSuggestions(change, impact) {
|
|
19
|
-
return suggestionGenerator.generateSuggestions(change, impact);
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Calculate compatibility metrics from enhanced changes.
|
|
23
|
-
* @deprecated Use MetricsCalculatorService.calculateMetrics instead
|
|
24
|
-
*/
|
|
25
|
-
function calculateMetrics(changes) {
|
|
26
|
-
return metricsCalculator.calculateMetrics(changes);
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Perform enhanced diff analysis with impact assessment and compatibility metrics.
|
|
30
|
-
*
|
|
31
|
-
* This function extends the basic diff functionality with:
|
|
32
|
-
* - Detailed impact analysis for each change
|
|
33
|
-
* - Compatibility metrics
|
|
34
|
-
* - Migration suggestions
|
|
35
|
-
* - Risk assessment
|
|
36
|
-
*
|
|
37
|
-
* @param oldDoc - The previous version of the UniSpec document
|
|
38
|
-
* @param newDoc - The current version of the UniSpec document
|
|
39
|
-
* @returns Enhanced diff result with comprehensive analysis
|
|
40
|
-
*/
|
|
41
|
-
function diffUniSpecEnhanced(oldDoc, newDoc) {
|
|
42
|
-
// Get basic diff
|
|
43
|
-
const basicDiff = (0, core_1.diffUniSpec)(oldDoc, newDoc);
|
|
44
|
-
// Enhance each change with impact analysis using strategy pattern
|
|
45
|
-
const enhancedChanges = basicDiff.changes.map((change) => {
|
|
46
|
-
// Get appropriate strategy for the protocol
|
|
47
|
-
const strategy = impact_strategies_refactored_1.ImpactAnalysisStrategyFactory.getStrategy(change.protocol);
|
|
48
|
-
// Analyze impact using strategy
|
|
49
|
-
const impact = strategy.analyze(change);
|
|
50
|
-
// Generate suggestions
|
|
51
|
-
const suggestions = generateSuggestions(change, impact);
|
|
52
|
-
// Calculate risk level using calculator
|
|
53
|
-
const riskLevel = risk_calculator_1.RiskLevelCalculator.calculate(impact);
|
|
54
|
-
return {
|
|
55
|
-
...change,
|
|
56
|
-
impact,
|
|
57
|
-
suggestions,
|
|
58
|
-
riskLevel,
|
|
59
|
-
};
|
|
60
|
-
});
|
|
61
|
-
// Calculate metrics
|
|
62
|
-
const metrics = calculateMetrics(enhancedChanges);
|
|
63
|
-
// Generate summary
|
|
64
|
-
const summary = {
|
|
65
|
-
totalChanges: enhancedChanges.length,
|
|
66
|
-
criticalChanges: enhancedChanges.filter((c) => c.riskLevel === "critical")
|
|
67
|
-
.length,
|
|
68
|
-
highRiskChanges: enhancedChanges.filter((c) => c.riskLevel === "high")
|
|
69
|
-
.length,
|
|
70
|
-
mediumRiskChanges: enhancedChanges.filter((c) => c.riskLevel === "medium")
|
|
71
|
-
.length,
|
|
72
|
-
lowRiskChanges: enhancedChanges.filter((c) => c.riskLevel === "low").length,
|
|
73
|
-
};
|
|
74
|
-
return {
|
|
75
|
-
changes: enhancedChanges,
|
|
76
|
-
metrics,
|
|
77
|
-
summary,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
@@ -1,230 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ImpactAnalysisStrategyFactory = exports.DefaultImpactStrategy = exports.WebSocketImpactStrategy = exports.GraphQLOperationImpactStrategy = exports.RestRouteImpactStrategy = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Base class for impact analysis strategies with common functionality.
|
|
6
|
-
*/
|
|
7
|
-
class BaseImpactStrategy {
|
|
8
|
-
createDefaultImpact() {
|
|
9
|
-
return {
|
|
10
|
-
backwardCompatibility: "unknown",
|
|
11
|
-
clientImpact: "none",
|
|
12
|
-
serverImpact: "none",
|
|
13
|
-
migrationComplexity: "none",
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
setBreakingChange(impact, clientImpact = "high", serverImpact = "medium", migrationComplexity = "moderate") {
|
|
17
|
-
impact.backwardCompatibility = "incompatible";
|
|
18
|
-
impact.clientImpact = clientImpact;
|
|
19
|
-
impact.serverImpact = serverImpact;
|
|
20
|
-
impact.migrationComplexity = migrationComplexity;
|
|
21
|
-
return impact;
|
|
22
|
-
}
|
|
23
|
-
setNonBreakingChange(impact, clientImpact = "none", serverImpact = "low", migrationComplexity = "none") {
|
|
24
|
-
impact.backwardCompatibility = "compatible";
|
|
25
|
-
impact.clientImpact = clientImpact;
|
|
26
|
-
impact.serverImpact = serverImpact;
|
|
27
|
-
impact.migrationComplexity = migrationComplexity;
|
|
28
|
-
return impact;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* REST route impact analysis strategy.
|
|
33
|
-
*/
|
|
34
|
-
class RestRouteImpactStrategy extends BaseImpactStrategy {
|
|
35
|
-
analyze(change) {
|
|
36
|
-
const impact = this.createDefaultImpact();
|
|
37
|
-
// Route removal is always breaking
|
|
38
|
-
if (this.isRouteRemoval(change)) {
|
|
39
|
-
return this.setBreakingChange(impact, "high", "medium", "complex");
|
|
40
|
-
}
|
|
41
|
-
// Route addition is non-breaking
|
|
42
|
-
if (this.isRouteAddition(change)) {
|
|
43
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
44
|
-
}
|
|
45
|
-
// Method change is breaking
|
|
46
|
-
if (this.isMethodChange(change)) {
|
|
47
|
-
return this.setBreakingChange(impact, "high", "medium", "moderate");
|
|
48
|
-
}
|
|
49
|
-
// Path change is breaking
|
|
50
|
-
if (this.isPathChange(change)) {
|
|
51
|
-
return this.setBreakingChange(impact, "high", "medium", "moderate");
|
|
52
|
-
}
|
|
53
|
-
// Required parameter change is breaking
|
|
54
|
-
if (this.isRequiredParameterChange(change)) {
|
|
55
|
-
return this.setBreakingChange(impact, "medium", "low", "simple");
|
|
56
|
-
}
|
|
57
|
-
// Response status code removal is breaking
|
|
58
|
-
if (this.isResponseRemoval(change)) {
|
|
59
|
-
return this.setBreakingChange(impact, "medium", "low", "simple");
|
|
60
|
-
}
|
|
61
|
-
// Adding optional parameter is non-breaking
|
|
62
|
-
if (this.isOptionalParameterAddition(change)) {
|
|
63
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
64
|
-
}
|
|
65
|
-
return impact;
|
|
66
|
-
}
|
|
67
|
-
isRouteRemoval(change) {
|
|
68
|
-
return (change.description === "Item removed" &&
|
|
69
|
-
!!change.kind?.includes("route.removed"));
|
|
70
|
-
}
|
|
71
|
-
isRouteAddition(change) {
|
|
72
|
-
return (change.description === "Item added" &&
|
|
73
|
-
!!change.kind?.includes("route.added"));
|
|
74
|
-
}
|
|
75
|
-
isMethodChange(change) {
|
|
76
|
-
return (change.path.includes("/method") && change.description === "Value changed");
|
|
77
|
-
}
|
|
78
|
-
isPathChange(change) {
|
|
79
|
-
return (change.path.includes("/path") && change.description === "Value changed");
|
|
80
|
-
}
|
|
81
|
-
isRequiredParameterChange(change) {
|
|
82
|
-
return (change.path.includes("/required") &&
|
|
83
|
-
change.description === "Value changed");
|
|
84
|
-
}
|
|
85
|
-
isResponseRemoval(change) {
|
|
86
|
-
return (change.path.includes("/responses/") &&
|
|
87
|
-
change.description === "Item removed");
|
|
88
|
-
}
|
|
89
|
-
isOptionalParameterAddition(change) {
|
|
90
|
-
return (change.path.includes("/queryParams/") &&
|
|
91
|
-
change.description === "Item added");
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
exports.RestRouteImpactStrategy = RestRouteImpactStrategy;
|
|
95
|
-
/**
|
|
96
|
-
* GraphQL operation impact analysis strategy.
|
|
97
|
-
*/
|
|
98
|
-
class GraphQLOperationImpactStrategy extends BaseImpactStrategy {
|
|
99
|
-
analyze(change) {
|
|
100
|
-
const impact = this.createDefaultImpact();
|
|
101
|
-
// Operation removal is breaking
|
|
102
|
-
if (this.isOperationRemoval(change)) {
|
|
103
|
-
return this.setBreakingChange(impact, "high", "medium", "complex");
|
|
104
|
-
}
|
|
105
|
-
// Operation addition is non-breaking
|
|
106
|
-
if (this.isOperationAddition(change)) {
|
|
107
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
108
|
-
}
|
|
109
|
-
// Return type change is breaking
|
|
110
|
-
if (this.isReturnTypeChange(change)) {
|
|
111
|
-
return this.setBreakingChange(impact, "high", "medium", "moderate");
|
|
112
|
-
}
|
|
113
|
-
// Adding optional argument is non-breaking
|
|
114
|
-
if (this.isOptionalArgumentAddition(change)) {
|
|
115
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
116
|
-
}
|
|
117
|
-
// Making argument required is breaking
|
|
118
|
-
if (this.isRequiredArgumentChange(change)) {
|
|
119
|
-
return this.setBreakingChange(impact, "medium", "low", "simple");
|
|
120
|
-
}
|
|
121
|
-
return impact;
|
|
122
|
-
}
|
|
123
|
-
isOperationRemoval(change) {
|
|
124
|
-
return (change.description === "Item removed" &&
|
|
125
|
-
!!change.kind?.includes("operation.removed"));
|
|
126
|
-
}
|
|
127
|
-
isOperationAddition(change) {
|
|
128
|
-
return (change.description === "Item added" &&
|
|
129
|
-
!!change.kind?.includes("operation.added"));
|
|
130
|
-
}
|
|
131
|
-
isReturnTypeChange(change) {
|
|
132
|
-
return (change.path.includes("/returnType") &&
|
|
133
|
-
change.description === "Value changed");
|
|
134
|
-
}
|
|
135
|
-
isOptionalArgumentAddition(change) {
|
|
136
|
-
return (change.path.includes("/args/") && change.description === "Item added");
|
|
137
|
-
}
|
|
138
|
-
isRequiredArgumentChange(change) {
|
|
139
|
-
return (change.path.includes("/args/") &&
|
|
140
|
-
change.path.includes("/required") &&
|
|
141
|
-
change.description === "Value changed");
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
exports.GraphQLOperationImpactStrategy = GraphQLOperationImpactStrategy;
|
|
145
|
-
/**
|
|
146
|
-
* WebSocket impact analysis strategy.
|
|
147
|
-
*/
|
|
148
|
-
class WebSocketImpactStrategy extends BaseImpactStrategy {
|
|
149
|
-
analyze(change) {
|
|
150
|
-
const impact = this.createDefaultImpact();
|
|
151
|
-
// Channel removal is breaking
|
|
152
|
-
if (this.isChannelRemoval(change)) {
|
|
153
|
-
return this.setBreakingChange(impact, "high", "medium", "complex");
|
|
154
|
-
}
|
|
155
|
-
// Channel addition is non-breaking
|
|
156
|
-
if (this.isChannelAddition(change)) {
|
|
157
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
158
|
-
}
|
|
159
|
-
// Message removal is breaking
|
|
160
|
-
if (this.isMessageRemoval(change)) {
|
|
161
|
-
return this.setBreakingChange(impact, "medium", "low", "moderate");
|
|
162
|
-
}
|
|
163
|
-
// Message addition is non-breaking
|
|
164
|
-
if (this.isMessageAddition(change)) {
|
|
165
|
-
return this.setNonBreakingChange(impact, "none", "low", "none");
|
|
166
|
-
}
|
|
167
|
-
// Message schema change is breaking
|
|
168
|
-
if (this.isMessageSchemaChange(change)) {
|
|
169
|
-
return this.setBreakingChange(impact, "medium", "low", "moderate");
|
|
170
|
-
}
|
|
171
|
-
return impact;
|
|
172
|
-
}
|
|
173
|
-
isChannelRemoval(change) {
|
|
174
|
-
return (change.description === "Item removed" &&
|
|
175
|
-
!!change.kind?.includes("channel.removed"));
|
|
176
|
-
}
|
|
177
|
-
isChannelAddition(change) {
|
|
178
|
-
return (change.description === "Item added" &&
|
|
179
|
-
!!change.kind?.includes("channel.added"));
|
|
180
|
-
}
|
|
181
|
-
isMessageRemoval(change) {
|
|
182
|
-
return (change.description === "Item removed" &&
|
|
183
|
-
!!change.kind?.includes("message.removed"));
|
|
184
|
-
}
|
|
185
|
-
isMessageAddition(change) {
|
|
186
|
-
return (change.description === "Item added" &&
|
|
187
|
-
!!change.kind?.includes("message.added"));
|
|
188
|
-
}
|
|
189
|
-
isMessageSchemaChange(change) {
|
|
190
|
-
return (change.path.includes("/schemaRef") &&
|
|
191
|
-
change.description === "Value changed");
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
exports.WebSocketImpactStrategy = WebSocketImpactStrategy;
|
|
195
|
-
/**
|
|
196
|
-
* Default impact analysis strategy for unknown changes.
|
|
197
|
-
*/
|
|
198
|
-
class DefaultImpactStrategy extends BaseImpactStrategy {
|
|
199
|
-
analyze(_change) {
|
|
200
|
-
return this.createDefaultImpact();
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
exports.DefaultImpactStrategy = DefaultImpactStrategy;
|
|
204
|
-
/**
|
|
205
|
-
* Factory for creating impact analysis strategies.
|
|
206
|
-
*/
|
|
207
|
-
const ImpactAnalysisStrategyFactory = {
|
|
208
|
-
strategies: new Map([
|
|
209
|
-
["rest", new RestRouteImpactStrategy()],
|
|
210
|
-
["graphql", new GraphQLOperationImpactStrategy()],
|
|
211
|
-
["websocket", new WebSocketImpactStrategy()],
|
|
212
|
-
]),
|
|
213
|
-
getStrategy(protocol) {
|
|
214
|
-
if (!protocol) {
|
|
215
|
-
return new DefaultImpactStrategy();
|
|
216
|
-
}
|
|
217
|
-
const strategy = this.strategies.get(protocol);
|
|
218
|
-
return strategy || new DefaultImpactStrategy();
|
|
219
|
-
},
|
|
220
|
-
registerStrategy(protocol, strategy) {
|
|
221
|
-
this.strategies.set(protocol, strategy);
|
|
222
|
-
},
|
|
223
|
-
getAvailableStrategies() {
|
|
224
|
-
return Array.from(this.strategies.keys());
|
|
225
|
-
},
|
|
226
|
-
clearStrategies() {
|
|
227
|
-
this.strategies.clear();
|
|
228
|
-
},
|
|
229
|
-
};
|
|
230
|
-
exports.ImpactAnalysisStrategyFactory = ImpactAnalysisStrategyFactory;
|
|
@@ -1,219 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ImpactAnalysisStrategyFactory = exports.DefaultImpactStrategy = exports.WebSocketImpactStrategy = exports.GraphQLOperationImpactStrategy = exports.RestRouteImpactStrategy = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* REST route impact analysis strategy.
|
|
6
|
-
*/
|
|
7
|
-
class RestRouteImpactStrategy {
|
|
8
|
-
analyze(change) {
|
|
9
|
-
const impact = {
|
|
10
|
-
backwardCompatibility: "unknown",
|
|
11
|
-
clientImpact: "none",
|
|
12
|
-
serverImpact: "none",
|
|
13
|
-
migrationComplexity: "none",
|
|
14
|
-
};
|
|
15
|
-
// Route removal is always breaking
|
|
16
|
-
if (change.description === "Item removed" &&
|
|
17
|
-
change.kind?.includes("route.removed")) {
|
|
18
|
-
impact.backwardCompatibility = "incompatible";
|
|
19
|
-
impact.clientImpact = "high";
|
|
20
|
-
impact.serverImpact = "medium";
|
|
21
|
-
impact.migrationComplexity = "complex";
|
|
22
|
-
}
|
|
23
|
-
// Route addition is non-breaking
|
|
24
|
-
if (change.description === "Item added" &&
|
|
25
|
-
change.kind?.includes("route.added")) {
|
|
26
|
-
impact.backwardCompatibility = "compatible";
|
|
27
|
-
impact.clientImpact = "none";
|
|
28
|
-
impact.serverImpact = "low";
|
|
29
|
-
impact.migrationComplexity = "none";
|
|
30
|
-
}
|
|
31
|
-
// Method change is breaking
|
|
32
|
-
if (change.path.includes("/method") &&
|
|
33
|
-
change.description === "Value changed") {
|
|
34
|
-
impact.backwardCompatibility = "incompatible";
|
|
35
|
-
impact.clientImpact = "high";
|
|
36
|
-
impact.serverImpact = "medium";
|
|
37
|
-
impact.migrationComplexity = "moderate";
|
|
38
|
-
}
|
|
39
|
-
// Path change is breaking
|
|
40
|
-
if (change.path.includes("/path") &&
|
|
41
|
-
change.description === "Value changed") {
|
|
42
|
-
impact.backwardCompatibility = "incompatible";
|
|
43
|
-
impact.clientImpact = "high";
|
|
44
|
-
impact.serverImpact = "medium";
|
|
45
|
-
impact.migrationComplexity = "moderate";
|
|
46
|
-
}
|
|
47
|
-
// Required parameter change is breaking
|
|
48
|
-
if (change.path.includes("/required") &&
|
|
49
|
-
change.description === "Value changed") {
|
|
50
|
-
impact.backwardCompatibility = "incompatible";
|
|
51
|
-
impact.clientImpact = "medium";
|
|
52
|
-
impact.serverImpact = "low";
|
|
53
|
-
impact.migrationComplexity = "simple";
|
|
54
|
-
}
|
|
55
|
-
// Response status code removal is breaking
|
|
56
|
-
if (change.path.includes("/responses/") &&
|
|
57
|
-
change.description === "Item removed") {
|
|
58
|
-
impact.backwardCompatibility = "incompatible";
|
|
59
|
-
impact.clientImpact = "medium";
|
|
60
|
-
impact.serverImpact = "low";
|
|
61
|
-
impact.migrationComplexity = "simple";
|
|
62
|
-
}
|
|
63
|
-
// Adding optional parameter is non-breaking
|
|
64
|
-
if (change.path.includes("/queryParams/") &&
|
|
65
|
-
change.description === "Item added") {
|
|
66
|
-
impact.backwardCompatibility = "compatible";
|
|
67
|
-
impact.clientImpact = "none";
|
|
68
|
-
impact.serverImpact = "low";
|
|
69
|
-
impact.migrationComplexity = "none";
|
|
70
|
-
}
|
|
71
|
-
return impact;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
exports.RestRouteImpactStrategy = RestRouteImpactStrategy;
|
|
75
|
-
/**
|
|
76
|
-
* GraphQL operation impact analysis strategy.
|
|
77
|
-
*/
|
|
78
|
-
class GraphQLOperationImpactStrategy {
|
|
79
|
-
analyze(change) {
|
|
80
|
-
const impact = {
|
|
81
|
-
backwardCompatibility: "unknown",
|
|
82
|
-
clientImpact: "none",
|
|
83
|
-
serverImpact: "none",
|
|
84
|
-
migrationComplexity: "none",
|
|
85
|
-
};
|
|
86
|
-
// Operation removal is breaking
|
|
87
|
-
if (change.description === "Item removed" &&
|
|
88
|
-
change.kind?.includes("operation.removed")) {
|
|
89
|
-
impact.backwardCompatibility = "incompatible";
|
|
90
|
-
impact.clientImpact = "high";
|
|
91
|
-
impact.serverImpact = "medium";
|
|
92
|
-
impact.migrationComplexity = "complex";
|
|
93
|
-
}
|
|
94
|
-
// Operation addition is non-breaking
|
|
95
|
-
if (change.description === "Item added" &&
|
|
96
|
-
change.kind?.includes("operation.added")) {
|
|
97
|
-
impact.backwardCompatibility = "compatible";
|
|
98
|
-
impact.clientImpact = "none";
|
|
99
|
-
impact.serverImpact = "low";
|
|
100
|
-
impact.migrationComplexity = "none";
|
|
101
|
-
}
|
|
102
|
-
// Return type change is breaking
|
|
103
|
-
if (change.path.includes("/returnType") &&
|
|
104
|
-
change.description === "Value changed") {
|
|
105
|
-
impact.backwardCompatibility = "incompatible";
|
|
106
|
-
impact.clientImpact = "high";
|
|
107
|
-
impact.serverImpact = "medium";
|
|
108
|
-
impact.migrationComplexity = "moderate";
|
|
109
|
-
}
|
|
110
|
-
// Adding optional argument is non-breaking
|
|
111
|
-
if (change.path.includes("/args/") && change.description === "Item added") {
|
|
112
|
-
impact.backwardCompatibility = "compatible";
|
|
113
|
-
impact.clientImpact = "none";
|
|
114
|
-
impact.serverImpact = "low";
|
|
115
|
-
impact.migrationComplexity = "none";
|
|
116
|
-
}
|
|
117
|
-
// Making argument required is breaking
|
|
118
|
-
if (change.path.includes("/args/") &&
|
|
119
|
-
change.path.includes("/required") &&
|
|
120
|
-
change.description === "Value changed") {
|
|
121
|
-
impact.backwardCompatibility = "incompatible";
|
|
122
|
-
impact.clientImpact = "medium";
|
|
123
|
-
impact.serverImpact = "low";
|
|
124
|
-
impact.migrationComplexity = "simple";
|
|
125
|
-
}
|
|
126
|
-
return impact;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
exports.GraphQLOperationImpactStrategy = GraphQLOperationImpactStrategy;
|
|
130
|
-
/**
|
|
131
|
-
* WebSocket impact analysis strategy.
|
|
132
|
-
*/
|
|
133
|
-
class WebSocketImpactStrategy {
|
|
134
|
-
analyze(change) {
|
|
135
|
-
const impact = {
|
|
136
|
-
backwardCompatibility: "unknown",
|
|
137
|
-
clientImpact: "none",
|
|
138
|
-
serverImpact: "none",
|
|
139
|
-
migrationComplexity: "none",
|
|
140
|
-
};
|
|
141
|
-
// Channel removal is breaking
|
|
142
|
-
if (change.description === "Item removed" &&
|
|
143
|
-
change.kind?.includes("channel.removed")) {
|
|
144
|
-
impact.backwardCompatibility = "incompatible";
|
|
145
|
-
impact.clientImpact = "high";
|
|
146
|
-
impact.serverImpact = "medium";
|
|
147
|
-
impact.migrationComplexity = "complex";
|
|
148
|
-
}
|
|
149
|
-
// Channel addition is non-breaking
|
|
150
|
-
if (change.description === "Item added" &&
|
|
151
|
-
change.kind?.includes("channel.added")) {
|
|
152
|
-
impact.backwardCompatibility = "compatible";
|
|
153
|
-
impact.clientImpact = "none";
|
|
154
|
-
impact.serverImpact = "low";
|
|
155
|
-
impact.migrationComplexity = "none";
|
|
156
|
-
}
|
|
157
|
-
// Message removal is breaking
|
|
158
|
-
if (change.description === "Item removed" &&
|
|
159
|
-
change.kind?.includes("message.removed")) {
|
|
160
|
-
impact.backwardCompatibility = "incompatible";
|
|
161
|
-
impact.clientImpact = "medium";
|
|
162
|
-
impact.serverImpact = "low";
|
|
163
|
-
impact.migrationComplexity = "moderate";
|
|
164
|
-
}
|
|
165
|
-
// Message addition is non-breaking
|
|
166
|
-
if (change.description === "Item added" &&
|
|
167
|
-
change.kind?.includes("message.added")) {
|
|
168
|
-
impact.backwardCompatibility = "compatible";
|
|
169
|
-
impact.clientImpact = "none";
|
|
170
|
-
impact.serverImpact = "low";
|
|
171
|
-
impact.migrationComplexity = "none";
|
|
172
|
-
}
|
|
173
|
-
// Message schema change is breaking
|
|
174
|
-
if (change.path.includes("/schemaRef") &&
|
|
175
|
-
change.description === "Value changed") {
|
|
176
|
-
impact.backwardCompatibility = "incompatible";
|
|
177
|
-
impact.clientImpact = "medium";
|
|
178
|
-
impact.serverImpact = "low";
|
|
179
|
-
impact.migrationComplexity = "moderate";
|
|
180
|
-
}
|
|
181
|
-
return impact;
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
exports.WebSocketImpactStrategy = WebSocketImpactStrategy;
|
|
185
|
-
/**
|
|
186
|
-
* Default impact analysis strategy for unknown changes.
|
|
187
|
-
*/
|
|
188
|
-
class DefaultImpactStrategy {
|
|
189
|
-
analyze(_change) {
|
|
190
|
-
return {
|
|
191
|
-
backwardCompatibility: "unknown",
|
|
192
|
-
clientImpact: "none",
|
|
193
|
-
serverImpact: "none",
|
|
194
|
-
migrationComplexity: "none",
|
|
195
|
-
};
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
exports.DefaultImpactStrategy = DefaultImpactStrategy;
|
|
199
|
-
/**
|
|
200
|
-
* Factory for creating impact analysis strategies.
|
|
201
|
-
*/
|
|
202
|
-
const ImpactAnalysisStrategyFactory = {
|
|
203
|
-
strategies: new Map([
|
|
204
|
-
["rest", new RestRouteImpactStrategy()],
|
|
205
|
-
["graphql", new GraphQLOperationImpactStrategy()],
|
|
206
|
-
["websocket", new WebSocketImpactStrategy()],
|
|
207
|
-
]),
|
|
208
|
-
getStrategy(protocol) {
|
|
209
|
-
if (!protocol) {
|
|
210
|
-
return new DefaultImpactStrategy();
|
|
211
|
-
}
|
|
212
|
-
const strategy = this.strategies.get(protocol);
|
|
213
|
-
return strategy || new DefaultImpactStrategy();
|
|
214
|
-
},
|
|
215
|
-
registerStrategy(protocol, strategy) {
|
|
216
|
-
this.strategies.set(protocol, strategy);
|
|
217
|
-
},
|
|
218
|
-
};
|
|
219
|
-
exports.ImpactAnalysisStrategyFactory = ImpactAnalysisStrategyFactory;
|
package/dist/cjs/diff/index.js
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// Export types
|
|
3
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
-
if (k2 === undefined) k2 = k;
|
|
5
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
-
}
|
|
9
|
-
Object.defineProperty(o, k2, desc);
|
|
10
|
-
}) : (function(o, m, k, k2) {
|
|
11
|
-
if (k2 === undefined) k2 = k;
|
|
12
|
-
o[k2] = m[k];
|
|
13
|
-
}));
|
|
14
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
16
|
-
};
|
|
17
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
__exportStar(require("./change-reports.js"), exports);
|
|
19
|
-
// Export core functionality
|
|
20
|
-
__exportStar(require("./core.js"), exports);
|
|
21
|
-
// Export enhanced functionality
|
|
22
|
-
__exportStar(require("./enhanced-diff.js"), exports);
|
|
23
|
-
__exportStar(require("./impact-strategies-refactored.js"), exports);
|
|
24
|
-
__exportStar(require("./metrics-calculator.js"), exports);
|
|
25
|
-
__exportStar(require("./risk-calculator.js"), exports);
|
|
26
|
-
__exportStar(require("./suggestion-generator.js"), exports);
|
|
27
|
-
__exportStar(require("./types.js"), exports);
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MetricsCalculatorService = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Service for calculating compatibility metrics from enhanced changes.
|
|
6
|
-
*/
|
|
7
|
-
class MetricsCalculatorService {
|
|
8
|
-
/**
|
|
9
|
-
* Calculate compatibility metrics from enhanced changes.
|
|
10
|
-
*/
|
|
11
|
-
calculateMetrics(changes) {
|
|
12
|
-
const breakingChanges = this.filterBreakingChanges(changes);
|
|
13
|
-
const nonBreakingChanges = this.filterNonBreakingChanges(changes);
|
|
14
|
-
const totalChanges = changes.length;
|
|
15
|
-
const breakingScore = this.calculateBreakingScore(breakingChanges.length, totalChanges);
|
|
16
|
-
const overallCompatibility = Math.max(0, 100 - breakingScore);
|
|
17
|
-
const clientScore = this.calculateClientCompatibilityScore(changes);
|
|
18
|
-
const serverScore = this.calculateServerCompatibilityScore(changes);
|
|
19
|
-
const migrationEffort = this.determineMigrationEffort(breakingChanges, nonBreakingChanges);
|
|
20
|
-
return {
|
|
21
|
-
overallCompatibility: Math.round(overallCompatibility),
|
|
22
|
-
breakingChangesCount: breakingChanges.length,
|
|
23
|
-
nonBreakingChangesCount: nonBreakingChanges.length,
|
|
24
|
-
clientCompatibilityScore: Math.round(clientScore),
|
|
25
|
-
serverCompatibilityScore: Math.round(serverScore),
|
|
26
|
-
migrationEffort,
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
filterBreakingChanges(changes) {
|
|
30
|
-
return changes.filter((c) => c.impact.backwardCompatibility === "incompatible");
|
|
31
|
-
}
|
|
32
|
-
filterNonBreakingChanges(changes) {
|
|
33
|
-
return changes.filter((c) => c.impact.backwardCompatibility === "compatible");
|
|
34
|
-
}
|
|
35
|
-
calculateBreakingScore(breakingCount, totalChanges) {
|
|
36
|
-
return totalChanges > 0 ? (breakingCount / totalChanges) * 100 : 0;
|
|
37
|
-
}
|
|
38
|
-
calculateClientCompatibilityScore(changes) {
|
|
39
|
-
const totalChanges = changes.length;
|
|
40
|
-
if (totalChanges === 0)
|
|
41
|
-
return 100;
|
|
42
|
-
const highClientImpact = changes.filter((c) => c.impact.clientImpact === "high").length;
|
|
43
|
-
const mediumClientImpact = changes.filter((c) => c.impact.clientImpact === "medium").length;
|
|
44
|
-
return (100 - (highClientImpact * 50 + mediumClientImpact * 25) / totalChanges);
|
|
45
|
-
}
|
|
46
|
-
calculateServerCompatibilityScore(changes) {
|
|
47
|
-
const totalChanges = changes.length;
|
|
48
|
-
if (totalChanges === 0)
|
|
49
|
-
return 100;
|
|
50
|
-
const highServerImpact = changes.filter((c) => c.impact.serverImpact === "high").length;
|
|
51
|
-
const mediumServerImpact = changes.filter((c) => c.impact.serverImpact === "medium").length;
|
|
52
|
-
return (100 - (highServerImpact * 30 + mediumServerImpact * 15) / totalChanges);
|
|
53
|
-
}
|
|
54
|
-
determineMigrationEffort(breakingChanges, _nonBreakingChanges) {
|
|
55
|
-
const complexMigrations = breakingChanges.filter((c) => c.impact.migrationComplexity === "complex").length;
|
|
56
|
-
const moderateMigrations = breakingChanges.filter((c) => c.impact.migrationComplexity === "moderate").length;
|
|
57
|
-
if (complexMigrations > 0) {
|
|
58
|
-
return "major";
|
|
59
|
-
}
|
|
60
|
-
else if (moderateMigrations > 2) {
|
|
61
|
-
return "significant";
|
|
62
|
-
}
|
|
63
|
-
else if (moderateMigrations > 0 || breakingChanges.length > 3) {
|
|
64
|
-
return "moderate";
|
|
65
|
-
}
|
|
66
|
-
return "minimal";
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
exports.MetricsCalculatorService = MetricsCalculatorService;
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.RiskLevelCalculator = void 0;
|
|
4
|
-
/**
|
|
5
|
-
* Calculator for determining risk levels based on change impact.
|
|
6
|
-
*/
|
|
7
|
-
exports.RiskLevelCalculator = {
|
|
8
|
-
/**
|
|
9
|
-
* Calculate risk level based on impact.
|
|
10
|
-
*/
|
|
11
|
-
calculate(impact) {
|
|
12
|
-
// Critical: Breaking changes with high client impact
|
|
13
|
-
if (impact.backwardCompatibility === "incompatible" &&
|
|
14
|
-
impact.clientImpact === "high") {
|
|
15
|
-
return "critical";
|
|
16
|
-
}
|
|
17
|
-
// High: Any breaking change
|
|
18
|
-
if (impact.backwardCompatibility === "incompatible") {
|
|
19
|
-
return "high";
|
|
20
|
-
}
|
|
21
|
-
// Medium: Medium impact on client or server
|
|
22
|
-
if (impact.clientImpact === "medium" || impact.serverImpact === "medium") {
|
|
23
|
-
return "medium";
|
|
24
|
-
}
|
|
25
|
-
// Low: Everything else
|
|
26
|
-
return "low";
|
|
27
|
-
},
|
|
28
|
-
/**
|
|
29
|
-
* Get risk level weight for sorting.
|
|
30
|
-
*/
|
|
31
|
-
getWeight(riskLevel) {
|
|
32
|
-
const weights = {
|
|
33
|
-
critical: 4,
|
|
34
|
-
high: 3,
|
|
35
|
-
medium: 2,
|
|
36
|
-
low: 1,
|
|
37
|
-
};
|
|
38
|
-
return weights[riskLevel];
|
|
39
|
-
},
|
|
40
|
-
/**
|
|
41
|
-
* Check if risk level requires immediate attention.
|
|
42
|
-
*/
|
|
43
|
-
requiresImmediateAttention(riskLevel) {
|
|
44
|
-
return riskLevel === "critical" || riskLevel === "high";
|
|
45
|
-
},
|
|
46
|
-
/**
|
|
47
|
-
* Get risk level description.
|
|
48
|
-
*/
|
|
49
|
-
getDescription(riskLevel) {
|
|
50
|
-
const descriptions = {
|
|
51
|
-
critical: "Critical breaking change requiring immediate action",
|
|
52
|
-
high: "Breaking change that requires attention",
|
|
53
|
-
medium: "Moderate change with some impact",
|
|
54
|
-
low: "Minor change with minimal impact",
|
|
55
|
-
};
|
|
56
|
-
return descriptions[riskLevel];
|
|
57
|
-
},
|
|
58
|
-
};
|