@opensip-cli/checks-universal 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__/all-checks-execute.test.d.ts +17 -0
- package/dist/__tests__/all-checks-execute.test.d.ts.map +1 -0
- package/dist/__tests__/all-checks-execute.test.js +452 -0
- package/dist/__tests__/all-checks-execute.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-10.test.d.ts +8 -0
- package/dist/__tests__/behavior-fixtures-10.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-10.test.js +200 -0
- package/dist/__tests__/behavior-fixtures-10.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-11.test.d.ts +8 -0
- package/dist/__tests__/behavior-fixtures-11.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-11.test.js +120 -0
- package/dist/__tests__/behavior-fixtures-11.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-12.test.d.ts +8 -0
- package/dist/__tests__/behavior-fixtures-12.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-12.test.js +157 -0
- package/dist/__tests__/behavior-fixtures-12.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-2.test.d.ts +8 -0
- package/dist/__tests__/behavior-fixtures-2.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-2.test.js +785 -0
- package/dist/__tests__/behavior-fixtures-2.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-3.test.d.ts +6 -0
- package/dist/__tests__/behavior-fixtures-3.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-3.test.js +663 -0
- package/dist/__tests__/behavior-fixtures-3.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-4.test.d.ts +5 -0
- package/dist/__tests__/behavior-fixtures-4.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-4.test.js +612 -0
- package/dist/__tests__/behavior-fixtures-4.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-5.test.d.ts +5 -0
- package/dist/__tests__/behavior-fixtures-5.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-5.test.js +469 -0
- package/dist/__tests__/behavior-fixtures-5.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-6.test.d.ts +8 -0
- package/dist/__tests__/behavior-fixtures-6.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-6.test.js +591 -0
- package/dist/__tests__/behavior-fixtures-6.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-7.test.d.ts +5 -0
- package/dist/__tests__/behavior-fixtures-7.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-7.test.js +662 -0
- package/dist/__tests__/behavior-fixtures-7.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-8.test.d.ts +11 -0
- package/dist/__tests__/behavior-fixtures-8.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-8.test.js +634 -0
- package/dist/__tests__/behavior-fixtures-8.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures-9.test.d.ts +11 -0
- package/dist/__tests__/behavior-fixtures-9.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures-9.test.js +271 -0
- package/dist/__tests__/behavior-fixtures-9.test.js.map +1 -0
- package/dist/__tests__/behavior-fixtures.test.d.ts +14 -0
- package/dist/__tests__/behavior-fixtures.test.d.ts.map +1 -0
- package/dist/__tests__/behavior-fixtures.test.js +1423 -0
- package/dist/__tests__/behavior-fixtures.test.js.map +1 -0
- package/dist/__tests__/checks.test.d.ts +2 -0
- package/dist/__tests__/checks.test.d.ts.map +1 -0
- package/dist/__tests__/checks.test.js +61 -0
- package/dist/__tests__/checks.test.js.map +1 -0
- package/dist/__tests__/env-var-validation.test.d.ts +14 -0
- package/dist/__tests__/env-var-validation.test.d.ts.map +1 -0
- package/dist/__tests__/env-var-validation.test.js +53 -0
- package/dist/__tests__/env-var-validation.test.js.map +1 -0
- package/dist/__tests__/file-length-limit.test.d.ts +2 -0
- package/dist/__tests__/file-length-limit.test.d.ts.map +1 -0
- package/dist/__tests__/file-length-limit.test.js +29 -0
- package/dist/__tests__/file-length-limit.test.js.map +1 -0
- package/dist/__tests__/fixture-coverage.allowlist.d.ts +18 -0
- package/dist/__tests__/fixture-coverage.allowlist.d.ts.map +1 -0
- package/dist/__tests__/fixture-coverage.allowlist.js +35 -0
- package/dist/__tests__/fixture-coverage.allowlist.js.map +1 -0
- package/dist/__tests__/fixture-coverage.test.d.ts +13 -0
- package/dist/__tests__/fixture-coverage.test.d.ts.map +1 -0
- package/dist/__tests__/fixture-coverage.test.js +57 -0
- package/dist/__tests__/fixture-coverage.test.js.map +1 -0
- package/dist/__tests__/iic.test.d.ts +15 -0
- package/dist/__tests__/iic.test.d.ts.map +1 -0
- package/dist/__tests__/iic.test.js +316 -0
- package/dist/__tests__/iic.test.js.map +1 -0
- package/dist/__tests__/no-skipped-tests.test.d.ts +14 -0
- package/dist/__tests__/no-skipped-tests.test.d.ts.map +1 -0
- package/dist/__tests__/no-skipped-tests.test.js +144 -0
- package/dist/__tests__/no-skipped-tests.test.js.map +1 -0
- package/dist/__tests__/no-todo-comments.test.d.ts +2 -0
- package/dist/__tests__/no-todo-comments.test.d.ts.map +1 -0
- package/dist/__tests__/no-todo-comments.test.js +31 -0
- package/dist/__tests__/no-todo-comments.test.js.map +1 -0
- package/dist/__tests__/no-unimplemented-markers.test.d.ts +2 -0
- package/dist/__tests__/no-unimplemented-markers.test.d.ts.map +1 -0
- package/dist/__tests__/no-unimplemented-markers.test.js +140 -0
- package/dist/__tests__/no-unimplemented-markers.test.js.map +1 -0
- package/dist/__tests__/public-api-jsdoc-scope.test.d.ts +10 -0
- package/dist/__tests__/public-api-jsdoc-scope.test.d.ts.map +1 -0
- package/dist/__tests__/public-api-jsdoc-scope.test.js +176 -0
- package/dist/__tests__/public-api-jsdoc-scope.test.js.map +1 -0
- package/dist/__tests__/resilience-fp.test.d.ts +14 -0
- package/dist/__tests__/resilience-fp.test.d.ts.map +1 -0
- package/dist/__tests__/resilience-fp.test.js +110 -0
- package/dist/__tests__/resilience-fp.test.js.map +1 -0
- package/dist/checks/architecture/__tests__/no-kebab-option-indexing.test.d.ts +2 -0
- package/dist/checks/architecture/__tests__/no-kebab-option-indexing.test.d.ts.map +1 -0
- package/dist/checks/architecture/__tests__/no-kebab-option-indexing.test.js +32 -0
- package/dist/checks/architecture/__tests__/no-kebab-option-indexing.test.js.map +1 -0
- package/dist/checks/architecture/__tests__/tool-has-manifest.test.d.ts +2 -0
- package/dist/checks/architecture/__tests__/tool-has-manifest.test.d.ts.map +1 -0
- package/dist/checks/architecture/__tests__/tool-has-manifest.test.js +152 -0
- package/dist/checks/architecture/__tests__/tool-has-manifest.test.js.map +1 -0
- package/dist/checks/architecture/__tests__/vitest-config-required-with-tests.test.d.ts +2 -0
- package/dist/checks/architecture/__tests__/vitest-config-required-with-tests.test.d.ts.map +1 -0
- package/dist/checks/architecture/__tests__/vitest-config-required-with-tests.test.js +129 -0
- package/dist/checks/architecture/__tests__/vitest-config-required-with-tests.test.js.map +1 -0
- package/dist/checks/architecture/_yaml-doc-bindings.d.ts +23 -0
- package/dist/checks/architecture/_yaml-doc-bindings.d.ts.map +1 -0
- package/dist/checks/architecture/_yaml-doc-bindings.js +29 -0
- package/dist/checks/architecture/_yaml-doc-bindings.js.map +1 -0
- package/dist/checks/architecture/dependencies/index.d.ts +2 -0
- package/dist/checks/architecture/dependencies/index.d.ts.map +1 -0
- package/dist/checks/architecture/dependencies/index.js +2 -0
- package/dist/checks/architecture/dependencies/index.js.map +1 -0
- package/dist/checks/architecture/dependencies/no-duplicate-packages.d.ts +11 -0
- package/dist/checks/architecture/dependencies/no-duplicate-packages.d.ts.map +1 -0
- package/dist/checks/architecture/dependencies/no-duplicate-packages.js +171 -0
- package/dist/checks/architecture/dependencies/no-duplicate-packages.js.map +1 -0
- package/dist/checks/architecture/docker-best-practices.d.ts +23 -0
- package/dist/checks/architecture/docker-best-practices.d.ts.map +1 -0
- package/dist/checks/architecture/docker-best-practices.js +427 -0
- package/dist/checks/architecture/docker-best-practices.js.map +1 -0
- package/dist/checks/architecture/docker-ignore-validation.d.ts +18 -0
- package/dist/checks/architecture/docker-ignore-validation.d.ts.map +1 -0
- package/dist/checks/architecture/docker-ignore-validation.js +117 -0
- package/dist/checks/architecture/docker-ignore-validation.js.map +1 -0
- package/dist/checks/architecture/docker-version-sync.d.ts +16 -0
- package/dist/checks/architecture/docker-version-sync.d.ts.map +1 -0
- package/dist/checks/architecture/docker-version-sync.js +193 -0
- package/dist/checks/architecture/docker-version-sync.js.map +1 -0
- package/dist/checks/architecture/env-var-validation.d.ts +14 -0
- package/dist/checks/architecture/env-var-validation.d.ts.map +1 -0
- package/dist/checks/architecture/env-var-validation.js +289 -0
- package/dist/checks/architecture/env-var-validation.js.map +1 -0
- package/dist/checks/architecture/heavy-import-detection.d.ts +11 -0
- package/dist/checks/architecture/heavy-import-detection.d.ts.map +1 -0
- package/dist/checks/architecture/heavy-import-detection.js +91 -0
- package/dist/checks/architecture/heavy-import-detection.js.map +1 -0
- package/dist/checks/architecture/index.d.ts +16 -0
- package/dist/checks/architecture/index.d.ts.map +1 -0
- package/dist/checks/architecture/index.js +16 -0
- package/dist/checks/architecture/index.js.map +1 -0
- package/dist/checks/architecture/modules/empty-package-detection.d.ts +11 -0
- package/dist/checks/architecture/modules/empty-package-detection.d.ts.map +1 -0
- package/dist/checks/architecture/modules/empty-package-detection.js +277 -0
- package/dist/checks/architecture/modules/empty-package-detection.js.map +1 -0
- package/dist/checks/architecture/modules/index.d.ts +3 -0
- package/dist/checks/architecture/modules/index.d.ts.map +1 -0
- package/dist/checks/architecture/modules/index.js +3 -0
- package/dist/checks/architecture/modules/index.js.map +1 -0
- package/dist/checks/architecture/modules/interface-implementation-consistency.d.ts +12 -0
- package/dist/checks/architecture/modules/interface-implementation-consistency.d.ts.map +1 -0
- package/dist/checks/architecture/modules/interface-implementation-consistency.js +555 -0
- package/dist/checks/architecture/modules/interface-implementation-consistency.js.map +1 -0
- package/dist/checks/architecture/no-custom-event-emitter.d.ts +11 -0
- package/dist/checks/architecture/no-custom-event-emitter.d.ts.map +1 -0
- package/dist/checks/architecture/no-custom-event-emitter.js +123 -0
- package/dist/checks/architecture/no-custom-event-emitter.js.map +1 -0
- package/dist/checks/architecture/no-kebab-option-indexing.d.ts +33 -0
- package/dist/checks/architecture/no-kebab-option-indexing.d.ts.map +1 -0
- package/dist/checks/architecture/no-kebab-option-indexing.js +81 -0
- package/dist/checks/architecture/no-kebab-option-indexing.js.map +1 -0
- package/dist/checks/architecture/node-version-consistency.d.ts +22 -0
- package/dist/checks/architecture/node-version-consistency.d.ts.map +1 -0
- package/dist/checks/architecture/node-version-consistency.js +225 -0
- package/dist/checks/architecture/node-version-consistency.js.map +1 -0
- package/dist/checks/architecture/project-readme-existence.d.ts +13 -0
- package/dist/checks/architecture/project-readme-existence.d.ts.map +1 -0
- package/dist/checks/architecture/project-readme-existence.js +55 -0
- package/dist/checks/architecture/project-readme-existence.js.map +1 -0
- package/dist/checks/architecture/stale-build-artifacts.d.ts +10 -0
- package/dist/checks/architecture/stale-build-artifacts.d.ts.map +1 -0
- package/dist/checks/architecture/stale-build-artifacts.js +55 -0
- package/dist/checks/architecture/stale-build-artifacts.js.map +1 -0
- package/dist/checks/architecture/tool-has-manifest.d.ts +27 -0
- package/dist/checks/architecture/tool-has-manifest.d.ts.map +1 -0
- package/dist/checks/architecture/tool-has-manifest.js +135 -0
- package/dist/checks/architecture/tool-has-manifest.js.map +1 -0
- package/dist/checks/architecture/vitest-config-extends-base.d.ts +15 -0
- package/dist/checks/architecture/vitest-config-extends-base.d.ts.map +1 -0
- package/dist/checks/architecture/vitest-config-extends-base.js +104 -0
- package/dist/checks/architecture/vitest-config-extends-base.js.map +1 -0
- package/dist/checks/architecture/vitest-config-required-with-tests.d.ts +49 -0
- package/dist/checks/architecture/vitest-config-required-with-tests.d.ts.map +1 -0
- package/dist/checks/architecture/vitest-config-required-with-tests.js +199 -0
- package/dist/checks/architecture/vitest-config-required-with-tests.js.map +1 -0
- package/dist/checks/documentation/_directives/eslint.d.ts +9 -0
- package/dist/checks/documentation/_directives/eslint.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/eslint.js +168 -0
- package/dist/checks/documentation/_directives/eslint.js.map +1 -0
- package/dist/checks/documentation/_directives/fitness.d.ts +9 -0
- package/dist/checks/documentation/_directives/fitness.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/fitness.js +64 -0
- package/dist/checks/documentation/_directives/fitness.js.map +1 -0
- package/dist/checks/documentation/_directives/graph.d.ts +10 -0
- package/dist/checks/documentation/_directives/graph.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/graph.js +65 -0
- package/dist/checks/documentation/_directives/graph.js.map +1 -0
- package/dist/checks/documentation/_directives/graph.test.d.ts +2 -0
- package/dist/checks/documentation/_directives/graph.test.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/graph.test.js +54 -0
- package/dist/checks/documentation/_directives/graph.test.js.map +1 -0
- package/dist/checks/documentation/_directives/semgrep.d.ts +8 -0
- package/dist/checks/documentation/_directives/semgrep.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/semgrep.js +72 -0
- package/dist/checks/documentation/_directives/semgrep.js.map +1 -0
- package/dist/checks/documentation/_directives/types.d.ts +21 -0
- package/dist/checks/documentation/_directives/types.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/types.js +9 -0
- package/dist/checks/documentation/_directives/types.js.map +1 -0
- package/dist/checks/documentation/_directives/typescript.d.ts +10 -0
- package/dist/checks/documentation/_directives/typescript.d.ts.map +1 -0
- package/dist/checks/documentation/_directives/typescript.js +54 -0
- package/dist/checks/documentation/_directives/typescript.js.map +1 -0
- package/dist/checks/documentation/_public-api-graph.d.ts +30 -0
- package/dist/checks/documentation/_public-api-graph.d.ts.map +1 -0
- package/dist/checks/documentation/_public-api-graph.js +304 -0
- package/dist/checks/documentation/_public-api-graph.js.map +1 -0
- package/dist/checks/documentation/directive-audit.d.ts +26 -0
- package/dist/checks/documentation/directive-audit.d.ts.map +1 -0
- package/dist/checks/documentation/directive-audit.js +144 -0
- package/dist/checks/documentation/directive-audit.js.map +1 -0
- package/dist/checks/documentation/index.d.ts +3 -0
- package/dist/checks/documentation/index.d.ts.map +1 -0
- package/dist/checks/documentation/index.js +3 -0
- package/dist/checks/documentation/index.js.map +1 -0
- package/dist/checks/documentation/public-api-jsdoc.d.ts +10 -0
- package/dist/checks/documentation/public-api-jsdoc.d.ts.map +1 -0
- package/dist/checks/documentation/public-api-jsdoc.js +131 -0
- package/dist/checks/documentation/public-api-jsdoc.js.map +1 -0
- package/dist/checks/file-length-limit.d.ts +16 -0
- package/dist/checks/file-length-limit.d.ts.map +1 -0
- package/dist/checks/file-length-limit.js +47 -0
- package/dist/checks/file-length-limit.js.map +1 -0
- package/dist/checks/index.d.ts +16 -0
- package/dist/checks/index.d.ts.map +1 -0
- package/dist/checks/index.js +16 -0
- package/dist/checks/index.js.map +1 -0
- package/dist/checks/no-todo-comments.d.ts +18 -0
- package/dist/checks/no-todo-comments.d.ts.map +1 -0
- package/dist/checks/no-todo-comments.js +79 -0
- package/dist/checks/no-todo-comments.js.map +1 -0
- package/dist/checks/no-unimplemented-markers.d.ts +24 -0
- package/dist/checks/no-unimplemented-markers.d.ts.map +1 -0
- package/dist/checks/no-unimplemented-markers.js +198 -0
- package/dist/checks/no-unimplemented-markers.js.map +1 -0
- package/dist/checks/quality/api/graphql-offset-pagination.d.ts +9 -0
- package/dist/checks/quality/api/graphql-offset-pagination.d.ts.map +1 -0
- package/dist/checks/quality/api/graphql-offset-pagination.js +63 -0
- package/dist/checks/quality/api/graphql-offset-pagination.js.map +1 -0
- package/dist/checks/quality/api/index.d.ts +3 -0
- package/dist/checks/quality/api/index.d.ts.map +1 -0
- package/dist/checks/quality/api/index.js +3 -0
- package/dist/checks/quality/api/index.js.map +1 -0
- package/dist/checks/quality/api/zod-openapi-sync.d.ts +13 -0
- package/dist/checks/quality/api/zod-openapi-sync.d.ts.map +1 -0
- package/dist/checks/quality/api/zod-openapi-sync.js +88 -0
- package/dist/checks/quality/api/zod-openapi-sync.js.map +1 -0
- package/dist/checks/quality/code-structure/dead-code.d.ts +12 -0
- package/dist/checks/quality/code-structure/dead-code.d.ts.map +1 -0
- package/dist/checks/quality/code-structure/dead-code.js +238 -0
- package/dist/checks/quality/code-structure/dead-code.js.map +1 -0
- package/dist/checks/quality/code-structure/index.d.ts +5 -0
- package/dist/checks/quality/code-structure/index.d.ts.map +1 -0
- package/dist/checks/quality/code-structure/index.js +5 -0
- package/dist/checks/quality/code-structure/index.js.map +1 -0
- package/dist/checks/quality/code-structure/no-ai-attribution.d.ts +25 -0
- package/dist/checks/quality/code-structure/no-ai-attribution.d.ts.map +1 -0
- package/dist/checks/quality/code-structure/no-ai-attribution.js +76 -0
- package/dist/checks/quality/code-structure/no-ai-attribution.js.map +1 -0
- package/dist/checks/quality/code-structure/no-console-log.d.ts +17 -0
- package/dist/checks/quality/code-structure/no-console-log.d.ts.map +1 -0
- package/dist/checks/quality/code-structure/no-console-log.js +106 -0
- package/dist/checks/quality/code-structure/no-console-log.js.map +1 -0
- package/dist/checks/quality/code-structure/no-process-artifacts.d.ts +25 -0
- package/dist/checks/quality/code-structure/no-process-artifacts.d.ts.map +1 -0
- package/dist/checks/quality/code-structure/no-process-artifacts.js +104 -0
- package/dist/checks/quality/code-structure/no-process-artifacts.js.map +1 -0
- package/dist/checks/quality/dependency-version-consistency.d.ts +20 -0
- package/dist/checks/quality/dependency-version-consistency.d.ts.map +1 -0
- package/dist/checks/quality/dependency-version-consistency.js +266 -0
- package/dist/checks/quality/dependency-version-consistency.js.map +1 -0
- package/dist/checks/quality/fitness-ignore-hygiene.d.ts +10 -0
- package/dist/checks/quality/fitness-ignore-hygiene.d.ts.map +1 -0
- package/dist/checks/quality/fitness-ignore-hygiene.js +93 -0
- package/dist/checks/quality/fitness-ignore-hygiene.js.map +1 -0
- package/dist/checks/quality/frontend/expo-vector-icons.d.ts +13 -0
- package/dist/checks/quality/frontend/expo-vector-icons.d.ts.map +1 -0
- package/dist/checks/quality/frontend/expo-vector-icons.js +80 -0
- package/dist/checks/quality/frontend/expo-vector-icons.js.map +1 -0
- package/dist/checks/quality/frontend/image-optimization.d.ts +13 -0
- package/dist/checks/quality/frontend/image-optimization.d.ts.map +1 -0
- package/dist/checks/quality/frontend/image-optimization.js +166 -0
- package/dist/checks/quality/frontend/image-optimization.js.map +1 -0
- package/dist/checks/quality/frontend/index.d.ts +4 -0
- package/dist/checks/quality/frontend/index.d.ts.map +1 -0
- package/dist/checks/quality/frontend/index.js +4 -0
- package/dist/checks/quality/frontend/index.js.map +1 -0
- package/dist/checks/quality/frontend/navigation-typing.d.ts +12 -0
- package/dist/checks/quality/frontend/navigation-typing.d.ts.map +1 -0
- package/dist/checks/quality/frontend/navigation-typing.js +77 -0
- package/dist/checks/quality/frontend/navigation-typing.js.map +1 -0
- package/dist/checks/quality/graph-ignore-hygiene.d.ts +10 -0
- package/dist/checks/quality/graph-ignore-hygiene.d.ts.map +1 -0
- package/dist/checks/quality/graph-ignore-hygiene.js +95 -0
- package/dist/checks/quality/graph-ignore-hygiene.js.map +1 -0
- package/dist/checks/quality/graph-ignore-hygiene.test.d.ts +14 -0
- package/dist/checks/quality/graph-ignore-hygiene.test.d.ts.map +1 -0
- package/dist/checks/quality/graph-ignore-hygiene.test.js +58 -0
- package/dist/checks/quality/graph-ignore-hygiene.test.js.map +1 -0
- package/dist/checks/quality/index.d.ts +16 -0
- package/dist/checks/quality/index.d.ts.map +1 -0
- package/dist/checks/quality/index.js +16 -0
- package/dist/checks/quality/index.js.map +1 -0
- package/dist/checks/quality/linting/eslint-justifications.d.ts +12 -0
- package/dist/checks/quality/linting/eslint-justifications.d.ts.map +1 -0
- package/dist/checks/quality/linting/eslint-justifications.js +328 -0
- package/dist/checks/quality/linting/eslint-justifications.js.map +1 -0
- package/dist/checks/quality/linting/index.d.ts +4 -0
- package/dist/checks/quality/linting/index.d.ts.map +1 -0
- package/dist/checks/quality/linting/index.js +4 -0
- package/dist/checks/quality/linting/index.js.map +1 -0
- package/dist/checks/quality/linting/semgrep-justifications.d.ts +16 -0
- package/dist/checks/quality/linting/semgrep-justifications.d.ts.map +1 -0
- package/dist/checks/quality/linting/semgrep-justifications.js +229 -0
- package/dist/checks/quality/linting/semgrep-justifications.js.map +1 -0
- package/dist/checks/quality/linting/typescript-directive-hygiene.d.ts +12 -0
- package/dist/checks/quality/linting/typescript-directive-hygiene.d.ts.map +1 -0
- package/dist/checks/quality/linting/typescript-directive-hygiene.js +142 -0
- package/dist/checks/quality/linting/typescript-directive-hygiene.js.map +1 -0
- package/dist/checks/quality/no-compatibility-layer-names.d.ts +13 -0
- package/dist/checks/quality/no-compatibility-layer-names.d.ts.map +1 -0
- package/dist/checks/quality/no-compatibility-layer-names.js +100 -0
- package/dist/checks/quality/no-compatibility-layer-names.js.map +1 -0
- package/dist/checks/quality/no-deprecated-tags.d.ts +11 -0
- package/dist/checks/quality/no-deprecated-tags.d.ts.map +1 -0
- package/dist/checks/quality/no-deprecated-tags.js +76 -0
- package/dist/checks/quality/no-deprecated-tags.js.map +1 -0
- package/dist/checks/quality/no-markdown-references.d.ts +16 -0
- package/dist/checks/quality/no-markdown-references.d.ts.map +1 -0
- package/dist/checks/quality/no-markdown-references.js +145 -0
- package/dist/checks/quality/no-markdown-references.js.map +1 -0
- package/dist/checks/quality/no-raw-regex-on-code.d.ts +9 -0
- package/dist/checks/quality/no-raw-regex-on-code.d.ts.map +1 -0
- package/dist/checks/quality/no-raw-regex-on-code.js +61 -0
- package/dist/checks/quality/no-raw-regex-on-code.js.map +1 -0
- package/dist/checks/quality/no-temporary-workarounds.d.ts +11 -0
- package/dist/checks/quality/no-temporary-workarounds.d.ts.map +1 -0
- package/dist/checks/quality/no-temporary-workarounds.js +69 -0
- package/dist/checks/quality/no-temporary-workarounds.js.map +1 -0
- package/dist/checks/quality/no-window-alert.d.ts +19 -0
- package/dist/checks/quality/no-window-alert.d.ts.map +1 -0
- package/dist/checks/quality/no-window-alert.js +74 -0
- package/dist/checks/quality/no-window-alert.js.map +1 -0
- package/dist/checks/quality/observability/index.d.ts +2 -0
- package/dist/checks/quality/observability/index.d.ts.map +1 -0
- package/dist/checks/quality/observability/index.js +2 -0
- package/dist/checks/quality/observability/index.js.map +1 -0
- package/dist/checks/quality/observability/pino-serializer-coverage.d.ts +15 -0
- package/dist/checks/quality/observability/pino-serializer-coverage.d.ts.map +1 -0
- package/dist/checks/quality/observability/pino-serializer-coverage.js +209 -0
- package/dist/checks/quality/observability/pino-serializer-coverage.js.map +1 -0
- package/dist/checks/quality/patterns/async-state-pattern.d.ts +14 -0
- package/dist/checks/quality/patterns/async-state-pattern.d.ts.map +1 -0
- package/dist/checks/quality/patterns/async-state-pattern.js +80 -0
- package/dist/checks/quality/patterns/async-state-pattern.js.map +1 -0
- package/dist/checks/quality/patterns/index.d.ts +4 -0
- package/dist/checks/quality/patterns/index.d.ts.map +1 -0
- package/dist/checks/quality/patterns/index.js +4 -0
- package/dist/checks/quality/patterns/index.js.map +1 -0
- package/dist/checks/quality/patterns/no-non-null-assertions.d.ts +10 -0
- package/dist/checks/quality/patterns/no-non-null-assertions.d.ts.map +1 -0
- package/dist/checks/quality/patterns/no-non-null-assertions.js +97 -0
- package/dist/checks/quality/patterns/no-non-null-assertions.js.map +1 -0
- package/dist/checks/quality/patterns/performance-anti-patterns.d.ts +16 -0
- package/dist/checks/quality/patterns/performance-anti-patterns.d.ts.map +1 -0
- package/dist/checks/quality/patterns/performance-anti-patterns.js +239 -0
- package/dist/checks/quality/patterns/performance-anti-patterns.js.map +1 -0
- package/dist/checks/resilience/_helpers/config-validation.d.ts +27 -0
- package/dist/checks/resilience/_helpers/config-validation.d.ts.map +1 -0
- package/dist/checks/resilience/_helpers/config-validation.js +61 -0
- package/dist/checks/resilience/_helpers/config-validation.js.map +1 -0
- package/dist/checks/resilience/batch-operations.d.ts +22 -0
- package/dist/checks/resilience/batch-operations.d.ts.map +1 -0
- package/dist/checks/resilience/batch-operations.js +422 -0
- package/dist/checks/resilience/batch-operations.js.map +1 -0
- package/dist/checks/resilience/cache-ttl-validation.d.ts +13 -0
- package/dist/checks/resilience/cache-ttl-validation.d.ts.map +1 -0
- package/dist/checks/resilience/cache-ttl-validation.js +222 -0
- package/dist/checks/resilience/cache-ttl-validation.js.map +1 -0
- package/dist/checks/resilience/catch-clause-safety.d.ts +12 -0
- package/dist/checks/resilience/catch-clause-safety.d.ts.map +1 -0
- package/dist/checks/resilience/catch-clause-safety.js +110 -0
- package/dist/checks/resilience/catch-clause-safety.js.map +1 -0
- package/dist/checks/resilience/dangerous-config-defaults.d.ts +11 -0
- package/dist/checks/resilience/dangerous-config-defaults.d.ts.map +1 -0
- package/dist/checks/resilience/dangerous-config-defaults.js +304 -0
- package/dist/checks/resilience/dangerous-config-defaults.js.map +1 -0
- package/dist/checks/resilience/error-code-registration.d.ts +11 -0
- package/dist/checks/resilience/error-code-registration.d.ts.map +1 -0
- package/dist/checks/resilience/error-code-registration.js +88 -0
- package/dist/checks/resilience/error-code-registration.js.map +1 -0
- package/dist/checks/resilience/event-patterns.d.ts +21 -0
- package/dist/checks/resilience/event-patterns.d.ts.map +1 -0
- package/dist/checks/resilience/event-patterns.js +232 -0
- package/dist/checks/resilience/event-patterns.js.map +1 -0
- package/dist/checks/resilience/exit-code-correctness.d.ts +12 -0
- package/dist/checks/resilience/exit-code-correctness.d.ts.map +1 -0
- package/dist/checks/resilience/exit-code-correctness.js +107 -0
- package/dist/checks/resilience/exit-code-correctness.js.map +1 -0
- package/dist/checks/resilience/index.d.ts +18 -0
- package/dist/checks/resilience/index.d.ts.map +1 -0
- package/dist/checks/resilience/index.js +18 -0
- package/dist/checks/resilience/index.js.map +1 -0
- package/dist/checks/resilience/no-hardcoded-timeouts.d.ts +10 -0
- package/dist/checks/resilience/no-hardcoded-timeouts.d.ts.map +1 -0
- package/dist/checks/resilience/no-hardcoded-timeouts.js +291 -0
- package/dist/checks/resilience/no-hardcoded-timeouts.js.map +1 -0
- package/dist/checks/resilience/no-process-exit-in-finally.d.ts +11 -0
- package/dist/checks/resilience/no-process-exit-in-finally.d.ts.map +1 -0
- package/dist/checks/resilience/no-process-exit-in-finally.js +89 -0
- package/dist/checks/resilience/no-process-exit-in-finally.js.map +1 -0
- package/dist/checks/resilience/readline-cleanup.d.ts +11 -0
- package/dist/checks/resilience/readline-cleanup.d.ts.map +1 -0
- package/dist/checks/resilience/readline-cleanup.js +107 -0
- package/dist/checks/resilience/readline-cleanup.js.map +1 -0
- package/dist/checks/resilience/recovery-patterns.d.ts +25 -0
- package/dist/checks/resilience/recovery-patterns.d.ts.map +1 -0
- package/dist/checks/resilience/recovery-patterns.js +273 -0
- package/dist/checks/resilience/recovery-patterns.js.map +1 -0
- package/dist/checks/resilience/reentrancy-guard.d.ts +12 -0
- package/dist/checks/resilience/reentrancy-guard.d.ts.map +1 -0
- package/dist/checks/resilience/reentrancy-guard.js +86 -0
- package/dist/checks/resilience/reentrancy-guard.js.map +1 -0
- package/dist/checks/resilience/retry-config-validation.d.ts +13 -0
- package/dist/checks/resilience/retry-config-validation.d.ts.map +1 -0
- package/dist/checks/resilience/retry-config-validation.js +159 -0
- package/dist/checks/resilience/retry-config-validation.js.map +1 -0
- package/dist/checks/resilience/sentry/_helpers/sentry.d.ts +25 -0
- package/dist/checks/resilience/sentry/_helpers/sentry.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/_helpers/sentry.js +68 -0
- package/dist/checks/resilience/sentry/_helpers/sentry.js.map +1 -0
- package/dist/checks/resilience/sentry/index.d.ts +8 -0
- package/dist/checks/resilience/sentry/index.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/index.js +8 -0
- package/dist/checks/resilience/sentry/index.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-dsn-configured.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-dsn-configured.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-dsn-configured.js +55 -0
- package/dist/checks/resilience/sentry/sentry-dsn-configured.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-environment-set.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-environment-set.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-environment-set.js +51 -0
- package/dist/checks/resilience/sentry/sentry-environment-set.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-error-boundary.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-error-boundary.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-error-boundary.js +75 -0
- package/dist/checks/resilience/sentry/sentry-error-boundary.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-pii-scrubbing.d.ts +13 -0
- package/dist/checks/resilience/sentry/sentry-pii-scrubbing.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-pii-scrubbing.js +125 -0
- package/dist/checks/resilience/sentry/sentry-pii-scrubbing.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-release-set.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-release-set.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-release-set.js +51 -0
- package/dist/checks/resilience/sentry/sentry-release-set.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-sample-rate.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-sample-rate.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-sample-rate.js +78 -0
- package/dist/checks/resilience/sentry/sentry-sample-rate.js.map +1 -0
- package/dist/checks/resilience/sentry/sentry-source-maps.d.ts +12 -0
- package/dist/checks/resilience/sentry/sentry-source-maps.d.ts.map +1 -0
- package/dist/checks/resilience/sentry/sentry-source-maps.js +83 -0
- package/dist/checks/resilience/sentry/sentry-source-maps.js.map +1 -0
- package/dist/checks/resilience/service-patterns.d.ts +18 -0
- package/dist/checks/resilience/service-patterns.d.ts.map +1 -0
- package/dist/checks/resilience/service-patterns.js +230 -0
- package/dist/checks/resilience/service-patterns.js.map +1 -0
- package/dist/checks/resilience/timer-lifecycle.d.ts +10 -0
- package/dist/checks/resilience/timer-lifecycle.d.ts.map +1 -0
- package/dist/checks/resilience/timer-lifecycle.js +78 -0
- package/dist/checks/resilience/timer-lifecycle.js.map +1 -0
- package/dist/checks/resilience/transaction-patterns.d.ts +21 -0
- package/dist/checks/resilience/transaction-patterns.d.ts.map +1 -0
- package/dist/checks/resilience/transaction-patterns.js +258 -0
- package/dist/checks/resilience/transaction-patterns.js.map +1 -0
- package/dist/checks/security/__tests__/no-hardcoded-secrets.test.d.ts +9 -0
- package/dist/checks/security/__tests__/no-hardcoded-secrets.test.d.ts.map +1 -0
- package/dist/checks/security/__tests__/no-hardcoded-secrets.test.js +37 -0
- package/dist/checks/security/__tests__/no-hardcoded-secrets.test.js.map +1 -0
- package/dist/checks/security/__tests__/package-supply-chain-policy.test.d.ts +2 -0
- package/dist/checks/security/__tests__/package-supply-chain-policy.test.d.ts.map +1 -0
- package/dist/checks/security/__tests__/package-supply-chain-policy.test.js +128 -0
- package/dist/checks/security/__tests__/package-supply-chain-policy.test.js.map +1 -0
- package/dist/checks/security/api-key-rotation.d.ts +10 -0
- package/dist/checks/security/api-key-rotation.d.ts.map +1 -0
- package/dist/checks/security/api-key-rotation.js +186 -0
- package/dist/checks/security/api-key-rotation.js.map +1 -0
- package/dist/checks/security/auth-middleware-coverage.d.ts +11 -0
- package/dist/checks/security/auth-middleware-coverage.d.ts.map +1 -0
- package/dist/checks/security/auth-middleware-coverage.js +210 -0
- package/dist/checks/security/auth-middleware-coverage.js.map +1 -0
- package/dist/checks/security/auth-route-guard.d.ts +12 -0
- package/dist/checks/security/auth-route-guard.d.ts.map +1 -0
- package/dist/checks/security/auth-route-guard.js +70 -0
- package/dist/checks/security/auth-route-guard.js.map +1 -0
- package/dist/checks/security/cors-configuration.d.ts +11 -0
- package/dist/checks/security/cors-configuration.d.ts.map +1 -0
- package/dist/checks/security/cors-configuration.js +126 -0
- package/dist/checks/security/cors-configuration.js.map +1 -0
- package/dist/checks/security/csp-headers.d.ts +11 -0
- package/dist/checks/security/csp-headers.d.ts.map +1 -0
- package/dist/checks/security/csp-headers.js +192 -0
- package/dist/checks/security/csp-headers.js.map +1 -0
- package/dist/checks/security/dependency-vulnerability-audit.d.ts +15 -0
- package/dist/checks/security/dependency-vulnerability-audit.d.ts.map +1 -0
- package/dist/checks/security/dependency-vulnerability-audit.js +184 -0
- package/dist/checks/security/dependency-vulnerability-audit.js.map +1 -0
- package/dist/checks/security/env-secret-exposure.d.ts +11 -0
- package/dist/checks/security/env-secret-exposure.d.ts.map +1 -0
- package/dist/checks/security/env-secret-exposure.js +127 -0
- package/dist/checks/security/env-secret-exposure.js.map +1 -0
- package/dist/checks/security/hasura-production-config.d.ts +11 -0
- package/dist/checks/security/hasura-production-config.d.ts.map +1 -0
- package/dist/checks/security/hasura-production-config.js +122 -0
- package/dist/checks/security/hasura-production-config.js.map +1 -0
- package/dist/checks/security/index.d.ts +17 -0
- package/dist/checks/security/index.d.ts.map +1 -0
- package/dist/checks/security/index.js +17 -0
- package/dist/checks/security/index.js.map +1 -0
- package/dist/checks/security/jwt-validation.d.ts +11 -0
- package/dist/checks/security/jwt-validation.d.ts.map +1 -0
- package/dist/checks/security/jwt-validation.js +294 -0
- package/dist/checks/security/jwt-validation.js.map +1 -0
- package/dist/checks/security/no-eval.d.ts +16 -0
- package/dist/checks/security/no-eval.d.ts.map +1 -0
- package/dist/checks/security/no-eval.js +83 -0
- package/dist/checks/security/no-eval.js.map +1 -0
- package/dist/checks/security/no-hardcoded-secrets.d.ts +28 -0
- package/dist/checks/security/no-hardcoded-secrets.d.ts.map +1 -0
- package/dist/checks/security/no-hardcoded-secrets.js +209 -0
- package/dist/checks/security/no-hardcoded-secrets.js.map +1 -0
- package/dist/checks/security/package-supply-chain-policy.d.ts +12 -0
- package/dist/checks/security/package-supply-chain-policy.d.ts.map +1 -0
- package/dist/checks/security/package-supply-chain-policy.js +534 -0
- package/dist/checks/security/package-supply-chain-policy.js.map +1 -0
- package/dist/checks/security/rate-limit-coverage.d.ts +10 -0
- package/dist/checks/security/rate-limit-coverage.d.ts.map +1 -0
- package/dist/checks/security/rate-limit-coverage.js +143 -0
- package/dist/checks/security/rate-limit-coverage.js.map +1 -0
- package/dist/checks/security/semgrep-scan.d.ts +13 -0
- package/dist/checks/security/semgrep-scan.d.ts.map +1 -0
- package/dist/checks/security/semgrep-scan.js +86 -0
- package/dist/checks/security/semgrep-scan.js.map +1 -0
- package/dist/checks/security/use-centralized-crypto.d.ts +11 -0
- package/dist/checks/security/use-centralized-crypto.d.ts.map +1 -0
- package/dist/checks/security/use-centralized-crypto.js +129 -0
- package/dist/checks/security/use-centralized-crypto.js.map +1 -0
- package/dist/checks/security/webhook-signature-verification.d.ts +10 -0
- package/dist/checks/security/webhook-signature-verification.d.ts.map +1 -0
- package/dist/checks/security/webhook-signature-verification.js +183 -0
- package/dist/checks/security/webhook-signature-verification.js.map +1 -0
- package/dist/checks/testing/index.d.ts +6 -0
- package/dist/checks/testing/index.d.ts.map +1 -0
- package/dist/checks/testing/index.js +6 -0
- package/dist/checks/testing/index.js.map +1 -0
- package/dist/checks/testing/no-skipped-tests.d.ts +40 -0
- package/dist/checks/testing/no-skipped-tests.d.ts.map +1 -0
- package/dist/checks/testing/no-skipped-tests.js +174 -0
- package/dist/checks/testing/no-skipped-tests.js.map +1 -0
- package/dist/checks/testing/no-stub-tests.d.ts +11 -0
- package/dist/checks/testing/no-stub-tests.d.ts.map +1 -0
- package/dist/checks/testing/no-stub-tests.js +103 -0
- package/dist/checks/testing/no-stub-tests.js.map +1 -0
- package/dist/checks/testing/test-convention-consistency.d.ts +14 -0
- package/dist/checks/testing/test-convention-consistency.d.ts.map +1 -0
- package/dist/checks/testing/test-convention-consistency.js +93 -0
- package/dist/checks/testing/test-convention-consistency.js.map +1 -0
- package/dist/checks/testing/test-file-naming.d.ts +13 -0
- package/dist/checks/testing/test-file-naming.d.ts.map +1 -0
- package/dist/checks/testing/test-file-naming.js +218 -0
- package/dist/checks/testing/test-file-naming.js.map +1 -0
- package/dist/checks/testing/test-file-pairing.d.ts +13 -0
- package/dist/checks/testing/test-file-pairing.d.ts.map +1 -0
- package/dist/checks/testing/test-file-pairing.js +274 -0
- package/dist/checks/testing/test-file-pairing.js.map +1 -0
- package/dist/display/architecture.d.ts +9 -0
- package/dist/display/architecture.d.ts.map +1 -0
- package/dist/display/architecture.js +29 -0
- package/dist/display/architecture.js.map +1 -0
- package/dist/display/index.d.ts +20 -0
- package/dist/display/index.d.ts.map +1 -0
- package/dist/display/index.js +30 -0
- package/dist/display/index.js.map +1 -0
- package/dist/display/quality.d.ts +7 -0
- package/dist/display/quality.d.ts.map +1 -0
- package/dist/display/quality.js +34 -0
- package/dist/display/quality.js.map +1 -0
- package/dist/display/resilience.d.ts +7 -0
- package/dist/display/resilience.d.ts.map +1 -0
- package/dist/display/resilience.js +36 -0
- package/dist/display/resilience.js.map +1 -0
- package/dist/display/security-testing.d.ts +9 -0
- package/dist/display/security-testing.d.ts.map +1 -0
- package/dist/display/security-testing.js +31 -0
- package/dist/display/security-testing.js.map +1 -0
- package/dist/display/types.d.ts +6 -0
- package/dist/display/types.d.ts.map +1 -0
- package/dist/display/types.js +6 -0
- package/dist/display/types.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/package.json +52 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unit tests for the `tool-has-manifest` guardrail.
|
|
3
|
+
*
|
|
4
|
+
* Two layers:
|
|
5
|
+
* 1. The pure `analyzeToolHasManifest(pkg, filePath)` detector — exercised
|
|
6
|
+
* with in-memory parsed package.json objects (a conformant manifest → 0
|
|
7
|
+
* findings; each missing/invalid field → a finding).
|
|
8
|
+
* 2. The full `analyzeAll` over a fake in-memory `FileAccessor` — proves the
|
|
9
|
+
* self-targeting (only `kind:'tool'` package.json files are inspected;
|
|
10
|
+
* non-tool packages and non-package.json files are ignored) and the
|
|
11
|
+
* malformed-JSON skip.
|
|
12
|
+
*/
|
|
13
|
+
import { describe, expect, it } from 'vitest';
|
|
14
|
+
import { analyzeAllToolManifests, analyzeToolHasManifest } from '../tool-has-manifest.js';
|
|
15
|
+
const CONFORMANT = {
|
|
16
|
+
opensipTools: {
|
|
17
|
+
kind: 'tool',
|
|
18
|
+
id: 'fitness',
|
|
19
|
+
apiVersion: 1,
|
|
20
|
+
commands: [
|
|
21
|
+
{ name: 'fit', description: 'Run fitness checks' },
|
|
22
|
+
{ name: 'fit-list', description: 'List checks', aliases: ['checks'] },
|
|
23
|
+
],
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
const FILE = '/repo/packages/fitness/engine/package.json';
|
|
27
|
+
describe('analyzeToolHasManifest (pure detector)', () => {
|
|
28
|
+
it('returns 0 findings for a conformant tool manifest', () => {
|
|
29
|
+
expect(analyzeToolHasManifest(CONFORMANT, FILE)).toEqual([]);
|
|
30
|
+
});
|
|
31
|
+
it('returns 0 findings for a non-tool package (no opensipTools)', () => {
|
|
32
|
+
expect(analyzeToolHasManifest({}, FILE)).toEqual([]);
|
|
33
|
+
});
|
|
34
|
+
it('returns 0 findings for a package whose opensipTools.kind is not "tool"', () => {
|
|
35
|
+
expect(analyzeToolHasManifest({ opensipTools: { kind: 'fit-pack', id: 'x', commands: [] } }, FILE)).toEqual([]);
|
|
36
|
+
});
|
|
37
|
+
it('flags a missing id', () => {
|
|
38
|
+
const v = analyzeToolHasManifest({
|
|
39
|
+
opensipTools: { kind: 'tool', apiVersion: 1, commands: [{ name: 'x', description: 'y' }] },
|
|
40
|
+
}, FILE);
|
|
41
|
+
expect(v).toHaveLength(1);
|
|
42
|
+
expect(v[0]?.type).toBe('manifest-id');
|
|
43
|
+
expect(v[0]?.severity).toBe('error');
|
|
44
|
+
});
|
|
45
|
+
it('flags an empty id', () => {
|
|
46
|
+
const v = analyzeToolHasManifest({
|
|
47
|
+
opensipTools: {
|
|
48
|
+
kind: 'tool',
|
|
49
|
+
id: '',
|
|
50
|
+
apiVersion: 1,
|
|
51
|
+
commands: [{ name: 'x', description: 'y' }],
|
|
52
|
+
},
|
|
53
|
+
}, FILE);
|
|
54
|
+
expect(v.map((x) => x.type)).toContain('manifest-id');
|
|
55
|
+
});
|
|
56
|
+
it('flags a missing apiVersion', () => {
|
|
57
|
+
const v = analyzeToolHasManifest({
|
|
58
|
+
opensipTools: { kind: 'tool', id: 'fitness', commands: [{ name: 'x', description: 'y' }] },
|
|
59
|
+
}, FILE);
|
|
60
|
+
expect(v).toHaveLength(1);
|
|
61
|
+
expect(v[0]?.type).toBe('manifest-apiVersion');
|
|
62
|
+
});
|
|
63
|
+
it('flags a non-numeric apiVersion', () => {
|
|
64
|
+
const v = analyzeToolHasManifest({
|
|
65
|
+
opensipTools: {
|
|
66
|
+
kind: 'tool',
|
|
67
|
+
id: 'fitness',
|
|
68
|
+
apiVersion: 'one',
|
|
69
|
+
commands: [{ name: 'x', description: 'y' }],
|
|
70
|
+
},
|
|
71
|
+
}, FILE);
|
|
72
|
+
expect(v.map((x) => x.type)).toContain('manifest-apiVersion');
|
|
73
|
+
});
|
|
74
|
+
it('flags missing commands', () => {
|
|
75
|
+
const v = analyzeToolHasManifest({ opensipTools: { kind: 'tool', id: 'fitness', apiVersion: 1 } }, FILE);
|
|
76
|
+
expect(v).toHaveLength(1);
|
|
77
|
+
expect(v[0]?.type).toBe('manifest-commands');
|
|
78
|
+
});
|
|
79
|
+
it('flags an empty commands array', () => {
|
|
80
|
+
const v = analyzeToolHasManifest({ opensipTools: { kind: 'tool', id: 'fitness', apiVersion: 1, commands: [] } }, FILE);
|
|
81
|
+
expect(v).toHaveLength(1);
|
|
82
|
+
expect(v[0]?.type).toBe('manifest-commands');
|
|
83
|
+
});
|
|
84
|
+
it('flags a command entry missing a name', () => {
|
|
85
|
+
const v = analyzeToolHasManifest({
|
|
86
|
+
opensipTools: {
|
|
87
|
+
kind: 'tool',
|
|
88
|
+
id: 'fitness',
|
|
89
|
+
apiVersion: 1,
|
|
90
|
+
commands: [{ description: 'no name' }],
|
|
91
|
+
},
|
|
92
|
+
}, FILE);
|
|
93
|
+
expect(v.map((x) => x.type)).toContain('manifest-commands');
|
|
94
|
+
});
|
|
95
|
+
it('flags a command entry missing a description', () => {
|
|
96
|
+
const v = analyzeToolHasManifest({
|
|
97
|
+
opensipTools: {
|
|
98
|
+
kind: 'tool',
|
|
99
|
+
id: 'fitness',
|
|
100
|
+
apiVersion: 1,
|
|
101
|
+
commands: [{ name: 'fit' }],
|
|
102
|
+
},
|
|
103
|
+
}, FILE);
|
|
104
|
+
expect(v.map((x) => x.type)).toContain('manifest-commands');
|
|
105
|
+
});
|
|
106
|
+
it('accumulates findings across several invalid fields', () => {
|
|
107
|
+
const v = analyzeToolHasManifest({ opensipTools: { kind: 'tool' } }, FILE);
|
|
108
|
+
const types = new Set(v.map((x) => x.type));
|
|
109
|
+
expect(types).toEqual(new Set(['manifest-id', 'manifest-apiVersion', 'manifest-commands']));
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
/** Build a fake FileAccessor over an in-memory path→content map. */
|
|
113
|
+
function fakeAccessor(files) {
|
|
114
|
+
return {
|
|
115
|
+
paths: Object.keys(files),
|
|
116
|
+
read: (p) => Promise.resolve(files[p] ?? ''),
|
|
117
|
+
readMany: (ps) => Promise.resolve(new Map(ps.map((p) => [p, files[p] ?? '']))),
|
|
118
|
+
readAll: () => Promise.resolve(new Map(Object.entries(files))),
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
describe('analyzeAllToolManifests (self-targeting over the file set)', () => {
|
|
122
|
+
it('returns 0 findings when every tool package is conformant', async () => {
|
|
123
|
+
const files = {
|
|
124
|
+
'/repo/packages/fitness/engine/package.json': JSON.stringify(CONFORMANT),
|
|
125
|
+
// a non-tool package — ignored
|
|
126
|
+
'/repo/packages/core/package.json': JSON.stringify({ name: '@x/core' }),
|
|
127
|
+
// a non-package.json file in the set — ignored
|
|
128
|
+
'/repo/src/index.ts': 'export const x = 1',
|
|
129
|
+
};
|
|
130
|
+
const v = await analyzeAllToolManifests(fakeAccessor(files));
|
|
131
|
+
expect(v).toEqual([]);
|
|
132
|
+
});
|
|
133
|
+
it('flags a tool package with a broken manifest, ignoring non-tool packages', async () => {
|
|
134
|
+
const files = {
|
|
135
|
+
'/repo/packages/fitness/engine/package.json': JSON.stringify(CONFORMANT),
|
|
136
|
+
'/repo/packages/graph/engine/package.json': JSON.stringify({
|
|
137
|
+
opensipTools: { kind: 'tool', id: 'graph' /* no apiVersion, no commands */ },
|
|
138
|
+
}),
|
|
139
|
+
'/repo/packages/core/package.json': JSON.stringify({ name: '@x/core' }),
|
|
140
|
+
};
|
|
141
|
+
const v = await analyzeAllToolManifests(fakeAccessor(files));
|
|
142
|
+
expect(v.length).toBeGreaterThanOrEqual(2);
|
|
143
|
+
expect(v.every((x) => x.filePath === '/repo/packages/graph/engine/package.json')).toBe(true);
|
|
144
|
+
expect(new Set(v.map((x) => x.type))).toEqual(new Set(['manifest-apiVersion', 'manifest-commands']));
|
|
145
|
+
});
|
|
146
|
+
it('skips a malformed package.json without throwing', async () => {
|
|
147
|
+
const files = { '/repo/packages/x/package.json': '{ not valid json' };
|
|
148
|
+
const v = await analyzeAllToolManifests(fakeAccessor(files));
|
|
149
|
+
expect(v).toEqual([]);
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
//# sourceMappingURL=tool-has-manifest.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-has-manifest.test.js","sourceRoot":"","sources":["../../../../src/checks/architecture/__tests__/tool-has-manifest.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest-config-required-with-tests.test.d.ts","sourceRoot":"","sources":["../../../../src/checks/architecture/__tests__/vitest-config-required-with-tests.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unit tests for the `vitest-config-required-with-tests` check.
|
|
3
|
+
*
|
|
4
|
+
* Two layers:
|
|
5
|
+
* 1. The pure `detectMissingVitestConfig` detector, exercised with an
|
|
6
|
+
* injected in-memory filesystem port — deterministic, no disk, no mocks.
|
|
7
|
+
* 2. The default `nodeFsPort` exercised against the on-disk `__fixtures__`
|
|
8
|
+
* trees, validating the real recursive test-file scan and `existsSync`
|
|
9
|
+
* wiring end-to-end.
|
|
10
|
+
*
|
|
11
|
+
* The workspace root is DERIVED from the package paths (common ancestor +
|
|
12
|
+
* its parent), so the workspace-root-config cases use >=2 packages — that is
|
|
13
|
+
* the only shape in which a centralized config sits one level above the
|
|
14
|
+
* shared `packages/` ancestor.
|
|
15
|
+
*/
|
|
16
|
+
import * as path from 'node:path';
|
|
17
|
+
import { fileURLToPath } from 'node:url';
|
|
18
|
+
import { describe, expect, it } from 'vitest';
|
|
19
|
+
import { detectMissingVitestConfig, nodeFsPort, vitestConfigRequiredWithTests, } from '../vitest-config-required-with-tests.js';
|
|
20
|
+
const FIXTURES = path.join(path.dirname(fileURLToPath(import.meta.url)), '..', '__fixtures__', 'vitest-config-required-with-tests');
|
|
21
|
+
/**
|
|
22
|
+
* Build an in-memory port from a set of existing paths and a set of
|
|
23
|
+
* package dirs that contain test files.
|
|
24
|
+
*/
|
|
25
|
+
function fakePort(existing, withTests) {
|
|
26
|
+
return {
|
|
27
|
+
exists: (p) => existing.has(p),
|
|
28
|
+
hasTestFiles: (dir) => withTests.has(dir),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
const ROOT = '/repo';
|
|
32
|
+
describe('detectMissingVitestConfig (pure detector)', () => {
|
|
33
|
+
it('flags exactly the package that has tests but no vitest config', () => {
|
|
34
|
+
const goodPkg = `${ROOT}/packages/good/package.json`;
|
|
35
|
+
const badPkg = `${ROOT}/packages/bad/package.json`;
|
|
36
|
+
const port = fakePort(new Set([`${ROOT}/packages/good/vitest.config.ts`]), new Set([`${ROOT}/packages/good`, `${ROOT}/packages/bad`]));
|
|
37
|
+
const violations = detectMissingVitestConfig([goodPkg, badPkg], port);
|
|
38
|
+
expect(violations).toHaveLength(1);
|
|
39
|
+
expect(violations[0]?.filePath).toBe(badPkg);
|
|
40
|
+
expect(violations[0]?.severity).toBe('error');
|
|
41
|
+
expect(violations[0]?.line).toBe(1);
|
|
42
|
+
expect(violations[0]?.match).toBe('bad');
|
|
43
|
+
expect(violations[0]?.type).toBe('missing-vitest-config');
|
|
44
|
+
expect(violations[0]?.message).toContain('bad');
|
|
45
|
+
expect(violations[0]?.suggestion).toContain('vitest.config');
|
|
46
|
+
});
|
|
47
|
+
it('accepts a .mts package-root config', () => {
|
|
48
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
49
|
+
const m = `${ROOT}/packages/m/package.json`;
|
|
50
|
+
const port = fakePort(new Set([`${ROOT}/packages/a/vitest.config.ts`, `${ROOT}/packages/m/vitest.config.mts`]), new Set([`${ROOT}/packages/a`, `${ROOT}/packages/m`]));
|
|
51
|
+
expect(detectMissingVitestConfig([a, m], port)).toHaveLength(0);
|
|
52
|
+
});
|
|
53
|
+
it('does NOT flag a package that has NO test files (even without a config)', () => {
|
|
54
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
55
|
+
const lib = `${ROOT}/packages/lib/package.json`;
|
|
56
|
+
// `lib` has no config, but also no tests -> not a violation. `a` is a
|
|
57
|
+
// second package so the derived workspace root is `packages/` (no config).
|
|
58
|
+
const port = fakePort(new Set([`${ROOT}/packages/a/vitest.config.ts`]), new Set([`${ROOT}/packages/a`]));
|
|
59
|
+
expect(detectMissingVitestConfig([a, lib], port)).toHaveLength(0);
|
|
60
|
+
});
|
|
61
|
+
it('does NOT flag any package when a workspace-root vitest.config.ts exists', () => {
|
|
62
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
63
|
+
const bad = `${ROOT}/packages/bad/package.json`;
|
|
64
|
+
const port = fakePort(new Set([`${ROOT}/vitest.config.ts`]), // centralized config at repo root
|
|
65
|
+
new Set([`${ROOT}/packages/a`, `${ROOT}/packages/bad`]));
|
|
66
|
+
expect(detectMissingVitestConfig([a, bad], port)).toHaveLength(0);
|
|
67
|
+
});
|
|
68
|
+
it('treats a workspace-root vitest.workspace.ts as satisfying every package', () => {
|
|
69
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
70
|
+
const bad = `${ROOT}/packages/bad/package.json`;
|
|
71
|
+
const port = fakePort(new Set([`${ROOT}/vitest.workspace.ts`]), new Set([`${ROOT}/packages/a`, `${ROOT}/packages/bad`]));
|
|
72
|
+
expect(detectMissingVitestConfig([a, bad], port)).toHaveLength(0);
|
|
73
|
+
});
|
|
74
|
+
it('does NOT count tests as covered by a sibling package config', () => {
|
|
75
|
+
// `a` has a config; `bad` does not. A config under `a` must not satisfy
|
|
76
|
+
// `bad` — only a per-package or true workspace-root config counts.
|
|
77
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
78
|
+
const bad = `${ROOT}/packages/bad/package.json`;
|
|
79
|
+
const port = fakePort(new Set([`${ROOT}/packages/a/vitest.config.ts`]), new Set([`${ROOT}/packages/bad`]));
|
|
80
|
+
const violations = detectMissingVitestConfig([a, bad], port);
|
|
81
|
+
expect(violations).toHaveLength(1);
|
|
82
|
+
expect(violations[0]?.match).toBe('bad');
|
|
83
|
+
});
|
|
84
|
+
it('skips the workspace-root package.json itself (multi-package repo)', () => {
|
|
85
|
+
// The repo-root package.json reports tests but no config; it is not a
|
|
86
|
+
// leaf package and must not self-flag.
|
|
87
|
+
const rootPkg = `${ROOT}/package.json`;
|
|
88
|
+
const a = `${ROOT}/packages/a/package.json`;
|
|
89
|
+
const port = fakePort(new Set([`${ROOT}/packages/a/vitest.config.ts`]), new Set([ROOT, `${ROOT}/packages/a`]));
|
|
90
|
+
expect(detectMissingVitestConfig([rootPkg, a], port)).toHaveLength(0);
|
|
91
|
+
});
|
|
92
|
+
it('returns no violations for an empty package list', () => {
|
|
93
|
+
const port = fakePort(new Set(), new Set());
|
|
94
|
+
expect(detectMissingVitestConfig([], port)).toEqual([]);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
describe('nodeFsPort against on-disk fixtures', () => {
|
|
98
|
+
it('clean fixture (tests + config) yields no violation', () => {
|
|
99
|
+
const pkg = path.join(FIXTURES, 'clean', 'packages', 'x', 'package.json');
|
|
100
|
+
// hasTestFiles must find the nested src/sum.test.ts.
|
|
101
|
+
expect(nodeFsPort.hasTestFiles(path.dirname(pkg))).toBe(true);
|
|
102
|
+
expect(detectMissingVitestConfig([pkg], nodeFsPort)).toHaveLength(0);
|
|
103
|
+
});
|
|
104
|
+
it('violation fixture (tests, no config) yields exactly one violation', () => {
|
|
105
|
+
const pkg = path.join(FIXTURES, 'violation', 'packages', 'x', 'package.json');
|
|
106
|
+
expect(nodeFsPort.hasTestFiles(path.dirname(pkg))).toBe(true);
|
|
107
|
+
const violations = detectMissingVitestConfig([pkg], nodeFsPort);
|
|
108
|
+
expect(violations).toHaveLength(1);
|
|
109
|
+
expect(violations[0]?.filePath).toBe(pkg);
|
|
110
|
+
expect(violations[0]?.match).toBe('x');
|
|
111
|
+
});
|
|
112
|
+
it('hasTestFiles finds nested tests and exists() reflects real files', () => {
|
|
113
|
+
expect(nodeFsPort.hasTestFiles(path.join(FIXTURES, 'clean', 'packages', 'x', 'src'))).toBe(true);
|
|
114
|
+
expect(nodeFsPort.exists(path.join(FIXTURES, 'clean', 'packages', 'x', 'vitest.config.ts'))).toBe(true);
|
|
115
|
+
expect(nodeFsPort.exists(path.join(FIXTURES, 'clean', 'packages', 'x', 'nope.ts'))).toBe(false);
|
|
116
|
+
});
|
|
117
|
+
it('hasTestFiles returns false for an unreadable / nonexistent directory', () => {
|
|
118
|
+
expect(nodeFsPort.hasTestFiles(path.join(FIXTURES, 'does-not-exist'))).toBe(false);
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
describe('vitestConfigRequiredWithTests check descriptor', () => {
|
|
122
|
+
it('is registered as an analyzeAll check with the expected metadata', () => {
|
|
123
|
+
expect(vitestConfigRequiredWithTests.config.slug).toBe('vitest-config-required-with-tests');
|
|
124
|
+
expect(vitestConfigRequiredWithTests.config.id).toBe('b7363db9-c3f7-47bc-8c25-1ddeebf53904');
|
|
125
|
+
expect(vitestConfigRequiredWithTests.config.analysisMode).toBe('analyzeAll');
|
|
126
|
+
expect(vitestConfigRequiredWithTests.config.tags).toContain('testing');
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=vitest-config-required-with-tests.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest-config-required-with-tests.test.js","sourceRoot":"","sources":["../../../../src/checks/architecture/__tests__/vitest-config-required-with-tests.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EACL,yBAAyB,EACzB,UAAU,EACV,6BAA6B,GAE9B,MAAM,yCAAyC,CAAC;AAEjD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CACxB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAC5C,IAAI,EACJ,cAAc,EACd,mCAAmC,CACpC,CAAC;AAEF;;;GAGG;AACH,SAAS,QAAQ,CAAC,QAAqB,EAAE,SAAsB;IAC7D,OAAO;QACL,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9B,YAAY,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC;KAC1C,CAAC;AACJ,CAAC;AAED,MAAM,IAAI,GAAG,OAAO,CAAC;AAErB,QAAQ,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACzD,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,OAAO,GAAG,GAAG,IAAI,6BAA6B,CAAC;QACrD,MAAM,MAAM,GAAG,GAAG,IAAI,4BAA4B,CAAC;QACnD,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,iCAAiC,CAAC,CAAC,EACnD,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,gBAAgB,EAAE,GAAG,IAAI,eAAe,CAAC,CAAC,CAC3D,CAAC;QAEF,MAAM,UAAU,GAAG,yBAAyB,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC;QAEtE,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7C,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9C,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QAC1D,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAChD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,8BAA8B,EAAE,GAAG,IAAI,+BAA+B,CAAC,CAAC,EACxF,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,aAAa,EAAE,GAAG,IAAI,aAAa,CAAC,CAAC,CACtD,CAAC;QACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE,EAAE,GAAG,EAAE;QAChF,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,GAAG,GAAG,GAAG,IAAI,4BAA4B,CAAC;QAChD,sEAAsE;QACtE,2EAA2E;QAC3E,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,8BAA8B,CAAC,CAAC,EAChD,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,aAAa,CAAC,CAAC,CAChC,CAAC;QACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EAAE,GAAG,EAAE;QACjF,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,GAAG,GAAG,GAAG,IAAI,4BAA4B,CAAC;QAChD,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,mBAAmB,CAAC,CAAC,EAAE,kCAAkC;QACzE,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,aAAa,EAAE,GAAG,IAAI,eAAe,CAAC,CAAC,CACxD,CAAC;QACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EAAE,GAAG,EAAE;QACjF,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,GAAG,GAAG,GAAG,IAAI,4BAA4B,CAAC;QAChD,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,sBAAsB,CAAC,CAAC,EACxC,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,aAAa,EAAE,GAAG,IAAI,eAAe,CAAC,CAAC,CACxD,CAAC;QACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,wEAAwE;QACxE,mEAAmE;QACnE,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,GAAG,GAAG,GAAG,IAAI,4BAA4B,CAAC;QAChD,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,8BAA8B,CAAC,CAAC,EAChD,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,eAAe,CAAC,CAAC,CAClC,CAAC;QACF,MAAM,UAAU,GAAG,yBAAyB,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;QAC7D,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;QAC3E,sEAAsE;QACtE,uCAAuC;QACvC,MAAM,OAAO,GAAG,GAAG,IAAI,eAAe,CAAC;QACvC,MAAM,CAAC,GAAG,GAAG,IAAI,0BAA0B,CAAC;QAC5C,MAAM,IAAI,GAAG,QAAQ,CACnB,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,8BAA8B,CAAC,CAAC,EAChD,IAAI,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,IAAI,aAAa,CAAC,CAAC,CACtC,CAAC;QACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAC5C,MAAM,CAAC,yBAAyB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,qCAAqC,EAAE,GAAG,EAAE;IACnD,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;QAC1E,qDAAqD;QACrD,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9D,MAAM,CAAC,yBAAyB,CAAC,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;QAC3E,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,GAAG,EAAE,cAAc,CAAC,CAAC;QAC9E,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9D,MAAM,UAAU,GAAG,yBAAyB,CAAC,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,CAAC;QAChE,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1C,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kEAAkE,EAAE,GAAG,EAAE;QAC1E,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CACxF,IAAI,CACL,CAAC;QACF,MAAM,CACJ,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,kBAAkB,CAAC,CAAC,CACrF,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACb,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClG,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sEAAsE,EAAE,GAAG,EAAE;QAC9E,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,gDAAgD,EAAE,GAAG,EAAE;IAC9D,EAAE,CAAC,iEAAiE,EAAE,GAAG,EAAE;QACzE,MAAM,CAAC,6BAA6B,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;QAC5F,MAAM,CAAC,6BAA6B,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;QAC7F,MAAM,CAAC,6BAA6B,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7E,MAAM,CAAC,6BAA6B,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Shared helper for the two config-document architecture checks
|
|
3
|
+
* (`one-config-document`, `no-config-loader-outside-config`).
|
|
4
|
+
*
|
|
5
|
+
* Both checks must first identify which local identifiers in a file are bound to
|
|
6
|
+
* a parsed YAML document — only a namespace/block read OFF one of those counts
|
|
7
|
+
* as a config hand-projection; a read off a request object, `scope`, etc. is
|
|
8
|
+
* unrelated and ignored. The detection was byte-identical in both files (it
|
|
9
|
+
* tripped the graph `duplicated-function-body` rule), so it lives here once.
|
|
10
|
+
*
|
|
11
|
+
* Underscore-prefixed and absent from the check barrel (`index.ts`): this is an
|
|
12
|
+
* internal helper, not a `defineCheck` export.
|
|
13
|
+
*/
|
|
14
|
+
/**
|
|
15
|
+
* Identifiers bound to a parsed YAML document in this file — the result of a
|
|
16
|
+
* `const <id> = readYamlFile(...)` (or a sibling reader: `readYamlFileOrThrow`,
|
|
17
|
+
* `parseYaml`, `loadYaml`).
|
|
18
|
+
*
|
|
19
|
+
* @param content - the source text of the file under analysis.
|
|
20
|
+
* @returns the set of local binding names that hold a parsed YAML document.
|
|
21
|
+
*/
|
|
22
|
+
export declare function yamlDocBindings(content: string): Set<string>;
|
|
23
|
+
//# sourceMappingURL=_yaml-doc-bindings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_yaml-doc-bindings.d.ts","sourceRoot":"","sources":["../../../src/checks/architecture/_yaml-doc-bindings.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH;;;;;;;GAOG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAM5D"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Shared helper for the two config-document architecture checks
|
|
3
|
+
* (`one-config-document`, `no-config-loader-outside-config`).
|
|
4
|
+
*
|
|
5
|
+
* Both checks must first identify which local identifiers in a file are bound to
|
|
6
|
+
* a parsed YAML document — only a namespace/block read OFF one of those counts
|
|
7
|
+
* as a config hand-projection; a read off a request object, `scope`, etc. is
|
|
8
|
+
* unrelated and ignored. The detection was byte-identical in both files (it
|
|
9
|
+
* tripped the graph `duplicated-function-body` rule), so it lives here once.
|
|
10
|
+
*
|
|
11
|
+
* Underscore-prefixed and absent from the check barrel (`index.ts`): this is an
|
|
12
|
+
* internal helper, not a `defineCheck` export.
|
|
13
|
+
*/
|
|
14
|
+
/**
|
|
15
|
+
* Identifiers bound to a parsed YAML document in this file — the result of a
|
|
16
|
+
* `const <id> = readYamlFile(...)` (or a sibling reader: `readYamlFileOrThrow`,
|
|
17
|
+
* `parseYaml`, `loadYaml`).
|
|
18
|
+
*
|
|
19
|
+
* @param content - the source text of the file under analysis.
|
|
20
|
+
* @returns the set of local binding names that hold a parsed YAML document.
|
|
21
|
+
*/
|
|
22
|
+
export function yamlDocBindings(content) {
|
|
23
|
+
const docs = new Set();
|
|
24
|
+
const re = /(?:const|let)\s+([A-Za-z_$][\w$]*)\s*=\s*(?:await\s+)?(?:readYamlFile|readYamlFileOrThrow|parseYaml|loadYaml)\s*\(/g;
|
|
25
|
+
for (const m of content.matchAll(re))
|
|
26
|
+
docs.add(m[1]);
|
|
27
|
+
return docs;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=_yaml-doc-bindings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_yaml-doc-bindings.js","sourceRoot":"","sources":["../../../src/checks/architecture/_yaml-doc-bindings.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH;;;;;;;GAOG;AACH,MAAM,UAAU,eAAe,CAAC,OAAe;IAC7C,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,MAAM,EAAE,GACN,qHAAqH,CAAC;IACxH,KAAK,MAAM,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACrD,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/checks/architecture/dependencies/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/checks/architecture/dependencies/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview No Duplicate Packages check
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Check: architecture/no-duplicate-packages
|
|
6
|
+
*
|
|
7
|
+
* Detects packages that serve the same purpose or have overlapping functionality.
|
|
8
|
+
* This prevents confusion about which package to use and unnecessary duplication.
|
|
9
|
+
*/
|
|
10
|
+
export declare const noDuplicatePackages: import("@opensip-cli/fitness").Check;
|
|
11
|
+
//# sourceMappingURL=no-duplicate-packages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-packages.d.ts","sourceRoot":"","sources":["../../../../src/checks/architecture/dependencies/no-duplicate-packages.ts"],"names":[],"mappings":"AAEA;;GAEG;AAmJH;;;;;GAKG;AACH,eAAO,MAAM,mBAAmB,sCAsD9B,CAAC"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
// @fitness-ignore-file fitness-check-standards -- Uses fs for directory listing/stat operations, not file content reading
|
|
2
|
+
// @fitness-ignore-file unbounded-memory -- reads workspace package.json files; bounded by standard package metadata size
|
|
3
|
+
/**
|
|
4
|
+
* @fileoverview No Duplicate Packages check
|
|
5
|
+
*/
|
|
6
|
+
import * as fs from 'node:fs';
|
|
7
|
+
import * as path from 'node:path';
|
|
8
|
+
import { defineCheck } from '@opensip-cli/fitness';
|
|
9
|
+
const DUPLICATE_PATTERNS = [
|
|
10
|
+
{
|
|
11
|
+
category: 'contracts/types',
|
|
12
|
+
namePatterns: [/contracts?$/, /types?$/, /shared-types?$/, /common-types?$/],
|
|
13
|
+
minForWarning: 2,
|
|
14
|
+
minForError: 3,
|
|
15
|
+
reason: 'Multiple type definition packages cause confusion',
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
category: 'utilities',
|
|
19
|
+
namePatterns: [/utils?$/, /helpers?$/, /common$/, /shared$/],
|
|
20
|
+
minForWarning: 2,
|
|
21
|
+
minForError: 3,
|
|
22
|
+
reason: 'Multiple utility packages lead to scattered helper functions',
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
category: 'api-client',
|
|
26
|
+
namePatterns: [/api-client$/, /http-client$/, /-client$/],
|
|
27
|
+
minForWarning: 2,
|
|
28
|
+
minForError: 3,
|
|
29
|
+
reason: 'Multiple API clients create inconsistent data fetching patterns',
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
category: 'config',
|
|
33
|
+
namePatterns: [/config$/, /configuration$/, /settings$/],
|
|
34
|
+
minForWarning: 2,
|
|
35
|
+
minForError: 3,
|
|
36
|
+
reason: 'Multiple configuration packages scatter environment setup',
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
category: 'logging',
|
|
40
|
+
namePatterns: [/logger$/, /logging$/, /log$/],
|
|
41
|
+
minForWarning: 2,
|
|
42
|
+
minForError: 2,
|
|
43
|
+
reason: 'Multiple logging packages lead to inconsistent log formats',
|
|
44
|
+
},
|
|
45
|
+
];
|
|
46
|
+
const EXCLUDED_PACKAGES = [/__fixtures__/, /__mocks__/, /examples?$/, /-test$/, /-mock$/];
|
|
47
|
+
function getPackageInfo(packageJsonPath, projectRoot) {
|
|
48
|
+
try {
|
|
49
|
+
const content = fs.readFileSync(packageJsonPath, 'utf8');
|
|
50
|
+
const pkg = JSON.parse(content);
|
|
51
|
+
const packageDir = path.dirname(packageJsonPath);
|
|
52
|
+
const relativePath = path.relative(projectRoot, packageDir);
|
|
53
|
+
if (EXCLUDED_PACKAGES.some((p) => p.test(relativePath))) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
return {
|
|
57
|
+
name: pkg.name ?? path.basename(packageDir),
|
|
58
|
+
path: relativePath,
|
|
59
|
+
keywords: pkg.keywords,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
catch {
|
|
63
|
+
// @swallow-ok graceful degradation - return sentinel on failure
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
function matchesPattern(pkg, patterns) {
|
|
68
|
+
/* v8 ignore next 4 -- defensive: callers always pass an array */
|
|
69
|
+
// Validate array parameter
|
|
70
|
+
if (!Array.isArray(patterns)) {
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
/* v8 ignore next -- defensive: split + pop on a non-empty string never returns undefined */
|
|
74
|
+
const namePart = pkg.name.split('/').pop() ?? pkg.name;
|
|
75
|
+
if (patterns.some((p) => p.test(namePart)))
|
|
76
|
+
return true;
|
|
77
|
+
if (pkg.keywords) {
|
|
78
|
+
for (const keyword of pkg.keywords) {
|
|
79
|
+
if (patterns.some((p) => p.test(keyword)))
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return false;
|
|
84
|
+
}
|
|
85
|
+
/** Deduplicate packages by their unscoped name part to avoid counting @scope/foo and foo as separate entries */
|
|
86
|
+
function deduplicateByNamePart(packages) {
|
|
87
|
+
const seen = new Map();
|
|
88
|
+
for (const pkg of packages) {
|
|
89
|
+
/* v8 ignore next -- defensive: split + pop on a non-empty string never returns undefined */
|
|
90
|
+
const namePart = pkg.name.split('/').pop() ?? pkg.name;
|
|
91
|
+
if (!seen.has(namePart)) {
|
|
92
|
+
seen.set(namePart, pkg);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return [...seen.values()];
|
|
96
|
+
}
|
|
97
|
+
function detectDuplicates(packages) {
|
|
98
|
+
/* v8 ignore next 4 -- defensive: callers always pass an array */
|
|
99
|
+
// Validate array parameter
|
|
100
|
+
if (!Array.isArray(packages)) {
|
|
101
|
+
return [];
|
|
102
|
+
}
|
|
103
|
+
const groups = [];
|
|
104
|
+
for (const pattern of DUPLICATE_PATTERNS) {
|
|
105
|
+
const matching = deduplicateByNamePart(packages.filter((pkg) => matchesPattern(pkg, pattern.namePatterns)));
|
|
106
|
+
if (matching.length >= pattern.minForWarning) {
|
|
107
|
+
groups.push({
|
|
108
|
+
category: pattern.category,
|
|
109
|
+
reason: pattern.reason,
|
|
110
|
+
packages: matching,
|
|
111
|
+
severity: matching.length >= pattern.minForError ? 'error' : 'warning',
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return groups;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Check: architecture/no-duplicate-packages
|
|
119
|
+
*
|
|
120
|
+
* Detects packages that serve the same purpose or have overlapping functionality.
|
|
121
|
+
* This prevents confusion about which package to use and unnecessary duplication.
|
|
122
|
+
*/
|
|
123
|
+
export const noDuplicatePackages = defineCheck({
|
|
124
|
+
id: '06c7c267-c5a6-4386-81ab-88ddc2c4f5a4',
|
|
125
|
+
slug: 'no-duplicate-packages',
|
|
126
|
+
tags: ['architecture'],
|
|
127
|
+
scope: { languages: ['json', 'typescript', 'yaml'], concerns: ['config'] },
|
|
128
|
+
contentFilter: 'strip-strings',
|
|
129
|
+
confidence: 'medium',
|
|
130
|
+
description: 'Detects packages that serve the same purpose',
|
|
131
|
+
longDescription: `**Purpose:** Detects multiple packages in the monorepo that serve the same functional purpose, preventing fragmentation of shared concerns.
|
|
132
|
+
|
|
133
|
+
**Detects:**
|
|
134
|
+
- Package names or keywords matching duplicate-prone categories: contracts/types (\`/contracts?$/\`, \`/types?$/\`), utilities (\`/utils?$/\`, \`/helpers?$/\`), api-client (\`/api-client$/\`, \`/-client$/\`), config (\`/config$/\`, \`/settings$/\`), logging (\`/logger$/\`, \`/logging$/\`)
|
|
135
|
+
- Warns at 2+ matches per category; errors at 3+ (logging errors at 2+)
|
|
136
|
+
|
|
137
|
+
**Why it matters:** Duplicate packages create confusion about which to use, scatter related logic, and lead to inconsistent patterns across the codebase.
|
|
138
|
+
|
|
139
|
+
**Scope:** General best practice. Cross-file analysis over all \`packages/**/package.json\` files.`,
|
|
140
|
+
fileTypes: ['json'],
|
|
141
|
+
// @fitness-ignore-next-line concurrency-safety -- async keyword required by analyzeAll interface contract; synchronous analysis implementation
|
|
142
|
+
// eslint-disable-next-line @typescript-eslint/require-await -- AnalyzeAllCheckConfig requires Promise<CheckViolation[]>; this implementation is synchronous
|
|
143
|
+
async analyzeAll(files) {
|
|
144
|
+
// Get the cwd from the first file path
|
|
145
|
+
const firstFile = files.paths[0];
|
|
146
|
+
const cwd = firstFile ? path.dirname(path.dirname(path.dirname(firstFile))) : process.cwd();
|
|
147
|
+
const packages = [];
|
|
148
|
+
for (const packageJsonPath of files.paths) {
|
|
149
|
+
const info = getPackageInfo(packageJsonPath, cwd);
|
|
150
|
+
if (info)
|
|
151
|
+
packages.push(info);
|
|
152
|
+
}
|
|
153
|
+
const duplicateGroups = detectDuplicates(packages);
|
|
154
|
+
const violations = [];
|
|
155
|
+
for (const group of duplicateGroups) {
|
|
156
|
+
const packageNames = group.packages.map((p) => p.name);
|
|
157
|
+
const firstPath = group.packages[0]?.path || 'packages';
|
|
158
|
+
violations.push({
|
|
159
|
+
filePath: path.join(cwd, firstPath, 'package.json'),
|
|
160
|
+
line: 1,
|
|
161
|
+
message: `Duplicate ${group.category} packages: ${packageNames.join(', ')}. ${group.reason}`,
|
|
162
|
+
severity: group.severity,
|
|
163
|
+
suggestion: `Consolidate ${group.category} packages into a single canonical package. Remove duplicates and update all consumers to use the canonical package.`,
|
|
164
|
+
match: group.category,
|
|
165
|
+
type: 'duplicate-package',
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
return violations;
|
|
169
|
+
},
|
|
170
|
+
});
|
|
171
|
+
//# sourceMappingURL=no-duplicate-packages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-packages.js","sourceRoot":"","sources":["../../../../src/checks/architecture/dependencies/no-duplicate-packages.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Docker best practices fitness check
|
|
3
|
+
* @invariants
|
|
4
|
+
* - Security rules (non-root user, no secrets, production-dependencies) are errors (blocking)
|
|
5
|
+
* - Efficiency rules (layer ordering, multi-stage, no-build-tools-in-runner) are warnings (advisory)
|
|
6
|
+
* - All Dockerfiles in the repository are scanned
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* Check: architecture/docker-best-practices
|
|
10
|
+
*
|
|
11
|
+
* Validates Dockerfiles follow security and efficiency best practices:
|
|
12
|
+
* - Multi-stage builds
|
|
13
|
+
* - Non-root user
|
|
14
|
+
* - No hardcoded secrets
|
|
15
|
+
* - Frozen lockfiles for package managers
|
|
16
|
+
* - HEALTHCHECK instruction
|
|
17
|
+
* - Proper COPY order for layer caching
|
|
18
|
+
* - Production-only dependencies in runtime image (no devDependencies)
|
|
19
|
+
* - No build tools (pnpm, corepack) inherited in runtime stage
|
|
20
|
+
* - BuildKit cache mounts for package install commands
|
|
21
|
+
*/
|
|
22
|
+
export declare const dockerBestPractices: import("@opensip-cli/fitness").Check;
|
|
23
|
+
//# sourceMappingURL=docker-best-practices.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"docker-best-practices.d.ts","sourceRoot":"","sources":["../../../src/checks/architecture/docker-best-practices.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AA2hBH;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,mBAAmB,sCAqC9B,CAAC"}
|