driftdetect-core 0.7.1 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/boundaries/types.d.ts +1 -1
- package/dist/boundaries/types.d.ts.map +1 -1
- package/dist/call-graph/analysis/graph-builder.d.ts.map +1 -1
- package/dist/call-graph/analysis/graph-builder.js +2 -0
- package/dist/call-graph/analysis/graph-builder.js.map +1 -1
- package/dist/call-graph/extractors/cpp-data-access-extractor.d.ts +37 -0
- package/dist/call-graph/extractors/cpp-data-access-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/cpp-data-access-extractor.js +467 -0
- package/dist/call-graph/extractors/cpp-data-access-extractor.js.map +1 -0
- package/dist/call-graph/extractors/cpp-hybrid-extractor.d.ts +89 -0
- package/dist/call-graph/extractors/cpp-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/cpp-hybrid-extractor.js +541 -0
- package/dist/call-graph/extractors/cpp-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/extractors/index.d.ts +8 -1
- package/dist/call-graph/extractors/index.d.ts.map +1 -1
- package/dist/call-graph/extractors/index.js +9 -1
- package/dist/call-graph/extractors/index.js.map +1 -1
- package/dist/call-graph/extractors/regex/cpp-regex.d.ts +46 -0
- package/dist/call-graph/extractors/regex/cpp-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/cpp-regex.js +325 -0
- package/dist/call-graph/extractors/regex/cpp-regex.js.map +1 -0
- package/dist/call-graph/extractors/regex/index.d.ts +2 -0
- package/dist/call-graph/extractors/regex/index.d.ts.map +1 -1
- package/dist/call-graph/extractors/regex/index.js +16 -0
- package/dist/call-graph/extractors/regex/index.js.map +1 -1
- package/dist/call-graph/extractors/regex/rust-regex.d.ts +45 -0
- package/dist/call-graph/extractors/regex/rust-regex.d.ts.map +1 -0
- package/dist/call-graph/extractors/regex/rust-regex.js +517 -0
- package/dist/call-graph/extractors/regex/rust-regex.js.map +1 -0
- package/dist/call-graph/extractors/rust-data-access-extractor.d.ts +35 -0
- package/dist/call-graph/extractors/rust-data-access-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/rust-data-access-extractor.js +349 -0
- package/dist/call-graph/extractors/rust-data-access-extractor.js.map +1 -0
- package/dist/call-graph/extractors/rust-extractor.d.ts +125 -0
- package/dist/call-graph/extractors/rust-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/rust-extractor.js +604 -0
- package/dist/call-graph/extractors/rust-extractor.js.map +1 -0
- package/dist/call-graph/extractors/rust-hybrid-extractor.d.ts +119 -0
- package/dist/call-graph/extractors/rust-hybrid-extractor.d.ts.map +1 -0
- package/dist/call-graph/extractors/rust-hybrid-extractor.js +548 -0
- package/dist/call-graph/extractors/rust-hybrid-extractor.js.map +1 -0
- package/dist/call-graph/index.d.ts +2 -0
- package/dist/call-graph/index.d.ts.map +1 -1
- package/dist/call-graph/index.js +4 -0
- package/dist/call-graph/index.js.map +1 -1
- package/dist/call-graph/streaming-builder.d.ts +60 -0
- package/dist/call-graph/streaming-builder.d.ts.map +1 -0
- package/dist/call-graph/streaming-builder.js +204 -0
- package/dist/call-graph/streaming-builder.js.map +1 -0
- package/dist/call-graph/types.d.ts +1 -1
- package/dist/call-graph/types.d.ts.map +1 -1
- package/dist/call-graph/unified-provider.d.ts +72 -0
- package/dist/call-graph/unified-provider.d.ts.map +1 -0
- package/dist/call-graph/unified-provider.js +502 -0
- package/dist/call-graph/unified-provider.js.map +1 -0
- package/dist/constants/extractors/regex/rust-regex.d.ts +43 -0
- package/dist/constants/extractors/regex/rust-regex.d.ts.map +1 -0
- package/dist/constants/extractors/regex/rust-regex.js +370 -0
- package/dist/constants/extractors/regex/rust-regex.js.map +1 -0
- package/dist/constants/types.d.ts +1 -1
- package/dist/constants/types.d.ts.map +1 -1
- package/dist/constants/types.js.map +1 -1
- package/dist/constraints/store/constraint-store.d.ts.map +1 -1
- package/dist/constraints/store/constraint-store.js +2 -0
- package/dist/constraints/store/constraint-store.js.map +1 -1
- package/dist/constraints/types.d.ts +1 -1
- package/dist/constraints/types.d.ts.map +1 -1
- package/dist/constraints/types.js +2 -0
- package/dist/constraints/types.js.map +1 -1
- package/dist/context/context-generator.d.ts +38 -0
- package/dist/context/context-generator.d.ts.map +1 -0
- package/dist/context/context-generator.js +392 -0
- package/dist/context/context-generator.js.map +1 -0
- package/dist/context/index.d.ts +13 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +14 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/package-detector.d.ts +53 -0
- package/dist/context/package-detector.d.ts.map +1 -0
- package/dist/context/package-detector.js +672 -0
- package/dist/context/package-detector.js.map +1 -0
- package/dist/context/types.d.ts +258 -0
- package/dist/context/types.d.ts.map +1 -0
- package/dist/context/types.js +10 -0
- package/dist/context/types.js.map +1 -0
- package/dist/cpp/cpp-analyzer.d.ts +179 -0
- package/dist/cpp/cpp-analyzer.d.ts.map +1 -0
- package/dist/cpp/cpp-analyzer.js +532 -0
- package/dist/cpp/cpp-analyzer.js.map +1 -0
- package/dist/cpp/index.d.ts +9 -0
- package/dist/cpp/index.d.ts.map +1 -0
- package/dist/cpp/index.js +9 -0
- package/dist/cpp/index.js.map +1 -0
- package/dist/decisions/analyzer/decision-mining-analyzer.d.ts.map +1 -1
- package/dist/decisions/analyzer/decision-mining-analyzer.js +4 -0
- package/dist/decisions/analyzer/decision-mining-analyzer.js.map +1 -1
- package/dist/decisions/types.d.ts +1 -1
- package/dist/decisions/types.d.ts.map +1 -1
- package/dist/environment/extractors/cpp-env-extractor.d.ts +58 -0
- package/dist/environment/extractors/cpp-env-extractor.d.ts.map +1 -0
- package/dist/environment/extractors/cpp-env-extractor.js +298 -0
- package/dist/environment/extractors/cpp-env-extractor.js.map +1 -0
- package/dist/environment/extractors/index.d.ts +2 -0
- package/dist/environment/extractors/index.d.ts.map +1 -1
- package/dist/environment/extractors/index.js +2 -0
- package/dist/environment/extractors/index.js.map +1 -1
- package/dist/environment/extractors/rust-env-extractor.d.ts +58 -0
- package/dist/environment/extractors/rust-env-extractor.d.ts.map +1 -0
- package/dist/environment/extractors/rust-env-extractor.js +297 -0
- package/dist/environment/extractors/rust-env-extractor.js.map +1 -0
- package/dist/environment/index.d.ts +1 -1
- package/dist/environment/index.d.ts.map +1 -1
- package/dist/environment/index.js +1 -1
- package/dist/environment/index.js.map +1 -1
- package/dist/environment/types.d.ts +2 -2
- package/dist/environment/types.d.ts.map +1 -1
- package/dist/environment/types.js.map +1 -1
- package/dist/index.d.ts +15 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +62 -2
- package/dist/index.js.map +1 -1
- package/dist/licensing/feature-guard.d.ts +103 -0
- package/dist/licensing/feature-guard.d.ts.map +1 -0
- package/dist/licensing/feature-guard.js +195 -0
- package/dist/licensing/feature-guard.js.map +1 -0
- package/dist/licensing/index.d.ts +46 -0
- package/dist/licensing/index.d.ts.map +1 -0
- package/dist/licensing/index.js +47 -0
- package/dist/licensing/index.js.map +1 -0
- package/dist/licensing/license-manager.d.ts +88 -0
- package/dist/licensing/license-manager.d.ts.map +1 -0
- package/dist/licensing/license-manager.js +251 -0
- package/dist/licensing/license-manager.js.map +1 -0
- package/dist/licensing/license-validator.d.ts +60 -0
- package/dist/licensing/license-validator.d.ts.map +1 -0
- package/dist/licensing/license-validator.js +300 -0
- package/dist/licensing/license-validator.js.map +1 -0
- package/dist/licensing/types.d.ts +76 -0
- package/dist/licensing/types.d.ts.map +1 -0
- package/dist/licensing/types.js +51 -0
- package/dist/licensing/types.js.map +1 -0
- package/dist/parsers/tree-sitter/cpp-loader.d.ts +51 -0
- package/dist/parsers/tree-sitter/cpp-loader.d.ts.map +1 -0
- package/dist/parsers/tree-sitter/cpp-loader.js +162 -0
- package/dist/parsers/tree-sitter/cpp-loader.js.map +1 -0
- package/dist/parsers/tree-sitter/index.d.ts +6 -0
- package/dist/parsers/tree-sitter/index.d.ts.map +1 -1
- package/dist/parsers/tree-sitter/index.js +16 -0
- package/dist/parsers/tree-sitter/index.js.map +1 -1
- package/dist/parsers/tree-sitter/rust-loader.d.ts +50 -0
- package/dist/parsers/tree-sitter/rust-loader.d.ts.map +1 -0
- package/dist/parsers/tree-sitter/rust-loader.js +161 -0
- package/dist/parsers/tree-sitter/rust-loader.js.map +1 -0
- package/dist/parsers/tree-sitter/tree-sitter-cpp-parser.d.ts +198 -0
- package/dist/parsers/tree-sitter/tree-sitter-cpp-parser.d.ts.map +1 -0
- package/dist/parsers/tree-sitter/tree-sitter-cpp-parser.js +671 -0
- package/dist/parsers/tree-sitter/tree-sitter-cpp-parser.js.map +1 -0
- package/dist/parsers/tree-sitter/tree-sitter-rust-parser.d.ts +180 -0
- package/dist/parsers/tree-sitter/tree-sitter-rust-parser.d.ts.map +1 -0
- package/dist/parsers/tree-sitter/tree-sitter-rust-parser.js +478 -0
- package/dist/parsers/tree-sitter/tree-sitter-rust-parser.js.map +1 -0
- package/dist/parsers/types.d.ts +1 -1
- package/dist/parsers/types.d.ts.map +1 -1
- package/dist/patterns/adapters/pattern-store-adapter.d.ts.map +1 -1
- package/dist/patterns/adapters/pattern-store-adapter.js +35 -10
- package/dist/patterns/adapters/pattern-store-adapter.js.map +1 -1
- package/dist/quality-gates/gates/base-gate.d.ts +71 -0
- package/dist/quality-gates/gates/base-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/base-gate.js +178 -0
- package/dist/quality-gates/gates/base-gate.js.map +1 -0
- package/dist/quality-gates/gates/constraint-verification/constraint-verification-gate.d.ts +62 -0
- package/dist/quality-gates/gates/constraint-verification/constraint-verification-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/constraint-verification/constraint-verification-gate.js +255 -0
- package/dist/quality-gates/gates/constraint-verification/constraint-verification-gate.js.map +1 -0
- package/dist/quality-gates/gates/constraint-verification/index.d.ts +7 -0
- package/dist/quality-gates/gates/constraint-verification/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/constraint-verification/index.js +7 -0
- package/dist/quality-gates/gates/constraint-verification/index.js.map +1 -0
- package/dist/quality-gates/gates/custom-rules/custom-rules-gate.d.ts +73 -0
- package/dist/quality-gates/gates/custom-rules/custom-rules-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/custom-rules/custom-rules-gate.js +351 -0
- package/dist/quality-gates/gates/custom-rules/custom-rules-gate.js.map +1 -0
- package/dist/quality-gates/gates/custom-rules/index.d.ts +7 -0
- package/dist/quality-gates/gates/custom-rules/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/custom-rules/index.js +7 -0
- package/dist/quality-gates/gates/custom-rules/index.js.map +1 -0
- package/dist/quality-gates/gates/impact-simulation/impact-simulation-gate.d.ts +61 -0
- package/dist/quality-gates/gates/impact-simulation/impact-simulation-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/impact-simulation/impact-simulation-gate.js +318 -0
- package/dist/quality-gates/gates/impact-simulation/impact-simulation-gate.js.map +1 -0
- package/dist/quality-gates/gates/impact-simulation/index.d.ts +7 -0
- package/dist/quality-gates/gates/impact-simulation/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/impact-simulation/index.js +7 -0
- package/dist/quality-gates/gates/impact-simulation/index.js.map +1 -0
- package/dist/quality-gates/gates/index.d.ts +13 -0
- package/dist/quality-gates/gates/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/index.js +13 -0
- package/dist/quality-gates/gates/index.js.map +1 -0
- package/dist/quality-gates/gates/pattern-compliance/index.d.ts +7 -0
- package/dist/quality-gates/gates/pattern-compliance/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/pattern-compliance/index.js +7 -0
- package/dist/quality-gates/gates/pattern-compliance/index.js.map +1 -0
- package/dist/quality-gates/gates/pattern-compliance/pattern-compliance-gate.d.ts +61 -0
- package/dist/quality-gates/gates/pattern-compliance/pattern-compliance-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/pattern-compliance/pattern-compliance-gate.js +261 -0
- package/dist/quality-gates/gates/pattern-compliance/pattern-compliance-gate.js.map +1 -0
- package/dist/quality-gates/gates/regression-detection/index.d.ts +7 -0
- package/dist/quality-gates/gates/regression-detection/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/regression-detection/index.js +7 -0
- package/dist/quality-gates/gates/regression-detection/index.js.map +1 -0
- package/dist/quality-gates/gates/regression-detection/regression-detection-gate.d.ts +69 -0
- package/dist/quality-gates/gates/regression-detection/regression-detection-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/regression-detection/regression-detection-gate.js +330 -0
- package/dist/quality-gates/gates/regression-detection/regression-detection-gate.js.map +1 -0
- package/dist/quality-gates/gates/security-boundary/index.d.ts +7 -0
- package/dist/quality-gates/gates/security-boundary/index.d.ts.map +1 -0
- package/dist/quality-gates/gates/security-boundary/index.js +7 -0
- package/dist/quality-gates/gates/security-boundary/index.js.map +1 -0
- package/dist/quality-gates/gates/security-boundary/security-boundary-gate.d.ts +65 -0
- package/dist/quality-gates/gates/security-boundary/security-boundary-gate.d.ts.map +1 -0
- package/dist/quality-gates/gates/security-boundary/security-boundary-gate.js +307 -0
- package/dist/quality-gates/gates/security-boundary/security-boundary-gate.js.map +1 -0
- package/dist/quality-gates/index.d.ts +35 -0
- package/dist/quality-gates/index.d.ts.map +1 -0
- package/dist/quality-gates/index.js +43 -0
- package/dist/quality-gates/index.js.map +1 -0
- package/dist/quality-gates/orchestrator/gate-orchestrator.d.ts +79 -0
- package/dist/quality-gates/orchestrator/gate-orchestrator.d.ts.map +1 -0
- package/dist/quality-gates/orchestrator/gate-orchestrator.js +314 -0
- package/dist/quality-gates/orchestrator/gate-orchestrator.js.map +1 -0
- package/dist/quality-gates/orchestrator/gate-registry.d.ts +53 -0
- package/dist/quality-gates/orchestrator/gate-registry.d.ts.map +1 -0
- package/dist/quality-gates/orchestrator/gate-registry.js +141 -0
- package/dist/quality-gates/orchestrator/gate-registry.js.map +1 -0
- package/dist/quality-gates/orchestrator/index.d.ts +10 -0
- package/dist/quality-gates/orchestrator/index.d.ts.map +1 -0
- package/dist/quality-gates/orchestrator/index.js +10 -0
- package/dist/quality-gates/orchestrator/index.js.map +1 -0
- package/dist/quality-gates/orchestrator/parallel-executor.d.ts +35 -0
- package/dist/quality-gates/orchestrator/parallel-executor.d.ts.map +1 -0
- package/dist/quality-gates/orchestrator/parallel-executor.js +70 -0
- package/dist/quality-gates/orchestrator/parallel-executor.js.map +1 -0
- package/dist/quality-gates/orchestrator/result-aggregator.d.ts +27 -0
- package/dist/quality-gates/orchestrator/result-aggregator.d.ts.map +1 -0
- package/dist/quality-gates/orchestrator/result-aggregator.js +70 -0
- package/dist/quality-gates/orchestrator/result-aggregator.js.map +1 -0
- package/dist/quality-gates/policy/default-policies.d.ts +14 -0
- package/dist/quality-gates/policy/default-policies.d.ts.map +1 -0
- package/dist/quality-gates/policy/default-policies.js +266 -0
- package/dist/quality-gates/policy/default-policies.js.map +1 -0
- package/dist/quality-gates/policy/index.d.ts +9 -0
- package/dist/quality-gates/policy/index.d.ts.map +1 -0
- package/dist/quality-gates/policy/index.js +9 -0
- package/dist/quality-gates/policy/index.js.map +1 -0
- package/dist/quality-gates/policy/policy-evaluator.d.ts +43 -0
- package/dist/quality-gates/policy/policy-evaluator.d.ts.map +1 -0
- package/dist/quality-gates/policy/policy-evaluator.js +136 -0
- package/dist/quality-gates/policy/policy-evaluator.js.map +1 -0
- package/dist/quality-gates/policy/policy-loader.d.ts +72 -0
- package/dist/quality-gates/policy/policy-loader.d.ts.map +1 -0
- package/dist/quality-gates/policy/policy-loader.js +228 -0
- package/dist/quality-gates/policy/policy-loader.js.map +1 -0
- package/dist/quality-gates/reporters/github-reporter.d.ts +19 -0
- package/dist/quality-gates/reporters/github-reporter.d.ts.map +1 -0
- package/dist/quality-gates/reporters/github-reporter.js +49 -0
- package/dist/quality-gates/reporters/github-reporter.js.map +1 -0
- package/dist/quality-gates/reporters/gitlab-reporter.d.ts +20 -0
- package/dist/quality-gates/reporters/gitlab-reporter.d.ts.map +1 -0
- package/dist/quality-gates/reporters/gitlab-reporter.js +42 -0
- package/dist/quality-gates/reporters/gitlab-reporter.js.map +1 -0
- package/dist/quality-gates/reporters/index.d.ts +12 -0
- package/dist/quality-gates/reporters/index.d.ts.map +1 -0
- package/dist/quality-gates/reporters/index.js +12 -0
- package/dist/quality-gates/reporters/index.js.map +1 -0
- package/dist/quality-gates/reporters/json-reporter.d.ts +18 -0
- package/dist/quality-gates/reporters/json-reporter.d.ts.map +1 -0
- package/dist/quality-gates/reporters/json-reporter.js +51 -0
- package/dist/quality-gates/reporters/json-reporter.js.map +1 -0
- package/dist/quality-gates/reporters/reporter-interface.d.ts +35 -0
- package/dist/quality-gates/reporters/reporter-interface.d.ts.map +1 -0
- package/dist/quality-gates/reporters/reporter-interface.js +22 -0
- package/dist/quality-gates/reporters/reporter-interface.js.map +1 -0
- package/dist/quality-gates/reporters/sarif-reporter.d.ts +22 -0
- package/dist/quality-gates/reporters/sarif-reporter.d.ts.map +1 -0
- package/dist/quality-gates/reporters/sarif-reporter.js +85 -0
- package/dist/quality-gates/reporters/sarif-reporter.js.map +1 -0
- package/dist/quality-gates/reporters/text-reporter.d.ts +18 -0
- package/dist/quality-gates/reporters/text-reporter.d.ts.map +1 -0
- package/dist/quality-gates/reporters/text-reporter.js +92 -0
- package/dist/quality-gates/reporters/text-reporter.js.map +1 -0
- package/dist/quality-gates/store/gate-run-store.d.ts +37 -0
- package/dist/quality-gates/store/gate-run-store.d.ts.map +1 -0
- package/dist/quality-gates/store/gate-run-store.js +104 -0
- package/dist/quality-gates/store/gate-run-store.js.map +1 -0
- package/dist/quality-gates/store/index.d.ts +8 -0
- package/dist/quality-gates/store/index.d.ts.map +1 -0
- package/dist/quality-gates/store/index.js +8 -0
- package/dist/quality-gates/store/index.js.map +1 -0
- package/dist/quality-gates/store/snapshot-store.d.ts +41 -0
- package/dist/quality-gates/store/snapshot-store.d.ts.map +1 -0
- package/dist/quality-gates/store/snapshot-store.js +117 -0
- package/dist/quality-gates/store/snapshot-store.js.map +1 -0
- package/dist/quality-gates/types.d.ts +992 -0
- package/dist/quality-gates/types.d.ts.map +1 -0
- package/dist/quality-gates/types.js +14 -0
- package/dist/quality-gates/types.js.map +1 -0
- package/dist/rust/index.d.ts +7 -0
- package/dist/rust/index.d.ts.map +1 -0
- package/dist/rust/index.js +8 -0
- package/dist/rust/index.js.map +1 -0
- package/dist/rust/rust-analyzer.d.ts +185 -0
- package/dist/rust/rust-analyzer.d.ts.map +1 -0
- package/dist/rust/rust-analyzer.js +538 -0
- package/dist/rust/rust-analyzer.js.map +1 -0
- package/dist/scanner/file-walker.d.ts.map +1 -1
- package/dist/scanner/file-walker.js +11 -0
- package/dist/scanner/file-walker.js.map +1 -1
- package/dist/simulation/simulation-engine.d.ts +6 -0
- package/dist/simulation/simulation-engine.d.ts.map +1 -1
- package/dist/simulation/simulation-engine.js +6 -0
- package/dist/simulation/simulation-engine.js.map +1 -1
- package/dist/speculative/types.d.ts +1 -1
- package/dist/speculative/types.d.ts.map +1 -1
- package/dist/speculative/types.js +2 -0
- package/dist/speculative/types.js.map +1 -1
- package/dist/store/project-config.d.ts +19 -0
- package/dist/store/project-config.d.ts.map +1 -1
- package/dist/store/project-config.js.map +1 -1
- package/dist/telemetry/index.d.ts +10 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +11 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/telemetry-client.d.ts +127 -0
- package/dist/telemetry/telemetry-client.d.ts.map +1 -0
- package/dist/telemetry/telemetry-client.js +373 -0
- package/dist/telemetry/telemetry-client.js.map +1 -0
- package/dist/telemetry/types.d.ts +160 -0
- package/dist/telemetry/types.d.ts.map +1 -0
- package/dist/telemetry/types.js +27 -0
- package/dist/telemetry/types.js.map +1 -0
- package/dist/test-topology/extractors/cpp-test-extractor.d.ts +38 -0
- package/dist/test-topology/extractors/cpp-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/cpp-test-extractor.js +507 -0
- package/dist/test-topology/extractors/cpp-test-extractor.js.map +1 -0
- package/dist/test-topology/extractors/index.d.ts +2 -0
- package/dist/test-topology/extractors/index.d.ts.map +1 -1
- package/dist/test-topology/extractors/index.js +2 -0
- package/dist/test-topology/extractors/index.js.map +1 -1
- package/dist/test-topology/extractors/regex/index.d.ts +1 -0
- package/dist/test-topology/extractors/regex/index.d.ts.map +1 -1
- package/dist/test-topology/extractors/regex/index.js +4 -0
- package/dist/test-topology/extractors/regex/index.js.map +1 -1
- package/dist/test-topology/extractors/regex/rust-test-regex.d.ts +66 -0
- package/dist/test-topology/extractors/regex/rust-test-regex.d.ts.map +1 -0
- package/dist/test-topology/extractors/regex/rust-test-regex.js +565 -0
- package/dist/test-topology/extractors/regex/rust-test-regex.js.map +1 -0
- package/dist/test-topology/extractors/rust-test-extractor.d.ts +49 -0
- package/dist/test-topology/extractors/rust-test-extractor.d.ts.map +1 -0
- package/dist/test-topology/extractors/rust-test-extractor.js +422 -0
- package/dist/test-topology/extractors/rust-test-extractor.js.map +1 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.d.ts.map +1 -1
- package/dist/test-topology/hybrid-test-topology-analyzer.js +2 -0
- package/dist/test-topology/hybrid-test-topology-analyzer.js.map +1 -1
- package/dist/test-topology/test-topology-analyzer.d.ts.map +1 -1
- package/dist/test-topology/test-topology-analyzer.js +2 -0
- package/dist/test-topology/test-topology-analyzer.js.map +1 -1
- package/dist/test-topology/types.d.ts +2 -2
- package/dist/test-topology/types.d.ts.map +1 -1
- package/dist/unified-provider/integration/unified-scanner.d.ts.map +1 -1
- package/dist/unified-provider/integration/unified-scanner.js +3 -0
- package/dist/unified-provider/integration/unified-scanner.js.map +1 -1
- package/dist/unified-provider/matching/diesel-matcher.d.ts +33 -0
- package/dist/unified-provider/matching/diesel-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/diesel-matcher.js +210 -0
- package/dist/unified-provider/matching/diesel-matcher.js.map +1 -0
- package/dist/unified-provider/matching/index.d.ts +3 -1
- package/dist/unified-provider/matching/index.d.ts.map +1 -1
- package/dist/unified-provider/matching/index.js +4 -1
- package/dist/unified-provider/matching/index.js.map +1 -1
- package/dist/unified-provider/matching/matcher-registry.d.ts.map +1 -1
- package/dist/unified-provider/matching/matcher-registry.js +7 -2
- package/dist/unified-provider/matching/matcher-registry.js.map +1 -1
- package/dist/unified-provider/matching/seaorm-matcher.d.ts +35 -0
- package/dist/unified-provider/matching/seaorm-matcher.d.ts.map +1 -0
- package/dist/unified-provider/matching/seaorm-matcher.js +200 -0
- package/dist/unified-provider/matching/seaorm-matcher.js.map +1 -0
- package/dist/unified-provider/matching/sqlx-matcher.d.ts +19 -24
- package/dist/unified-provider/matching/sqlx-matcher.d.ts.map +1 -1
- package/dist/unified-provider/matching/sqlx-matcher.js +171 -149
- package/dist/unified-provider/matching/sqlx-matcher.js.map +1 -1
- package/dist/unified-provider/normalization/cpp-normalizer.d.ts +62 -0
- package/dist/unified-provider/normalization/cpp-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/cpp-normalizer.js +581 -0
- package/dist/unified-provider/normalization/cpp-normalizer.js.map +1 -0
- package/dist/unified-provider/normalization/index.d.ts +2 -0
- package/dist/unified-provider/normalization/index.d.ts.map +1 -1
- package/dist/unified-provider/normalization/index.js +11 -1
- package/dist/unified-provider/normalization/index.js.map +1 -1
- package/dist/unified-provider/normalization/rust-normalizer.d.ts +71 -0
- package/dist/unified-provider/normalization/rust-normalizer.d.ts.map +1 -0
- package/dist/unified-provider/normalization/rust-normalizer.js +670 -0
- package/dist/unified-provider/normalization/rust-normalizer.js.map +1 -0
- package/dist/unified-provider/parsing/parser-registry.d.ts.map +1 -1
- package/dist/unified-provider/parsing/parser-registry.js +62 -1
- package/dist/unified-provider/parsing/parser-registry.js.map +1 -1
- package/dist/unified-provider/provider/unified-language-provider.js +1 -1
- package/dist/unified-provider/provider/unified-language-provider.js.map +1 -1
- package/dist/unified-provider/types.d.ts +1 -1
- package/dist/unified-provider/types.d.ts.map +1 -1
- package/dist/wrappers/index.d.ts.map +1 -1
- package/dist/wrappers/index.js +2 -0
- package/dist/wrappers/index.js.map +1 -1
- package/dist/wrappers/integration/adapter.d.ts.map +1 -1
- package/dist/wrappers/integration/adapter.js +2 -0
- package/dist/wrappers/integration/adapter.js.map +1 -1
- package/dist/wrappers/integration/scanner.d.ts.map +1 -1
- package/dist/wrappers/integration/scanner.js +2 -0
- package/dist/wrappers/integration/scanner.js.map +1 -1
- package/dist/wrappers/primitives/registry.d.ts +18 -0
- package/dist/wrappers/primitives/registry.d.ts.map +1 -1
- package/dist/wrappers/primitives/registry.js +190 -0
- package/dist/wrappers/primitives/registry.js.map +1 -1
- package/dist/wrappers/types.d.ts +1 -1
- package/dist/wrappers/types.d.ts.map +1 -1
- package/package.json +17 -14
- package/LICENSE +0 -21
- package/dist/lake/lake.bak/index-store.d.ts +0 -82
- package/dist/lake/lake.bak/index-store.d.ts.map +0 -1
- package/dist/lake/lake.bak/index-store.js +0 -357
- package/dist/lake/lake.bak/index-store.js.map +0 -1
- package/dist/lake/lake.bak/index.d.ts +0 -81
- package/dist/lake/lake.bak/index.d.ts.map +0 -1
- package/dist/lake/lake.bak/index.js +0 -114
- package/dist/lake/lake.bak/index.js.map +0 -1
- package/dist/lake/lake.bak/manifest-store.d.ts +0 -51
- package/dist/lake/lake.bak/manifest-store.d.ts.map +0 -1
- package/dist/lake/lake.bak/manifest-store.js +0 -347
- package/dist/lake/lake.bak/manifest-store.js.map +0 -1
- package/dist/lake/lake.bak/query-engine.d.ts +0 -112
- package/dist/lake/lake.bak/query-engine.d.ts.map +0 -1
- package/dist/lake/lake.bak/query-engine.js +0 -370
- package/dist/lake/lake.bak/query-engine.js.map +0 -1
- package/dist/lake/lake.bak/types.d.ts +0 -428
- package/dist/lake/lake.bak/types.d.ts.map +0 -1
- package/dist/lake/lake.bak/types.js +0 -46
- package/dist/lake/lake.bak/types.js.map +0 -1
- package/dist/lake/lake.bak/view-materializer.d.ts +0 -70
- package/dist/lake/lake.bak/view-materializer.d.ts.map +0 -1
- package/dist/lake/lake.bak/view-materializer.js +0 -314
- package/dist/lake/lake.bak/view-materializer.js.map +0 -1
- package/dist/lake/lake.bak/view-store.d.ts +0 -57
- package/dist/lake/lake.bak/view-store.d.ts.map +0 -1
- package/dist/lake/lake.bak/view-store.js +0 -348
- package/dist/lake/lake.bak/view-store.js.map +0 -1
- package/dist/unified-provider/migration/deprecated-extractors.d.ts +0 -104
- package/dist/unified-provider/migration/deprecated-extractors.d.ts.map +0 -1
- package/dist/unified-provider/migration/deprecated-extractors.js +0 -129
- package/dist/unified-provider/migration/deprecated-extractors.js.map +0 -1
- package/dist/unified-provider/migration/deprecated-scanner.d.ts +0 -40
- package/dist/unified-provider/migration/deprecated-scanner.d.ts.map +0 -1
- package/dist/unified-provider/migration/deprecated-scanner.js +0 -49
- package/dist/unified-provider/migration/deprecated-scanner.js.map +0 -1
- package/dist/unified-provider/migration/index.d.ts +0 -41
- package/dist/unified-provider/migration/index.d.ts.map +0 -1
- package/dist/unified-provider/migration/index.js +0 -43
- package/dist/unified-provider/migration/index.js.map +0 -1
|
@@ -0,0 +1,330 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Regression Detection Gate
|
|
3
|
+
*
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*
|
|
6
|
+
* Detects pattern regressions by comparing current state against a baseline.
|
|
7
|
+
* Catches when changes cause patterns to degrade (lower confidence, more outliers).
|
|
8
|
+
*
|
|
9
|
+
* FUTURE_GATE: gate:regression-detection (Team tier)
|
|
10
|
+
*/
|
|
11
|
+
import { BaseGate } from '../base-gate.js';
|
|
12
|
+
/**
|
|
13
|
+
* Regression Detection Gate
|
|
14
|
+
*
|
|
15
|
+
* Compares current pattern health against a baseline to detect regressions.
|
|
16
|
+
*/
|
|
17
|
+
export class RegressionDetectionGate extends BaseGate {
|
|
18
|
+
id = 'regression-detection';
|
|
19
|
+
name = 'Regression Detection';
|
|
20
|
+
description = 'Detects pattern regressions from baseline';
|
|
21
|
+
async executeGate(input) {
|
|
22
|
+
const config = input.config;
|
|
23
|
+
const patterns = input.context.patterns ?? [];
|
|
24
|
+
const previousSnapshot = input.context.previousSnapshot;
|
|
25
|
+
if (!previousSnapshot) {
|
|
26
|
+
return this.createPassedResult('No baseline snapshot available for comparison', {
|
|
27
|
+
regressions: [],
|
|
28
|
+
improvements: [],
|
|
29
|
+
overallHealthDelta: 0,
|
|
30
|
+
categoryDeltas: {},
|
|
31
|
+
baseline: {
|
|
32
|
+
type: config.baseline,
|
|
33
|
+
reference: 'none',
|
|
34
|
+
timestamp: new Date().toISOString(),
|
|
35
|
+
},
|
|
36
|
+
}, ['No baseline snapshot found. Run `drift gate` on main branch first to establish baseline.']);
|
|
37
|
+
}
|
|
38
|
+
// Compare current patterns against baseline
|
|
39
|
+
const comparison = this.comparePatterns(patterns, previousSnapshot, config);
|
|
40
|
+
// Build violations from regressions
|
|
41
|
+
const violations = this.buildViolations(comparison.regressions, config);
|
|
42
|
+
// Determine pass/fail based on thresholds
|
|
43
|
+
const passed = this.evaluateThresholds(comparison, config);
|
|
44
|
+
const score = this.calculateScore(comparison);
|
|
45
|
+
const status = passed ? (comparison.regressions.length > 0 ? 'warned' : 'passed') : 'failed';
|
|
46
|
+
const details = {
|
|
47
|
+
regressions: comparison.regressions,
|
|
48
|
+
improvements: comparison.improvements,
|
|
49
|
+
overallHealthDelta: comparison.overallHealthDelta,
|
|
50
|
+
categoryDeltas: comparison.categoryDeltas,
|
|
51
|
+
baseline: {
|
|
52
|
+
type: config.baseline,
|
|
53
|
+
reference: previousSnapshot.commitSha || previousSnapshot.branch,
|
|
54
|
+
timestamp: previousSnapshot.timestamp,
|
|
55
|
+
},
|
|
56
|
+
};
|
|
57
|
+
const summary = this.buildSummary(comparison, passed);
|
|
58
|
+
const warnings = this.buildWarnings(comparison);
|
|
59
|
+
if (!passed) {
|
|
60
|
+
return this.createFailedResult(summary, violations, details, score, warnings);
|
|
61
|
+
}
|
|
62
|
+
if (comparison.regressions.length > 0) {
|
|
63
|
+
return this.createWarnedResult(summary, violations, details, score, warnings);
|
|
64
|
+
}
|
|
65
|
+
return {
|
|
66
|
+
gateId: this.id,
|
|
67
|
+
gateName: this.name,
|
|
68
|
+
status,
|
|
69
|
+
passed,
|
|
70
|
+
score,
|
|
71
|
+
summary,
|
|
72
|
+
violations,
|
|
73
|
+
warnings,
|
|
74
|
+
executionTimeMs: 0,
|
|
75
|
+
details: details,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
validateConfig(config) {
|
|
79
|
+
const errors = [];
|
|
80
|
+
const c = config;
|
|
81
|
+
if (c.maxConfidenceDrop < 0 || c.maxConfidenceDrop > 100) {
|
|
82
|
+
errors.push('maxConfidenceDrop must be between 0 and 100');
|
|
83
|
+
}
|
|
84
|
+
if (c.maxComplianceDrop < 0 || c.maxComplianceDrop > 100) {
|
|
85
|
+
errors.push('maxComplianceDrop must be between 0 and 100');
|
|
86
|
+
}
|
|
87
|
+
if (c.maxNewOutliersPerPattern < 0) {
|
|
88
|
+
errors.push('maxNewOutliersPerPattern must be non-negative');
|
|
89
|
+
}
|
|
90
|
+
return { valid: errors.length === 0, errors };
|
|
91
|
+
}
|
|
92
|
+
getDefaultConfig() {
|
|
93
|
+
return {
|
|
94
|
+
enabled: true,
|
|
95
|
+
blocking: true,
|
|
96
|
+
maxConfidenceDrop: 10, // 10 percentage points
|
|
97
|
+
maxComplianceDrop: 10, // 10 percentage points
|
|
98
|
+
maxNewOutliersPerPattern: 3,
|
|
99
|
+
criticalCategories: ['security', 'auth'],
|
|
100
|
+
baseline: 'branch-base',
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Compare current patterns against baseline snapshot.
|
|
105
|
+
*/
|
|
106
|
+
comparePatterns(currentPatterns, baseline, config) {
|
|
107
|
+
const regressions = [];
|
|
108
|
+
const improvements = [];
|
|
109
|
+
const categoryDeltas = {};
|
|
110
|
+
// Build map of baseline patterns
|
|
111
|
+
const baselineMap = new Map();
|
|
112
|
+
for (const bp of baseline.patterns) {
|
|
113
|
+
const compliance = bp.locations > 0
|
|
114
|
+
? (bp.locations / (bp.locations + bp.outliers)) * 100
|
|
115
|
+
: 100;
|
|
116
|
+
baselineMap.set(bp.patternId, {
|
|
117
|
+
confidence: bp.confidence,
|
|
118
|
+
compliance,
|
|
119
|
+
outliers: bp.outliers,
|
|
120
|
+
category: bp.category,
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
// Compare each current pattern
|
|
124
|
+
for (const pattern of currentPatterns) {
|
|
125
|
+
const baselinePattern = baselineMap.get(pattern.id);
|
|
126
|
+
if (!baselinePattern)
|
|
127
|
+
continue; // New pattern, not a regression
|
|
128
|
+
const currentOutliers = pattern.outliers?.length ?? 0;
|
|
129
|
+
const currentLocations = pattern.locations?.length ?? 0;
|
|
130
|
+
const currentCompliance = currentLocations > 0
|
|
131
|
+
? (currentLocations / (currentLocations + currentOutliers)) * 100
|
|
132
|
+
: 100;
|
|
133
|
+
const confidenceDelta = (pattern.confidence * 100) - (baselinePattern.confidence * 100);
|
|
134
|
+
const complianceDelta = currentCompliance - baselinePattern.compliance;
|
|
135
|
+
const newOutliers = currentOutliers - baselinePattern.outliers;
|
|
136
|
+
// Track category deltas
|
|
137
|
+
if (!categoryDeltas[pattern.category]) {
|
|
138
|
+
categoryDeltas[pattern.category] = 0;
|
|
139
|
+
}
|
|
140
|
+
// Check for regression
|
|
141
|
+
if (confidenceDelta < -config.maxConfidenceDrop ||
|
|
142
|
+
complianceDelta < -config.maxComplianceDrop ||
|
|
143
|
+
newOutliers > config.maxNewOutliersPerPattern) {
|
|
144
|
+
const severity = this.classifyRegressionSeverity(confidenceDelta, complianceDelta, newOutliers, config);
|
|
145
|
+
regressions.push({
|
|
146
|
+
patternId: pattern.id,
|
|
147
|
+
patternName: pattern.name,
|
|
148
|
+
previousConfidence: baselinePattern.confidence * 100,
|
|
149
|
+
currentConfidence: pattern.confidence * 100,
|
|
150
|
+
confidenceDelta,
|
|
151
|
+
previousCompliance: baselinePattern.compliance,
|
|
152
|
+
currentCompliance,
|
|
153
|
+
complianceDelta,
|
|
154
|
+
newOutliers: Math.max(0, newOutliers),
|
|
155
|
+
severity,
|
|
156
|
+
});
|
|
157
|
+
categoryDeltas[pattern.category] += complianceDelta;
|
|
158
|
+
}
|
|
159
|
+
// Check for improvement
|
|
160
|
+
else if (confidenceDelta > 5 || complianceDelta > 5 || newOutliers < 0) {
|
|
161
|
+
improvements.push({
|
|
162
|
+
patternId: pattern.id,
|
|
163
|
+
patternName: pattern.name,
|
|
164
|
+
confidenceImprovement: Math.max(0, confidenceDelta),
|
|
165
|
+
complianceImprovement: Math.max(0, complianceDelta),
|
|
166
|
+
outliersFixed: Math.max(0, -newOutliers),
|
|
167
|
+
});
|
|
168
|
+
categoryDeltas[pattern.category] += complianceDelta;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
// Calculate overall health delta
|
|
172
|
+
const overallHealthDelta = this.calculateOverallDelta(categoryDeltas);
|
|
173
|
+
return { regressions, improvements, overallHealthDelta, categoryDeltas };
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Classify regression severity.
|
|
177
|
+
*/
|
|
178
|
+
classifyRegressionSeverity(confidenceDelta, complianceDelta, newOutliers, config) {
|
|
179
|
+
// Severe: More than 2x the threshold
|
|
180
|
+
if (confidenceDelta < -config.maxConfidenceDrop * 2 ||
|
|
181
|
+
complianceDelta < -config.maxComplianceDrop * 2 ||
|
|
182
|
+
newOutliers > config.maxNewOutliersPerPattern * 2) {
|
|
183
|
+
return 'severe';
|
|
184
|
+
}
|
|
185
|
+
// Moderate: Exceeds threshold
|
|
186
|
+
if (confidenceDelta < -config.maxConfidenceDrop ||
|
|
187
|
+
complianceDelta < -config.maxComplianceDrop ||
|
|
188
|
+
newOutliers > config.maxNewOutliersPerPattern) {
|
|
189
|
+
return 'moderate';
|
|
190
|
+
}
|
|
191
|
+
return 'minor';
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Calculate overall health delta.
|
|
195
|
+
*/
|
|
196
|
+
calculateOverallDelta(categoryDeltas) {
|
|
197
|
+
const values = Object.values(categoryDeltas);
|
|
198
|
+
if (values.length === 0)
|
|
199
|
+
return 0;
|
|
200
|
+
return values.reduce((sum, v) => sum + v, 0) / values.length;
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Evaluate whether the gate passes based on thresholds.
|
|
204
|
+
*/
|
|
205
|
+
evaluateThresholds(comparison, config) {
|
|
206
|
+
// Check for severe regressions
|
|
207
|
+
const severeRegressions = comparison.regressions.filter(r => r.severity === 'severe');
|
|
208
|
+
if (severeRegressions.length > 0)
|
|
209
|
+
return false;
|
|
210
|
+
// Check for regressions in critical categories
|
|
211
|
+
for (const regression of comparison.regressions) {
|
|
212
|
+
// Find the pattern's category from the regression
|
|
213
|
+
const category = this.getCategoryFromRegression(regression);
|
|
214
|
+
if (config.criticalCategories.includes(category)) {
|
|
215
|
+
return false;
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
// Check if moderate regressions exceed threshold
|
|
219
|
+
const moderateRegressions = comparison.regressions.filter(r => r.severity === 'moderate');
|
|
220
|
+
if (moderateRegressions.length > 3)
|
|
221
|
+
return false;
|
|
222
|
+
return true;
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Get category from regression (simplified - in full impl would track this).
|
|
226
|
+
*/
|
|
227
|
+
getCategoryFromRegression(_regression) {
|
|
228
|
+
// In full implementation, we'd track the category with the regression
|
|
229
|
+
return 'unknown';
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* Build violations from regressions.
|
|
233
|
+
*/
|
|
234
|
+
buildViolations(regressions, config) {
|
|
235
|
+
return regressions
|
|
236
|
+
.filter(r => r.severity !== 'minor')
|
|
237
|
+
.map(r => this.createViolation({
|
|
238
|
+
severity: r.severity === 'severe' ? 'error' : 'warning',
|
|
239
|
+
file: 'project',
|
|
240
|
+
line: 1,
|
|
241
|
+
column: 1,
|
|
242
|
+
message: `Pattern "${r.patternName}" regressed`,
|
|
243
|
+
explanation: this.formatRegressionExplanation(r, config),
|
|
244
|
+
ruleId: r.patternId,
|
|
245
|
+
suggestedFix: `Review changes that affected pattern "${r.patternName}" and ensure they follow the established pattern`,
|
|
246
|
+
}));
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* Format regression explanation.
|
|
250
|
+
*/
|
|
251
|
+
formatRegressionExplanation(regression, config) {
|
|
252
|
+
const parts = [];
|
|
253
|
+
if (regression.confidenceDelta < -config.maxConfidenceDrop) {
|
|
254
|
+
parts.push(`Confidence dropped ${Math.abs(regression.confidenceDelta).toFixed(1)}pp (${regression.previousConfidence.toFixed(1)}% → ${regression.currentConfidence.toFixed(1)}%)`);
|
|
255
|
+
}
|
|
256
|
+
if (regression.complianceDelta < -config.maxComplianceDrop) {
|
|
257
|
+
parts.push(`Compliance dropped ${Math.abs(regression.complianceDelta).toFixed(1)}pp (${regression.previousCompliance.toFixed(1)}% → ${regression.currentCompliance.toFixed(1)}%)`);
|
|
258
|
+
}
|
|
259
|
+
if (regression.newOutliers > config.maxNewOutliersPerPattern) {
|
|
260
|
+
parts.push(`${regression.newOutliers} new outlier${regression.newOutliers === 1 ? '' : 's'} introduced`);
|
|
261
|
+
}
|
|
262
|
+
return parts.join('. ');
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* Calculate score based on comparison.
|
|
266
|
+
*/
|
|
267
|
+
calculateScore(comparison) {
|
|
268
|
+
// Start at 100
|
|
269
|
+
let score = 100;
|
|
270
|
+
// Deduct for regressions
|
|
271
|
+
for (const r of comparison.regressions) {
|
|
272
|
+
switch (r.severity) {
|
|
273
|
+
case 'severe':
|
|
274
|
+
score -= 20;
|
|
275
|
+
break;
|
|
276
|
+
case 'moderate':
|
|
277
|
+
score -= 10;
|
|
278
|
+
break;
|
|
279
|
+
case 'minor':
|
|
280
|
+
score -= 3;
|
|
281
|
+
break;
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
// Small bonus for improvements (max 10 points)
|
|
285
|
+
const improvementBonus = Math.min(10, comparison.improvements.length * 2);
|
|
286
|
+
score += improvementBonus;
|
|
287
|
+
return Math.max(0, Math.min(100, Math.round(score)));
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* Build human-readable summary.
|
|
291
|
+
*/
|
|
292
|
+
buildSummary(comparison, passed) {
|
|
293
|
+
if (comparison.regressions.length === 0 && comparison.improvements.length === 0) {
|
|
294
|
+
return 'No pattern changes detected';
|
|
295
|
+
}
|
|
296
|
+
const parts = [];
|
|
297
|
+
if (comparison.regressions.length > 0) {
|
|
298
|
+
const severe = comparison.regressions.filter(r => r.severity === 'severe').length;
|
|
299
|
+
const moderate = comparison.regressions.filter(r => r.severity === 'moderate').length;
|
|
300
|
+
if (severe > 0) {
|
|
301
|
+
parts.push(`${severe} severe regression${severe === 1 ? '' : 's'}`);
|
|
302
|
+
}
|
|
303
|
+
if (moderate > 0) {
|
|
304
|
+
parts.push(`${moderate} moderate regression${moderate === 1 ? '' : 's'}`);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
if (comparison.improvements.length > 0) {
|
|
308
|
+
parts.push(`${comparison.improvements.length} improvement${comparison.improvements.length === 1 ? '' : 's'}`);
|
|
309
|
+
}
|
|
310
|
+
const prefix = passed ? 'Pattern health:' : 'Pattern regressions detected:';
|
|
311
|
+
return `${prefix} ${parts.join(', ')}`;
|
|
312
|
+
}
|
|
313
|
+
/**
|
|
314
|
+
* Build warnings for the result.
|
|
315
|
+
*/
|
|
316
|
+
buildWarnings(comparison) {
|
|
317
|
+
const warnings = [];
|
|
318
|
+
// Warn about minor regressions
|
|
319
|
+
const minorRegressions = comparison.regressions.filter(r => r.severity === 'minor');
|
|
320
|
+
if (minorRegressions.length > 0) {
|
|
321
|
+
warnings.push(`${minorRegressions.length} minor regression${minorRegressions.length === 1 ? '' : 's'} detected (within threshold)`);
|
|
322
|
+
}
|
|
323
|
+
// Warn about overall health trend
|
|
324
|
+
if (comparison.overallHealthDelta < -5) {
|
|
325
|
+
warnings.push(`Overall pattern health trending down (${comparison.overallHealthDelta.toFixed(1)}pp)`);
|
|
326
|
+
}
|
|
327
|
+
return warnings;
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
//# sourceMappingURL=regression-detection-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"regression-detection-gate.js","sourceRoot":"","sources":["../../../../src/quality-gates/gates/regression-detection/regression-detection-gate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/quality-gates/gates/security-boundary/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/quality-gates/gates/security-boundary/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Security Boundary Gate
|
|
3
|
+
*
|
|
4
|
+
* @license Apache-2.0
|
|
5
|
+
*
|
|
6
|
+
* Enforces security boundaries by checking that sensitive data access
|
|
7
|
+
* has proper authorization in the call chain.
|
|
8
|
+
*
|
|
9
|
+
* FUTURE_GATE: gate:security-boundary (Enterprise tier)
|
|
10
|
+
*/
|
|
11
|
+
import { BaseGate } from '../base-gate.js';
|
|
12
|
+
import type { GateId, GateInput, GateResult, GateConfig, SecurityBoundaryConfig } from '../../types.js';
|
|
13
|
+
/**
|
|
14
|
+
* Security Boundary Gate
|
|
15
|
+
*
|
|
16
|
+
* Checks that sensitive data access has proper authorization.
|
|
17
|
+
*/
|
|
18
|
+
export declare class SecurityBoundaryGate extends BaseGate {
|
|
19
|
+
readonly id: GateId;
|
|
20
|
+
readonly name = "Security Boundary";
|
|
21
|
+
readonly description = "Enforces authorization for sensitive data access";
|
|
22
|
+
protected executeGate(input: GateInput): Promise<GateResult>;
|
|
23
|
+
validateConfig(config: GateConfig): {
|
|
24
|
+
valid: boolean;
|
|
25
|
+
errors: string[];
|
|
26
|
+
};
|
|
27
|
+
getDefaultConfig(): SecurityBoundaryConfig;
|
|
28
|
+
/**
|
|
29
|
+
* Analyze security boundaries in changed files.
|
|
30
|
+
*/
|
|
31
|
+
private analyzeSecurityBoundaries;
|
|
32
|
+
/**
|
|
33
|
+
* Detect data access in a function (simplified).
|
|
34
|
+
*/
|
|
35
|
+
private detectDataAccess;
|
|
36
|
+
/**
|
|
37
|
+
* Check if auth is in the call chain.
|
|
38
|
+
*/
|
|
39
|
+
private hasAuthInCallChain;
|
|
40
|
+
/**
|
|
41
|
+
* Find the unauthorized path from entry point to function.
|
|
42
|
+
*/
|
|
43
|
+
private findUnauthorizedPath;
|
|
44
|
+
/**
|
|
45
|
+
* Evaluate whether the gate passes based on thresholds.
|
|
46
|
+
*/
|
|
47
|
+
private evaluateThresholds;
|
|
48
|
+
/**
|
|
49
|
+
* Build violations from unauthorized access.
|
|
50
|
+
*/
|
|
51
|
+
private buildViolations;
|
|
52
|
+
/**
|
|
53
|
+
* Calculate score based on analysis.
|
|
54
|
+
*/
|
|
55
|
+
private calculateScore;
|
|
56
|
+
/**
|
|
57
|
+
* Build human-readable summary.
|
|
58
|
+
*/
|
|
59
|
+
private buildSummary;
|
|
60
|
+
/**
|
|
61
|
+
* Build warnings for the result.
|
|
62
|
+
*/
|
|
63
|
+
private buildWarnings;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=security-boundary-gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-boundary-gate.d.ts","sourceRoot":"","sources":["../../../../src/quality-gates/gates/security-boundary/security-boundary-gate.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,KAAK,EACV,MAAM,EACN,SAAS,EACT,UAAU,EACV,UAAU,EACV,sBAAsB,EAMvB,MAAM,gBAAgB,CAAC;AAExB;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,QAAQ;IAChD,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAuB;IAC1C,QAAQ,CAAC,IAAI,uBAAuB;IACpC,QAAQ,CAAC,WAAW,sDAAsD;cAE1D,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC;IA8DlE,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,EAAE,CAAA;KAAE;IAWxE,gBAAgB,IAAI,sBAAsB;IAW1C;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAgGjC;;OAEG;IACH,OAAO,CAAC,gBAAgB;IASxB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAmC1B;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA6B5B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAwB1B;;OAEG;IACH,OAAO,CAAC,eAAe;IAuCvB;;OAEG;IACH,OAAO,CAAC,cAAc;IActB;;OAEG;IACH,OAAO,CAAC,YAAY;IAoBpB;;OAEG;IACH,OAAO,CAAC,aAAa;CA2BtB"}
|