@sk8metal/michi-cli 0.14.1 → 0.19.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/CHANGELOG.md +268 -2
- package/README.md +27 -2
- package/dist/scripts/config/config-schema.d.ts +5 -333
- package/dist/scripts/config/config-schema.d.ts.map +1 -1
- package/dist/scripts/config/config-schema.js +6 -233
- package/dist/scripts/config/config-schema.js.map +1 -1
- package/dist/scripts/config-global.d.ts.map +1 -1
- package/dist/scripts/config-global.js +3 -2
- package/dist/scripts/config-global.js.map +1 -1
- package/dist/scripts/confluence-sync.d.ts +5 -73
- package/dist/scripts/confluence-sync.d.ts.map +1 -1
- package/dist/scripts/confluence-sync.js +14 -392
- package/dist/scripts/confluence-sync.js.map +1 -1
- package/dist/scripts/constants/environments.d.ts +3 -30
- package/dist/scripts/constants/environments.d.ts.map +1 -1
- package/dist/scripts/constants/environments.js +3 -41
- package/dist/scripts/constants/environments.js.map +1 -1
- package/dist/scripts/constants/languages.d.ts +3 -20
- package/dist/scripts/constants/languages.d.ts.map +1 -1
- package/dist/scripts/constants/languages.js +3 -50
- package/dist/scripts/constants/languages.js.map +1 -1
- package/dist/scripts/constants/test-commands.d.ts +3 -33
- package/dist/scripts/constants/test-commands.d.ts.map +1 -1
- package/dist/scripts/constants/test-commands.js +3 -67
- package/dist/scripts/constants/test-commands.js.map +1 -1
- package/dist/scripts/dev-tools/mermaid-converter.d.ts.map +1 -0
- package/dist/scripts/dev-tools/mermaid-converter.js.map +1 -0
- package/dist/scripts/dev-tools/test-interactive.d.ts.map +1 -0
- package/dist/scripts/{test-interactive.js → dev-tools/test-interactive.js} +4 -3
- package/dist/scripts/dev-tools/test-interactive.js.map +1 -0
- package/dist/scripts/github-actions-client.d.ts +5 -75
- package/dist/scripts/github-actions-client.d.ts.map +1 -1
- package/dist/scripts/github-actions-client.js +4 -178
- package/dist/scripts/github-actions-client.js.map +1 -1
- package/dist/scripts/jira-sync.d.ts +3 -121
- package/dist/scripts/jira-sync.d.ts.map +1 -1
- package/dist/scripts/jira-sync.js +5 -879
- package/dist/scripts/jira-sync.js.map +1 -1
- package/dist/scripts/markdown-to-confluence.d.ts.map +1 -1
- package/dist/scripts/markdown-to-confluence.js +2 -2
- package/dist/scripts/markdown-to-confluence.js.map +1 -1
- package/dist/scripts/multi-project-estimate.d.ts.map +1 -1
- package/dist/scripts/multi-project-estimate.js +3 -2
- package/dist/scripts/multi-project-estimate.js.map +1 -1
- package/dist/scripts/phase-runner.d.ts.map +1 -1
- package/dist/scripts/phase-runner.js +34 -18
- package/dist/scripts/phase-runner.js.map +1 -1
- package/dist/scripts/pre-flight-check.d.ts.map +1 -1
- package/dist/scripts/pre-flight-check.js +27 -11
- package/dist/scripts/pre-flight-check.js.map +1 -1
- package/dist/scripts/template/multi-repo-renderer.js +2 -2
- package/dist/scripts/template/multi-repo-renderer.js.map +1 -1
- package/dist/scripts/test-execution-generator.d.ts.map +1 -1
- package/dist/scripts/test-execution-generator.js +5 -4
- package/dist/scripts/test-execution-generator.js.map +1 -1
- package/dist/scripts/utils/aidlc-parser.d.ts +5 -82
- package/dist/scripts/utils/aidlc-parser.d.ts.map +1 -1
- package/dist/scripts/utils/aidlc-parser.js +4 -204
- package/dist/scripts/utils/aidlc-parser.js.map +1 -1
- package/dist/scripts/utils/ci-generator.d.ts.map +1 -1
- package/dist/scripts/utils/ci-generator.js +4 -3
- package/dist/scripts/utils/ci-generator.js.map +1 -1
- package/dist/scripts/utils/config-loader.d.ts.map +1 -1
- package/dist/scripts/utils/config-loader.js +46 -49
- package/dist/scripts/utils/config-loader.js.map +1 -1
- package/dist/scripts/utils/config-validator.d.ts +9 -10
- package/dist/scripts/utils/config-validator.d.ts.map +1 -1
- package/dist/scripts/utils/config-validator.js +68 -70
- package/dist/scripts/utils/config-validator.js.map +1 -1
- package/dist/scripts/utils/docker-requirement-detector.d.ts.map +1 -1
- package/dist/scripts/utils/docker-requirement-detector.js +5 -4
- package/dist/scripts/utils/docker-requirement-detector.js.map +1 -1
- package/dist/scripts/utils/env-config.d.ts.map +1 -1
- package/dist/scripts/utils/env-config.js +55 -38
- package/dist/scripts/utils/env-config.js.map +1 -1
- package/dist/scripts/utils/feature-name-validator.d.ts +4 -9
- package/dist/scripts/utils/feature-name-validator.d.ts.map +1 -1
- package/dist/scripts/utils/feature-name-validator.js +12 -21
- package/dist/scripts/utils/feature-name-validator.js.map +1 -1
- package/dist/scripts/utils/interactive-helpers.d.ts +5 -29
- package/dist/scripts/utils/interactive-helpers.d.ts.map +1 -1
- package/dist/scripts/utils/interactive-helpers.js +5 -89
- package/dist/scripts/utils/interactive-helpers.js.map +1 -1
- package/dist/scripts/utils/language-detector.d.ts.map +1 -1
- package/dist/scripts/utils/language-detector.js +4 -3
- package/dist/scripts/utils/language-detector.js.map +1 -1
- package/dist/scripts/utils/markdown-parser.d.ts +6 -52
- package/dist/scripts/utils/markdown-parser.d.ts.map +1 -1
- package/dist/scripts/utils/markdown-parser.js +5 -286
- package/dist/scripts/utils/markdown-parser.js.map +1 -1
- package/dist/scripts/utils/multi-repo-validator.d.ts +9 -10
- package/dist/scripts/utils/multi-repo-validator.d.ts.map +1 -1
- package/dist/scripts/utils/multi-repo-validator.js +15 -17
- package/dist/scripts/utils/multi-repo-validator.js.map +1 -1
- package/dist/scripts/utils/project-analyzer.d.ts +120 -0
- package/dist/scripts/utils/project-analyzer.d.ts.map +1 -0
- package/dist/scripts/utils/project-analyzer.js +358 -0
- package/dist/scripts/utils/project-analyzer.js.map +1 -0
- package/dist/scripts/utils/project-detector.d.ts.map +1 -1
- package/dist/scripts/utils/project-detector.js +6 -5
- package/dist/scripts/utils/project-detector.js.map +1 -1
- package/dist/scripts/utils/project-finder.d.ts +1 -21
- package/dist/scripts/utils/project-finder.d.ts.map +1 -1
- package/dist/scripts/utils/project-finder.js +2 -121
- package/dist/scripts/utils/project-finder.js.map +1 -1
- package/dist/scripts/utils/project-meta.d.ts +4 -27
- package/dist/scripts/utils/project-meta.d.ts.map +1 -1
- package/dist/scripts/utils/project-meta.js +3 -67
- package/dist/scripts/utils/project-meta.js.map +1 -1
- package/dist/scripts/utils/safe-file-reader.d.ts +84 -0
- package/dist/scripts/utils/safe-file-reader.d.ts.map +1 -0
- package/dist/scripts/utils/safe-file-reader.js +122 -0
- package/dist/scripts/utils/safe-file-reader.js.map +1 -0
- package/dist/scripts/utils/security-validator.d.ts +8 -19
- package/dist/scripts/utils/security-validator.d.ts.map +1 -1
- package/dist/scripts/utils/security-validator.js +28 -58
- package/dist/scripts/utils/security-validator.js.map +1 -1
- package/dist/scripts/utils/spec-archiver.d.ts.map +1 -1
- package/dist/scripts/utils/spec-archiver.js +7 -6
- package/dist/scripts/utils/spec-archiver.js.map +1 -1
- package/dist/scripts/utils/spec-updater.d.ts.map +1 -1
- package/dist/scripts/utils/spec-updater.js +10 -7
- package/dist/scripts/utils/spec-updater.js.map +1 -1
- package/dist/scripts/utils/tasks-converter.js +2 -2
- package/dist/scripts/utils/tasks-converter.js.map +1 -1
- package/dist/scripts/utils/tasks-format-validator.js +4 -4
- package/dist/scripts/utils/tasks-format-validator.js.map +1 -1
- package/dist/scripts/utils/template-applier.d.ts.map +1 -1
- package/dist/scripts/utils/template-applier.js +4 -3
- package/dist/scripts/utils/template-applier.js.map +1 -1
- package/dist/scripts/utils/types/validation.d.ts +57 -0
- package/dist/scripts/utils/types/validation.d.ts.map +1 -0
- package/dist/scripts/utils/types/validation.js +50 -0
- package/dist/scripts/utils/types/validation.js.map +1 -0
- package/dist/scripts/validate-phase.d.ts +6 -1
- package/dist/scripts/validate-phase.d.ts.map +1 -1
- package/dist/scripts/validate-phase.js +42 -20
- package/dist/scripts/validate-phase.js.map +1 -1
- package/dist/scripts/workflow-orchestrator.d.ts +4 -40
- package/dist/scripts/workflow-orchestrator.d.ts.map +1 -1
- package/dist/scripts/workflow-orchestrator.js +7 -194
- package/dist/scripts/workflow-orchestrator.js.map +1 -1
- package/dist/src/application/interfaces/config-provider.d.ts +89 -0
- package/dist/src/application/interfaces/config-provider.d.ts.map +1 -0
- package/dist/src/application/interfaces/config-provider.js +8 -0
- package/dist/src/application/interfaces/config-provider.js.map +1 -0
- package/dist/src/application/interfaces/external-api.d.ts +80 -0
- package/dist/src/application/interfaces/external-api.d.ts.map +1 -0
- package/dist/src/application/interfaces/external-api.js +8 -0
- package/dist/src/application/interfaces/external-api.js.map +1 -0
- package/dist/src/application/interfaces/spec-repository.d.ts +52 -0
- package/dist/src/application/interfaces/spec-repository.d.ts.map +1 -0
- package/dist/src/application/interfaces/spec-repository.js +8 -0
- package/dist/src/application/interfaces/spec-repository.js.map +1 -0
- package/dist/src/application/services/spec-service.d.ts +49 -0
- package/dist/src/application/services/spec-service.d.ts.map +1 -0
- package/dist/src/application/services/spec-service.js +94 -0
- package/dist/src/application/services/spec-service.js.map +1 -0
- package/dist/src/application/services/workflow-service.d.ts +58 -0
- package/dist/src/application/services/workflow-service.d.ts.map +1 -0
- package/dist/src/application/services/workflow-service.js +125 -0
- package/dist/src/application/services/workflow-service.js.map +1 -0
- package/dist/src/application/templates/processor.d.ts +31 -0
- package/dist/src/application/templates/processor.d.ts.map +1 -0
- package/dist/src/application/templates/processor.js +58 -0
- package/dist/src/application/templates/processor.js.map +1 -0
- package/dist/src/application/use-cases/spec/archive-spec.d.ts +34 -0
- package/dist/src/application/use-cases/spec/archive-spec.d.ts.map +1 -0
- package/dist/src/application/use-cases/spec/archive-spec.js +56 -0
- package/dist/src/application/use-cases/spec/archive-spec.js.map +1 -0
- package/dist/src/application/use-cases/spec/generate-design.d.ts +34 -0
- package/dist/src/application/use-cases/spec/generate-design.d.ts.map +1 -0
- package/dist/src/application/use-cases/spec/generate-design.js +58 -0
- package/dist/src/application/use-cases/spec/generate-design.js.map +1 -0
- package/dist/src/application/use-cases/spec/generate-requirements.d.ts +34 -0
- package/dist/src/application/use-cases/spec/generate-requirements.d.ts.map +1 -0
- package/dist/src/application/use-cases/spec/generate-requirements.js +58 -0
- package/dist/src/application/use-cases/spec/generate-requirements.js.map +1 -0
- package/dist/src/application/use-cases/spec/generate-tasks.d.ts +34 -0
- package/dist/src/application/use-cases/spec/generate-tasks.d.ts.map +1 -0
- package/dist/src/application/use-cases/spec/generate-tasks.js +58 -0
- package/dist/src/application/use-cases/spec/generate-tasks.js.map +1 -0
- package/dist/src/application/use-cases/spec/init-spec.d.ts +48 -0
- package/dist/src/application/use-cases/spec/init-spec.d.ts.map +1 -0
- package/dist/src/application/use-cases/spec/init-spec.js +121 -0
- package/dist/src/application/use-cases/spec/init-spec.js.map +1 -0
- package/dist/src/cli.d.ts +6 -7
- package/dist/src/cli.d.ts.map +1 -1
- package/dist/src/cli.js +6 -745
- package/dist/src/cli.js.map +1 -1
- package/dist/src/commands/config-validate.js +2 -2
- package/dist/src/commands/init.d.ts +6 -21
- package/dist/src/commands/init.d.ts.map +1 -1
- package/dist/src/commands/init.js +5 -508
- package/dist/src/commands/init.js.map +1 -1
- package/dist/src/commands/migrate.js +4 -3
- package/dist/src/commands/migrate.js.map +1 -1
- package/dist/src/commands/spec-archive.d.ts +6 -13
- package/dist/src/commands/spec-archive.d.ts.map +1 -1
- package/dist/src/commands/spec-archive.js +5 -36
- package/dist/src/commands/spec-archive.js.map +1 -1
- package/dist/src/commands/spec-list.d.ts +6 -11
- package/dist/src/commands/spec-list.d.ts.map +1 -1
- package/dist/src/commands/spec-list.js +5 -51
- package/dist/src/commands/spec-list.js.map +1 -1
- package/dist/src/domain/constants/approval.d.ts +18 -0
- package/dist/src/domain/constants/approval.d.ts.map +1 -0
- package/dist/src/domain/constants/approval.js +23 -0
- package/dist/src/domain/constants/approval.js.map +1 -0
- package/dist/src/domain/constants/environments.d.ts +33 -0
- package/dist/src/domain/constants/environments.d.ts.map +1 -0
- package/dist/src/domain/constants/environments.js +44 -0
- package/dist/src/domain/constants/environments.js.map +1 -0
- package/dist/src/domain/constants/index.d.ts +12 -0
- package/dist/src/domain/constants/index.d.ts.map +1 -0
- package/dist/src/domain/constants/index.js +18 -0
- package/dist/src/domain/constants/index.js.map +1 -0
- package/dist/src/domain/constants/languages.d.ts +23 -0
- package/dist/src/domain/constants/languages.d.ts.map +1 -0
- package/dist/src/domain/constants/languages.js +53 -0
- package/dist/src/domain/constants/languages.js.map +1 -0
- package/dist/src/domain/constants/phases.d.ts +32 -0
- package/dist/src/domain/constants/phases.d.ts.map +1 -0
- package/dist/src/domain/constants/phases.js +52 -0
- package/dist/src/domain/constants/phases.js.map +1 -0
- package/dist/src/domain/constants/test-commands.d.ts +36 -0
- package/dist/src/domain/constants/test-commands.d.ts.map +1 -0
- package/dist/src/domain/constants/test-commands.js +70 -0
- package/dist/src/domain/constants/test-commands.js.map +1 -0
- package/dist/src/domain/constants/validation-rules.d.ts +32 -0
- package/dist/src/domain/constants/validation-rules.d.ts.map +1 -0
- package/dist/src/domain/constants/validation-rules.js +51 -0
- package/dist/src/domain/constants/validation-rules.js.map +1 -0
- package/dist/src/domain/entities/spec.d.ts +66 -0
- package/dist/src/domain/entities/spec.d.ts.map +1 -0
- package/dist/src/domain/entities/spec.js +112 -0
- package/dist/src/domain/entities/spec.js.map +1 -0
- package/dist/src/domain/entities/task.d.ts +43 -0
- package/dist/src/domain/entities/task.d.ts.map +1 -0
- package/dist/src/domain/entities/task.js +65 -0
- package/dist/src/domain/entities/task.js.map +1 -0
- package/dist/src/domain/services/spec-validator.d.ts +46 -0
- package/dist/src/domain/services/spec-validator.d.ts.map +1 -0
- package/dist/src/domain/services/spec-validator.js +99 -0
- package/dist/src/domain/services/spec-validator.js.map +1 -0
- package/dist/src/domain/value-objects/feature-name.d.ts +24 -0
- package/dist/src/domain/value-objects/feature-name.d.ts.map +1 -0
- package/dist/src/domain/value-objects/feature-name.js +36 -0
- package/dist/src/domain/value-objects/feature-name.js.map +1 -0
- package/dist/src/domain/value-objects/index.d.ts +7 -0
- package/dist/src/domain/value-objects/index.d.ts.map +1 -0
- package/dist/src/domain/value-objects/index.js +7 -0
- package/dist/src/domain/value-objects/index.js.map +1 -0
- package/dist/src/infrastructure/config/index.d.ts +5 -0
- package/dist/src/infrastructure/config/index.d.ts.map +1 -0
- package/dist/src/infrastructure/config/index.js +6 -0
- package/dist/src/infrastructure/config/index.js.map +1 -0
- package/dist/src/infrastructure/config/schema.d.ts +337 -0
- package/dist/src/infrastructure/config/schema.d.ts.map +1 -0
- package/dist/src/infrastructure/config/schema.js +237 -0
- package/dist/src/infrastructure/config/schema.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/approval.d.ts +14 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/approval.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/approval.js +102 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/approval.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/client.d.ts +23 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/client.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/client.js +192 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/client.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/hierarchy.d.ts +48 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/hierarchy.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/hierarchy.js +531 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/hierarchy.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/index.d.ts +10 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/index.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/index.js +12 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/index.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/sync-service.d.ts +13 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/sync-service.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/sync-service.js +129 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/sync-service.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/types.d.ts +113 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/types.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/types.js +5 -0
- package/dist/src/infrastructure/external-apis/atlassian/confluence/types.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/adf-converter.d.ts +15 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/adf-converter.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/adf-converter.js +141 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/adf-converter.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/client.d.ts +50 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/client.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/client.js +226 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/client.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/index.d.ts +12 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/index.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/index.js +16 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/index.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/issue-builder.d.ts +49 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/issue-builder.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/issue-builder.js +165 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/issue-builder.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/status-mapper.d.ts +14 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/status-mapper.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/status-mapper.js +110 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/status-mapper.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/sync-service.d.ts +32 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/sync-service.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/sync-service.js +284 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/sync-service.js.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/types.d.ts +114 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/types.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/types.js +7 -0
- package/dist/src/infrastructure/external-apis/atlassian/jira/types.js.map +1 -0
- package/dist/src/infrastructure/external-apis/github/client.d.ts +25 -0
- package/dist/src/infrastructure/external-apis/github/client.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/github/client.js +109 -0
- package/dist/src/infrastructure/external-apis/github/client.js.map +1 -0
- package/dist/src/infrastructure/external-apis/github/index.d.ts +7 -0
- package/dist/src/infrastructure/external-apis/github/index.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/github/index.js +8 -0
- package/dist/src/infrastructure/external-apis/github/index.js.map +1 -0
- package/dist/src/infrastructure/external-apis/github/types.d.ts +69 -0
- package/dist/src/infrastructure/external-apis/github/types.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/github/types.js +5 -0
- package/dist/src/infrastructure/external-apis/github/types.js.map +1 -0
- package/dist/src/infrastructure/external-apis/github/utils.d.ts +18 -0
- package/dist/src/infrastructure/external-apis/github/utils.d.ts.map +1 -0
- package/dist/src/infrastructure/external-apis/github/utils.js +84 -0
- package/dist/src/infrastructure/external-apis/github/utils.js.map +1 -0
- package/dist/src/infrastructure/filesystem/index.d.ts +6 -0
- package/dist/src/infrastructure/filesystem/index.d.ts.map +1 -0
- package/dist/src/infrastructure/filesystem/index.js +5 -0
- package/dist/src/infrastructure/filesystem/index.js.map +1 -0
- package/dist/src/infrastructure/filesystem/project-meta.d.ts +32 -0
- package/dist/src/infrastructure/filesystem/project-meta.d.ts.map +1 -0
- package/dist/src/infrastructure/filesystem/project-meta.js +75 -0
- package/dist/src/infrastructure/filesystem/project-meta.js.map +1 -0
- package/dist/src/infrastructure/parsers/aidlc-parser.d.ts +86 -0
- package/dist/src/infrastructure/parsers/aidlc-parser.d.ts.map +1 -0
- package/dist/src/infrastructure/parsers/aidlc-parser.js +208 -0
- package/dist/src/infrastructure/parsers/aidlc-parser.js.map +1 -0
- package/dist/src/infrastructure/parsers/index.d.ts +8 -0
- package/dist/src/infrastructure/parsers/index.d.ts.map +1 -0
- package/dist/src/infrastructure/parsers/index.js +6 -0
- package/dist/src/infrastructure/parsers/index.js.map +1 -0
- package/dist/src/infrastructure/parsers/markdown-parser.d.ts +51 -0
- package/dist/src/infrastructure/parsers/markdown-parser.d.ts.map +1 -0
- package/dist/src/infrastructure/parsers/markdown-parser.js +253 -0
- package/dist/src/infrastructure/parsers/markdown-parser.js.map +1 -0
- package/dist/src/presentation/cli/config.d.ts +12 -0
- package/dist/src/presentation/cli/config.d.ts.map +1 -0
- package/dist/src/presentation/cli/config.js +22 -0
- package/dist/src/presentation/cli/config.js.map +1 -0
- package/dist/src/presentation/cli/version.d.ts +10 -0
- package/dist/src/presentation/cli/version.d.ts.map +1 -0
- package/dist/src/presentation/cli/version.js +41 -0
- package/dist/src/presentation/cli/version.js.map +1 -0
- package/dist/src/presentation/cli.d.ts +22 -0
- package/dist/src/presentation/cli.d.ts.map +1 -0
- package/dist/src/presentation/cli.js +85 -0
- package/dist/src/presentation/cli.js.map +1 -0
- package/dist/src/presentation/commands/config/register.d.ts +11 -0
- package/dist/src/presentation/commands/config/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/config/register.js +44 -0
- package/dist/src/presentation/commands/config/register.js.map +1 -0
- package/dist/src/presentation/commands/confluence/register.d.ts +11 -0
- package/dist/src/presentation/commands/confluence/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/confluence/register.js +32 -0
- package/dist/src/presentation/commands/confluence/register.js.map +1 -0
- package/dist/src/presentation/commands/confluence/sync.d.ts +17 -0
- package/dist/src/presentation/commands/confluence/sync.d.ts.map +1 -0
- package/dist/src/presentation/commands/confluence/sync.js +25 -0
- package/dist/src/presentation/commands/confluence/sync.js.map +1 -0
- package/dist/src/presentation/commands/init/handler.d.ts +10 -0
- package/dist/src/presentation/commands/init/handler.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/handler.js +64 -0
- package/dist/src/presentation/commands/init/handler.js.map +1 -0
- package/dist/src/presentation/commands/init/prompts.d.ts +41 -0
- package/dist/src/presentation/commands/init/prompts.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/prompts.js +119 -0
- package/dist/src/presentation/commands/init/prompts.js.map +1 -0
- package/dist/src/presentation/commands/init/register.d.ts +11 -0
- package/dist/src/presentation/commands/init/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/register.js +141 -0
- package/dist/src/presentation/commands/init/register.js.map +1 -0
- package/dist/src/presentation/commands/init/setup.d.ts +26 -0
- package/dist/src/presentation/commands/init/setup.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/setup.js +196 -0
- package/dist/src/presentation/commands/init/setup.js.map +1 -0
- package/dist/src/presentation/commands/init/templates.d.ts +19 -0
- package/dist/src/presentation/commands/init/templates.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/templates.js +140 -0
- package/dist/src/presentation/commands/init/templates.js.map +1 -0
- package/dist/src/presentation/commands/init/validation.d.ts +21 -0
- package/dist/src/presentation/commands/init/validation.d.ts.map +1 -0
- package/dist/src/presentation/commands/init/validation.js +65 -0
- package/dist/src/presentation/commands/init/validation.js.map +1 -0
- package/dist/src/presentation/commands/jira/register.d.ts +11 -0
- package/dist/src/presentation/commands/jira/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/jira/register.js +75 -0
- package/dist/src/presentation/commands/jira/register.js.map +1 -0
- package/dist/src/presentation/commands/jira/sync.d.ts +29 -0
- package/dist/src/presentation/commands/jira/sync.d.ts.map +1 -0
- package/dist/src/presentation/commands/jira/sync.js +37 -0
- package/dist/src/presentation/commands/jira/sync.js.map +1 -0
- package/dist/src/{commands/multi-repo-add-repo.d.ts → presentation/commands/multi-repo/add-repo.d.ts} +1 -1
- package/dist/src/presentation/commands/multi-repo/add-repo.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-add-repo.js → presentation/commands/multi-repo/add-repo.js} +4 -4
- package/dist/src/presentation/commands/multi-repo/add-repo.js.map +1 -0
- package/dist/src/{commands/multi-repo-ci-status.d.ts → presentation/commands/multi-repo/ci-status.d.ts} +2 -2
- package/dist/src/presentation/commands/multi-repo/ci-status.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-ci-status.js → presentation/commands/multi-repo/ci-status.js} +95 -81
- package/dist/src/presentation/commands/multi-repo/ci-status.js.map +1 -0
- package/dist/src/{commands/multi-repo-confluence-sync.d.ts → presentation/commands/multi-repo/confluence-sync.d.ts} +1 -1
- package/dist/src/presentation/commands/multi-repo/confluence-sync.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-confluence-sync.js → presentation/commands/multi-repo/confluence-sync.js} +7 -6
- package/dist/src/presentation/commands/multi-repo/confluence-sync.js.map +1 -0
- package/dist/src/{commands/multi-repo-init.d.ts → presentation/commands/multi-repo/init.d.ts} +1 -1
- package/dist/src/presentation/commands/multi-repo/init.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-init.js → presentation/commands/multi-repo/init.js} +6 -6
- package/dist/src/presentation/commands/multi-repo/init.js.map +1 -0
- package/dist/src/{commands/multi-repo-list.d.ts → presentation/commands/multi-repo/list.d.ts} +1 -1
- package/dist/src/presentation/commands/multi-repo/list.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-list.js → presentation/commands/multi-repo/list.js} +2 -2
- package/dist/src/presentation/commands/multi-repo/list.js.map +1 -0
- package/dist/src/presentation/commands/multi-repo/register.d.ts +12 -0
- package/dist/src/presentation/commands/multi-repo/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/multi-repo/register.js +249 -0
- package/dist/src/presentation/commands/multi-repo/register.js.map +1 -0
- package/dist/src/{commands/multi-repo-test.d.ts → presentation/commands/multi-repo/test.d.ts} +1 -1
- package/dist/src/presentation/commands/multi-repo/test.d.ts.map +1 -0
- package/dist/src/{commands/multi-repo-test.js → presentation/commands/multi-repo/test.js} +4 -4
- package/dist/src/presentation/commands/multi-repo/test.js.map +1 -0
- package/dist/src/presentation/commands/phase/register.d.ts +11 -0
- package/dist/src/presentation/commands/phase/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/phase/register.js +97 -0
- package/dist/src/presentation/commands/phase/register.js.map +1 -0
- package/dist/src/presentation/commands/spec/archive.d.ts +17 -0
- package/dist/src/presentation/commands/spec/archive.d.ts.map +1 -0
- package/dist/src/presentation/commands/spec/archive.js +40 -0
- package/dist/src/presentation/commands/spec/archive.js.map +1 -0
- package/dist/src/presentation/commands/spec/list.d.ts +15 -0
- package/dist/src/presentation/commands/spec/list.d.ts.map +1 -0
- package/dist/src/presentation/commands/spec/list.js +55 -0
- package/dist/src/presentation/commands/spec/list.js.map +1 -0
- package/dist/src/presentation/commands/spec/register.d.ts +11 -0
- package/dist/src/presentation/commands/spec/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/spec/register.js +45 -0
- package/dist/src/presentation/commands/spec/register.js.map +1 -0
- package/dist/src/presentation/commands/workflow/orchestrator.d.ts +50 -0
- package/dist/src/presentation/commands/workflow/orchestrator.d.ts.map +1 -0
- package/dist/src/presentation/commands/workflow/orchestrator.js +174 -0
- package/dist/src/presentation/commands/workflow/orchestrator.js.map +1 -0
- package/dist/src/presentation/commands/workflow/register.d.ts +11 -0
- package/dist/src/presentation/commands/workflow/register.d.ts.map +1 -0
- package/dist/src/presentation/commands/workflow/register.js +58 -0
- package/dist/src/presentation/commands/workflow/register.js.map +1 -0
- package/dist/src/presentation/formatters/error-formatter.d.ts +79 -0
- package/dist/src/presentation/formatters/error-formatter.d.ts.map +1 -0
- package/dist/src/presentation/formatters/error-formatter.js +150 -0
- package/dist/src/presentation/formatters/error-formatter.js.map +1 -0
- package/dist/src/presentation/formatters/index.d.ts +8 -0
- package/dist/src/presentation/formatters/index.d.ts.map +1 -0
- package/dist/src/presentation/formatters/index.js +11 -0
- package/dist/src/presentation/formatters/index.js.map +1 -0
- package/dist/src/presentation/formatters/output-formatter.d.ts +98 -0
- package/dist/src/presentation/formatters/output-formatter.d.ts.map +1 -0
- package/dist/src/presentation/formatters/output-formatter.js +165 -0
- package/dist/src/presentation/formatters/output-formatter.js.map +1 -0
- package/dist/src/presentation/formatters/progress-formatter.d.ts +121 -0
- package/dist/src/presentation/formatters/progress-formatter.d.ts.map +1 -0
- package/dist/src/presentation/formatters/progress-formatter.js +235 -0
- package/dist/src/presentation/formatters/progress-formatter.js.map +1 -0
- package/dist/src/presentation/interactive/confirmation.d.ts +24 -0
- package/dist/src/presentation/interactive/confirmation.d.ts.map +1 -0
- package/dist/src/presentation/interactive/confirmation.js +54 -0
- package/dist/src/presentation/interactive/confirmation.js.map +1 -0
- package/dist/src/presentation/interactive/index.d.ts +8 -0
- package/dist/src/presentation/interactive/index.d.ts.map +1 -0
- package/dist/src/presentation/interactive/index.js +11 -0
- package/dist/src/presentation/interactive/index.js.map +1 -0
- package/dist/src/presentation/interactive/prompts.d.ts +31 -0
- package/dist/src/presentation/interactive/prompts.d.ts.map +1 -0
- package/dist/src/presentation/interactive/prompts.js +71 -0
- package/dist/src/presentation/interactive/prompts.js.map +1 -0
- package/dist/src/presentation/interactive/selection.d.ts +31 -0
- package/dist/src/presentation/interactive/selection.d.ts.map +1 -0
- package/dist/src/presentation/interactive/selection.js +138 -0
- package/dist/src/presentation/interactive/selection.js.map +1 -0
- package/dist/src/shared/types/errors.d.ts +132 -0
- package/dist/src/shared/types/errors.d.ts.map +1 -0
- package/dist/src/shared/types/errors.js +61 -0
- package/dist/src/shared/types/errors.js.map +1 -0
- package/dist/src/shared/types/result.d.ts +53 -0
- package/dist/src/shared/types/result.d.ts.map +1 -0
- package/dist/src/shared/types/result.js +42 -0
- package/dist/src/shared/types/result.js.map +1 -0
- package/dist/test-confluence-auth.d.ts +6 -0
- package/dist/test-confluence-auth.d.ts.map +1 -0
- package/dist/test-confluence-auth.js +128 -0
- package/dist/test-confluence-auth.js.map +1 -0
- package/docs/MIGRATION.md +513 -0
- package/docs/architecture.md +774 -0
- package/docs/guides/comprehensive-verification-guide.md +1926 -0
- package/docs/onion-architecture-phase0-complete.md +91 -0
- package/package.json +6 -6
- package/scripts/README.md +148 -0
- package/scripts/__tests__/jira-transitions.test.ts +44 -30
- package/scripts/__tests__/mermaid-converter.test.ts +2 -2
- package/scripts/__tests__/multi-repo-validator.test.ts +62 -62
- package/scripts/__tests__/spec-archiver.test.ts +12 -0
- package/scripts/__tests__/validate-phase.test.ts +6 -6
- package/scripts/build/README.md +24 -0
- package/scripts/{copy-static-assets.js → build/copy-static-assets.js} +1 -1
- package/scripts/{set-permissions.js → build/set-permissions.js} +1 -1
- package/scripts/config/config-schema.ts +43 -302
- package/scripts/config-global.ts +3 -2
- package/scripts/confluence-sync.ts +17 -538
- package/scripts/constants/environments.ts +3 -53
- package/scripts/constants/languages.ts +3 -68
- package/scripts/constants/test-commands.ts +3 -94
- package/scripts/dev-tools/README.md +22 -0
- package/scripts/{test-interactive.ts → dev-tools/test-interactive.ts} +4 -3
- package/scripts/github-actions-client.ts +18 -256
- package/scripts/jira-sync.ts +5 -1270
- package/scripts/markdown-to-confluence.ts +5 -5
- package/scripts/multi-project-estimate.ts +3 -2
- package/scripts/phase-runner.ts +41 -19
- package/scripts/pre-flight-check.ts +27 -11
- package/scripts/template/__tests__/multi-repo-renderer.test.ts +12 -0
- package/scripts/template/multi-repo-renderer.ts +2 -2
- package/scripts/test-execution-generator.ts +5 -4
- package/scripts/utils/__tests__/config-validator.test.ts +19 -19
- package/scripts/utils/__tests__/feature-name-validator.test.ts +13 -13
- package/scripts/utils/__tests__/multi-repo-validator.test.ts +34 -34
- package/scripts/utils/__tests__/project-analyzer.test.ts +542 -0
- package/scripts/utils/__tests__/safe-file-reader.test.ts +208 -0
- package/scripts/utils/__tests__/security-validator.test.ts +33 -33
- package/scripts/utils/__tests__/validation-result.test.ts +112 -0
- package/scripts/utils/aidlc-parser.ts +18 -287
- package/scripts/utils/ci-generator.ts +4 -3
- package/scripts/utils/config-loader.ts +54 -50
- package/scripts/utils/config-validator.ts +89 -80
- package/scripts/utils/docker-requirement-detector.ts +5 -4
- package/scripts/utils/env-config.ts +59 -40
- package/scripts/utils/feature-name-validator.ts +25 -40
- package/scripts/utils/interactive-helpers.ts +24 -132
- package/scripts/utils/language-detector.ts +4 -3
- package/scripts/utils/markdown-parser.ts +18 -373
- package/scripts/utils/multi-repo-validator.ts +27 -28
- package/scripts/utils/project-analyzer.ts +429 -0
- package/scripts/utils/project-detector.ts +6 -5
- package/scripts/utils/project-finder.ts +2 -154
- package/scripts/utils/project-meta.ts +8 -91
- package/scripts/utils/safe-file-reader.ts +158 -0
- package/scripts/utils/security-validator.ts +42 -78
- package/scripts/utils/spec-archiver.ts +7 -6
- package/scripts/utils/spec-updater.ts +12 -6
- package/scripts/utils/tasks-converter.ts +2 -2
- package/scripts/utils/tasks-format-validator.ts +4 -4
- package/scripts/utils/template-applier.ts +4 -3
- package/scripts/utils/types/validation.ts +92 -0
- package/scripts/validate-phase.ts +51 -23
- package/scripts/workflow-orchestrator.ts +16 -251
- package/dist/scripts/mermaid-converter.d.ts.map +0 -1
- package/dist/scripts/mermaid-converter.js.map +0 -1
- package/dist/scripts/resource-dashboard.d.ts +0 -7
- package/dist/scripts/resource-dashboard.d.ts.map +0 -1
- package/dist/scripts/resource-dashboard.js +0 -157
- package/dist/scripts/resource-dashboard.js.map +0 -1
- package/dist/scripts/test-interactive.d.ts.map +0 -1
- package/dist/scripts/test-interactive.js.map +0 -1
- package/dist/scripts/test-new-features.d.ts +0 -5
- package/dist/scripts/test-new-features.d.ts.map +0 -1
- package/dist/scripts/test-new-features.js +0 -148
- package/dist/scripts/test-new-features.js.map +0 -1
- package/dist/scripts/test-spec-generator.d.ts +0 -29
- package/dist/scripts/test-spec-generator.d.ts.map +0 -1
- package/dist/scripts/test-spec-generator.js +0 -493
- package/dist/scripts/test-spec-generator.js.map +0 -1
- package/dist/scripts/utils/confluence-approval.d.ts +0 -46
- package/dist/scripts/utils/confluence-approval.d.ts.map +0 -1
- package/dist/scripts/utils/confluence-approval.js +0 -120
- package/dist/scripts/utils/confluence-approval.js.map +0 -1
- package/dist/scripts/utils/template-finder.d.ts +0 -37
- package/dist/scripts/utils/template-finder.d.ts.map +0 -1
- package/dist/scripts/utils/template-finder.js +0 -58
- package/dist/scripts/utils/template-finder.js.map +0 -1
- package/dist/src/commands/multi-repo-add-repo.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-add-repo.js.map +0 -1
- package/dist/src/commands/multi-repo-ci-status.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-ci-status.js.map +0 -1
- package/dist/src/commands/multi-repo-confluence-sync.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-confluence-sync.js.map +0 -1
- package/dist/src/commands/multi-repo-init.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-init.js.map +0 -1
- package/dist/src/commands/multi-repo-list.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-list.js.map +0 -1
- package/dist/src/commands/multi-repo-test.d.ts.map +0 -1
- package/dist/src/commands/multi-repo-test.js.map +0 -1
- package/dist/src/commands/setup-existing.d.ts +0 -22
- package/dist/src/commands/setup-existing.d.ts.map +0 -1
- package/dist/src/commands/setup-existing.js +0 -606
- package/dist/src/commands/setup-existing.js.map +0 -1
- package/scripts/__tests__/setup-existing-project.test.ts +0 -244
- package/scripts/resource-dashboard.ts +0 -189
- package/scripts/test-new-features.ts +0 -171
- package/scripts/test-spec-generator.ts +0 -570
- package/scripts/utils/confluence-approval.ts +0 -169
- package/scripts/utils/template-finder.ts +0 -69
- /package/dist/scripts/{mermaid-converter.d.ts → dev-tools/mermaid-converter.d.ts} +0 -0
- /package/dist/scripts/{mermaid-converter.js → dev-tools/mermaid-converter.js} +0 -0
- /package/dist/scripts/{test-interactive.d.ts → dev-tools/test-interactive.d.ts} +0 -0
- /package/scripts/{mermaid-converter.ts → dev-tools/mermaid-converter.ts} +0 -0
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* safeReadFile ユーティリティのテスト
|
|
3
|
+
* ファイル読み込み処理を統合し、一貫したエラーハンドリングを提供
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
7
|
+
import { mkdirSync, rmSync, writeFileSync, chmodSync } from 'fs';
|
|
8
|
+
import { join } from 'path';
|
|
9
|
+
import { safeReadFile, safeReadJsonFile } from '../safe-file-reader.js';
|
|
10
|
+
|
|
11
|
+
describe('safeReadFile', () => {
|
|
12
|
+
let testDir: string;
|
|
13
|
+
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
testDir = join(process.cwd(), 'tmp-test-safe-file-reader');
|
|
16
|
+
mkdirSync(testDir, { recursive: true });
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
afterEach(() => {
|
|
20
|
+
rmSync(testDir, { recursive: true, force: true });
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
describe('safeReadFile - テキストファイル読み込み', () => {
|
|
24
|
+
it('should successfully read existing file', () => {
|
|
25
|
+
// Setup
|
|
26
|
+
const filePath = join(testDir, 'test.txt');
|
|
27
|
+
writeFileSync(filePath, 'Hello World', 'utf-8');
|
|
28
|
+
|
|
29
|
+
// Execute
|
|
30
|
+
const result = safeReadFile(filePath);
|
|
31
|
+
|
|
32
|
+
// Verify
|
|
33
|
+
expect(result.success).toBe(true);
|
|
34
|
+
if (result.success) {
|
|
35
|
+
expect(result.value).toBe('Hello World');
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
it('should return FileNotFound error when file does not exist', () => {
|
|
40
|
+
// Setup
|
|
41
|
+
const filePath = join(testDir, 'non-existent.txt');
|
|
42
|
+
|
|
43
|
+
// Execute
|
|
44
|
+
const result = safeReadFile(filePath);
|
|
45
|
+
|
|
46
|
+
// Verify
|
|
47
|
+
expect(result.success).toBe(false);
|
|
48
|
+
if (!result.success) {
|
|
49
|
+
expect(result.errors[0].type).toBe('FileNotFound');
|
|
50
|
+
expect(result.errors[0].path).toBe(filePath);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it('should return PermissionDenied error when file is not readable', () => {
|
|
55
|
+
// Setup
|
|
56
|
+
const filePath = join(testDir, 'no-permission.txt');
|
|
57
|
+
writeFileSync(filePath, 'Secret', 'utf-8');
|
|
58
|
+
chmodSync(filePath, 0o000); // 読み取り不可に設定
|
|
59
|
+
|
|
60
|
+
// Execute
|
|
61
|
+
const result = safeReadFile(filePath);
|
|
62
|
+
|
|
63
|
+
// Verify
|
|
64
|
+
expect(result.success).toBe(false);
|
|
65
|
+
if (!result.success) {
|
|
66
|
+
expect(result.errors[0].type).toBe('PermissionDenied');
|
|
67
|
+
expect(result.errors[0].path).toBe(filePath);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// Cleanup: パーミッションを戻す
|
|
71
|
+
chmodSync(filePath, 0o644);
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it('should handle UTF-8 encoding correctly', () => {
|
|
75
|
+
// Setup
|
|
76
|
+
const filePath = join(testDir, 'utf8.txt');
|
|
77
|
+
writeFileSync(filePath, '日本語テスト🎉', 'utf-8');
|
|
78
|
+
|
|
79
|
+
// Execute
|
|
80
|
+
const result = safeReadFile(filePath);
|
|
81
|
+
|
|
82
|
+
// Verify
|
|
83
|
+
expect(result.success).toBe(true);
|
|
84
|
+
if (result.success) {
|
|
85
|
+
expect(result.value).toBe('日本語テスト🎉');
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
it('should support custom encoding', () => {
|
|
90
|
+
// Setup
|
|
91
|
+
const filePath = join(testDir, 'latin1.txt');
|
|
92
|
+
const content = 'Café';
|
|
93
|
+
writeFileSync(filePath, content, 'latin1');
|
|
94
|
+
|
|
95
|
+
// Execute
|
|
96
|
+
const result = safeReadFile(filePath, 'latin1');
|
|
97
|
+
|
|
98
|
+
// Verify
|
|
99
|
+
expect(result.success).toBe(true);
|
|
100
|
+
if (result.success) {
|
|
101
|
+
expect(result.value).toBe(content);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
describe('safeReadJsonFile - JSONファイル読み込み', () => {
|
|
107
|
+
it('should successfully read and parse valid JSON file', () => {
|
|
108
|
+
// Setup
|
|
109
|
+
const filePath = join(testDir, 'test.json');
|
|
110
|
+
const data = { name: 'test', value: 42 };
|
|
111
|
+
writeFileSync(filePath, JSON.stringify(data), 'utf-8');
|
|
112
|
+
|
|
113
|
+
// Execute
|
|
114
|
+
const result = safeReadJsonFile(filePath);
|
|
115
|
+
|
|
116
|
+
// Verify
|
|
117
|
+
expect(result.success).toBe(true);
|
|
118
|
+
if (result.success) {
|
|
119
|
+
expect(result.value).toEqual(data);
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
it('should return InvalidJSON error when JSON is malformed', () => {
|
|
124
|
+
// Setup
|
|
125
|
+
const filePath = join(testDir, 'invalid.json');
|
|
126
|
+
writeFileSync(filePath, '{ invalid json }', 'utf-8');
|
|
127
|
+
|
|
128
|
+
// Execute
|
|
129
|
+
const result = safeReadJsonFile(filePath);
|
|
130
|
+
|
|
131
|
+
// Verify
|
|
132
|
+
expect(result.success).toBe(false);
|
|
133
|
+
if (!result.success) {
|
|
134
|
+
expect(result.errors[0].type).toBe('InvalidJSON');
|
|
135
|
+
expect(result.errors[0].path).toBe(filePath);
|
|
136
|
+
expect(result.errors[0].cause).toBeDefined();
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it('should return FileNotFound error when JSON file does not exist', () => {
|
|
141
|
+
// Setup
|
|
142
|
+
const filePath = join(testDir, 'non-existent.json');
|
|
143
|
+
|
|
144
|
+
// Execute
|
|
145
|
+
const result = safeReadJsonFile(filePath);
|
|
146
|
+
|
|
147
|
+
// Verify
|
|
148
|
+
expect(result.success).toBe(false);
|
|
149
|
+
if (!result.success) {
|
|
150
|
+
expect(result.errors[0].type).toBe('FileNotFound');
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
it('should handle nested JSON structures', () => {
|
|
155
|
+
// Setup
|
|
156
|
+
const filePath = join(testDir, 'nested.json');
|
|
157
|
+
const data = {
|
|
158
|
+
project: {
|
|
159
|
+
name: 'michi',
|
|
160
|
+
config: {
|
|
161
|
+
language: 'ja',
|
|
162
|
+
features: ['spec', 'jira', 'confluence']
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
writeFileSync(filePath, JSON.stringify(data), 'utf-8');
|
|
167
|
+
|
|
168
|
+
// Execute
|
|
169
|
+
const result = safeReadJsonFile(filePath);
|
|
170
|
+
|
|
171
|
+
// Verify
|
|
172
|
+
expect(result.success).toBe(true);
|
|
173
|
+
if (result.success) {
|
|
174
|
+
expect(result.value).toEqual(data);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
it('should handle empty JSON object', () => {
|
|
179
|
+
// Setup
|
|
180
|
+
const filePath = join(testDir, 'empty.json');
|
|
181
|
+
writeFileSync(filePath, '{}', 'utf-8');
|
|
182
|
+
|
|
183
|
+
// Execute
|
|
184
|
+
const result = safeReadJsonFile(filePath);
|
|
185
|
+
|
|
186
|
+
// Verify
|
|
187
|
+
expect(result.success).toBe(true);
|
|
188
|
+
if (result.success) {
|
|
189
|
+
expect(result.value).toEqual({});
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
it('should handle empty JSON array', () => {
|
|
194
|
+
// Setup
|
|
195
|
+
const filePath = join(testDir, 'empty-array.json');
|
|
196
|
+
writeFileSync(filePath, '[]', 'utf-8');
|
|
197
|
+
|
|
198
|
+
// Execute
|
|
199
|
+
const result = safeReadJsonFile(filePath);
|
|
200
|
+
|
|
201
|
+
// Verify
|
|
202
|
+
expect(result.success).toBe(true);
|
|
203
|
+
if (result.success) {
|
|
204
|
+
expect(result.value).toEqual([]);
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
});
|
|
208
|
+
});
|
|
@@ -18,19 +18,19 @@ describe('security-validator', () => {
|
|
|
18
18
|
describe('validateAtlassianToken', () => {
|
|
19
19
|
it('空のトークンはエラー', () => {
|
|
20
20
|
const result = validateAtlassianToken('');
|
|
21
|
-
expect(result.
|
|
21
|
+
expect(result.success).toBe(false);
|
|
22
22
|
expect(result.errors).toContain('Atlassian API token is empty');
|
|
23
23
|
});
|
|
24
24
|
|
|
25
25
|
it('スペースを含むトークンはエラー', () => {
|
|
26
26
|
const result = validateAtlassianToken('token with spaces');
|
|
27
|
-
expect(result.
|
|
27
|
+
expect(result.success).toBe(false);
|
|
28
28
|
expect(result.errors).toContain('Atlassian API token contains spaces');
|
|
29
29
|
});
|
|
30
30
|
|
|
31
31
|
it('短すぎるトークンは警告', () => {
|
|
32
32
|
const result = validateAtlassianToken('short');
|
|
33
|
-
expect(result.
|
|
33
|
+
expect(result.success).toBe(true);
|
|
34
34
|
expect(result.warnings).toContain(
|
|
35
35
|
'Atlassian API token seems too short (expected >20 characters)',
|
|
36
36
|
);
|
|
@@ -38,13 +38,13 @@ describe('security-validator', () => {
|
|
|
38
38
|
|
|
39
39
|
it('プレースホルダー値はエラー', () => {
|
|
40
40
|
const result = validateAtlassianToken('your-token-here');
|
|
41
|
-
expect(result.
|
|
41
|
+
expect(result.success).toBe(false);
|
|
42
42
|
expect(result.errors).toContain('Atlassian API token is a placeholder value');
|
|
43
43
|
});
|
|
44
44
|
|
|
45
45
|
it('正しいトークンは成功', () => {
|
|
46
46
|
const result = validateAtlassianToken('ATATT3xFfGF0abcdefghijklmnopqrstuvwxyz1234567890');
|
|
47
|
-
expect(result.
|
|
47
|
+
expect(result.success).toBe(true);
|
|
48
48
|
expect(result.errors).toHaveLength(0);
|
|
49
49
|
expect(result.warnings).toHaveLength(0);
|
|
50
50
|
});
|
|
@@ -53,19 +53,19 @@ describe('security-validator', () => {
|
|
|
53
53
|
describe('validateGitHubToken', () => {
|
|
54
54
|
it('空のトークンはエラー', () => {
|
|
55
55
|
const result = validateGitHubToken('');
|
|
56
|
-
expect(result.
|
|
56
|
+
expect(result.success).toBe(false);
|
|
57
57
|
expect(result.errors).toContain('GitHub token is empty');
|
|
58
58
|
});
|
|
59
59
|
|
|
60
60
|
it('スペースを含むトークンはエラー', () => {
|
|
61
61
|
const result = validateGitHubToken('token with spaces');
|
|
62
|
-
expect(result.
|
|
62
|
+
expect(result.success).toBe(false);
|
|
63
63
|
expect(result.errors).toContain('GitHub token contains spaces');
|
|
64
64
|
});
|
|
65
65
|
|
|
66
66
|
it('プレフィックスなしのトークンは警告', () => {
|
|
67
67
|
const result = validateGitHubToken('abcdefghijklmnopqrstuvwxyz1234567890');
|
|
68
|
-
expect(result.
|
|
68
|
+
expect(result.success).toBe(true);
|
|
69
69
|
expect(result.warnings).toContain(
|
|
70
70
|
'GitHub token does not start with expected prefix (ghp_ or github_pat_)',
|
|
71
71
|
);
|
|
@@ -73,19 +73,19 @@ describe('security-validator', () => {
|
|
|
73
73
|
|
|
74
74
|
it('プレースホルダー値はエラー', () => {
|
|
75
75
|
const result = validateGitHubToken('ghp_xxx');
|
|
76
|
-
expect(result.
|
|
76
|
+
expect(result.success).toBe(false);
|
|
77
77
|
expect(result.errors).toContain('GitHub token is a placeholder value');
|
|
78
78
|
});
|
|
79
79
|
|
|
80
80
|
it('正しいトークン(ghp_)は成功', () => {
|
|
81
81
|
const result = validateGitHubToken('ghp_abcdefghijklmnopqrstuvwxyz1234567890');
|
|
82
|
-
expect(result.
|
|
82
|
+
expect(result.success).toBe(true);
|
|
83
83
|
expect(result.errors).toHaveLength(0);
|
|
84
84
|
});
|
|
85
85
|
|
|
86
86
|
it('正しいトークン(github_pat_)は成功', () => {
|
|
87
87
|
const result = validateGitHubToken('github_pat_abcdefghijklmnopqrstuvwxyz1234567890');
|
|
88
|
-
expect(result.
|
|
88
|
+
expect(result.success).toBe(true);
|
|
89
89
|
expect(result.errors).toHaveLength(0);
|
|
90
90
|
});
|
|
91
91
|
});
|
|
@@ -93,25 +93,25 @@ describe('security-validator', () => {
|
|
|
93
93
|
describe('validateEmail', () => {
|
|
94
94
|
it('空のメールアドレスはエラー', () => {
|
|
95
95
|
const result = validateEmail('');
|
|
96
|
-
expect(result.
|
|
96
|
+
expect(result.success).toBe(false);
|
|
97
97
|
expect(result.errors).toContain('Email is empty');
|
|
98
98
|
});
|
|
99
99
|
|
|
100
100
|
it('不正な形式のメールアドレスはエラー', () => {
|
|
101
101
|
const result = validateEmail('invalid-email');
|
|
102
|
-
expect(result.
|
|
102
|
+
expect(result.success).toBe(false);
|
|
103
103
|
expect(result.errors).toContain('Email format is invalid');
|
|
104
104
|
});
|
|
105
105
|
|
|
106
106
|
it('プレースホルダー値はエラー', () => {
|
|
107
107
|
const result = validateEmail('user@example.com');
|
|
108
|
-
expect(result.
|
|
108
|
+
expect(result.success).toBe(false);
|
|
109
109
|
expect(result.errors).toContain('Email is a placeholder value');
|
|
110
110
|
});
|
|
111
111
|
|
|
112
112
|
it('正しいメールアドレスは成功', () => {
|
|
113
113
|
const result = validateEmail('real.user@company.com');
|
|
114
|
-
expect(result.
|
|
114
|
+
expect(result.success).toBe(true);
|
|
115
115
|
expect(result.errors).toHaveLength(0);
|
|
116
116
|
});
|
|
117
117
|
});
|
|
@@ -119,19 +119,19 @@ describe('security-validator', () => {
|
|
|
119
119
|
describe('validateUrl', () => {
|
|
120
120
|
it('空のURLはエラー', () => {
|
|
121
121
|
const result = validateUrl('');
|
|
122
|
-
expect(result.
|
|
122
|
+
expect(result.success).toBe(false);
|
|
123
123
|
expect(result.errors).toContain('URL is empty');
|
|
124
124
|
});
|
|
125
125
|
|
|
126
126
|
it('不正な形式のURLはエラー', () => {
|
|
127
127
|
const result = validateUrl('not-a-url');
|
|
128
|
-
expect(result.
|
|
128
|
+
expect(result.success).toBe(false);
|
|
129
129
|
expect(result.errors.length).toBeGreaterThan(0);
|
|
130
130
|
});
|
|
131
131
|
|
|
132
132
|
it('httpプロトコルは警告', () => {
|
|
133
133
|
const result = validateUrl('http://example.com');
|
|
134
|
-
expect(result.
|
|
134
|
+
expect(result.success).toBe(true);
|
|
135
135
|
expect(result.warnings).toContain(
|
|
136
136
|
'URL uses insecure http:// protocol (consider using https://)',
|
|
137
137
|
);
|
|
@@ -139,19 +139,19 @@ describe('security-validator', () => {
|
|
|
139
139
|
|
|
140
140
|
it('プレースホルダー値はエラー', () => {
|
|
141
141
|
const result = validateUrl('https://example.com');
|
|
142
|
-
expect(result.
|
|
142
|
+
expect(result.success).toBe(false);
|
|
143
143
|
expect(result.errors).toContain('URL is a placeholder value');
|
|
144
144
|
});
|
|
145
145
|
|
|
146
146
|
it('正しいURLは成功', () => {
|
|
147
147
|
const result = validateUrl('https://real-domain.com');
|
|
148
|
-
expect(result.
|
|
148
|
+
expect(result.success).toBe(true);
|
|
149
149
|
expect(result.errors).toHaveLength(0);
|
|
150
150
|
});
|
|
151
151
|
|
|
152
152
|
it('expectedDomainが一致しない場合はエラー', () => {
|
|
153
153
|
const result = validateUrl('https://wrong.com', 'example.com');
|
|
154
|
-
expect(result.
|
|
154
|
+
expect(result.success).toBe(false);
|
|
155
155
|
expect(result.errors).toContain(
|
|
156
156
|
'URL hostname wrong.com does not contain expected domain: example.com',
|
|
157
157
|
);
|
|
@@ -159,20 +159,20 @@ describe('security-validator', () => {
|
|
|
159
159
|
|
|
160
160
|
it('expectedDomainが一致する場合は成功', () => {
|
|
161
161
|
const result = validateUrl('https://sub.example.com', 'example.com');
|
|
162
|
-
expect(result.
|
|
162
|
+
expect(result.success).toBe(true);
|
|
163
163
|
});
|
|
164
164
|
});
|
|
165
165
|
|
|
166
166
|
describe('validateAtlassianUrl', () => {
|
|
167
167
|
it('atlassian.netドメインでない場合はエラー', () => {
|
|
168
168
|
const result = validateAtlassianUrl('https://wrong-domain.com');
|
|
169
|
-
expect(result.
|
|
169
|
+
expect(result.success).toBe(false);
|
|
170
170
|
expect(result.errors.some((e) => e.includes('atlassian.net'))).toBe(true);
|
|
171
171
|
});
|
|
172
172
|
|
|
173
173
|
it('正しいAtlassian URLは成功', () => {
|
|
174
174
|
const result = validateAtlassianUrl('https://mycompany.atlassian.net');
|
|
175
|
-
expect(result.
|
|
175
|
+
expect(result.success).toBe(true);
|
|
176
176
|
expect(result.errors).toHaveLength(0);
|
|
177
177
|
});
|
|
178
178
|
});
|
|
@@ -180,43 +180,43 @@ describe('security-validator', () => {
|
|
|
180
180
|
describe('validateGitHubRepositoryUrl', () => {
|
|
181
181
|
it('空のURLはエラー', () => {
|
|
182
182
|
const result = validateGitHubRepositoryUrl('');
|
|
183
|
-
expect(result.
|
|
183
|
+
expect(result.success).toBe(false);
|
|
184
184
|
expect(result.errors).toContain('Repository URL is empty');
|
|
185
185
|
});
|
|
186
186
|
|
|
187
187
|
it('不正な形式はエラー', () => {
|
|
188
188
|
const result = validateGitHubRepositoryUrl('https://example.com/repo');
|
|
189
|
-
expect(result.
|
|
189
|
+
expect(result.success).toBe(false);
|
|
190
190
|
expect(result.errors.some((e) => e.includes('format'))).toBe(true);
|
|
191
191
|
});
|
|
192
192
|
|
|
193
193
|
it('プレースホルダー値はエラー', () => {
|
|
194
194
|
const result = validateGitHubRepositoryUrl('https://github.com/your-org/your-repo.git');
|
|
195
|
-
expect(result.
|
|
195
|
+
expect(result.success).toBe(false);
|
|
196
196
|
expect(result.errors).toContain('Repository URL contains placeholder values');
|
|
197
197
|
});
|
|
198
198
|
|
|
199
199
|
it('正しいHTTPS URLは成功', () => {
|
|
200
200
|
const result = validateGitHubRepositoryUrl('https://github.com/owner/repo.git');
|
|
201
|
-
expect(result.
|
|
201
|
+
expect(result.success).toBe(true);
|
|
202
202
|
expect(result.errors).toHaveLength(0);
|
|
203
203
|
});
|
|
204
204
|
|
|
205
205
|
it('正しいHTTPS URL(.gitなし)も成功', () => {
|
|
206
206
|
const result = validateGitHubRepositoryUrl('https://github.com/owner/repo');
|
|
207
|
-
expect(result.
|
|
207
|
+
expect(result.success).toBe(true);
|
|
208
208
|
expect(result.errors).toHaveLength(0);
|
|
209
209
|
});
|
|
210
210
|
|
|
211
211
|
it('正しいSSH URLは成功', () => {
|
|
212
212
|
const result = validateGitHubRepositoryUrl('git@github.com:owner/repo.git');
|
|
213
|
-
expect(result.
|
|
213
|
+
expect(result.success).toBe(true);
|
|
214
214
|
expect(result.errors).toHaveLength(0);
|
|
215
215
|
});
|
|
216
216
|
|
|
217
217
|
it('正しいSSH URL(.gitなし)も成功', () => {
|
|
218
218
|
const result = validateGitHubRepositoryUrl('git@github.com:owner/repo');
|
|
219
|
-
expect(result.
|
|
219
|
+
expect(result.success).toBe(true);
|
|
220
220
|
expect(result.errors).toHaveLength(0);
|
|
221
221
|
});
|
|
222
222
|
});
|
|
@@ -232,7 +232,7 @@ describe('security-validator', () => {
|
|
|
232
232
|
repositoryUrl: 'https://github.com/myorg/myrepo.git',
|
|
233
233
|
});
|
|
234
234
|
|
|
235
|
-
expect(result.
|
|
235
|
+
expect(result.success).toBe(true);
|
|
236
236
|
expect(result.errors).toHaveLength(0);
|
|
237
237
|
});
|
|
238
238
|
|
|
@@ -246,7 +246,7 @@ describe('security-validator', () => {
|
|
|
246
246
|
repositoryUrl: '', // 空
|
|
247
247
|
});
|
|
248
248
|
|
|
249
|
-
expect(result.
|
|
249
|
+
expect(result.success).toBe(false);
|
|
250
250
|
expect(result.errors.length).toBeGreaterThan(5);
|
|
251
251
|
expect(result.errors.some((e) => e.startsWith('ATLASSIAN_URL:'))).toBe(true);
|
|
252
252
|
expect(result.errors.some((e) => e.startsWith('ATLASSIAN_EMAIL:'))).toBe(true);
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ValidationResult 共通型のテスト
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { describe, it, expect } from 'vitest';
|
|
6
|
+
import type { Result } from '../types/validation.js';
|
|
7
|
+
|
|
8
|
+
describe('Result<T, E> type', () => {
|
|
9
|
+
describe('Success case', () => {
|
|
10
|
+
it('should represent successful validation', () => {
|
|
11
|
+
const result: Result<boolean, string> = {
|
|
12
|
+
success: true,
|
|
13
|
+
value: true,
|
|
14
|
+
errors: [],
|
|
15
|
+
warnings: []
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
expect(result.success).toBe(true);
|
|
19
|
+
expect(result.value).toBe(true);
|
|
20
|
+
expect(result.errors).toEqual([]);
|
|
21
|
+
expect(result.warnings).toEqual([]);
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
it('should allow warnings in successful result', () => {
|
|
25
|
+
const result: Result<boolean, string> = {
|
|
26
|
+
success: true,
|
|
27
|
+
value: true,
|
|
28
|
+
errors: [],
|
|
29
|
+
warnings: ['This is a warning']
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
expect(result.success).toBe(true);
|
|
33
|
+
expect(result.warnings.length).toBe(1);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
describe('Failure case', () => {
|
|
38
|
+
it('should represent failed validation', () => {
|
|
39
|
+
const result: Result<boolean, string> = {
|
|
40
|
+
success: false,
|
|
41
|
+
value: undefined,
|
|
42
|
+
errors: ['Error message'],
|
|
43
|
+
warnings: []
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
expect(result.success).toBe(false);
|
|
47
|
+
expect(result.value).toBeUndefined();
|
|
48
|
+
expect(result.errors.length).toBe(1);
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it('should allow multiple errors', () => {
|
|
52
|
+
const result: Result<boolean, string> = {
|
|
53
|
+
success: false,
|
|
54
|
+
value: undefined,
|
|
55
|
+
errors: ['Error 1', 'Error 2', 'Error 3'],
|
|
56
|
+
warnings: []
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
expect(result.success).toBe(false);
|
|
60
|
+
expect(result.errors.length).toBe(3);
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
describe('Type compatibility', () => {
|
|
65
|
+
it('should work with different value types', () => {
|
|
66
|
+
const stringResult: Result<string, string> = {
|
|
67
|
+
success: true,
|
|
68
|
+
value: 'test',
|
|
69
|
+
errors: [],
|
|
70
|
+
warnings: []
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
const numberResult: Result<number, string> = {
|
|
74
|
+
success: true,
|
|
75
|
+
value: 42,
|
|
76
|
+
errors: [],
|
|
77
|
+
warnings: []
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
const objectResult: Result<{ name: string }, string> = {
|
|
81
|
+
success: true,
|
|
82
|
+
value: { name: 'test' },
|
|
83
|
+
errors: [],
|
|
84
|
+
warnings: []
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
expect(stringResult.value).toBe('test');
|
|
88
|
+
expect(numberResult.value).toBe(42);
|
|
89
|
+
expect(objectResult.value).toEqual({ name: 'test' });
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it('should work with different error types', () => {
|
|
93
|
+
type ValidationError = {
|
|
94
|
+
field: string;
|
|
95
|
+
message: string;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
const result: Result<boolean, ValidationError> = {
|
|
99
|
+
success: false,
|
|
100
|
+
value: undefined,
|
|
101
|
+
errors: [
|
|
102
|
+
{ field: 'name', message: 'Required' },
|
|
103
|
+
{ field: 'email', message: 'Invalid format' }
|
|
104
|
+
],
|
|
105
|
+
warnings: []
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
expect(result.errors.length).toBe(2);
|
|
109
|
+
expect(result.errors[0].field).toBe('name');
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
});
|