specweave 0.13.5 → 0.14.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/CLAUDE.md +189 -0
- package/bin/specweave.js +1 -0
- package/dist/cli/commands/init.d.ts +1 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +51 -38
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/status-line.d.ts +14 -0
- package/dist/cli/commands/status-line.d.ts.map +1 -0
- package/dist/cli/commands/status-line.js +75 -0
- package/dist/cli/commands/status-line.js.map +1 -0
- package/dist/core/status-line/status-line-manager.d.ts +62 -0
- package/dist/core/status-line/status-line-manager.d.ts.map +1 -0
- package/dist/core/status-line/status-line-manager.js +169 -0
- package/dist/core/status-line/status-line-manager.js.map +1 -0
- package/dist/core/status-line/types.d.ts +50 -0
- package/dist/core/status-line/types.d.ts.map +1 -0
- package/dist/core/status-line/types.js +17 -0
- package/dist/core/status-line/types.js.map +1 -0
- package/dist/utils/project-mapper.d.ts +74 -0
- package/dist/utils/project-mapper.d.ts.map +1 -0
- package/dist/utils/project-mapper.js +273 -0
- package/dist/utils/project-mapper.js.map +1 -0
- package/dist/utils/spec-splitter.d.ts +68 -0
- package/dist/utils/spec-splitter.d.ts.map +1 -0
- package/dist/utils/spec-splitter.js +314 -0
- package/dist/utils/spec-splitter.js.map +1 -0
- package/package.json +1 -1
- package/plugins/specweave/hooks/lib/update-status-line.sh +138 -0
- package/plugins/specweave/hooks/post-task-completion.sh +10 -0
- package/plugins/specweave/lib/hooks/git-diff-analyzer.js +129 -213
- package/plugins/specweave/lib/hooks/invoke-translator-skill.js +146 -192
- package/plugins/specweave/lib/hooks/prepare-reflection-context.js +103 -116
- package/plugins/specweave/lib/hooks/reflection-config-loader.js +85 -125
- package/plugins/specweave/lib/hooks/reflection-parser.js +267 -385
- package/plugins/specweave/lib/hooks/reflection-prompt-builder.js +169 -226
- package/plugins/specweave/lib/hooks/reflection-storage.js +223 -297
- package/plugins/specweave/lib/hooks/run-self-reflection.js +120 -191
- package/plugins/specweave/lib/hooks/sync-living-docs.js +87 -129
- package/plugins/specweave/lib/hooks/translate-file.js +239 -300
- package/plugins/specweave/lib/hooks/translate-living-docs.js +88 -144
- package/plugins/specweave/lib/hooks/types/reflection-types.js +57 -72
- package/plugins/specweave/lib/hooks/update-tasks-md.js +117 -179
- package/plugins/specweave/skills/multi-project-spec-mapper/SKILL.md +399 -0
- package/plugins/specweave-ado/lib/ado-board-resolver.js +135 -205
- package/plugins/specweave-ado/lib/ado-hierarchical-sync.js +223 -335
- package/plugins/specweave-ado/lib/ado-multi-project-sync.js +453 -0
- package/plugins/specweave-ado/lib/ado-multi-project-sync.ts +633 -0
- package/plugins/specweave-ado/lib/ado-spec-sync.js +380 -414
- package/plugins/specweave-ado/lib/project-selector.js +168 -196
- package/plugins/specweave-docs/skills/docusaurus/SKILL.md +17 -3
- package/plugins/specweave-docs-preview/commands/preview.md +29 -4
- package/plugins/specweave-github/hooks/hooks.json +11 -0
- package/plugins/specweave-github/hooks/post-increment-done.sh +224 -0
- package/plugins/specweave-github/lib/cli-sync-increment-changes.js +9 -20
- package/plugins/specweave-github/lib/github-board-resolver.js +69 -115
- package/plugins/specweave-github/lib/github-client-v2.js +400 -389
- package/plugins/specweave-github/lib/github-client.js +246 -280
- package/plugins/specweave-github/lib/github-hierarchical-sync.js +168 -251
- package/plugins/specweave-github/lib/github-issue-updater.js +231 -288
- package/plugins/specweave-github/lib/github-multi-project-sync.js +340 -0
- package/plugins/specweave-github/lib/github-multi-project-sync.ts +461 -0
- package/plugins/specweave-github/lib/github-spec-sync.js +379 -420
- package/plugins/specweave-github/lib/github-sync-bidirectional.js +175 -202
- package/plugins/specweave-github/lib/github-sync-increment-changes.js +212 -251
- package/plugins/specweave-github/lib/index.js +11 -10
- package/plugins/specweave-github/lib/repo-selector.js +174 -201
- package/plugins/specweave-github/lib/subtask-sync.js +132 -125
- package/plugins/specweave-github/lib/task-parser.js +191 -207
- package/plugins/specweave-github/lib/task-sync.js +344 -296
- package/plugins/specweave-github/lib/types.js +0 -5
- package/plugins/specweave-jira/lib/jira-board-resolver.js +50 -79
- package/plugins/specweave-jira/lib/jira-hierarchical-sync.js +119 -191
- package/plugins/specweave-jira/lib/jira-multi-project-sync.js +244 -0
- package/plugins/specweave-jira/lib/jira-multi-project-sync.ts +358 -0
- package/plugins/specweave-jira/lib/jira-spec-sync.js +366 -405
- package/plugins/specweave-jira/lib/project-selector.js +172 -201
- package/plugins/specweave-jira/lib/reorganization-detector.js +202 -237
- package/plugins/specweave-jira/lib/setup-wizard.js +162 -204
- package/src/templates/AGENTS.md.template +42 -0
- package/dist/core/agent-model-manager.d.ts +0 -52
- package/dist/core/agent-model-manager.d.ts.map +0 -1
- package/dist/core/agent-model-manager.js +0 -120
- package/dist/core/agent-model-manager.js.map +0 -1
- package/dist/core/model-selector.d.ts +0 -57
- package/dist/core/model-selector.d.ts.map +0 -1
- package/dist/core/model-selector.js +0 -115
- package/dist/core/model-selector.js.map +0 -1
- package/dist/core/phase-detector.d.ts +0 -62
- package/dist/core/phase-detector.d.ts.map +0 -1
- package/dist/core/phase-detector.js +0 -229
- package/dist/core/phase-detector.js.map +0 -1
- package/dist/hooks/lib/git-diff-analyzer.d.ts +0 -89
- package/dist/hooks/lib/git-diff-analyzer.d.ts.map +0 -1
- package/dist/hooks/lib/git-diff-analyzer.js +0 -226
- package/dist/hooks/lib/git-diff-analyzer.js.map +0 -1
- package/dist/hooks/lib/invoke-translator-skill.d.ts +0 -60
- package/dist/hooks/lib/invoke-translator-skill.d.ts.map +0 -1
- package/dist/hooks/lib/invoke-translator-skill.js +0 -201
- package/dist/hooks/lib/invoke-translator-skill.js.map +0 -1
- package/dist/hooks/lib/prepare-reflection-context.d.ts +0 -42
- package/dist/hooks/lib/prepare-reflection-context.d.ts.map +0 -1
- package/dist/hooks/lib/prepare-reflection-context.js +0 -123
- package/dist/hooks/lib/prepare-reflection-context.js.map +0 -1
- package/dist/hooks/lib/reflection-config-loader.d.ts +0 -45
- package/dist/hooks/lib/reflection-config-loader.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-config-loader.js +0 -132
- package/dist/hooks/lib/reflection-config-loader.js.map +0 -1
- package/dist/hooks/lib/reflection-parser.d.ts +0 -33
- package/dist/hooks/lib/reflection-parser.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-parser.js +0 -419
- package/dist/hooks/lib/reflection-parser.js.map +0 -1
- package/dist/hooks/lib/reflection-prompt-builder.d.ts +0 -56
- package/dist/hooks/lib/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-prompt-builder.js +0 -239
- package/dist/hooks/lib/reflection-prompt-builder.js.map +0 -1
- package/dist/hooks/lib/reflection-storage.d.ts +0 -64
- package/dist/hooks/lib/reflection-storage.d.ts.map +0 -1
- package/dist/hooks/lib/reflection-storage.js +0 -305
- package/dist/hooks/lib/reflection-storage.js.map +0 -1
- package/dist/hooks/lib/run-self-reflection.d.ts +0 -43
- package/dist/hooks/lib/run-self-reflection.d.ts.map +0 -1
- package/dist/hooks/lib/run-self-reflection.js +0 -203
- package/dist/hooks/lib/run-self-reflection.js.map +0 -1
- package/dist/hooks/lib/sync-living-docs.d.ts +0 -27
- package/dist/hooks/lib/sync-living-docs.d.ts.map +0 -1
- package/dist/hooks/lib/sync-living-docs.js +0 -116
- package/dist/hooks/lib/sync-living-docs.js.map +0 -1
- package/dist/hooks/lib/translate-file.d.ts +0 -59
- package/dist/hooks/lib/translate-file.d.ts.map +0 -1
- package/dist/hooks/lib/translate-file.js +0 -350
- package/dist/hooks/lib/translate-file.js.map +0 -1
- package/dist/hooks/lib/translate-living-docs.d.ts +0 -13
- package/dist/hooks/lib/translate-living-docs.d.ts.map +0 -1
- package/dist/hooks/lib/translate-living-docs.js +0 -175
- package/dist/hooks/lib/translate-living-docs.js.map +0 -1
- package/dist/hooks/lib/types/reflection-types.d.ts +0 -164
- package/dist/hooks/lib/types/reflection-types.d.ts.map +0 -1
- package/dist/hooks/lib/types/reflection-types.js +0 -73
- package/dist/hooks/lib/types/reflection-types.js.map +0 -1
- package/dist/hooks/lib/update-tasks-md.d.ts +0 -29
- package/dist/hooks/lib/update-tasks-md.d.ts.map +0 -1
- package/dist/hooks/lib/update-tasks-md.js +0 -203
- package/dist/hooks/lib/update-tasks-md.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts +0 -89
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js +0 -226
- package/dist/plugins/specweave/lib/hooks/git-diff-analyzer.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts +0 -60
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js +0 -201
- package/dist/plugins/specweave/lib/hooks/invoke-translator-skill.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts +0 -42
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js +0 -123
- package/dist/plugins/specweave/lib/hooks/prepare-reflection-context.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts +0 -45
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js +0 -132
- package/dist/plugins/specweave/lib/hooks/reflection-config-loader.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts +0 -33
- package/dist/plugins/specweave/lib/hooks/reflection-parser.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-parser.js +0 -419
- package/dist/plugins/specweave/lib/hooks/reflection-parser.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts +0 -56
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js +0 -239
- package/dist/plugins/specweave/lib/hooks/reflection-prompt-builder.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts +0 -64
- package/dist/plugins/specweave/lib/hooks/reflection-storage.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/reflection-storage.js +0 -305
- package/dist/plugins/specweave/lib/hooks/reflection-storage.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts +0 -43
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.js +0 -203
- package/dist/plugins/specweave/lib/hooks/run-self-reflection.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts +0 -27
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js +0 -144
- package/dist/plugins/specweave/lib/hooks/sync-living-docs.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-file.d.ts +0 -59
- package/dist/plugins/specweave/lib/hooks/translate-file.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-file.js +0 -350
- package/dist/plugins/specweave/lib/hooks/translate-file.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts +0 -13
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.js +0 -175
- package/dist/plugins/specweave/lib/hooks/translate-living-docs.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts +0 -164
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.js +0 -73
- package/dist/plugins/specweave/lib/hooks/types/reflection-types.js.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts +0 -29
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.d.ts.map +0 -1
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.js +0 -203
- package/dist/plugins/specweave/lib/hooks/update-tasks-md.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts +0 -94
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.js +0 -219
- package/dist/plugins/specweave-ado/lib/ado-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts +0 -124
- package/dist/plugins/specweave-ado/lib/ado-client-v2.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client-v2.js +0 -382
- package/dist/plugins/specweave-ado/lib/ado-client-v2.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client.d.ts +0 -112
- package/dist/plugins/specweave-ado/lib/ado-client.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-client.js +0 -257
- package/dist/plugins/specweave-ado/lib/ado-client.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts +0 -40
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js +0 -370
- package/dist/plugins/specweave-ado/lib/ado-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.d.ts +0 -100
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.js +0 -471
- package/dist/plugins/specweave-ado/lib/ado-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-ado/lib/project-selector.d.ts +0 -42
- package/dist/plugins/specweave-ado/lib/project-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-ado/lib/project-selector.js +0 -211
- package/dist/plugins/specweave-ado/lib/project-selector.js.map +0 -1
- package/dist/plugins/specweave-github/lib/cli-sync-increment-changes.d.ts +0 -12
- package/dist/plugins/specweave-github/lib/cli-sync-increment-changes.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/cli-sync-increment-changes.js +0 -28
- package/dist/plugins/specweave-github/lib/cli-sync-increment-changes.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts +0 -54
- package/dist/plugins/specweave-github/lib/github-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-board-resolver.js +0 -122
- package/dist/plugins/specweave-github/lib/github-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts +0 -104
- package/dist/plugins/specweave-github/lib/github-client-v2.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client-v2.js +0 -408
- package/dist/plugins/specweave-github/lib/github-client-v2.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client.d.ts +0 -96
- package/dist/plugins/specweave-github/lib/github-client.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-client.js +0 -299
- package/dist/plugins/specweave-github/lib/github-client.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts +0 -29
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js +0 -268
- package/dist/plugins/specweave-github/lib/github-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-updater.d.ts +0 -61
- package/dist/plugins/specweave-github/lib/github-issue-updater.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-issue-updater.js +0 -327
- package/dist/plugins/specweave-github/lib/github-issue-updater.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts +0 -108
- package/dist/plugins/specweave-github/lib/github-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-spec-sync.js +0 -505
- package/dist/plugins/specweave-github/lib/github-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-bidirectional.d.ts +0 -36
- package/dist/plugins/specweave-github/lib/github-sync-bidirectional.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-bidirectional.js +0 -228
- package/dist/plugins/specweave-github/lib/github-sync-bidirectional.js.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-increment-changes.d.ts +0 -18
- package/dist/plugins/specweave-github/lib/github-sync-increment-changes.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/github-sync-increment-changes.js +0 -287
- package/dist/plugins/specweave-github/lib/github-sync-increment-changes.js.map +0 -1
- package/dist/plugins/specweave-github/lib/index.d.ts +0 -10
- package/dist/plugins/specweave-github/lib/index.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/index.js +0 -10
- package/dist/plugins/specweave-github/lib/index.js.map +0 -1
- package/dist/plugins/specweave-github/lib/repo-selector.d.ts +0 -49
- package/dist/plugins/specweave-github/lib/repo-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/repo-selector.js +0 -216
- package/dist/plugins/specweave-github/lib/repo-selector.js.map +0 -1
- package/dist/plugins/specweave-github/lib/subtask-sync.d.ts +0 -51
- package/dist/plugins/specweave-github/lib/subtask-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/subtask-sync.js +0 -147
- package/dist/plugins/specweave-github/lib/subtask-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/task-parser.d.ts +0 -37
- package/dist/plugins/specweave-github/lib/task-parser.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/task-parser.js +0 -211
- package/dist/plugins/specweave-github/lib/task-parser.js.map +0 -1
- package/dist/plugins/specweave-github/lib/task-sync.d.ts +0 -51
- package/dist/plugins/specweave-github/lib/task-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/task-sync.js +0 -332
- package/dist/plugins/specweave-github/lib/task-sync.js.map +0 -1
- package/dist/plugins/specweave-github/lib/types.d.ts +0 -80
- package/dist/plugins/specweave-github/lib/types.d.ts.map +0 -1
- package/dist/plugins/specweave-github/lib/types.js +0 -5
- package/dist/plugins/specweave-github/lib/types.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts +0 -50
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.js +0 -84
- package/dist/plugins/specweave-jira/lib/jira-board-resolver.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts +0 -33
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js +0 -206
- package/dist/plugins/specweave-jira/lib/jira-hierarchical-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.d.ts +0 -105
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.js +0 -456
- package/dist/plugins/specweave-jira/lib/jira-spec-sync.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/project-selector.d.ts +0 -42
- package/dist/plugins/specweave-jira/lib/project-selector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/project-selector.js +0 -216
- package/dist/plugins/specweave-jira/lib/project-selector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts +0 -67
- package/dist/plugins/specweave-jira/lib/reorganization-detector.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/reorganization-detector.js +0 -252
- package/dist/plugins/specweave-jira/lib/reorganization-detector.js.map +0 -1
- package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts +0 -29
- package/dist/plugins/specweave-jira/lib/setup-wizard.d.ts.map +0 -1
- package/dist/plugins/specweave-jira/lib/setup-wizard.js +0 -219
- package/dist/plugins/specweave-jira/lib/setup-wizard.js.map +0 -1
- package/dist/src/adapters/adapter-base.d.ts +0 -71
- package/dist/src/adapters/adapter-base.d.ts.map +0 -1
- package/dist/src/adapters/adapter-base.js +0 -139
- package/dist/src/adapters/adapter-base.js.map +0 -1
- package/dist/src/adapters/adapter-interface.d.ts +0 -149
- package/dist/src/adapters/adapter-interface.d.ts.map +0 -1
- package/dist/src/adapters/adapter-interface.js +0 -8
- package/dist/src/adapters/adapter-interface.js.map +0 -1
- package/dist/src/adapters/adapter-loader.d.ts +0 -91
- package/dist/src/adapters/adapter-loader.d.ts.map +0 -1
- package/dist/src/adapters/adapter-loader.js +0 -238
- package/dist/src/adapters/adapter-loader.js.map +0 -1
- package/dist/src/adapters/agents-md-generator.d.ts +0 -48
- package/dist/src/adapters/agents-md-generator.d.ts.map +0 -1
- package/dist/src/adapters/agents-md-generator.js +0 -193
- package/dist/src/adapters/agents-md-generator.js.map +0 -1
- package/dist/src/adapters/claude/adapter.d.ts +0 -128
- package/dist/src/adapters/claude/adapter.d.ts.map +0 -1
- package/dist/src/adapters/claude/adapter.js +0 -415
- package/dist/src/adapters/claude/adapter.js.map +0 -1
- package/dist/src/adapters/claude-md-generator.d.ts +0 -78
- package/dist/src/adapters/claude-md-generator.d.ts.map +0 -1
- package/dist/src/adapters/claude-md-generator.js +0 -307
- package/dist/src/adapters/claude-md-generator.js.map +0 -1
- package/dist/src/adapters/codex/adapter.d.ts +0 -50
- package/dist/src/adapters/codex/adapter.d.ts.map +0 -1
- package/dist/src/adapters/codex/adapter.js +0 -316
- package/dist/src/adapters/codex/adapter.js.map +0 -1
- package/dist/src/adapters/cursor/adapter.d.ts +0 -98
- package/dist/src/adapters/cursor/adapter.d.ts.map +0 -1
- package/dist/src/adapters/cursor/adapter.js +0 -406
- package/dist/src/adapters/cursor/adapter.js.map +0 -1
- package/dist/src/adapters/doc-generator.d.ts +0 -69
- package/dist/src/adapters/doc-generator.d.ts.map +0 -1
- package/dist/src/adapters/doc-generator.js +0 -247
- package/dist/src/adapters/doc-generator.js.map +0 -1
- package/dist/src/adapters/gemini/adapter.d.ts +0 -50
- package/dist/src/adapters/gemini/adapter.d.ts.map +0 -1
- package/dist/src/adapters/gemini/adapter.js +0 -281
- package/dist/src/adapters/gemini/adapter.js.map +0 -1
- package/dist/src/adapters/generic/adapter.d.ts +0 -86
- package/dist/src/adapters/generic/adapter.d.ts.map +0 -1
- package/dist/src/adapters/generic/adapter.js +0 -338
- package/dist/src/adapters/generic/adapter.js.map +0 -1
- package/dist/src/cli/commands/abandon.d.ts +0 -13
- package/dist/src/cli/commands/abandon.d.ts.map +0 -1
- package/dist/src/cli/commands/abandon.js +0 -15
- package/dist/src/cli/commands/abandon.js.map +0 -1
- package/dist/src/cli/commands/import-docs.d.ts +0 -21
- package/dist/src/cli/commands/import-docs.d.ts.map +0 -1
- package/dist/src/cli/commands/import-docs.js +0 -146
- package/dist/src/cli/commands/import-docs.js.map +0 -1
- package/dist/src/cli/commands/init-multiproject.d.ts +0 -11
- package/dist/src/cli/commands/init-multiproject.d.ts.map +0 -1
- package/dist/src/cli/commands/init-multiproject.js +0 -202
- package/dist/src/cli/commands/init-multiproject.js.map +0 -1
- package/dist/src/cli/commands/init.d.ts +0 -9
- package/dist/src/cli/commands/init.d.ts.map +0 -1
- package/dist/src/cli/commands/init.js +0 -1444
- package/dist/src/cli/commands/init.js.map +0 -1
- package/dist/src/cli/commands/install.d.ts +0 -9
- package/dist/src/cli/commands/install.d.ts.map +0 -1
- package/dist/src/cli/commands/install.js +0 -127
- package/dist/src/cli/commands/install.js.map +0 -1
- package/dist/src/cli/commands/list.d.ts +0 -8
- package/dist/src/cli/commands/list.d.ts.map +0 -1
- package/dist/src/cli/commands/list.js +0 -119
- package/dist/src/cli/commands/list.js.map +0 -1
- package/dist/src/cli/commands/migrate-to-multiproject.d.ts +0 -37
- package/dist/src/cli/commands/migrate-to-multiproject.d.ts.map +0 -1
- package/dist/src/cli/commands/migrate-to-multiproject.js +0 -189
- package/dist/src/cli/commands/migrate-to-multiproject.js.map +0 -1
- package/dist/src/cli/commands/migrate-to-profiles.d.ts +0 -25
- package/dist/src/cli/commands/migrate-to-profiles.d.ts.map +0 -1
- package/dist/src/cli/commands/migrate-to-profiles.js +0 -350
- package/dist/src/cli/commands/migrate-to-profiles.js.map +0 -1
- package/dist/src/cli/commands/pause.d.ts +0 -13
- package/dist/src/cli/commands/pause.d.ts.map +0 -1
- package/dist/src/cli/commands/pause.js +0 -15
- package/dist/src/cli/commands/pause.js.map +0 -1
- package/dist/src/cli/commands/qa.d.ts +0 -54
- package/dist/src/cli/commands/qa.d.ts.map +0 -1
- package/dist/src/cli/commands/qa.js +0 -98
- package/dist/src/cli/commands/qa.js.map +0 -1
- package/dist/src/cli/commands/resume.d.ts +0 -12
- package/dist/src/cli/commands/resume.d.ts.map +0 -1
- package/dist/src/cli/commands/resume.js +0 -14
- package/dist/src/cli/commands/resume.js.map +0 -1
- package/dist/src/cli/commands/status.d.ts +0 -12
- package/dist/src/cli/commands/status.d.ts.map +0 -1
- package/dist/src/cli/commands/status.js +0 -23
- package/dist/src/cli/commands/status.js.map +0 -1
- package/dist/src/cli/commands/switch-project.d.ts +0 -13
- package/dist/src/cli/commands/switch-project.d.ts.map +0 -1
- package/dist/src/cli/commands/switch-project.js +0 -91
- package/dist/src/cli/commands/switch-project.js.map +0 -1
- package/dist/src/cli/commands/validate-jira.d.ts +0 -35
- package/dist/src/cli/commands/validate-jira.d.ts.map +0 -1
- package/dist/src/cli/commands/validate-jira.js +0 -112
- package/dist/src/cli/commands/validate-jira.js.map +0 -1
- package/dist/src/cli/commands/validate-plugins.d.ts +0 -41
- package/dist/src/cli/commands/validate-plugins.d.ts.map +0 -1
- package/dist/src/cli/commands/validate-plugins.js +0 -171
- package/dist/src/cli/commands/validate-plugins.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/ado.d.ts +0 -57
- package/dist/src/cli/helpers/issue-tracker/ado.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/ado.js +0 -243
- package/dist/src/cli/helpers/issue-tracker/ado.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/github.d.ts +0 -65
- package/dist/src/cli/helpers/issue-tracker/github.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/github.js +0 -426
- package/dist/src/cli/helpers/issue-tracker/github.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/index.d.ts +0 -22
- package/dist/src/cli/helpers/issue-tracker/index.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/index.js +0 -314
- package/dist/src/cli/helpers/issue-tracker/index.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/jira.d.ts +0 -61
- package/dist/src/cli/helpers/issue-tracker/jira.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/jira.js +0 -404
- package/dist/src/cli/helpers/issue-tracker/jira.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/types.d.ts +0 -108
- package/dist/src/cli/helpers/issue-tracker/types.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/types.js +0 -16
- package/dist/src/cli/helpers/issue-tracker/types.js.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/utils.d.ts +0 -112
- package/dist/src/cli/helpers/issue-tracker/utils.d.ts.map +0 -1
- package/dist/src/cli/helpers/issue-tracker/utils.js +0 -247
- package/dist/src/cli/helpers/issue-tracker/utils.js.map +0 -1
- package/dist/src/core/agent-model-manager.d.ts +0 -52
- package/dist/src/core/agent-model-manager.d.ts.map +0 -1
- package/dist/src/core/agent-model-manager.js +0 -120
- package/dist/src/core/agent-model-manager.js.map +0 -1
- package/dist/src/core/brownfield/analyzer.d.ts +0 -86
- package/dist/src/core/brownfield/analyzer.d.ts.map +0 -1
- package/dist/src/core/brownfield/analyzer.js +0 -365
- package/dist/src/core/brownfield/analyzer.js.map +0 -1
- package/dist/src/core/brownfield/importer.d.ts +0 -76
- package/dist/src/core/brownfield/importer.d.ts.map +0 -1
- package/dist/src/core/brownfield/importer.js +0 -287
- package/dist/src/core/brownfield/importer.js.map +0 -1
- package/dist/src/core/config-manager.d.ts +0 -47
- package/dist/src/core/config-manager.d.ts.map +0 -1
- package/dist/src/core/config-manager.js +0 -136
- package/dist/src/core/config-manager.js.map +0 -1
- package/dist/src/core/cost-tracker.d.ts +0 -108
- package/dist/src/core/cost-tracker.d.ts.map +0 -1
- package/dist/src/core/cost-tracker.js +0 -281
- package/dist/src/core/cost-tracker.js.map +0 -1
- package/dist/src/core/credentials-manager.d.ts +0 -107
- package/dist/src/core/credentials-manager.d.ts.map +0 -1
- package/dist/src/core/credentials-manager.js +0 -457
- package/dist/src/core/credentials-manager.js.map +0 -1
- package/dist/src/core/i18n/language-detector.d.ts +0 -29
- package/dist/src/core/i18n/language-detector.d.ts.map +0 -1
- package/dist/src/core/i18n/language-detector.js +0 -143
- package/dist/src/core/i18n/language-detector.js.map +0 -1
- package/dist/src/core/i18n/language-manager.d.ts +0 -101
- package/dist/src/core/i18n/language-manager.d.ts.map +0 -1
- package/dist/src/core/i18n/language-manager.js +0 -232
- package/dist/src/core/i18n/language-manager.js.map +0 -1
- package/dist/src/core/i18n/language-registry.d.ts +0 -44
- package/dist/src/core/i18n/language-registry.d.ts.map +0 -1
- package/dist/src/core/i18n/language-registry.js +0 -234
- package/dist/src/core/i18n/language-registry.js.map +0 -1
- package/dist/src/core/i18n/locale-manager.d.ts +0 -62
- package/dist/src/core/i18n/locale-manager.d.ts.map +0 -1
- package/dist/src/core/i18n/locale-manager.js +0 -137
- package/dist/src/core/i18n/locale-manager.js.map +0 -1
- package/dist/src/core/i18n/system-prompt-injector.d.ts +0 -33
- package/dist/src/core/i18n/system-prompt-injector.d.ts.map +0 -1
- package/dist/src/core/i18n/system-prompt-injector.js +0 -131
- package/dist/src/core/i18n/system-prompt-injector.js.map +0 -1
- package/dist/src/core/i18n/types.d.ts +0 -151
- package/dist/src/core/i18n/types.d.ts.map +0 -1
- package/dist/src/core/i18n/types.js +0 -11
- package/dist/src/core/i18n/types.js.map +0 -1
- package/dist/src/core/increment/limits.d.ts +0 -68
- package/dist/src/core/increment/limits.d.ts.map +0 -1
- package/dist/src/core/increment/limits.js +0 -224
- package/dist/src/core/increment/limits.js.map +0 -1
- package/dist/src/core/increment/metadata-manager.d.ts +0 -114
- package/dist/src/core/increment/metadata-manager.d.ts.map +0 -1
- package/dist/src/core/increment/metadata-manager.js +0 -320
- package/dist/src/core/increment/metadata-manager.js.map +0 -1
- package/dist/src/core/increment/status-commands.d.ts +0 -43
- package/dist/src/core/increment/status-commands.d.ts.map +0 -1
- package/dist/src/core/increment/status-commands.js +0 -277
- package/dist/src/core/increment/status-commands.js.map +0 -1
- package/dist/src/core/increment-status.d.ts +0 -72
- package/dist/src/core/increment-status.d.ts.map +0 -1
- package/dist/src/core/increment-status.js +0 -227
- package/dist/src/core/increment-status.js.map +0 -1
- package/dist/src/core/model-selector.d.ts +0 -57
- package/dist/src/core/model-selector.d.ts.map +0 -1
- package/dist/src/core/model-selector.js +0 -115
- package/dist/src/core/model-selector.js.map +0 -1
- package/dist/src/core/phase-detector.d.ts +0 -62
- package/dist/src/core/phase-detector.d.ts.map +0 -1
- package/dist/src/core/phase-detector.js +0 -229
- package/dist/src/core/phase-detector.js.map +0 -1
- package/dist/src/core/plugin-loader.d.ts +0 -131
- package/dist/src/core/plugin-loader.d.ts.map +0 -1
- package/dist/src/core/plugin-loader.js +0 -421
- package/dist/src/core/plugin-loader.js.map +0 -1
- package/dist/src/core/project-manager.d.ts +0 -127
- package/dist/src/core/project-manager.d.ts.map +0 -1
- package/dist/src/core/project-manager.js +0 -524
- package/dist/src/core/project-manager.js.map +0 -1
- package/dist/src/core/project-structure-detector.d.ts +0 -92
- package/dist/src/core/project-structure-detector.d.ts.map +0 -1
- package/dist/src/core/project-structure-detector.js +0 -289
- package/dist/src/core/project-structure-detector.js.map +0 -1
- package/dist/src/core/qa/qa-runner.d.ts +0 -16
- package/dist/src/core/qa/qa-runner.d.ts.map +0 -1
- package/dist/src/core/qa/qa-runner.js +0 -404
- package/dist/src/core/qa/qa-runner.js.map +0 -1
- package/dist/src/core/qa/quality-gate-decider.d.ts +0 -53
- package/dist/src/core/qa/quality-gate-decider.d.ts.map +0 -1
- package/dist/src/core/qa/quality-gate-decider.js +0 -268
- package/dist/src/core/qa/quality-gate-decider.js.map +0 -1
- package/dist/src/core/qa/risk-calculator.d.ts +0 -126
- package/dist/src/core/qa/risk-calculator.d.ts.map +0 -1
- package/dist/src/core/qa/risk-calculator.js +0 -247
- package/dist/src/core/qa/risk-calculator.js.map +0 -1
- package/dist/src/core/qa/types.d.ts +0 -315
- package/dist/src/core/qa/types.d.ts.map +0 -1
- package/dist/src/core/qa/types.js +0 -8
- package/dist/src/core/qa/types.js.map +0 -1
- package/dist/src/core/rfc-generator-v2.d.ts +0 -149
- package/dist/src/core/rfc-generator-v2.d.ts.map +0 -1
- package/dist/src/core/rfc-generator-v2.js +0 -399
- package/dist/src/core/rfc-generator-v2.js.map +0 -1
- package/dist/src/core/specs/spec-metadata-manager.d.ts +0 -70
- package/dist/src/core/specs/spec-metadata-manager.d.ts.map +0 -1
- package/dist/src/core/specs/spec-metadata-manager.js +0 -371
- package/dist/src/core/specs/spec-metadata-manager.js.map +0 -1
- package/dist/src/core/specs/spec-parser.d.ts +0 -66
- package/dist/src/core/specs/spec-parser.d.ts.map +0 -1
- package/dist/src/core/specs/spec-parser.js +0 -276
- package/dist/src/core/specs/spec-parser.js.map +0 -1
- package/dist/src/core/sync/bidirectional-engine.d.ts +0 -110
- package/dist/src/core/sync/bidirectional-engine.d.ts.map +0 -1
- package/dist/src/core/sync/bidirectional-engine.js +0 -356
- package/dist/src/core/sync/bidirectional-engine.js.map +0 -1
- package/dist/src/core/sync/folder-mapper.d.ts +0 -71
- package/dist/src/core/sync/folder-mapper.d.ts.map +0 -1
- package/dist/src/core/sync/folder-mapper.js +0 -168
- package/dist/src/core/sync/folder-mapper.js.map +0 -1
- package/dist/src/core/sync/profile-manager.d.ts +0 -72
- package/dist/src/core/sync/profile-manager.d.ts.map +0 -1
- package/dist/src/core/sync/profile-manager.js +0 -338
- package/dist/src/core/sync/profile-manager.js.map +0 -1
- package/dist/src/core/sync/profile-selector.d.ts +0 -52
- package/dist/src/core/sync/profile-selector.d.ts.map +0 -1
- package/dist/src/core/sync/profile-selector.js +0 -179
- package/dist/src/core/sync/profile-selector.js.map +0 -1
- package/dist/src/core/sync/profile-validator.d.ts +0 -52
- package/dist/src/core/sync/profile-validator.d.ts.map +0 -1
- package/dist/src/core/sync/profile-validator.js +0 -225
- package/dist/src/core/sync/profile-validator.js.map +0 -1
- package/dist/src/core/sync/project-context.d.ts +0 -81
- package/dist/src/core/sync/project-context.d.ts.map +0 -1
- package/dist/src/core/sync/project-context.js +0 -354
- package/dist/src/core/sync/project-context.js.map +0 -1
- package/dist/src/core/sync/rate-limiter.d.ts +0 -116
- package/dist/src/core/sync/rate-limiter.d.ts.map +0 -1
- package/dist/src/core/sync/rate-limiter.js +0 -308
- package/dist/src/core/sync/rate-limiter.js.map +0 -1
- package/dist/src/core/sync/time-range-selector.d.ts +0 -48
- package/dist/src/core/sync/time-range-selector.d.ts.map +0 -1
- package/dist/src/core/sync/time-range-selector.js +0 -224
- package/dist/src/core/sync/time-range-selector.js.map +0 -1
- package/dist/src/core/types/config.d.ts +0 -90
- package/dist/src/core/types/config.d.ts.map +0 -1
- package/dist/src/core/types/config.js +0 -44
- package/dist/src/core/types/config.js.map +0 -1
- package/dist/src/core/types/increment-metadata.d.ts +0 -120
- package/dist/src/core/types/increment-metadata.d.ts.map +0 -1
- package/dist/src/core/types/increment-metadata.js +0 -138
- package/dist/src/core/types/increment-metadata.js.map +0 -1
- package/dist/src/core/types/plugin.d.ts +0 -283
- package/dist/src/core/types/plugin.d.ts.map +0 -1
- package/dist/src/core/types/plugin.js +0 -49
- package/dist/src/core/types/plugin.js.map +0 -1
- package/dist/src/core/types/spec-metadata.d.ts +0 -229
- package/dist/src/core/types/spec-metadata.d.ts.map +0 -1
- package/dist/src/core/types/spec-metadata.js +0 -14
- package/dist/src/core/types/spec-metadata.js.map +0 -1
- package/dist/src/core/types/sync-profile.d.ts +0 -403
- package/dist/src/core/types/sync-profile.d.ts.map +0 -1
- package/dist/src/core/types/sync-profile.js +0 -55
- package/dist/src/core/types/sync-profile.js.map +0 -1
- package/dist/src/hooks/lib/git-diff-analyzer.d.ts +0 -89
- package/dist/src/hooks/lib/git-diff-analyzer.d.ts.map +0 -1
- package/dist/src/hooks/lib/git-diff-analyzer.js +0 -226
- package/dist/src/hooks/lib/git-diff-analyzer.js.map +0 -1
- package/dist/src/hooks/lib/invoke-translator-skill.d.ts +0 -60
- package/dist/src/hooks/lib/invoke-translator-skill.d.ts.map +0 -1
- package/dist/src/hooks/lib/invoke-translator-skill.js +0 -201
- package/dist/src/hooks/lib/invoke-translator-skill.js.map +0 -1
- package/dist/src/hooks/lib/prepare-reflection-context.d.ts +0 -42
- package/dist/src/hooks/lib/prepare-reflection-context.d.ts.map +0 -1
- package/dist/src/hooks/lib/prepare-reflection-context.js +0 -123
- package/dist/src/hooks/lib/prepare-reflection-context.js.map +0 -1
- package/dist/src/hooks/lib/reflection-config-loader.d.ts +0 -45
- package/dist/src/hooks/lib/reflection-config-loader.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-config-loader.js +0 -132
- package/dist/src/hooks/lib/reflection-config-loader.js.map +0 -1
- package/dist/src/hooks/lib/reflection-parser.d.ts +0 -33
- package/dist/src/hooks/lib/reflection-parser.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-parser.js +0 -419
- package/dist/src/hooks/lib/reflection-parser.js.map +0 -1
- package/dist/src/hooks/lib/reflection-prompt-builder.d.ts +0 -56
- package/dist/src/hooks/lib/reflection-prompt-builder.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-prompt-builder.js +0 -239
- package/dist/src/hooks/lib/reflection-prompt-builder.js.map +0 -1
- package/dist/src/hooks/lib/reflection-storage.d.ts +0 -64
- package/dist/src/hooks/lib/reflection-storage.d.ts.map +0 -1
- package/dist/src/hooks/lib/reflection-storage.js +0 -305
- package/dist/src/hooks/lib/reflection-storage.js.map +0 -1
- package/dist/src/hooks/lib/run-self-reflection.d.ts +0 -43
- package/dist/src/hooks/lib/run-self-reflection.d.ts.map +0 -1
- package/dist/src/hooks/lib/run-self-reflection.js +0 -203
- package/dist/src/hooks/lib/run-self-reflection.js.map +0 -1
- package/dist/src/hooks/lib/sync-living-docs.d.ts +0 -27
- package/dist/src/hooks/lib/sync-living-docs.d.ts.map +0 -1
- package/dist/src/hooks/lib/sync-living-docs.js +0 -116
- package/dist/src/hooks/lib/sync-living-docs.js.map +0 -1
- package/dist/src/hooks/lib/translate-file.d.ts +0 -59
- package/dist/src/hooks/lib/translate-file.d.ts.map +0 -1
- package/dist/src/hooks/lib/translate-file.js +0 -350
- package/dist/src/hooks/lib/translate-file.js.map +0 -1
- package/dist/src/hooks/lib/translate-living-docs.d.ts +0 -13
- package/dist/src/hooks/lib/translate-living-docs.d.ts.map +0 -1
- package/dist/src/hooks/lib/translate-living-docs.js +0 -175
- package/dist/src/hooks/lib/translate-living-docs.js.map +0 -1
- package/dist/src/hooks/lib/types/reflection-types.d.ts +0 -164
- package/dist/src/hooks/lib/types/reflection-types.d.ts.map +0 -1
- package/dist/src/hooks/lib/types/reflection-types.js +0 -73
- package/dist/src/hooks/lib/types/reflection-types.js.map +0 -1
- package/dist/src/hooks/lib/update-tasks-md.d.ts +0 -29
- package/dist/src/hooks/lib/update-tasks-md.d.ts.map +0 -1
- package/dist/src/hooks/lib/update-tasks-md.js +0 -203
- package/dist/src/hooks/lib/update-tasks-md.js.map +0 -1
- package/dist/src/integrations/ado/ado-client.d.ts +0 -127
- package/dist/src/integrations/ado/ado-client.d.ts.map +0 -1
- package/dist/src/integrations/ado/ado-client.js +0 -416
- package/dist/src/integrations/ado/ado-client.js.map +0 -1
- package/dist/src/integrations/jira/jira-client.d.ts +0 -139
- package/dist/src/integrations/jira/jira-client.d.ts.map +0 -1
- package/dist/src/integrations/jira/jira-client.js +0 -386
- package/dist/src/integrations/jira/jira-client.js.map +0 -1
- package/dist/src/integrations/jira/jira-incremental-mapper.d.ts +0 -75
- package/dist/src/integrations/jira/jira-incremental-mapper.d.ts.map +0 -1
- package/dist/src/integrations/jira/jira-incremental-mapper.js +0 -474
- package/dist/src/integrations/jira/jira-incremental-mapper.js.map +0 -1
- package/dist/src/integrations/jira/jira-mapper.d.ts +0 -105
- package/dist/src/integrations/jira/jira-mapper.d.ts.map +0 -1
- package/dist/src/integrations/jira/jira-mapper.js +0 -494
- package/dist/src/integrations/jira/jira-mapper.js.map +0 -1
- package/dist/src/metrics/calculators/change-failure-rate.d.ts +0 -22
- package/dist/src/metrics/calculators/change-failure-rate.d.ts.map +0 -1
- package/dist/src/metrics/calculators/change-failure-rate.js +0 -70
- package/dist/src/metrics/calculators/change-failure-rate.js.map +0 -1
- package/dist/src/metrics/calculators/deployment-frequency.d.ts +0 -20
- package/dist/src/metrics/calculators/deployment-frequency.d.ts.map +0 -1
- package/dist/src/metrics/calculators/deployment-frequency.js +0 -61
- package/dist/src/metrics/calculators/deployment-frequency.js.map +0 -1
- package/dist/src/metrics/calculators/lead-time.d.ts +0 -22
- package/dist/src/metrics/calculators/lead-time.d.ts.map +0 -1
- package/dist/src/metrics/calculators/lead-time.js +0 -82
- package/dist/src/metrics/calculators/lead-time.js.map +0 -1
- package/dist/src/metrics/calculators/mttr.d.ts +0 -21
- package/dist/src/metrics/calculators/mttr.d.ts.map +0 -1
- package/dist/src/metrics/calculators/mttr.js +0 -60
- package/dist/src/metrics/calculators/mttr.js.map +0 -1
- package/dist/src/metrics/dora-calculator.d.ts +0 -28
- package/dist/src/metrics/dora-calculator.d.ts.map +0 -1
- package/dist/src/metrics/dora-calculator.js +0 -117
- package/dist/src/metrics/dora-calculator.js.map +0 -1
- package/dist/src/metrics/github-client.d.ts +0 -51
- package/dist/src/metrics/github-client.d.ts.map +0 -1
- package/dist/src/metrics/github-client.js +0 -133
- package/dist/src/metrics/github-client.js.map +0 -1
- package/dist/src/metrics/report-generator.d.ts +0 -17
- package/dist/src/metrics/report-generator.d.ts.map +0 -1
- package/dist/src/metrics/report-generator.js +0 -403
- package/dist/src/metrics/report-generator.js.map +0 -1
- package/dist/src/metrics/types.d.ts +0 -112
- package/dist/src/metrics/types.d.ts.map +0 -1
- package/dist/src/metrics/types.js +0 -10
- package/dist/src/metrics/types.js.map +0 -1
- package/dist/src/metrics/utils/percentile.d.ts +0 -25
- package/dist/src/metrics/utils/percentile.d.ts.map +0 -1
- package/dist/src/metrics/utils/percentile.js +0 -46
- package/dist/src/metrics/utils/percentile.js.map +0 -1
- package/dist/src/metrics/utils/tier-classifier.d.ts +0 -61
- package/dist/src/metrics/utils/tier-classifier.d.ts.map +0 -1
- package/dist/src/metrics/utils/tier-classifier.js +0 -100
- package/dist/src/metrics/utils/tier-classifier.js.map +0 -1
- package/dist/src/testing/test-generator.d.ts +0 -117
- package/dist/src/testing/test-generator.d.ts.map +0 -1
- package/dist/src/testing/test-generator.js +0 -370
- package/dist/src/testing/test-generator.js.map +0 -1
- package/dist/src/types/cost-tracking.d.ts +0 -43
- package/dist/src/types/cost-tracking.d.ts.map +0 -1
- package/dist/src/types/cost-tracking.js +0 -8
- package/dist/src/types/cost-tracking.js.map +0 -1
- package/dist/src/types/model-selection.d.ts +0 -53
- package/dist/src/types/model-selection.d.ts.map +0 -1
- package/dist/src/types/model-selection.js +0 -12
- package/dist/src/types/model-selection.js.map +0 -1
- package/dist/src/utils/agents-md-compiler.d.ts +0 -68
- package/dist/src/utils/agents-md-compiler.d.ts.map +0 -1
- package/dist/src/utils/agents-md-compiler.js +0 -420
- package/dist/src/utils/agents-md-compiler.js.map +0 -1
- package/dist/src/utils/auth-helpers.d.ts +0 -58
- package/dist/src/utils/auth-helpers.d.ts.map +0 -1
- package/dist/src/utils/auth-helpers.js +0 -108
- package/dist/src/utils/auth-helpers.js.map +0 -1
- package/dist/src/utils/auto-install.d.ts +0 -47
- package/dist/src/utils/auto-install.d.ts.map +0 -1
- package/dist/src/utils/auto-install.js +0 -211
- package/dist/src/utils/auto-install.js.map +0 -1
- package/dist/src/utils/claude-cli-detector.d.ts +0 -75
- package/dist/src/utils/claude-cli-detector.d.ts.map +0 -1
- package/dist/src/utils/claude-cli-detector.js +0 -285
- package/dist/src/utils/claude-cli-detector.js.map +0 -1
- package/dist/src/utils/cost-reporter.d.ts +0 -58
- package/dist/src/utils/cost-reporter.d.ts.map +0 -1
- package/dist/src/utils/cost-reporter.js +0 -224
- package/dist/src/utils/cost-reporter.js.map +0 -1
- package/dist/src/utils/docs-preview/config-generator.d.ts +0 -46
- package/dist/src/utils/docs-preview/config-generator.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/config-generator.js +0 -377
- package/dist/src/utils/docs-preview/config-generator.js.map +0 -1
- package/dist/src/utils/docs-preview/docusaurus-setup.d.ts +0 -38
- package/dist/src/utils/docs-preview/docusaurus-setup.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/docusaurus-setup.js +0 -177
- package/dist/src/utils/docs-preview/docusaurus-setup.js.map +0 -1
- package/dist/src/utils/docs-preview/index.d.ts +0 -7
- package/dist/src/utils/docs-preview/index.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/index.js +0 -7
- package/dist/src/utils/docs-preview/index.js.map +0 -1
- package/dist/src/utils/docs-preview/package-installer.d.ts +0 -42
- package/dist/src/utils/docs-preview/package-installer.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/package-installer.js +0 -182
- package/dist/src/utils/docs-preview/package-installer.js.map +0 -1
- package/dist/src/utils/docs-preview/server-manager.d.ts +0 -30
- package/dist/src/utils/docs-preview/server-manager.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/server-manager.js +0 -212
- package/dist/src/utils/docs-preview/server-manager.js.map +0 -1
- package/dist/src/utils/docs-preview/sidebar-builder.d.ts +0 -32
- package/dist/src/utils/docs-preview/sidebar-builder.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/sidebar-builder.js +0 -202
- package/dist/src/utils/docs-preview/sidebar-builder.js.map +0 -1
- package/dist/src/utils/docs-preview/types.d.ts +0 -57
- package/dist/src/utils/docs-preview/types.d.ts.map +0 -1
- package/dist/src/utils/docs-preview/types.js +0 -2
- package/dist/src/utils/docs-preview/types.js.map +0 -1
- package/dist/src/utils/env-file.d.ts +0 -88
- package/dist/src/utils/env-file.d.ts.map +0 -1
- package/dist/src/utils/env-file.js +0 -180
- package/dist/src/utils/env-file.js.map +0 -1
- package/dist/src/utils/env-multi-project-parser.d.ts +0 -220
- package/dist/src/utils/env-multi-project-parser.d.ts.map +0 -1
- package/dist/src/utils/env-multi-project-parser.js +0 -403
- package/dist/src/utils/env-multi-project-parser.js.map +0 -1
- package/dist/src/utils/esm-helpers.d.ts +0 -50
- package/dist/src/utils/esm-helpers.d.ts.map +0 -1
- package/dist/src/utils/esm-helpers.js +0 -57
- package/dist/src/utils/esm-helpers.js.map +0 -1
- package/dist/src/utils/execFileNoThrow.d.ts +0 -99
- package/dist/src/utils/execFileNoThrow.d.ts.map +0 -1
- package/dist/src/utils/execFileNoThrow.js +0 -137
- package/dist/src/utils/execFileNoThrow.js.map +0 -1
- package/dist/src/utils/external-resource-validator.d.ts +0 -102
- package/dist/src/utils/external-resource-validator.d.ts.map +0 -1
- package/dist/src/utils/external-resource-validator.js +0 -442
- package/dist/src/utils/external-resource-validator.js.map +0 -1
- package/dist/src/utils/generate-skills-index.d.ts +0 -24
- package/dist/src/utils/generate-skills-index.d.ts.map +0 -1
- package/dist/src/utils/generate-skills-index.js +0 -410
- package/dist/src/utils/generate-skills-index.js.map +0 -1
- package/dist/src/utils/model-selection.d.ts +0 -75
- package/dist/src/utils/model-selection.d.ts.map +0 -1
- package/dist/src/utils/model-selection.js +0 -204
- package/dist/src/utils/model-selection.js.map +0 -1
- package/dist/src/utils/plugin-validator.d.ts +0 -161
- package/dist/src/utils/plugin-validator.d.ts.map +0 -1
- package/dist/src/utils/plugin-validator.js +0 -558
- package/dist/src/utils/plugin-validator.js.map +0 -1
- package/dist/src/utils/pricing-constants.d.ts +0 -70
- package/dist/src/utils/pricing-constants.d.ts.map +0 -1
- package/dist/src/utils/pricing-constants.js +0 -71
- package/dist/src/utils/pricing-constants.js.map +0 -1
- package/dist/src/utils/project-detection.d.ts +0 -141
- package/dist/src/utils/project-detection.d.ts.map +0 -1
- package/dist/src/utils/project-detection.js +0 -321
- package/dist/src/utils/project-detection.js.map +0 -1
- package/dist/src/utils/string-utils.d.ts +0 -40
- package/dist/src/utils/string-utils.d.ts.map +0 -1
- package/dist/src/utils/string-utils.js +0 -58
- package/dist/src/utils/string-utils.js.map +0 -1
- package/dist/src/utils/translation.d.ts +0 -187
- package/dist/src/utils/translation.d.ts.map +0 -1
- package/dist/src/utils/translation.js +0 -414
- package/dist/src/utils/translation.js.map +0 -1
|
@@ -1,268 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Quality Gate Decider - PASS/CONCERNS/FAIL decision logic
|
|
3
|
-
*
|
|
4
|
-
* @module qa/quality-gate-decider
|
|
5
|
-
* @since v0.8.0
|
|
6
|
-
*/
|
|
7
|
-
/**
|
|
8
|
-
* Default quality gate thresholds (BMAD pattern)
|
|
9
|
-
*/
|
|
10
|
-
export const DEFAULT_THRESHOLDS = {
|
|
11
|
-
fail: {
|
|
12
|
-
riskScore: 9.0, // Risk >= 9.0 → FAIL
|
|
13
|
-
testCoverage: 60, // Coverage < 60% → FAIL
|
|
14
|
-
specQuality: 50, // Spec score < 50 → FAIL
|
|
15
|
-
criticalVulnerabilities: 1, // Critical vulns >= 1 → FAIL
|
|
16
|
-
},
|
|
17
|
-
concerns: {
|
|
18
|
-
riskScore: 6.0, // Risk >= 6.0 → CONCERNS
|
|
19
|
-
testCoverage: 80, // Coverage < 80% → CONCERNS
|
|
20
|
-
specQuality: 70, // Spec score < 70 → CONCERNS
|
|
21
|
-
highVulnerabilities: 1, // High vulns >= 1 → CONCERNS
|
|
22
|
-
},
|
|
23
|
-
};
|
|
24
|
-
export class QualityGateDecider {
|
|
25
|
-
constructor(thresholds = DEFAULT_THRESHOLDS) {
|
|
26
|
-
this.thresholds = thresholds;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Main decision logic - determine PASS/CONCERNS/FAIL
|
|
30
|
-
*
|
|
31
|
-
* @param assessment - Quality assessment result from AI judge
|
|
32
|
-
* @param testCoverage - Optional test coverage result
|
|
33
|
-
* @param securityAudit - Optional security audit result
|
|
34
|
-
* @returns Quality gate result with decision and issues
|
|
35
|
-
*/
|
|
36
|
-
decide(assessment, testCoverage, securityAudit) {
|
|
37
|
-
const blockers = [];
|
|
38
|
-
const concerns = [];
|
|
39
|
-
const recommendations = [];
|
|
40
|
-
// Check 1: Risk Assessment (BMAD pattern)
|
|
41
|
-
if (assessment.risk_assessment) {
|
|
42
|
-
this.assessRisks(assessment.risk_assessment, blockers, concerns);
|
|
43
|
-
}
|
|
44
|
-
// Check 2: Test Coverage
|
|
45
|
-
if (testCoverage) {
|
|
46
|
-
this.assessTestCoverage(testCoverage, blockers, concerns);
|
|
47
|
-
}
|
|
48
|
-
// Check 3: Spec Quality
|
|
49
|
-
this.assessSpecQuality(assessment, blockers, concerns, recommendations);
|
|
50
|
-
// Check 4: Security Vulnerabilities
|
|
51
|
-
if (securityAudit) {
|
|
52
|
-
this.assessSecurity(securityAudit, blockers, concerns);
|
|
53
|
-
}
|
|
54
|
-
// Make final decision
|
|
55
|
-
const { decision, reasoning } = this.makeDecision(blockers, concerns);
|
|
56
|
-
return {
|
|
57
|
-
decision,
|
|
58
|
-
blockers,
|
|
59
|
-
concerns,
|
|
60
|
-
recommendations,
|
|
61
|
-
reasoning,
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Assess risks and categorize into blockers/concerns
|
|
66
|
-
*/
|
|
67
|
-
assessRisks(riskAssessment, blockers, concerns) {
|
|
68
|
-
const overallRisk = riskAssessment.overall_risk_score;
|
|
69
|
-
// Check overall risk score first
|
|
70
|
-
if (overallRisk >= this.thresholds.fail.riskScore) {
|
|
71
|
-
// Find all critical risks (score >= 9.0)
|
|
72
|
-
const criticalRisks = riskAssessment.risks.filter((r) => r.score >= this.thresholds.fail.riskScore);
|
|
73
|
-
for (const risk of criticalRisks) {
|
|
74
|
-
blockers.push({
|
|
75
|
-
type: 'risk',
|
|
76
|
-
severity: 'critical',
|
|
77
|
-
title: `CRITICAL RISK: ${risk.title}`,
|
|
78
|
-
description: `${risk.description} (Score: ${risk.score.toFixed(1)}/10)`,
|
|
79
|
-
mitigation: risk.mitigation,
|
|
80
|
-
location: risk.location,
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
else if (overallRisk >= this.thresholds.concerns.riskScore) {
|
|
85
|
-
// Find all high risks (score 6.0-8.9)
|
|
86
|
-
const highRisks = riskAssessment.risks.filter((r) => r.score >= this.thresholds.concerns.riskScore &&
|
|
87
|
-
r.score < this.thresholds.fail.riskScore);
|
|
88
|
-
for (const risk of highRisks) {
|
|
89
|
-
concerns.push({
|
|
90
|
-
type: 'risk',
|
|
91
|
-
severity: 'high',
|
|
92
|
-
title: `HIGH RISK: ${risk.title}`,
|
|
93
|
-
description: `${risk.description} (Score: ${risk.score.toFixed(1)}/10)`,
|
|
94
|
-
mitigation: risk.mitigation,
|
|
95
|
-
location: risk.location,
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Assess test coverage and identify gaps
|
|
102
|
-
*/
|
|
103
|
-
assessTestCoverage(testCoverage, blockers, concerns) {
|
|
104
|
-
const coverage = testCoverage.coverage_percentage;
|
|
105
|
-
if (coverage < this.thresholds.fail.testCoverage) {
|
|
106
|
-
blockers.push({
|
|
107
|
-
type: 'test_coverage',
|
|
108
|
-
severity: 'critical',
|
|
109
|
-
title: 'Insufficient test coverage',
|
|
110
|
-
description: `Coverage is ${coverage}% (minimum: ${this.thresholds.fail.testCoverage}%)`,
|
|
111
|
-
mitigation: `Add tests to reach ${this.thresholds.fail.testCoverage}% coverage`,
|
|
112
|
-
});
|
|
113
|
-
}
|
|
114
|
-
else if (coverage < this.thresholds.concerns.testCoverage) {
|
|
115
|
-
concerns.push({
|
|
116
|
-
type: 'test_coverage',
|
|
117
|
-
severity: 'high',
|
|
118
|
-
title: 'Test coverage below target',
|
|
119
|
-
description: `Coverage is ${coverage}% (target: ${this.thresholds.concerns.testCoverage}%)`,
|
|
120
|
-
mitigation: `Add tests to reach ${this.thresholds.concerns.testCoverage}% coverage`,
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
// Check for AC-ID coverage gaps
|
|
124
|
-
for (const gap of testCoverage.gaps) {
|
|
125
|
-
concerns.push({
|
|
126
|
-
type: 'test_gap',
|
|
127
|
-
severity: 'high',
|
|
128
|
-
title: `Missing test: ${gap.acceptance_criteria}`,
|
|
129
|
-
description: gap.description,
|
|
130
|
-
mitigation: gap.recommendation,
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
/**
|
|
135
|
-
* Assess specification quality
|
|
136
|
-
*/
|
|
137
|
-
assessSpecQuality(assessment, blockers, concerns, recommendations) {
|
|
138
|
-
const score = assessment.overall_score;
|
|
139
|
-
if (score < this.thresholds.fail.specQuality) {
|
|
140
|
-
blockers.push({
|
|
141
|
-
type: 'spec_quality',
|
|
142
|
-
severity: 'critical',
|
|
143
|
-
title: 'Specification quality unacceptable',
|
|
144
|
-
description: `Score is ${score}/100 (minimum: ${this.thresholds.fail.specQuality})`,
|
|
145
|
-
mitigation: 'Revise spec to address critical issues',
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
else if (score < this.thresholds.concerns.specQuality) {
|
|
149
|
-
concerns.push({
|
|
150
|
-
type: 'spec_quality',
|
|
151
|
-
severity: 'high',
|
|
152
|
-
title: 'Specification quality needs improvement',
|
|
153
|
-
description: `Score is ${score}/100 (target: ${this.thresholds.concerns.specQuality})`,
|
|
154
|
-
mitigation: 'Address HIGH priority suggestions',
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
// Add dimension-specific issues
|
|
158
|
-
for (const issue of assessment.issues) {
|
|
159
|
-
const gateIssue = {
|
|
160
|
-
type: `spec_${issue.dimension}`,
|
|
161
|
-
severity: issue.severity === 'critical' ? 'critical' : issue.severity === 'major' ? 'high' : 'medium',
|
|
162
|
-
title: `${issue.dimension.toUpperCase()}: ${issue.description}`,
|
|
163
|
-
description: issue.impact,
|
|
164
|
-
location: issue.location,
|
|
165
|
-
};
|
|
166
|
-
if (issue.severity === 'critical') {
|
|
167
|
-
blockers.push(gateIssue);
|
|
168
|
-
}
|
|
169
|
-
else if (issue.severity === 'major') {
|
|
170
|
-
concerns.push(gateIssue);
|
|
171
|
-
}
|
|
172
|
-
else {
|
|
173
|
-
recommendations.push(gateIssue);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
/**
|
|
178
|
-
* Assess security vulnerabilities
|
|
179
|
-
*/
|
|
180
|
-
assessSecurity(securityAudit, blockers, concerns) {
|
|
181
|
-
const deps = securityAudit.dependency_vulnerabilities;
|
|
182
|
-
// Check critical vulnerabilities
|
|
183
|
-
if (deps.critical >= this.thresholds.fail.criticalVulnerabilities) {
|
|
184
|
-
const criticalVulns = deps.issues.filter((v) => v.severity === 'critical');
|
|
185
|
-
for (const vuln of criticalVulns) {
|
|
186
|
-
blockers.push({
|
|
187
|
-
type: 'security',
|
|
188
|
-
severity: 'critical',
|
|
189
|
-
title: `Critical vulnerability: ${vuln.vulnerability}`,
|
|
190
|
-
description: `Package: ${vuln.package}@${vuln.version}`,
|
|
191
|
-
mitigation: vuln.fix,
|
|
192
|
-
});
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
// Check high vulnerabilities
|
|
196
|
-
if (deps.high >= this.thresholds.concerns.highVulnerabilities) {
|
|
197
|
-
const highVulns = deps.issues.filter((v) => v.severity === 'high');
|
|
198
|
-
for (const vuln of highVulns) {
|
|
199
|
-
concerns.push({
|
|
200
|
-
type: 'security',
|
|
201
|
-
severity: 'high',
|
|
202
|
-
title: `High vulnerability: ${vuln.vulnerability}`,
|
|
203
|
-
description: `Package: ${vuln.package}@${vuln.version}`,
|
|
204
|
-
mitigation: vuln.fix,
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
// Check OWASP failures
|
|
209
|
-
const owaspFailures = securityAudit.owasp_checks.filter((c) => c.status === 'FAIL');
|
|
210
|
-
for (const check of owaspFailures) {
|
|
211
|
-
concerns.push({
|
|
212
|
-
type: 'security',
|
|
213
|
-
severity: 'high',
|
|
214
|
-
title: `OWASP ${check.category}`,
|
|
215
|
-
description: check.details,
|
|
216
|
-
mitigation: check.recommendation,
|
|
217
|
-
});
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
/**
|
|
221
|
-
* Make final decision based on blockers and concerns
|
|
222
|
-
*/
|
|
223
|
-
makeDecision(blockers, concerns) {
|
|
224
|
-
if (blockers.length > 0) {
|
|
225
|
-
return {
|
|
226
|
-
decision: 'FAIL',
|
|
227
|
-
reasoning: `Found ${blockers.length} blocker(s) that MUST be fixed before proceeding.`,
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
if (concerns.length > 0) {
|
|
231
|
-
return {
|
|
232
|
-
decision: 'CONCERNS',
|
|
233
|
-
reasoning: `Found ${concerns.length} concern(s) that SHOULD be addressed before release.`,
|
|
234
|
-
};
|
|
235
|
-
}
|
|
236
|
-
return {
|
|
237
|
-
decision: 'PASS',
|
|
238
|
-
reasoning: 'All quality checks passed. Ready for production.',
|
|
239
|
-
};
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* Get decision icon/emoji
|
|
243
|
-
*/
|
|
244
|
-
static getDecisionIcon(decision) {
|
|
245
|
-
switch (decision) {
|
|
246
|
-
case 'PASS':
|
|
247
|
-
return '🟢';
|
|
248
|
-
case 'CONCERNS':
|
|
249
|
-
return '🟡';
|
|
250
|
-
case 'FAIL':
|
|
251
|
-
return '🔴';
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
/**
|
|
255
|
-
* Get decision color (for terminal output)
|
|
256
|
-
*/
|
|
257
|
-
static getDecisionColor(decision) {
|
|
258
|
-
switch (decision) {
|
|
259
|
-
case 'PASS':
|
|
260
|
-
return 'green';
|
|
261
|
-
case 'CONCERNS':
|
|
262
|
-
return 'yellow';
|
|
263
|
-
case 'FAIL':
|
|
264
|
-
return 'red';
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
//# sourceMappingURL=quality-gate-decider.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"quality-gate-decider.js","sourceRoot":"","sources":["../../../../src/core/qa/quality-gate-decider.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Risk Calculator using BMAD pattern (Probability × Impact)
|
|
3
|
-
*
|
|
4
|
-
* @module qa/risk-calculator
|
|
5
|
-
* @since v0.8.0
|
|
6
|
-
*/
|
|
7
|
-
import { Risk, RiskAssessmentResult, RiskCategory, RiskSeverity } from './types';
|
|
8
|
-
export declare class RiskCalculator {
|
|
9
|
-
/**
|
|
10
|
-
* Calculate risk score using BMAD formula: P × I
|
|
11
|
-
*
|
|
12
|
-
* @param probability - Probability of risk occurring (0.0-1.0)
|
|
13
|
-
* @param impact - Impact severity if risk occurs (1-10)
|
|
14
|
-
* @returns Risk score (0.0-10.0)
|
|
15
|
-
* @throws Error if probability or impact out of range
|
|
16
|
-
*
|
|
17
|
-
* @example
|
|
18
|
-
* ```typescript
|
|
19
|
-
* const score = RiskCalculator.calculateRiskScore(0.9, 10);
|
|
20
|
-
* // Returns: 9.0 (CRITICAL)
|
|
21
|
-
* ```
|
|
22
|
-
*/
|
|
23
|
-
static calculateRiskScore(probability: number, impact: number): number;
|
|
24
|
-
/**
|
|
25
|
-
* Determine severity level based on risk score
|
|
26
|
-
*
|
|
27
|
-
* @param score - Risk score (0.0-10.0)
|
|
28
|
-
* @returns Severity level
|
|
29
|
-
*
|
|
30
|
-
* Thresholds:
|
|
31
|
-
* - 9.0-10.0: CRITICAL (must fix immediately)
|
|
32
|
-
* - 6.0-8.9: HIGH (should fix before release)
|
|
33
|
-
* - 3.0-5.9: MEDIUM (monitor, fix if time permits)
|
|
34
|
-
* - 0.0-2.9: LOW (acceptable risk)
|
|
35
|
-
*/
|
|
36
|
-
static determineSeverity(score: number): RiskSeverity;
|
|
37
|
-
/**
|
|
38
|
-
* Calculate overall risk score using weighted average
|
|
39
|
-
*
|
|
40
|
-
* Higher severity risks are weighted more heavily:
|
|
41
|
-
* - CRITICAL: 1.0
|
|
42
|
-
* - HIGH: 0.7
|
|
43
|
-
* - MEDIUM: 0.4
|
|
44
|
-
* - LOW: 0.1
|
|
45
|
-
*
|
|
46
|
-
* @param risks - Array of risk objects
|
|
47
|
-
* @returns Overall weighted risk score (0.0-10.0)
|
|
48
|
-
*
|
|
49
|
-
* @example
|
|
50
|
-
* ```typescript
|
|
51
|
-
* const risks = [
|
|
52
|
-
* { score: 9.0, severity: 'CRITICAL', ... },
|
|
53
|
-
* { score: 6.0, severity: 'HIGH', ... },
|
|
54
|
-
* { score: 2.0, severity: 'LOW', ... }
|
|
55
|
-
* ];
|
|
56
|
-
* const overall = RiskCalculator.calculateOverallRisk(risks);
|
|
57
|
-
* // Returns: ~7.5 (weighted towards critical risks)
|
|
58
|
-
* ```
|
|
59
|
-
*/
|
|
60
|
-
static calculateOverallRisk(risks: Risk[]): number;
|
|
61
|
-
/**
|
|
62
|
-
* Group risks by category and calculate category scores
|
|
63
|
-
*
|
|
64
|
-
* @param risks - Array of risk objects
|
|
65
|
-
* @returns Object with risk scores per category
|
|
66
|
-
*
|
|
67
|
-
* @example
|
|
68
|
-
* ```typescript
|
|
69
|
-
* const grouped = RiskCalculator.groupRisksByCategory(risks);
|
|
70
|
-
* // Returns: { security: 7.5, technical: 4.2, implementation: 3.0, operational: 2.1 }
|
|
71
|
-
* ```
|
|
72
|
-
*/
|
|
73
|
-
static groupRisksByCategory(risks: Risk[]): Record<RiskCategory, number>;
|
|
74
|
-
/**
|
|
75
|
-
* Normalize probability from descriptive text to numeric value
|
|
76
|
-
*
|
|
77
|
-
* @param description - Text description (low/medium/high or percentage)
|
|
78
|
-
* @returns Numeric probability (0.0-1.0)
|
|
79
|
-
*
|
|
80
|
-
* @example
|
|
81
|
-
* ```typescript
|
|
82
|
-
* RiskCalculator.normalizeProbability('high'); // 0.8
|
|
83
|
-
* RiskCalculator.normalizeProbability('50%'); // 0.5
|
|
84
|
-
* RiskCalculator.normalizeProbability('0.9'); // 0.9
|
|
85
|
-
* ```
|
|
86
|
-
*/
|
|
87
|
-
static normalizeProbability(description: string): number;
|
|
88
|
-
/**
|
|
89
|
-
* Normalize impact from descriptive text to numeric value
|
|
90
|
-
*
|
|
91
|
-
* @param description - Text description (minor/moderate/major/critical)
|
|
92
|
-
* @returns Numeric impact (1-10)
|
|
93
|
-
*
|
|
94
|
-
* @example
|
|
95
|
-
* ```typescript
|
|
96
|
-
* RiskCalculator.normalizeImpact('critical'); // 10
|
|
97
|
-
* RiskCalculator.normalizeImpact('moderate'); // 5
|
|
98
|
-
* ```
|
|
99
|
-
*/
|
|
100
|
-
static normalizeImpact(description: string): number;
|
|
101
|
-
/**
|
|
102
|
-
* Create a risk object from raw data
|
|
103
|
-
*
|
|
104
|
-
* @param data - Partial risk data
|
|
105
|
-
* @returns Complete risk object with calculated fields
|
|
106
|
-
*/
|
|
107
|
-
static createRisk(data: {
|
|
108
|
-
id: string;
|
|
109
|
-
category: RiskCategory;
|
|
110
|
-
title: string;
|
|
111
|
-
description: string;
|
|
112
|
-
probability: number | string;
|
|
113
|
-
impact: number | string;
|
|
114
|
-
mitigation: string;
|
|
115
|
-
location: string;
|
|
116
|
-
acceptance_criteria?: string;
|
|
117
|
-
}): Risk;
|
|
118
|
-
/**
|
|
119
|
-
* Calculate full risk assessment result
|
|
120
|
-
*
|
|
121
|
-
* @param risks - Array of risk objects
|
|
122
|
-
* @returns Complete risk assessment result
|
|
123
|
-
*/
|
|
124
|
-
static calculateAssessment(risks: Risk[]): RiskAssessmentResult;
|
|
125
|
-
}
|
|
126
|
-
//# sourceMappingURL=risk-calculator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"risk-calculator.d.ts","sourceRoot":"","sources":["../../../../src/core/qa/risk-calculator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,IAAI,EAAE,oBAAoB,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEjF,qBAAa,cAAc;IACzB;;;;;;;;;;;;;OAaG;IACH,MAAM,CAAC,kBAAkB,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;IAUtE;;;;;;;;;;;OAWG;IACH,MAAM,CAAC,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY;IAOrD;;;;;;;;;;;;;;;;;;;;;;OAsBG;IACH,MAAM,CAAC,oBAAoB,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM;IAsBlD;;;;;;;;;;;OAWG;IACH,MAAM,CAAC,oBAAoB,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC;IAYxE;;;;;;;;;;;;OAYG;IACH,MAAM,CAAC,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM;IAqCxD;;;;;;;;;;;OAWG;IACH,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM;IAmCnD;;;;;OAKG;IACH,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE;QACtB,EAAE,EAAE,MAAM,CAAC;QACX,QAAQ,EAAE,YAAY,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC;QACd,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,GAAG,MAAM,CAAC;QAC7B,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;QACxB,UAAU,EAAE,MAAM,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;QACjB,mBAAmB,CAAC,EAAE,MAAM,CAAC;KAC9B,GAAG,IAAI;IA4BR;;;;;OAKG;IACH,MAAM,CAAC,mBAAmB,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,oBAAoB;CAOhE"}
|
|
@@ -1,247 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Risk Calculator using BMAD pattern (Probability × Impact)
|
|
3
|
-
*
|
|
4
|
-
* @module qa/risk-calculator
|
|
5
|
-
* @since v0.8.0
|
|
6
|
-
*/
|
|
7
|
-
export class RiskCalculator {
|
|
8
|
-
/**
|
|
9
|
-
* Calculate risk score using BMAD formula: P × I
|
|
10
|
-
*
|
|
11
|
-
* @param probability - Probability of risk occurring (0.0-1.0)
|
|
12
|
-
* @param impact - Impact severity if risk occurs (1-10)
|
|
13
|
-
* @returns Risk score (0.0-10.0)
|
|
14
|
-
* @throws Error if probability or impact out of range
|
|
15
|
-
*
|
|
16
|
-
* @example
|
|
17
|
-
* ```typescript
|
|
18
|
-
* const score = RiskCalculator.calculateRiskScore(0.9, 10);
|
|
19
|
-
* // Returns: 9.0 (CRITICAL)
|
|
20
|
-
* ```
|
|
21
|
-
*/
|
|
22
|
-
static calculateRiskScore(probability, impact) {
|
|
23
|
-
if (probability < 0 || probability > 1) {
|
|
24
|
-
throw new Error(`Probability must be 0.0-1.0, got ${probability}`);
|
|
25
|
-
}
|
|
26
|
-
if (impact < 1 || impact > 10) {
|
|
27
|
-
throw new Error(`Impact must be 1-10, got ${impact}`);
|
|
28
|
-
}
|
|
29
|
-
return probability * impact;
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Determine severity level based on risk score
|
|
33
|
-
*
|
|
34
|
-
* @param score - Risk score (0.0-10.0)
|
|
35
|
-
* @returns Severity level
|
|
36
|
-
*
|
|
37
|
-
* Thresholds:
|
|
38
|
-
* - 9.0-10.0: CRITICAL (must fix immediately)
|
|
39
|
-
* - 6.0-8.9: HIGH (should fix before release)
|
|
40
|
-
* - 3.0-5.9: MEDIUM (monitor, fix if time permits)
|
|
41
|
-
* - 0.0-2.9: LOW (acceptable risk)
|
|
42
|
-
*/
|
|
43
|
-
static determineSeverity(score) {
|
|
44
|
-
if (score >= 9.0)
|
|
45
|
-
return 'CRITICAL';
|
|
46
|
-
if (score >= 6.0)
|
|
47
|
-
return 'HIGH';
|
|
48
|
-
if (score >= 3.0)
|
|
49
|
-
return 'MEDIUM';
|
|
50
|
-
return 'LOW';
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Calculate overall risk score using weighted average
|
|
54
|
-
*
|
|
55
|
-
* Higher severity risks are weighted more heavily:
|
|
56
|
-
* - CRITICAL: 1.0
|
|
57
|
-
* - HIGH: 0.7
|
|
58
|
-
* - MEDIUM: 0.4
|
|
59
|
-
* - LOW: 0.1
|
|
60
|
-
*
|
|
61
|
-
* @param risks - Array of risk objects
|
|
62
|
-
* @returns Overall weighted risk score (0.0-10.0)
|
|
63
|
-
*
|
|
64
|
-
* @example
|
|
65
|
-
* ```typescript
|
|
66
|
-
* const risks = [
|
|
67
|
-
* { score: 9.0, severity: 'CRITICAL', ... },
|
|
68
|
-
* { score: 6.0, severity: 'HIGH', ... },
|
|
69
|
-
* { score: 2.0, severity: 'LOW', ... }
|
|
70
|
-
* ];
|
|
71
|
-
* const overall = RiskCalculator.calculateOverallRisk(risks);
|
|
72
|
-
* // Returns: ~7.5 (weighted towards critical risks)
|
|
73
|
-
* ```
|
|
74
|
-
*/
|
|
75
|
-
static calculateOverallRisk(risks) {
|
|
76
|
-
if (risks.length === 0)
|
|
77
|
-
return 0;
|
|
78
|
-
const weights = {
|
|
79
|
-
CRITICAL: 1.0,
|
|
80
|
-
HIGH: 0.7,
|
|
81
|
-
MEDIUM: 0.4,
|
|
82
|
-
LOW: 0.1,
|
|
83
|
-
};
|
|
84
|
-
let weightedSum = 0;
|
|
85
|
-
let totalWeight = 0;
|
|
86
|
-
for (const risk of risks) {
|
|
87
|
-
const weight = weights[risk.severity];
|
|
88
|
-
weightedSum += risk.score * weight;
|
|
89
|
-
totalWeight += weight;
|
|
90
|
-
}
|
|
91
|
-
return totalWeight > 0 ? weightedSum / totalWeight : 0;
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* Group risks by category and calculate category scores
|
|
95
|
-
*
|
|
96
|
-
* @param risks - Array of risk objects
|
|
97
|
-
* @returns Object with risk scores per category
|
|
98
|
-
*
|
|
99
|
-
* @example
|
|
100
|
-
* ```typescript
|
|
101
|
-
* const grouped = RiskCalculator.groupRisksByCategory(risks);
|
|
102
|
-
* // Returns: { security: 7.5, technical: 4.2, implementation: 3.0, operational: 2.1 }
|
|
103
|
-
* ```
|
|
104
|
-
*/
|
|
105
|
-
static groupRisksByCategory(risks) {
|
|
106
|
-
const categories = ['security', 'technical', 'implementation', 'operational'];
|
|
107
|
-
const result = {};
|
|
108
|
-
for (const category of categories) {
|
|
109
|
-
const categoryRisks = risks.filter((r) => r.category === category);
|
|
110
|
-
result[category] = this.calculateOverallRisk(categoryRisks);
|
|
111
|
-
}
|
|
112
|
-
return result;
|
|
113
|
-
}
|
|
114
|
-
/**
|
|
115
|
-
* Normalize probability from descriptive text to numeric value
|
|
116
|
-
*
|
|
117
|
-
* @param description - Text description (low/medium/high or percentage)
|
|
118
|
-
* @returns Numeric probability (0.0-1.0)
|
|
119
|
-
*
|
|
120
|
-
* @example
|
|
121
|
-
* ```typescript
|
|
122
|
-
* RiskCalculator.normalizeProbability('high'); // 0.8
|
|
123
|
-
* RiskCalculator.normalizeProbability('50%'); // 0.5
|
|
124
|
-
* RiskCalculator.normalizeProbability('0.9'); // 0.9
|
|
125
|
-
* ```
|
|
126
|
-
*/
|
|
127
|
-
static normalizeProbability(description) {
|
|
128
|
-
const normalized = description.toLowerCase().trim();
|
|
129
|
-
// Handle percentage
|
|
130
|
-
if (normalized.includes('%')) {
|
|
131
|
-
const percent = parseFloat(normalized.replace('%', ''));
|
|
132
|
-
return Math.min(Math.max(percent / 100, 0), 1);
|
|
133
|
-
}
|
|
134
|
-
// Handle decimal
|
|
135
|
-
if (/^[0-9.]+$/.test(normalized)) {
|
|
136
|
-
const value = parseFloat(normalized);
|
|
137
|
-
return Math.min(Math.max(value, 0), 1);
|
|
138
|
-
}
|
|
139
|
-
// Handle descriptive text
|
|
140
|
-
switch (normalized) {
|
|
141
|
-
case 'low':
|
|
142
|
-
case 'unlikely':
|
|
143
|
-
return 0.2;
|
|
144
|
-
case 'medium':
|
|
145
|
-
case 'possible':
|
|
146
|
-
case 'moderate':
|
|
147
|
-
return 0.5;
|
|
148
|
-
case 'high':
|
|
149
|
-
case 'likely':
|
|
150
|
-
case 'probable':
|
|
151
|
-
return 0.8;
|
|
152
|
-
case 'very high':
|
|
153
|
-
case 'certain':
|
|
154
|
-
case 'definite':
|
|
155
|
-
return 0.95;
|
|
156
|
-
default:
|
|
157
|
-
return 0.5; // Default to medium if unknown
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
/**
|
|
161
|
-
* Normalize impact from descriptive text to numeric value
|
|
162
|
-
*
|
|
163
|
-
* @param description - Text description (minor/moderate/major/critical)
|
|
164
|
-
* @returns Numeric impact (1-10)
|
|
165
|
-
*
|
|
166
|
-
* @example
|
|
167
|
-
* ```typescript
|
|
168
|
-
* RiskCalculator.normalizeImpact('critical'); // 10
|
|
169
|
-
* RiskCalculator.normalizeImpact('moderate'); // 5
|
|
170
|
-
* ```
|
|
171
|
-
*/
|
|
172
|
-
static normalizeImpact(description) {
|
|
173
|
-
const normalized = description.toLowerCase().trim();
|
|
174
|
-
// Handle numeric
|
|
175
|
-
if (/^[0-9]+$/.test(normalized)) {
|
|
176
|
-
const value = parseInt(normalized, 10);
|
|
177
|
-
return Math.min(Math.max(value, 1), 10);
|
|
178
|
-
}
|
|
179
|
-
// Handle descriptive text
|
|
180
|
-
switch (normalized) {
|
|
181
|
-
case 'minor':
|
|
182
|
-
case 'trivial':
|
|
183
|
-
case 'cosmetic':
|
|
184
|
-
return 2;
|
|
185
|
-
case 'moderate':
|
|
186
|
-
case 'medium':
|
|
187
|
-
case 'some impact':
|
|
188
|
-
return 5;
|
|
189
|
-
case 'major':
|
|
190
|
-
case 'significant':
|
|
191
|
-
case 'high':
|
|
192
|
-
return 8;
|
|
193
|
-
case 'critical':
|
|
194
|
-
case 'severe':
|
|
195
|
-
case 'catastrophic':
|
|
196
|
-
case 'system failure':
|
|
197
|
-
case 'data loss':
|
|
198
|
-
case 'security breach':
|
|
199
|
-
return 10;
|
|
200
|
-
default:
|
|
201
|
-
return 5; // Default to moderate if unknown
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
/**
|
|
205
|
-
* Create a risk object from raw data
|
|
206
|
-
*
|
|
207
|
-
* @param data - Partial risk data
|
|
208
|
-
* @returns Complete risk object with calculated fields
|
|
209
|
-
*/
|
|
210
|
-
static createRisk(data) {
|
|
211
|
-
// Normalize probability and impact
|
|
212
|
-
const probability = typeof data.probability === 'string'
|
|
213
|
-
? this.normalizeProbability(data.probability)
|
|
214
|
-
: data.probability;
|
|
215
|
-
const impact = typeof data.impact === 'string' ? this.normalizeImpact(data.impact) : data.impact;
|
|
216
|
-
// Calculate score and severity
|
|
217
|
-
const score = this.calculateRiskScore(probability, impact);
|
|
218
|
-
const severity = this.determineSeverity(score);
|
|
219
|
-
return {
|
|
220
|
-
id: data.id,
|
|
221
|
-
category: data.category,
|
|
222
|
-
title: data.title,
|
|
223
|
-
description: data.description,
|
|
224
|
-
probability,
|
|
225
|
-
impact,
|
|
226
|
-
score,
|
|
227
|
-
severity,
|
|
228
|
-
mitigation: data.mitigation,
|
|
229
|
-
location: data.location,
|
|
230
|
-
acceptance_criteria: data.acceptance_criteria,
|
|
231
|
-
};
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* Calculate full risk assessment result
|
|
235
|
-
*
|
|
236
|
-
* @param risks - Array of risk objects
|
|
237
|
-
* @returns Complete risk assessment result
|
|
238
|
-
*/
|
|
239
|
-
static calculateAssessment(risks) {
|
|
240
|
-
return {
|
|
241
|
-
risks,
|
|
242
|
-
overall_risk_score: this.calculateOverallRisk(risks),
|
|
243
|
-
risk_by_category: this.groupRisksByCategory(risks),
|
|
244
|
-
};
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
//# sourceMappingURL=risk-calculator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"risk-calculator.js","sourceRoot":"","sources":["../../../../src/core/qa/risk-calculator.ts"],"names":[],"mappings":"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"}
|