@opensip-cli/fitness 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/NOTICE +8 -0
- package/README.md +31 -0
- package/dist/__tests__/baseline-plane.test.d.ts +12 -0
- package/dist/__tests__/baseline-plane.test.d.ts.map +1 -0
- package/dist/__tests__/baseline-plane.test.js +63 -0
- package/dist/__tests__/baseline-plane.test.js.map +1 -0
- package/dist/__tests__/check-utils.test.d.ts +10 -0
- package/dist/__tests__/check-utils.test.d.ts.map +1 -0
- package/dist/__tests__/check-utils.test.js +193 -0
- package/dist/__tests__/check-utils.test.js.map +1 -0
- package/dist/__tests__/fingerprint-parity.test.d.ts +14 -0
- package/dist/__tests__/fingerprint-parity.test.d.ts.map +1 -0
- package/dist/__tests__/fingerprint-parity.test.js +59 -0
- package/dist/__tests__/fingerprint-parity.test.js.map +1 -0
- package/dist/__tests__/fit-execute-opts.test.d.ts +15 -0
- package/dist/__tests__/fit-execute-opts.test.d.ts.map +1 -0
- package/dist/__tests__/fit-execute-opts.test.js +124 -0
- package/dist/__tests__/fit-execute-opts.test.js.map +1 -0
- package/dist/__tests__/public-api.test.d.ts +19 -0
- package/dist/__tests__/public-api.test.d.ts.map +1 -0
- package/dist/__tests__/public-api.test.js +85 -0
- package/dist/__tests__/public-api.test.js.map +1 -0
- package/dist/__tests__/tool.test.d.ts +10 -0
- package/dist/__tests__/tool.test.d.ts.map +1 -0
- package/dist/__tests__/tool.test.js +57 -0
- package/dist/__tests__/tool.test.js.map +1 -0
- package/dist/baseline-strategy.d.ts +21 -0
- package/dist/baseline-strategy.d.ts.map +1 -0
- package/dist/baseline-strategy.js +21 -0
- package/dist/baseline-strategy.js.map +1 -0
- package/dist/check-utils/display.d.ts +52 -0
- package/dist/check-utils/display.d.ts.map +1 -0
- package/dist/check-utils/display.js +66 -0
- package/dist/check-utils/display.js.map +1 -0
- package/dist/check-utils/index.d.ts +17 -0
- package/dist/check-utils/index.d.ts.map +1 -0
- package/dist/check-utils/index.js +13 -0
- package/dist/check-utils/index.js.map +1 -0
- package/dist/check-utils/path-matching.d.ts +40 -0
- package/dist/check-utils/path-matching.d.ts.map +1 -0
- package/dist/check-utils/path-matching.js +38 -0
- package/dist/check-utils/path-matching.js.map +1 -0
- package/dist/check-utils/source-analysis.d.ts +36 -0
- package/dist/check-utils/source-analysis.d.ts.map +1 -0
- package/dist/check-utils/source-analysis.js +44 -0
- package/dist/check-utils/source-analysis.js.map +1 -0
- package/dist/check-utils/test-helpers.d.ts +57 -0
- package/dist/check-utils/test-helpers.d.ts.map +1 -0
- package/dist/check-utils/test-helpers.js +71 -0
- package/dist/check-utils/test-helpers.js.map +1 -0
- package/dist/cli/__tests__/fit-gate-mode.test.d.ts +14 -0
- package/dist/cli/__tests__/fit-gate-mode.test.d.ts.map +1 -0
- package/dist/cli/__tests__/fit-gate-mode.test.js +110 -0
- package/dist/cli/__tests__/fit-gate-mode.test.js.map +1 -0
- package/dist/cli/__tests__/fit-modes-live.test.d.ts +13 -0
- package/dist/cli/__tests__/fit-modes-live.test.d.ts.map +1 -0
- package/dist/cli/__tests__/fit-modes-live.test.js +182 -0
- package/dist/cli/__tests__/fit-modes-live.test.js.map +1 -0
- package/dist/cli/__tests__/report-data.test.d.ts +12 -0
- package/dist/cli/__tests__/report-data.test.d.ts.map +1 -0
- package/dist/cli/__tests__/report-data.test.js +113 -0
- package/dist/cli/__tests__/report-data.test.js.map +1 -0
- package/dist/cli/fit/__tests__/display-fold.test.d.ts +8 -0
- package/dist/cli/fit/__tests__/display-fold.test.d.ts.map +1 -0
- package/dist/cli/fit/__tests__/display-fold.test.js +87 -0
- package/dist/cli/fit/__tests__/display-fold.test.js.map +1 -0
- package/dist/cli/fit/__tests__/gate-resolved-config.test.d.ts +16 -0
- package/dist/cli/fit/__tests__/gate-resolved-config.test.d.ts.map +1 -0
- package/dist/cli/fit/__tests__/gate-resolved-config.test.js +62 -0
- package/dist/cli/fit/__tests__/gate-resolved-config.test.js.map +1 -0
- package/dist/cli/fit/check-loader.d.ts +37 -0
- package/dist/cli/fit/check-loader.d.ts.map +1 -0
- package/dist/cli/fit/check-loader.js +154 -0
- package/dist/cli/fit/check-loader.js.map +1 -0
- package/dist/cli/fit/config-loader.d.ts +55 -0
- package/dist/cli/fit/config-loader.d.ts.map +1 -0
- package/dist/cli/fit/config-loader.js +107 -0
- package/dist/cli/fit/config-loader.js.map +1 -0
- package/dist/cli/fit/display-registry.d.ts +19 -0
- package/dist/cli/fit/display-registry.d.ts.map +1 -0
- package/dist/cli/fit/display-registry.js +33 -0
- package/dist/cli/fit/display-registry.js.map +1 -0
- package/dist/cli/fit/envelope-view.d.ts +49 -0
- package/dist/cli/fit/envelope-view.d.ts.map +1 -0
- package/dist/cli/fit/envelope-view.js +85 -0
- package/dist/cli/fit/envelope-view.js.map +1 -0
- package/dist/cli/fit/fit-aux-command-specs.d.ts +35 -0
- package/dist/cli/fit/fit-aux-command-specs.d.ts.map +1 -0
- package/dist/cli/fit/fit-aux-command-specs.js +110 -0
- package/dist/cli/fit/fit-aux-command-specs.js.map +1 -0
- package/dist/cli/fit/fit-command-spec.d.ts +24 -0
- package/dist/cli/fit/fit-command-spec.d.ts.map +1 -0
- package/dist/cli/fit/fit-command-spec.js +131 -0
- package/dist/cli/fit/fit-command-spec.js.map +1 -0
- package/dist/cli/fit/gate-compare-render.d.ts +13 -0
- package/dist/cli/fit/gate-compare-render.d.ts.map +1 -0
- package/dist/cli/fit/gate-compare-render.js +87 -0
- package/dist/cli/fit/gate-compare-render.js.map +1 -0
- package/dist/cli/fit/recipe-selector.d.ts +53 -0
- package/dist/cli/fit/recipe-selector.d.ts.map +1 -0
- package/dist/cli/fit/recipe-selector.js +106 -0
- package/dist/cli/fit/recipe-selector.js.map +1 -0
- package/dist/cli/fit/recipe-selector.test.d.ts +2 -0
- package/dist/cli/fit/recipe-selector.test.d.ts.map +1 -0
- package/dist/cli/fit/recipe-selector.test.js +69 -0
- package/dist/cli/fit/recipe-selector.test.js.map +1 -0
- package/dist/cli/fit/resolved-fitness-config.d.ts +48 -0
- package/dist/cli/fit/resolved-fitness-config.d.ts.map +1 -0
- package/dist/cli/fit/resolved-fitness-config.js +46 -0
- package/dist/cli/fit/resolved-fitness-config.js.map +1 -0
- package/dist/cli/fit/result-builders.d.ts +91 -0
- package/dist/cli/fit/result-builders.d.ts.map +1 -0
- package/dist/cli/fit/result-builders.js +206 -0
- package/dist/cli/fit/result-builders.js.map +1 -0
- package/dist/cli/fit-list.d.ts +7 -0
- package/dist/cli/fit-list.d.ts.map +1 -0
- package/dist/cli/fit-list.js +24 -0
- package/dist/cli/fit-list.js.map +1 -0
- package/dist/cli/fit-modes.d.ts +42 -0
- package/dist/cli/fit-modes.d.ts.map +1 -0
- package/dist/cli/fit-modes.js +322 -0
- package/dist/cli/fit-modes.js.map +1 -0
- package/dist/cli/fit-recipes.d.ts +7 -0
- package/dist/cli/fit-recipes.d.ts.map +1 -0
- package/dist/cli/fit-recipes.js +34 -0
- package/dist/cli/fit-recipes.js.map +1 -0
- package/dist/cli/fit-runner-views.d.ts +33 -0
- package/dist/cli/fit-runner-views.d.ts.map +1 -0
- package/dist/cli/fit-runner-views.js +92 -0
- package/dist/cli/fit-runner-views.js.map +1 -0
- package/dist/cli/fit-runner.d.ts +44 -0
- package/dist/cli/fit-runner.d.ts.map +1 -0
- package/dist/cli/fit-runner.js +250 -0
- package/dist/cli/fit-runner.js.map +1 -0
- package/dist/cli/fit-worker.d.ts +26 -0
- package/dist/cli/fit-worker.d.ts.map +1 -0
- package/dist/cli/fit-worker.js +67 -0
- package/dist/cli/fit-worker.js.map +1 -0
- package/dist/cli/fit.d.ts +74 -0
- package/dist/cli/fit.d.ts.map +1 -0
- package/dist/cli/fit.js +149 -0
- package/dist/cli/fit.js.map +1 -0
- package/dist/cli/report-data.d.ts +44 -0
- package/dist/cli/report-data.d.ts.map +1 -0
- package/dist/cli/report-data.js +89 -0
- package/dist/cli/report-data.js.map +1 -0
- package/dist/config/__tests__/fitness-config-schema.test.d.ts +6 -0
- package/dist/config/__tests__/fitness-config-schema.test.d.ts.map +1 -0
- package/dist/config/__tests__/fitness-config-schema.test.js +37 -0
- package/dist/config/__tests__/fitness-config-schema.test.js.map +1 -0
- package/dist/config/fitness-config-schema.d.ts +48 -0
- package/dist/config/fitness-config-schema.d.ts.map +1 -0
- package/dist/config/fitness-config-schema.js +62 -0
- package/dist/config/fitness-config-schema.js.map +1 -0
- package/dist/framework/__tests__/abortable-exec.test.d.ts +9 -0
- package/dist/framework/__tests__/abortable-exec.test.d.ts.map +1 -0
- package/dist/framework/__tests__/abortable-exec.test.js +102 -0
- package/dist/framework/__tests__/abortable-exec.test.js.map +1 -0
- package/dist/framework/__tests__/check-config.test.d.ts +2 -0
- package/dist/framework/__tests__/check-config.test.d.ts.map +1 -0
- package/dist/framework/__tests__/check-config.test.js +56 -0
- package/dist/framework/__tests__/check-config.test.js.map +1 -0
- package/dist/framework/__tests__/check-types.test.d.ts +2 -0
- package/dist/framework/__tests__/check-types.test.d.ts.map +1 -0
- package/dist/framework/__tests__/check-types.test.js +76 -0
- package/dist/framework/__tests__/check-types.test.js.map +1 -0
- package/dist/framework/__tests__/command-executor.test.d.ts +2 -0
- package/dist/framework/__tests__/command-executor.test.d.ts.map +1 -0
- package/dist/framework/__tests__/command-executor.test.js +110 -0
- package/dist/framework/__tests__/command-executor.test.js.map +1 -0
- package/dist/framework/__tests__/content-filter-dispatch.test.d.ts +2 -0
- package/dist/framework/__tests__/content-filter-dispatch.test.d.ts.map +1 -0
- package/dist/framework/__tests__/content-filter-dispatch.test.js +122 -0
- package/dist/framework/__tests__/content-filter-dispatch.test.js.map +1 -0
- package/dist/framework/__tests__/define-check.test.d.ts +2 -0
- package/dist/framework/__tests__/define-check.test.d.ts.map +1 -0
- package/dist/framework/__tests__/define-check.test.js +402 -0
- package/dist/framework/__tests__/define-check.test.js.map +1 -0
- package/dist/framework/__tests__/define-regex-list-check.test.d.ts +15 -0
- package/dist/framework/__tests__/define-regex-list-check.test.d.ts.map +1 -0
- package/dist/framework/__tests__/define-regex-list-check.test.js +299 -0
- package/dist/framework/__tests__/define-regex-list-check.test.js.map +1 -0
- package/dist/framework/__tests__/directive-inventory.test.d.ts +2 -0
- package/dist/framework/__tests__/directive-inventory.test.d.ts.map +1 -0
- package/dist/framework/__tests__/directive-inventory.test.js +111 -0
- package/dist/framework/__tests__/directive-inventory.test.js.map +1 -0
- package/dist/framework/__tests__/directive-parsing.test.d.ts +13 -0
- package/dist/framework/__tests__/directive-parsing.test.d.ts.map +1 -0
- package/dist/framework/__tests__/directive-parsing.test.js +86 -0
- package/dist/framework/__tests__/directive-parsing.test.js.map +1 -0
- package/dist/framework/__tests__/execution-context.globalexcludes-parity.test.d.ts +2 -0
- package/dist/framework/__tests__/execution-context.globalexcludes-parity.test.d.ts.map +1 -0
- package/dist/framework/__tests__/execution-context.globalexcludes-parity.test.js +56 -0
- package/dist/framework/__tests__/execution-context.globalexcludes-parity.test.js.map +1 -0
- package/dist/framework/__tests__/execution-context.test.d.ts +2 -0
- package/dist/framework/__tests__/execution-context.test.d.ts.map +1 -0
- package/dist/framework/__tests__/execution-context.test.js +140 -0
- package/dist/framework/__tests__/execution-context.test.js.map +1 -0
- package/dist/framework/__tests__/file-accessor.test.d.ts +2 -0
- package/dist/framework/__tests__/file-accessor.test.d.ts.map +1 -0
- package/dist/framework/__tests__/file-accessor.test.js +106 -0
- package/dist/framework/__tests__/file-accessor.test.js.map +1 -0
- package/dist/framework/__tests__/file-cache.test.d.ts +2 -0
- package/dist/framework/__tests__/file-cache.test.d.ts.map +1 -0
- package/dist/framework/__tests__/file-cache.test.js +122 -0
- package/dist/framework/__tests__/file-cache.test.js.map +1 -0
- package/dist/framework/__tests__/file-type-filter.test.d.ts +9 -0
- package/dist/framework/__tests__/file-type-filter.test.d.ts.map +1 -0
- package/dist/framework/__tests__/file-type-filter.test.js +39 -0
- package/dist/framework/__tests__/file-type-filter.test.js.map +1 -0
- package/dist/framework/__tests__/ignore-processing.test.d.ts +11 -0
- package/dist/framework/__tests__/ignore-processing.test.d.ts.map +1 -0
- package/dist/framework/__tests__/ignore-processing.test.js +175 -0
- package/dist/framework/__tests__/ignore-processing.test.js.map +1 -0
- package/dist/framework/__tests__/import-graph.test.d.ts +15 -0
- package/dist/framework/__tests__/import-graph.test.d.ts.map +1 -0
- package/dist/framework/__tests__/import-graph.test.js +164 -0
- package/dist/framework/__tests__/import-graph.test.js.map +1 -0
- package/dist/framework/__tests__/memory-profiler.test.d.ts +9 -0
- package/dist/framework/__tests__/memory-profiler.test.d.ts.map +1 -0
- package/dist/framework/__tests__/memory-profiler.test.js +108 -0
- package/dist/framework/__tests__/memory-profiler.test.js.map +1 -0
- package/dist/framework/__tests__/parse-cache.test.d.ts +9 -0
- package/dist/framework/__tests__/parse-cache.test.d.ts.map +1 -0
- package/dist/framework/__tests__/parse-cache.test.js +51 -0
- package/dist/framework/__tests__/parse-cache.test.js.map +1 -0
- package/dist/framework/__tests__/path-matcher.test.d.ts +2 -0
- package/dist/framework/__tests__/path-matcher.test.d.ts.map +1 -0
- package/dist/framework/__tests__/path-matcher.test.js +113 -0
- package/dist/framework/__tests__/path-matcher.test.js.map +1 -0
- package/dist/framework/__tests__/register-helpers.test.d.ts +2 -0
- package/dist/framework/__tests__/register-helpers.test.d.ts.map +1 -0
- package/dist/framework/__tests__/register-helpers.test.js +51 -0
- package/dist/framework/__tests__/register-helpers.test.js.map +1 -0
- package/dist/framework/__tests__/registry.test.d.ts +2 -0
- package/dist/framework/__tests__/registry.test.d.ts.map +1 -0
- package/dist/framework/__tests__/registry.test.js +211 -0
- package/dist/framework/__tests__/registry.test.js.map +1 -0
- package/dist/framework/__tests__/result-builder.test.d.ts +2 -0
- package/dist/framework/__tests__/result-builder.test.d.ts.map +1 -0
- package/dist/framework/__tests__/result-builder.test.js +153 -0
- package/dist/framework/__tests__/result-builder.test.js.map +1 -0
- package/dist/framework/__tests__/scope-registry.test.d.ts +8 -0
- package/dist/framework/__tests__/scope-registry.test.d.ts.map +1 -0
- package/dist/framework/__tests__/scope-registry.test.js +156 -0
- package/dist/framework/__tests__/scope-registry.test.js.map +1 -0
- package/dist/framework/__tests__/scope-resolver.golden.test.d.ts +2 -0
- package/dist/framework/__tests__/scope-resolver.golden.test.d.ts.map +1 -0
- package/dist/framework/__tests__/scope-resolver.golden.test.js +105 -0
- package/dist/framework/__tests__/scope-resolver.golden.test.js.map +1 -0
- package/dist/framework/__tests__/scope-resolver.test.d.ts +2 -0
- package/dist/framework/__tests__/scope-resolver.test.d.ts.map +1 -0
- package/dist/framework/__tests__/scope-resolver.test.js +150 -0
- package/dist/framework/__tests__/scope-resolver.test.js.map +1 -0
- package/dist/framework/__tests__/severity-mapping.test.d.ts +2 -0
- package/dist/framework/__tests__/severity-mapping.test.d.ts.map +1 -0
- package/dist/framework/__tests__/severity-mapping.test.js +74 -0
- package/dist/framework/__tests__/severity-mapping.test.js.map +1 -0
- package/dist/framework/__tests__/strip-literals.test.d.ts +2 -0
- package/dist/framework/__tests__/strip-literals.test.d.ts.map +1 -0
- package/dist/framework/__tests__/strip-literals.test.js +87 -0
- package/dist/framework/__tests__/strip-literals.test.js.map +1 -0
- package/dist/framework/abortable-exec.d.ts +34 -0
- package/dist/framework/abortable-exec.d.ts.map +1 -0
- package/dist/framework/abortable-exec.js +143 -0
- package/dist/framework/abortable-exec.js.map +1 -0
- package/dist/framework/check-config.d.ts +175 -0
- package/dist/framework/check-config.d.ts.map +1 -0
- package/dist/framework/check-config.js +115 -0
- package/dist/framework/check-config.js.map +1 -0
- package/dist/framework/check-types.d.ts +82 -0
- package/dist/framework/check-types.d.ts.map +1 -0
- package/dist/framework/check-types.js +63 -0
- package/dist/framework/check-types.js.map +1 -0
- package/dist/framework/command-executor.d.ts +25 -0
- package/dist/framework/command-executor.d.ts.map +1 -0
- package/dist/framework/command-executor.js +63 -0
- package/dist/framework/command-executor.js.map +1 -0
- package/dist/framework/comment-openers.d.ts +11 -0
- package/dist/framework/comment-openers.d.ts.map +1 -0
- package/dist/framework/comment-openers.js +11 -0
- package/dist/framework/comment-openers.js.map +1 -0
- package/dist/framework/constants.d.ts +9 -0
- package/dist/framework/constants.d.ts.map +1 -0
- package/dist/framework/constants.js +16 -0
- package/dist/framework/constants.js.map +1 -0
- package/dist/framework/define-check.d.ts +38 -0
- package/dist/framework/define-check.d.ts.map +1 -0
- package/dist/framework/define-check.js +296 -0
- package/dist/framework/define-check.js.map +1 -0
- package/dist/framework/define-regex-list-check.d.ts +160 -0
- package/dist/framework/define-regex-list-check.d.ts.map +1 -0
- package/dist/framework/define-regex-list-check.js +177 -0
- package/dist/framework/define-regex-list-check.js.map +1 -0
- package/dist/framework/directive-inventory.d.ts +37 -0
- package/dist/framework/directive-inventory.d.ts.map +1 -0
- package/dist/framework/directive-inventory.js +82 -0
- package/dist/framework/directive-inventory.js.map +1 -0
- package/dist/framework/directive-parsing.d.ts +23 -0
- package/dist/framework/directive-parsing.d.ts.map +1 -0
- package/dist/framework/directive-parsing.js +39 -0
- package/dist/framework/directive-parsing.js.map +1 -0
- package/dist/framework/execution-context.d.ts +98 -0
- package/dist/framework/execution-context.d.ts.map +1 -0
- package/dist/framework/execution-context.js +145 -0
- package/dist/framework/execution-context.js.map +1 -0
- package/dist/framework/file-accessor.d.ts +20 -0
- package/dist/framework/file-accessor.d.ts.map +1 -0
- package/dist/framework/file-accessor.js +122 -0
- package/dist/framework/file-accessor.js.map +1 -0
- package/dist/framework/file-cache.d.ts +70 -0
- package/dist/framework/file-cache.d.ts.map +1 -0
- package/dist/framework/file-cache.js +199 -0
- package/dist/framework/file-cache.js.map +1 -0
- package/dist/framework/file-type-filter.d.ts +11 -0
- package/dist/framework/file-type-filter.d.ts.map +1 -0
- package/dist/framework/file-type-filter.js +21 -0
- package/dist/framework/file-type-filter.js.map +1 -0
- package/dist/framework/ignore-processing.d.ts +36 -0
- package/dist/framework/ignore-processing.d.ts.map +1 -0
- package/dist/framework/ignore-processing.js +172 -0
- package/dist/framework/ignore-processing.js.map +1 -0
- package/dist/framework/import-graph.d.ts +51 -0
- package/dist/framework/import-graph.d.ts.map +1 -0
- package/dist/framework/import-graph.js +217 -0
- package/dist/framework/import-graph.js.map +1 -0
- package/dist/framework/memory-profiler.d.ts +53 -0
- package/dist/framework/memory-profiler.d.ts.map +1 -0
- package/dist/framework/memory-profiler.js +92 -0
- package/dist/framework/memory-profiler.js.map +1 -0
- package/dist/framework/parse-cache.d.ts +24 -0
- package/dist/framework/parse-cache.d.ts.map +1 -0
- package/dist/framework/parse-cache.js +41 -0
- package/dist/framework/parse-cache.js.map +1 -0
- package/dist/framework/path-matcher.d.ts +86 -0
- package/dist/framework/path-matcher.d.ts.map +1 -0
- package/dist/framework/path-matcher.js +138 -0
- package/dist/framework/path-matcher.js.map +1 -0
- package/dist/framework/register-helpers.d.ts +11 -0
- package/dist/framework/register-helpers.d.ts.map +1 -0
- package/dist/framework/register-helpers.js +19 -0
- package/dist/framework/register-helpers.js.map +1 -0
- package/dist/framework/registry.d.ts +51 -0
- package/dist/framework/registry.d.ts.map +1 -0
- package/dist/framework/registry.js +131 -0
- package/dist/framework/registry.js.map +1 -0
- package/dist/framework/result-builder.d.ts +74 -0
- package/dist/framework/result-builder.d.ts.map +1 -0
- package/dist/framework/result-builder.js +154 -0
- package/dist/framework/result-builder.js.map +1 -0
- package/dist/framework/scope-registry.d.ts +38 -0
- package/dist/framework/scope-registry.d.ts.map +1 -0
- package/dist/framework/scope-registry.js +77 -0
- package/dist/framework/scope-registry.js.map +1 -0
- package/dist/framework/scope-resolver.d.ts +23 -0
- package/dist/framework/scope-resolver.d.ts.map +1 -0
- package/dist/framework/scope-resolver.js +102 -0
- package/dist/framework/scope-resolver.js.map +1 -0
- package/dist/framework/severity-mapping.d.ts +17 -0
- package/dist/framework/severity-mapping.d.ts.map +1 -0
- package/dist/framework/severity-mapping.js +71 -0
- package/dist/framework/severity-mapping.js.map +1 -0
- package/dist/framework/strip-literals.d.ts +73 -0
- package/dist/framework/strip-literals.d.ts.map +1 -0
- package/dist/framework/strip-literals.js +213 -0
- package/dist/framework/strip-literals.js.map +1 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +64 -0
- package/dist/index.js.map +1 -0
- package/dist/internal.d.ts +17 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +17 -0
- package/dist/internal.js.map +1 -0
- package/dist/persistence/session-payload.d.ts +68 -0
- package/dist/persistence/session-payload.d.ts.map +1 -0
- package/dist/persistence/session-payload.js +78 -0
- package/dist/persistence/session-payload.js.map +1 -0
- package/dist/persistence/session-payload.test.d.ts +11 -0
- package/dist/persistence/session-payload.test.d.ts.map +1 -0
- package/dist/persistence/session-payload.test.js +80 -0
- package/dist/persistence/session-payload.test.js.map +1 -0
- package/dist/persistence/session-replay.d.ts +14 -0
- package/dist/persistence/session-replay.d.ts.map +1 -0
- package/dist/persistence/session-replay.js +85 -0
- package/dist/persistence/session-replay.js.map +1 -0
- package/dist/persistence/session-replay.test.d.ts +10 -0
- package/dist/persistence/session-replay.test.d.ts.map +1 -0
- package/dist/persistence/session-replay.test.js +171 -0
- package/dist/persistence/session-replay.test.js.map +1 -0
- package/dist/plugins/__tests__/check-package-discovery.test.d.ts +2 -0
- package/dist/plugins/__tests__/check-package-discovery.test.d.ts.map +1 -0
- package/dist/plugins/__tests__/check-package-discovery.test.js +48 -0
- package/dist/plugins/__tests__/check-package-discovery.test.js.map +1 -0
- package/dist/plugins/__tests__/lang-domain.test.d.ts +2 -0
- package/dist/plugins/__tests__/lang-domain.test.d.ts.map +1 -0
- package/dist/plugins/__tests__/lang-domain.test.js +192 -0
- package/dist/plugins/__tests__/lang-domain.test.js.map +1 -0
- package/dist/plugins/__tests__/loader.test.d.ts +2 -0
- package/dist/plugins/__tests__/loader.test.d.ts.map +1 -0
- package/dist/plugins/__tests__/loader.test.js +271 -0
- package/dist/plugins/__tests__/loader.test.js.map +1 -0
- package/dist/plugins/check-package-discovery.d.ts +19 -0
- package/dist/plugins/check-package-discovery.d.ts.map +1 -0
- package/dist/plugins/check-package-discovery.js +34 -0
- package/dist/plugins/check-package-discovery.js.map +1 -0
- package/dist/plugins/loader.d.ts +32 -0
- package/dist/plugins/loader.d.ts.map +1 -0
- package/dist/plugins/loader.js +198 -0
- package/dist/plugins/loader.js.map +1 -0
- package/dist/plugins/types.d.ts +29 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +9 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/recipes/__tests__/built-in-recipes.test.d.ts +2 -0
- package/dist/recipes/__tests__/built-in-recipes.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/built-in-recipes.test.js +93 -0
- package/dist/recipes/__tests__/built-in-recipes.test.js.map +1 -0
- package/dist/recipes/__tests__/check-config.test.d.ts +12 -0
- package/dist/recipes/__tests__/check-config.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/check-config.test.js +90 -0
- package/dist/recipes/__tests__/check-config.test.js.map +1 -0
- package/dist/recipes/__tests__/check-resolution.test.d.ts +2 -0
- package/dist/recipes/__tests__/check-resolution.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/check-resolution.test.js +160 -0
- package/dist/recipes/__tests__/check-resolution.test.js.map +1 -0
- package/dist/recipes/__tests__/execution-branches.test.d.ts +10 -0
- package/dist/recipes/__tests__/execution-branches.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/execution-branches.test.js +612 -0
- package/dist/recipes/__tests__/execution-branches.test.js.map +1 -0
- package/dist/recipes/__tests__/execution-paths.test.d.ts +10 -0
- package/dist/recipes/__tests__/execution-paths.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/execution-paths.test.js +280 -0
- package/dist/recipes/__tests__/execution-paths.test.js.map +1 -0
- package/dist/recipes/__tests__/registry.test.d.ts +2 -0
- package/dist/recipes/__tests__/registry.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/registry.test.js +89 -0
- package/dist/recipes/__tests__/registry.test.js.map +1 -0
- package/dist/recipes/__tests__/retry.test.d.ts +2 -0
- package/dist/recipes/__tests__/retry.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/retry.test.js +75 -0
- package/dist/recipes/__tests__/retry.test.js.map +1 -0
- package/dist/recipes/__tests__/run-one-check.test.d.ts +14 -0
- package/dist/recipes/__tests__/run-one-check.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/run-one-check.test.js +182 -0
- package/dist/recipes/__tests__/run-one-check.test.js.map +1 -0
- package/dist/recipes/__tests__/service.test.d.ts +11 -0
- package/dist/recipes/__tests__/service.test.d.ts.map +1 -0
- package/dist/recipes/__tests__/service.test.js +572 -0
- package/dist/recipes/__tests__/service.test.js.map +1 -0
- package/dist/recipes/built-in-recipes.d.ts +14 -0
- package/dist/recipes/built-in-recipes.d.ts.map +1 -0
- package/dist/recipes/built-in-recipes.js +241 -0
- package/dist/recipes/built-in-recipes.js.map +1 -0
- package/dist/recipes/check-config.d.ts +56 -0
- package/dist/recipes/check-config.d.ts.map +1 -0
- package/dist/recipes/check-config.js +61 -0
- package/dist/recipes/check-config.js.map +1 -0
- package/dist/recipes/check-resolution.d.ts +36 -0
- package/dist/recipes/check-resolution.d.ts.map +1 -0
- package/dist/recipes/check-resolution.js +81 -0
- package/dist/recipes/check-resolution.js.map +1 -0
- package/dist/recipes/check-result-processor.d.ts +51 -0
- package/dist/recipes/check-result-processor.d.ts.map +1 -0
- package/dist/recipes/check-result-processor.js +197 -0
- package/dist/recipes/check-result-processor.js.map +1 -0
- package/dist/recipes/parallel-execution.d.ts +38 -0
- package/dist/recipes/parallel-execution.d.ts.map +1 -0
- package/dist/recipes/parallel-execution.js +61 -0
- package/dist/recipes/parallel-execution.js.map +1 -0
- package/dist/recipes/registry.d.ts +47 -0
- package/dist/recipes/registry.d.ts.map +1 -0
- package/dist/recipes/registry.js +70 -0
- package/dist/recipes/registry.js.map +1 -0
- package/dist/recipes/retry.d.ts +29 -0
- package/dist/recipes/retry.d.ts.map +1 -0
- package/dist/recipes/retry.js +23 -0
- package/dist/recipes/retry.js.map +1 -0
- package/dist/recipes/run-one-check.d.ts +59 -0
- package/dist/recipes/run-one-check.d.ts.map +1 -0
- package/dist/recipes/run-one-check.js +174 -0
- package/dist/recipes/run-one-check.js.map +1 -0
- package/dist/recipes/sequential-execution.d.ts +12 -0
- package/dist/recipes/sequential-execution.d.ts.map +1 -0
- package/dist/recipes/sequential-execution.js +48 -0
- package/dist/recipes/sequential-execution.js.map +1 -0
- package/dist/recipes/service-types.d.ts +87 -0
- package/dist/recipes/service-types.d.ts.map +1 -0
- package/dist/recipes/service-types.js +8 -0
- package/dist/recipes/service-types.js.map +1 -0
- package/dist/recipes/service.d.ts +73 -0
- package/dist/recipes/service.d.ts.map +1 -0
- package/dist/recipes/service.js +438 -0
- package/dist/recipes/service.js.map +1 -0
- package/dist/recipes/types.d.ts +155 -0
- package/dist/recipes/types.d.ts.map +1 -0
- package/dist/recipes/types.js +56 -0
- package/dist/recipes/types.js.map +1 -0
- package/dist/scaffold/config-block.d.ts +17 -0
- package/dist/scaffold/config-block.d.ts.map +1 -0
- package/dist/scaffold/config-block.js +30 -0
- package/dist/scaffold/config-block.js.map +1 -0
- package/dist/scaffold/examples.d.ts +30 -0
- package/dist/scaffold/examples.d.ts.map +1 -0
- package/dist/scaffold/examples.js +129 -0
- package/dist/scaffold/examples.js.map +1 -0
- package/dist/scope-augmentation.d.ts +77 -0
- package/dist/scope-augmentation.d.ts.map +1 -0
- package/dist/scope-augmentation.js +31 -0
- package/dist/scope-augmentation.js.map +1 -0
- package/dist/signalers/__tests__/loader.test.d.ts +2 -0
- package/dist/signalers/__tests__/loader.test.d.ts.map +1 -0
- package/dist/signalers/__tests__/loader.test.js +141 -0
- package/dist/signalers/__tests__/loader.test.js.map +1 -0
- package/dist/signalers/__tests__/violation-to-signal.test.d.ts +2 -0
- package/dist/signalers/__tests__/violation-to-signal.test.d.ts.map +1 -0
- package/dist/signalers/__tests__/violation-to-signal.test.js +59 -0
- package/dist/signalers/__tests__/violation-to-signal.test.js.map +1 -0
- package/dist/signalers/index.d.ts +8 -0
- package/dist/signalers/index.d.ts.map +1 -0
- package/dist/signalers/index.js +9 -0
- package/dist/signalers/index.js.map +1 -0
- package/dist/signalers/loader.d.ts +30 -0
- package/dist/signalers/loader.d.ts.map +1 -0
- package/dist/signalers/loader.js +120 -0
- package/dist/signalers/loader.js.map +1 -0
- package/dist/signalers/schema.d.ts +60 -0
- package/dist/signalers/schema.d.ts.map +1 -0
- package/dist/signalers/schema.js +74 -0
- package/dist/signalers/schema.js.map +1 -0
- package/dist/signalers/types.d.ts +13 -0
- package/dist/signalers/types.d.ts.map +1 -0
- package/dist/signalers/types.js +5 -0
- package/dist/signalers/types.js.map +1 -0
- package/dist/signalers/violation-to-signal.d.ts +38 -0
- package/dist/signalers/violation-to-signal.d.ts.map +1 -0
- package/dist/signalers/violation-to-signal.js +43 -0
- package/dist/signalers/violation-to-signal.js.map +1 -0
- package/dist/targets/__tests__/loader.test.d.ts +2 -0
- package/dist/targets/__tests__/loader.test.d.ts.map +1 -0
- package/dist/targets/__tests__/loader.test.js +190 -0
- package/dist/targets/__tests__/loader.test.js.map +1 -0
- package/dist/targets/__tests__/target-registry.test.d.ts +2 -0
- package/dist/targets/__tests__/target-registry.test.d.ts.map +1 -0
- package/dist/targets/__tests__/target-registry.test.js +182 -0
- package/dist/targets/__tests__/target-registry.test.js.map +1 -0
- package/dist/targets/index.d.ts +18 -0
- package/dist/targets/index.d.ts.map +1 -0
- package/dist/targets/index.js +21 -0
- package/dist/targets/index.js.map +1 -0
- package/dist/targets/loader.d.ts +27 -0
- package/dist/targets/loader.d.ts.map +1 -0
- package/dist/targets/loader.js +178 -0
- package/dist/targets/loader.js.map +1 -0
- package/dist/targets/target-registry.d.ts +41 -0
- package/dist/targets/target-registry.d.ts.map +1 -0
- package/dist/targets/target-registry.js +71 -0
- package/dist/targets/target-registry.js.map +1 -0
- package/dist/targets/types.d.ts +14 -0
- package/dist/targets/types.d.ts.map +1 -0
- package/dist/targets/types.js +14 -0
- package/dist/targets/types.js.map +1 -0
- package/dist/tool.d.ts +61 -0
- package/dist/tool.d.ts.map +1 -0
- package/dist/tool.js +260 -0
- package/dist/tool.js.map +1 -0
- package/dist/types/findings.d.ts +113 -0
- package/dist/types/findings.d.ts.map +1 -0
- package/dist/types/findings.js +89 -0
- package/dist/types/findings.js.map +1 -0
- package/dist/types/severity.d.ts +15 -0
- package/dist/types/severity.d.ts.map +1 -0
- package/dist/types/severity.js +33 -0
- package/dist/types/severity.js.map +1 -0
- package/package.json +137 -0
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Scope-owned fitness registry contract (mirrors simulation's
|
|
3
|
+
* scope-bound registry tests). Covers the factories, the scope readers, the
|
|
4
|
+
* throw-outside-scope guards, and scope isolation — two concurrent
|
|
5
|
+
* `runWithScope` contexts must carry INDEPENDENT check/recipe registries.
|
|
6
|
+
*/
|
|
7
|
+
import { RunScope, runWithScope } from '@opensip-cli/core';
|
|
8
|
+
import { describe, expect, it } from 'vitest';
|
|
9
|
+
import { defineRecipe } from '../../recipes/types.js';
|
|
10
|
+
import { fitnessTool } from '../../tool.js';
|
|
11
|
+
import { defineCheck } from '../define-check.js';
|
|
12
|
+
import { createCheckRegistry, createFitnessLoadState, createRecipeRegistry, currentCheckRegistry, currentFitnessLoadState, currentRecipeRegistry, } from '../scope-registry.js';
|
|
13
|
+
let nextId = 0;
|
|
14
|
+
function stubCheck(slug) {
|
|
15
|
+
nextId++;
|
|
16
|
+
return defineCheck({
|
|
17
|
+
id: `00000000-0000-4000-8000-${nextId.toString(16).padStart(12, '0')}`,
|
|
18
|
+
slug,
|
|
19
|
+
description: slug,
|
|
20
|
+
tags: ['demo'],
|
|
21
|
+
analyze: () => [],
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
/** Minimal user recipe for isolation assertions. */
|
|
25
|
+
function stubRecipe(name) {
|
|
26
|
+
return defineRecipe({
|
|
27
|
+
name,
|
|
28
|
+
displayName: name,
|
|
29
|
+
description: name,
|
|
30
|
+
checks: { type: 'all' },
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
/** Construct a RunScope carrying fitness's contributed subscope. */
|
|
34
|
+
function fitnessScope() {
|
|
35
|
+
const scope = new RunScope();
|
|
36
|
+
Object.assign(scope, fitnessTool.contributeScope?.() ?? {});
|
|
37
|
+
return scope;
|
|
38
|
+
}
|
|
39
|
+
describe('fitness scope-registry — factories', () => {
|
|
40
|
+
it('createCheckRegistry returns a fresh empty CheckRegistry', () => {
|
|
41
|
+
const reg = createCheckRegistry();
|
|
42
|
+
expect(reg.size).toBe(0);
|
|
43
|
+
reg.register(stubCheck('factory-check'));
|
|
44
|
+
expect(reg.size).toBe(1);
|
|
45
|
+
});
|
|
46
|
+
it('createRecipeRegistry returns a registry pre-seeded with built-ins', () => {
|
|
47
|
+
const reg = createRecipeRegistry();
|
|
48
|
+
expect(reg.has('default')).toBe(true);
|
|
49
|
+
});
|
|
50
|
+
it('createFitnessLoadState returns an empty lifecycle slot', () => {
|
|
51
|
+
const load = createFitnessLoadState();
|
|
52
|
+
expect(load.loadedFor).toBeNull();
|
|
53
|
+
expect(load.pluginLoadErrors).toEqual([]);
|
|
54
|
+
expect(load.loadWarnings).toEqual([]);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
describe('fitness scope-registry — readers throw outside a scope', () => {
|
|
58
|
+
it('currentCheckRegistry throws when no scope is active', () => {
|
|
59
|
+
expect(() => currentCheckRegistry()).toThrow(/outside a RunScope/);
|
|
60
|
+
});
|
|
61
|
+
it('currentRecipeRegistry throws when no scope is active', () => {
|
|
62
|
+
expect(() => currentRecipeRegistry()).toThrow(/outside a RunScope/);
|
|
63
|
+
});
|
|
64
|
+
it('currentFitnessLoadState throws when no scope is active', () => {
|
|
65
|
+
expect(() => currentFitnessLoadState()).toThrow(/outside a RunScope/);
|
|
66
|
+
});
|
|
67
|
+
it('readers throw when the scope has no fitness subscope', async () => {
|
|
68
|
+
await runWithScope(new RunScope(), () => {
|
|
69
|
+
expect(() => currentCheckRegistry()).toThrow(/scope\.fitness is missing/);
|
|
70
|
+
expect(() => currentRecipeRegistry()).toThrow(/scope\.fitness is missing/);
|
|
71
|
+
expect(() => currentFitnessLoadState()).toThrow(/scope\.fitness is missing/);
|
|
72
|
+
return Promise.resolve();
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
describe('fitness scope-registry — readers resolve the scope-bound instances', () => {
|
|
77
|
+
it('currentCheckRegistry returns the scope.fitness.checks instance', async () => {
|
|
78
|
+
const scope = fitnessScope();
|
|
79
|
+
await runWithScope(scope, () => {
|
|
80
|
+
expect(currentCheckRegistry()).toBe(scope.fitness?.checks);
|
|
81
|
+
return Promise.resolve();
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
it('currentRecipeRegistry returns the scope.fitness.recipes instance', async () => {
|
|
85
|
+
const scope = fitnessScope();
|
|
86
|
+
await runWithScope(scope, () => {
|
|
87
|
+
expect(currentRecipeRegistry()).toBe(scope.fitness?.recipes);
|
|
88
|
+
return Promise.resolve();
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
describe('fitness scope-registry — scope isolation', () => {
|
|
93
|
+
it('two scopes carry INDEPENDENT check registries', async () => {
|
|
94
|
+
const scopeA = fitnessScope();
|
|
95
|
+
const scopeB = fitnessScope();
|
|
96
|
+
await runWithScope(scopeA, () => {
|
|
97
|
+
currentCheckRegistry().register(stubCheck('only-in-a'), 'a');
|
|
98
|
+
return Promise.resolve();
|
|
99
|
+
});
|
|
100
|
+
await runWithScope(scopeB, () => {
|
|
101
|
+
currentCheckRegistry().register(stubCheck('only-in-b'), 'b');
|
|
102
|
+
return Promise.resolve();
|
|
103
|
+
});
|
|
104
|
+
await runWithScope(scopeA, () => {
|
|
105
|
+
expect(currentCheckRegistry().getBySlug('a:only-in-a')).toBeDefined();
|
|
106
|
+
expect(currentCheckRegistry().getBySlug('b:only-in-b')).toBeUndefined();
|
|
107
|
+
return Promise.resolve();
|
|
108
|
+
});
|
|
109
|
+
await runWithScope(scopeB, () => {
|
|
110
|
+
expect(currentCheckRegistry().getBySlug('b:only-in-b')).toBeDefined();
|
|
111
|
+
expect(currentCheckRegistry().getBySlug('a:only-in-a')).toBeUndefined();
|
|
112
|
+
return Promise.resolve();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
it('two scopes carry INDEPENDENT recipe registries', async () => {
|
|
116
|
+
const scopeA = fitnessScope();
|
|
117
|
+
const scopeB = fitnessScope();
|
|
118
|
+
await runWithScope(scopeA, () => {
|
|
119
|
+
currentRecipeRegistry().register(stubRecipe('only-in-a'));
|
|
120
|
+
return Promise.resolve();
|
|
121
|
+
});
|
|
122
|
+
await runWithScope(scopeB, () => {
|
|
123
|
+
currentRecipeRegistry().register(stubRecipe('only-in-b'));
|
|
124
|
+
return Promise.resolve();
|
|
125
|
+
});
|
|
126
|
+
await runWithScope(scopeA, () => {
|
|
127
|
+
// A's user recipe is visible in A; B's is not. Built-ins stay shared-by-value.
|
|
128
|
+
expect(currentRecipeRegistry().has('only-in-a')).toBe(true);
|
|
129
|
+
expect(currentRecipeRegistry().has('only-in-b')).toBe(false);
|
|
130
|
+
expect(currentRecipeRegistry().has('default')).toBe(true);
|
|
131
|
+
return Promise.resolve();
|
|
132
|
+
});
|
|
133
|
+
await runWithScope(scopeB, () => {
|
|
134
|
+
expect(currentRecipeRegistry().has('only-in-b')).toBe(true);
|
|
135
|
+
expect(currentRecipeRegistry().has('only-in-a')).toBe(false);
|
|
136
|
+
return Promise.resolve();
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
it('two scopes carry INDEPENDENT load state', async () => {
|
|
140
|
+
const scopeA = fitnessScope();
|
|
141
|
+
const scopeB = fitnessScope();
|
|
142
|
+
await runWithScope(scopeA, () => {
|
|
143
|
+
currentFitnessLoadState().loadedFor = '/project/a';
|
|
144
|
+
return Promise.resolve();
|
|
145
|
+
});
|
|
146
|
+
await runWithScope(scopeA, () => {
|
|
147
|
+
expect(currentFitnessLoadState().loadedFor).toBe('/project/a');
|
|
148
|
+
return Promise.resolve();
|
|
149
|
+
});
|
|
150
|
+
await runWithScope(scopeB, () => {
|
|
151
|
+
expect(currentFitnessLoadState().loadedFor).toBeNull();
|
|
152
|
+
return Promise.resolve();
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
//# sourceMappingURL=scope-registry.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-registry.test.js","sourceRoot":"","sources":["../../../src/framework/__tests__/scope-registry.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-resolver.golden.test.d.ts","sourceRoot":"","sources":["../../../src/framework/__tests__/scope-resolver.golden.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { tmpdir } from 'node:os';
|
|
3
|
+
import { dirname, join } from 'node:path';
|
|
4
|
+
import { afterEach, beforeEach, describe, expect, it } from 'vitest';
|
|
5
|
+
import { TargetRegistry } from '../../targets/target-registry.js';
|
|
6
|
+
import { buildScopeBasedFileMap } from '../scope-resolver.js';
|
|
7
|
+
/**
|
|
8
|
+
* ADR-0037 enforcement-reason guard (2): fitness per-check file-set resolution
|
|
9
|
+
* is BYTE-IDENTICAL through the Phase 2 substrate migration. A fixed corpus of
|
|
10
|
+
* checks × targets is resolved by the live `buildScopeBasedFileMap` (which now
|
|
11
|
+
* globs via `@opensip-cli/targeting`) and asserted against a checked-in golden.
|
|
12
|
+
*
|
|
13
|
+
* The corpus exercises every resolution path:
|
|
14
|
+
* - per-target `exclude` (the test-file glob drops src test files from ts-src)
|
|
15
|
+
* - project `globalExcludes` (the generated-dir glob drops files everywhere)
|
|
16
|
+
* - multi-target union (multi-check → ts-src ∪ rs-src)
|
|
17
|
+
* - checkOverrides precedence (tier 1: override-check → docs)
|
|
18
|
+
* - findByScope match (tier 2: ts-check, multi-check)
|
|
19
|
+
* - unscoped → not-in-map (tier 3: unscoped-check absent)
|
|
20
|
+
*
|
|
21
|
+
* The golden was eyeballed for correctness; equality with the pre-migration
|
|
22
|
+
* output is further backed by the unchanged scope-resolver.test.ts behavior
|
|
23
|
+
* anchor (Phase 2 kept all 689 fitness tests green).
|
|
24
|
+
*/
|
|
25
|
+
let testDir;
|
|
26
|
+
function fixture(rel) {
|
|
27
|
+
const abs = join(testDir, rel);
|
|
28
|
+
mkdirSync(dirname(abs), { recursive: true });
|
|
29
|
+
writeFileSync(abs, '');
|
|
30
|
+
}
|
|
31
|
+
function makeTarget(name, opts) {
|
|
32
|
+
return {
|
|
33
|
+
config: {
|
|
34
|
+
name,
|
|
35
|
+
description: name,
|
|
36
|
+
include: opts.include ?? [],
|
|
37
|
+
exclude: opts.exclude ?? [],
|
|
38
|
+
...(opts.languages && { languages: opts.languages }),
|
|
39
|
+
...(opts.concerns && { concerns: opts.concerns }),
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
/** Relativize + sort each entry so the golden is path-stable across machines. */
|
|
44
|
+
function relativizeMap(map) {
|
|
45
|
+
const out = {};
|
|
46
|
+
for (const [slug, files] of map) {
|
|
47
|
+
out[slug] = files.map((f) => f.slice(testDir.length + 1)).sort();
|
|
48
|
+
}
|
|
49
|
+
return out;
|
|
50
|
+
}
|
|
51
|
+
beforeEach(() => {
|
|
52
|
+
testDir = mkdtempSync(join(tmpdir(), 'opensip-scope-golden-'));
|
|
53
|
+
// ── corpus fixtures ──
|
|
54
|
+
fixture('src/a.ts');
|
|
55
|
+
fixture('src/b.ts');
|
|
56
|
+
fixture('src/a.test.ts'); // dropped by ts-src per-target exclude
|
|
57
|
+
fixture('src/generated/g.ts'); // dropped by globalExcludes
|
|
58
|
+
fixture('rust/lib.rs');
|
|
59
|
+
fixture('rust/generated/g.rs'); // dropped by globalExcludes
|
|
60
|
+
fixture('docs/readme.md');
|
|
61
|
+
});
|
|
62
|
+
afterEach(() => {
|
|
63
|
+
rmSync(testDir, { recursive: true, force: true });
|
|
64
|
+
});
|
|
65
|
+
describe('scope-resolver golden (byte-identical through the substrate migration)', () => {
|
|
66
|
+
it('resolves the fixed corpus to the golden file sets', () => {
|
|
67
|
+
const registry = new TargetRegistry();
|
|
68
|
+
registry.register(makeTarget('ts-src', {
|
|
69
|
+
include: ['src/**/*.ts'],
|
|
70
|
+
exclude: ['**/*.test.ts'],
|
|
71
|
+
languages: ['typescript'],
|
|
72
|
+
concerns: ['backend'],
|
|
73
|
+
}));
|
|
74
|
+
registry.register(makeTarget('rs-src', {
|
|
75
|
+
include: ['rust/**/*.rs'],
|
|
76
|
+
languages: ['rust'],
|
|
77
|
+
concerns: ['backend'],
|
|
78
|
+
}));
|
|
79
|
+
registry.register(makeTarget('docs', {
|
|
80
|
+
include: ['docs/**/*.md'],
|
|
81
|
+
languages: ['markdown'],
|
|
82
|
+
concerns: ['documentation'],
|
|
83
|
+
}));
|
|
84
|
+
const config = {
|
|
85
|
+
globalExcludes: ['**/generated/**'],
|
|
86
|
+
checkOverrides: { 'override-check': 'docs' },
|
|
87
|
+
};
|
|
88
|
+
const checks = [
|
|
89
|
+
{ slug: 'ts-check', scope: { languages: ['typescript'], concerns: ['backend'] } },
|
|
90
|
+
{ slug: 'multi-check', scope: { languages: ['typescript', 'rust'], concerns: ['backend'] } },
|
|
91
|
+
{ slug: 'override-check' }, // tier 1 via checkOverrides
|
|
92
|
+
{ slug: 'unscoped-check' }, // tier 3 → absent from the map
|
|
93
|
+
];
|
|
94
|
+
const result = relativizeMap(buildScopeBasedFileMap(checks, registry, config, testDir));
|
|
95
|
+
const golden = {
|
|
96
|
+
'ts-check': ['src/a.ts', 'src/b.ts'],
|
|
97
|
+
'multi-check': ['rust/lib.rs', 'src/a.ts', 'src/b.ts'],
|
|
98
|
+
'override-check': ['docs/readme.md'],
|
|
99
|
+
// unscoped-check intentionally ABSENT (tier 3 → fileCache fallback)
|
|
100
|
+
};
|
|
101
|
+
expect(result).toEqual(golden);
|
|
102
|
+
expect(result['unscoped-check']).toBeUndefined();
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
//# sourceMappingURL=scope-resolver.golden.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-resolver.golden.test.js","sourceRoot":"","sources":["../../../src/framework/__tests__/scope-resolver.golden.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-resolver.test.d.ts","sourceRoot":"","sources":["../../../src/framework/__tests__/scope-resolver.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { tmpdir } from 'node:os';
|
|
3
|
+
import { dirname, join } from 'node:path';
|
|
4
|
+
import { afterEach, beforeEach, describe, expect, it } from 'vitest';
|
|
5
|
+
import { TargetRegistry } from '../../targets/target-registry.js';
|
|
6
|
+
import { buildScopeBasedFileMap } from '../scope-resolver.js';
|
|
7
|
+
let testDir;
|
|
8
|
+
function fixture(rel, content = '') {
|
|
9
|
+
const abs = join(testDir, rel);
|
|
10
|
+
mkdirSync(dirname(abs), { recursive: true });
|
|
11
|
+
writeFileSync(abs, content);
|
|
12
|
+
return abs;
|
|
13
|
+
}
|
|
14
|
+
function makeRegistry(targets) {
|
|
15
|
+
const reg = new TargetRegistry();
|
|
16
|
+
for (const t of targets)
|
|
17
|
+
reg.register(t);
|
|
18
|
+
return reg;
|
|
19
|
+
}
|
|
20
|
+
function makeTarget(name, opts) {
|
|
21
|
+
return {
|
|
22
|
+
config: {
|
|
23
|
+
name,
|
|
24
|
+
description: name,
|
|
25
|
+
include: opts.include ?? [],
|
|
26
|
+
exclude: opts.exclude ?? [],
|
|
27
|
+
...(opts.languages && { languages: opts.languages }),
|
|
28
|
+
...(opts.concerns && { concerns: opts.concerns }),
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
function makeConfig(overrides = {}) {
|
|
33
|
+
return {
|
|
34
|
+
globalExcludes: overrides.globalExcludes ?? [],
|
|
35
|
+
checkOverrides: overrides.checkOverrides ?? {},
|
|
36
|
+
...overrides,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
beforeEach(() => {
|
|
40
|
+
testDir = mkdtempSync(join(tmpdir(), 'opensip-scope-resolver-'));
|
|
41
|
+
});
|
|
42
|
+
afterEach(() => {
|
|
43
|
+
rmSync(testDir, { recursive: true, force: true });
|
|
44
|
+
});
|
|
45
|
+
describe('buildScopeBasedFileMap', () => {
|
|
46
|
+
it('returns an empty map when no checks have scopes or overrides', () => {
|
|
47
|
+
const registry = makeRegistry([
|
|
48
|
+
makeTarget('src', {
|
|
49
|
+
include: ['src/**/*.ts'],
|
|
50
|
+
languages: ['typescript'],
|
|
51
|
+
concerns: ['backend'],
|
|
52
|
+
}),
|
|
53
|
+
]);
|
|
54
|
+
const out = buildScopeBasedFileMap([], registry, makeConfig(), testDir);
|
|
55
|
+
expect(out.size).toBe(0);
|
|
56
|
+
});
|
|
57
|
+
it('matches checks to targets by scope.languages + concerns', () => {
|
|
58
|
+
fixture('src/a.ts');
|
|
59
|
+
fixture('src/b.ts');
|
|
60
|
+
fixture('lib/c.rs');
|
|
61
|
+
const registry = makeRegistry([
|
|
62
|
+
makeTarget('ts-src', {
|
|
63
|
+
include: ['src/**/*.ts'],
|
|
64
|
+
languages: ['typescript'],
|
|
65
|
+
concerns: ['backend'],
|
|
66
|
+
}),
|
|
67
|
+
makeTarget('rs-lib', {
|
|
68
|
+
include: ['lib/**/*.rs'],
|
|
69
|
+
languages: ['rust'],
|
|
70
|
+
concerns: ['backend'],
|
|
71
|
+
}),
|
|
72
|
+
]);
|
|
73
|
+
const out = buildScopeBasedFileMap([{ slug: 'ts-check', scope: { languages: ['typescript'], concerns: ['backend'] } }], registry, makeConfig(), testDir);
|
|
74
|
+
const tsFiles = out.get('ts-check');
|
|
75
|
+
expect(tsFiles).toBeDefined();
|
|
76
|
+
expect(tsFiles?.length).toBe(2);
|
|
77
|
+
expect(tsFiles?.every((f) => f.endsWith('.ts'))).toBe(true);
|
|
78
|
+
});
|
|
79
|
+
it('returns empty when scope matches no targets', () => {
|
|
80
|
+
fixture('src/a.ts');
|
|
81
|
+
const registry = makeRegistry([
|
|
82
|
+
makeTarget('ts-src', {
|
|
83
|
+
include: ['src/**/*.ts'],
|
|
84
|
+
languages: ['typescript'],
|
|
85
|
+
concerns: ['backend'],
|
|
86
|
+
}),
|
|
87
|
+
]);
|
|
88
|
+
const out = buildScopeBasedFileMap([{ slug: 'cobol-check', scope: { languages: ['cobol'], concerns: ['mainframe'] } }], registry, makeConfig(), testDir);
|
|
89
|
+
expect(out.get('cobol-check')).toEqual([]);
|
|
90
|
+
});
|
|
91
|
+
it('uses checkOverrides when present', () => {
|
|
92
|
+
fixture('src/a.ts');
|
|
93
|
+
fixture('test/b.ts');
|
|
94
|
+
const registry = makeRegistry([
|
|
95
|
+
makeTarget('src', { include: ['src/**/*.ts'] }),
|
|
96
|
+
makeTarget('test', { include: ['test/**/*.ts'] }),
|
|
97
|
+
]);
|
|
98
|
+
const out = buildScopeBasedFileMap([{ slug: 'narrow-check', scope: { languages: [], concerns: [] } }], registry, makeConfig({ checkOverrides: { 'narrow-check': 'test' } }), testDir);
|
|
99
|
+
const files = out.get('narrow-check');
|
|
100
|
+
expect(files?.length).toBe(1);
|
|
101
|
+
expect(files?.[0]?.endsWith('test/b.ts')).toBe(true);
|
|
102
|
+
});
|
|
103
|
+
it('honors checkOverrides that point to multiple targets', () => {
|
|
104
|
+
fixture('src/a.ts');
|
|
105
|
+
fixture('test/b.ts');
|
|
106
|
+
const registry = makeRegistry([
|
|
107
|
+
makeTarget('src', { include: ['src/**/*.ts'] }),
|
|
108
|
+
makeTarget('test', { include: ['test/**/*.ts'] }),
|
|
109
|
+
]);
|
|
110
|
+
const out = buildScopeBasedFileMap([{ slug: 'broad-check', scope: { languages: [], concerns: [] } }], registry, makeConfig({ checkOverrides: { 'broad-check': ['src', 'test'] } }), testDir);
|
|
111
|
+
expect(out.get('broad-check')?.length).toBe(2);
|
|
112
|
+
});
|
|
113
|
+
it('applies globalExcludes during pre-resolution', () => {
|
|
114
|
+
fixture('src/a.ts');
|
|
115
|
+
fixture('src/ignore-me/b.ts');
|
|
116
|
+
const registry = makeRegistry([
|
|
117
|
+
makeTarget('src', {
|
|
118
|
+
include: ['src/**/*.ts'],
|
|
119
|
+
languages: ['typescript'],
|
|
120
|
+
concerns: ['backend'],
|
|
121
|
+
}),
|
|
122
|
+
]);
|
|
123
|
+
const out = buildScopeBasedFileMap([{ slug: 'check', scope: { languages: ['typescript'], concerns: ['backend'] } }], registry, makeConfig({ globalExcludes: ['**/ignore-me/**'] }), testDir);
|
|
124
|
+
const files = out.get('check') ?? [];
|
|
125
|
+
expect(files.some((f) => f.includes('ignore-me'))).toBe(false);
|
|
126
|
+
expect(files.length).toBe(1);
|
|
127
|
+
});
|
|
128
|
+
it('applies per-target excludes', () => {
|
|
129
|
+
fixture('src/a.ts');
|
|
130
|
+
fixture('src/skip.ts');
|
|
131
|
+
const registry = makeRegistry([
|
|
132
|
+
makeTarget('src', {
|
|
133
|
+
include: ['src/**/*.ts'],
|
|
134
|
+
exclude: ['**/skip.ts'],
|
|
135
|
+
languages: ['typescript'],
|
|
136
|
+
concerns: ['backend'],
|
|
137
|
+
}),
|
|
138
|
+
]);
|
|
139
|
+
const out = buildScopeBasedFileMap([{ slug: 'check', scope: { languages: ['typescript'], concerns: ['backend'] } }], registry, makeConfig(), testDir);
|
|
140
|
+
const files = out.get('check') ?? [];
|
|
141
|
+
expect(files.some((f) => f.endsWith('skip.ts'))).toBe(false);
|
|
142
|
+
});
|
|
143
|
+
it('skips checks without a scope and without an override', () => {
|
|
144
|
+
fixture('src/a.ts');
|
|
145
|
+
const registry = makeRegistry([makeTarget('src', { include: ['src/**/*.ts'] })]);
|
|
146
|
+
const out = buildScopeBasedFileMap([{ slug: 'unscoped' }], registry, makeConfig(), testDir);
|
|
147
|
+
expect(out.has('unscoped')).toBe(false);
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
//# sourceMappingURL=scope-resolver.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scope-resolver.test.js","sourceRoot":"","sources":["../../../src/framework/__tests__/scope-resolver.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"severity-mapping.test.d.ts","sourceRoot":"","sources":["../../../src/framework/__tests__/severity-mapping.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { logger } from '@opensip-cli/core';
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
3
|
+
import { mapFindingSeverity, mapTagsToSignalCategory } from '../severity-mapping.js';
|
|
4
|
+
describe('mapFindingSeverity', () => {
|
|
5
|
+
it('maps "error" to "high"', () => {
|
|
6
|
+
expect(mapFindingSeverity('error')).toBe('high');
|
|
7
|
+
});
|
|
8
|
+
it('maps "warning" to "medium"', () => {
|
|
9
|
+
expect(mapFindingSeverity('warning')).toBe('medium');
|
|
10
|
+
});
|
|
11
|
+
it('falls back to "medium" for unknown severities', () => {
|
|
12
|
+
// @ts-expect-error — exercising the runtime default
|
|
13
|
+
expect(mapFindingSeverity('whatever')).toBe('medium');
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
describe('mapTagsToSignalCategory', () => {
|
|
17
|
+
it.each([
|
|
18
|
+
['security', 'security'],
|
|
19
|
+
['performance', 'performance'],
|
|
20
|
+
['architecture', 'architecture'],
|
|
21
|
+
['resilience', 'resilience'],
|
|
22
|
+
['testing', 'testing'],
|
|
23
|
+
['documentation', 'documentation'],
|
|
24
|
+
])('maps %s tag to %s category', (tag, category) => {
|
|
25
|
+
expect(mapTagsToSignalCategory([tag])).toBe(category);
|
|
26
|
+
});
|
|
27
|
+
it('maps "quality" tag to "warning" category', () => {
|
|
28
|
+
expect(mapTagsToSignalCategory(['quality'])).toBe('warning');
|
|
29
|
+
});
|
|
30
|
+
it('falls back to "warning" when no recognized tag matches', () => {
|
|
31
|
+
expect(mapTagsToSignalCategory(['custom-tag'])).toBe('warning');
|
|
32
|
+
});
|
|
33
|
+
it('returns "warning" for an empty tag list', () => {
|
|
34
|
+
expect(mapTagsToSignalCategory([])).toBe('warning');
|
|
35
|
+
});
|
|
36
|
+
it('uses the first matching tag (priority order)', () => {
|
|
37
|
+
// 'quality' comes after 'security' lexically but the function iterates the
|
|
38
|
+
// input array in order, so 'security' wins here.
|
|
39
|
+
expect(mapTagsToSignalCategory(['quality', 'security'])).toBe('warning');
|
|
40
|
+
expect(mapTagsToSignalCategory(['security', 'quality'])).toBe('security');
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
describe('mapTagsToSignalCategory — warn-once on unknown tags', () => {
|
|
44
|
+
let warnSpy;
|
|
45
|
+
beforeEach(() => {
|
|
46
|
+
warnSpy = vi.spyOn(logger, 'warn').mockImplementation(() => undefined);
|
|
47
|
+
});
|
|
48
|
+
afterEach(() => {
|
|
49
|
+
warnSpy.mockRestore();
|
|
50
|
+
});
|
|
51
|
+
it("warns when a check's tags include none of the known categories", () => {
|
|
52
|
+
// Use a tag-set we have not seen before so the dedupe cache misses.
|
|
53
|
+
expect(mapTagsToSignalCategory(['custom-foo-misspelled'])).toBe('warning');
|
|
54
|
+
expect(warnSpy).toHaveBeenCalled();
|
|
55
|
+
const call = warnSpy.mock.calls[0]?.[0];
|
|
56
|
+
expect(call?.evt).toBe('fitness.severity_mapping.unknown_tags');
|
|
57
|
+
expect(call?.tags).toEqual(['custom-foo-misspelled']);
|
|
58
|
+
});
|
|
59
|
+
it('warns only once for the same unknown tag-set', () => {
|
|
60
|
+
mapTagsToSignalCategory(['warn-once-fixture-tag']);
|
|
61
|
+
mapTagsToSignalCategory(['warn-once-fixture-tag']);
|
|
62
|
+
mapTagsToSignalCategory(['warn-once-fixture-tag']);
|
|
63
|
+
const matching = warnSpy.mock.calls.filter((c) => {
|
|
64
|
+
const arg = c[0];
|
|
65
|
+
return arg?.tags?.[0] === 'warn-once-fixture-tag';
|
|
66
|
+
});
|
|
67
|
+
expect(matching.length).toBe(1);
|
|
68
|
+
});
|
|
69
|
+
it('does not warn when at least one known tag is present', () => {
|
|
70
|
+
mapTagsToSignalCategory(['security', 'totally-unknown']);
|
|
71
|
+
expect(warnSpy).not.toHaveBeenCalled();
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
//# sourceMappingURL=severity-mapping.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"severity-mapping.test.js","sourceRoot":"","sources":["../../../src/framework/__tests__/severity-mapping.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strip-literals.test.d.ts","sourceRoot":"","sources":["../../../src/framework/__tests__/strip-literals.test.ts"],"names":[],"mappings":""}
|