reviewflow 3.26.0 → 3.27.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 +10 -0
- package/dist/config/projectConfig.d.ts +1 -0
- package/dist/config/projectConfig.d.ts.map +1 -1
- package/dist/config/projectConfig.js +17 -0
- package/dist/config/projectConfig.js.map +1 -1
- package/dist/dashboard/index.html +77 -2
- package/dist/dashboard/modules/headerCapacityBadge.d.ts +33 -0
- package/dist/dashboard/modules/headerCapacityBadge.d.ts.map +1 -0
- package/dist/dashboard/modules/headerCapacityBadge.js +53 -0
- package/dist/dashboard/modules/headerCapacityBadge.js.map +1 -0
- package/dist/dashboard/modules/i18n.d.ts.map +1 -1
- package/dist/dashboard/modules/i18n.js +4 -0
- package/dist/dashboard/modules/i18n.js.map +1 -1
- package/dist/dashboard/modules/settingsModal.d.ts +17 -0
- package/dist/dashboard/modules/settingsModal.d.ts.map +1 -1
- package/dist/dashboard/modules/settingsModal.js +38 -0
- package/dist/dashboard/modules/settingsModal.js.map +1 -1
- package/dist/dashboard/modules/worktreePanel.d.ts +40 -0
- package/dist/dashboard/modules/worktreePanel.d.ts.map +1 -1
- package/dist/dashboard/modules/worktreePanel.js +98 -1
- package/dist/dashboard/modules/worktreePanel.js.map +1 -1
- package/dist/dashboard/styles.css +125 -1
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +5 -10
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- package/dist/frameworks/config/configLoader.d.ts +1 -0
- package/dist/frameworks/config/configLoader.d.ts.map +1 -1
- package/dist/frameworks/config/configLoader.js +11 -0
- package/dist/frameworks/config/configLoader.js.map +1 -1
- package/dist/frameworks/queue/pQueueAdapter.d.ts +17 -0
- package/dist/frameworks/queue/pQueueAdapter.d.ts.map +1 -1
- package/dist/frameworks/queue/pQueueAdapter.js +103 -40
- package/dist/frameworks/queue/pQueueAdapter.js.map +1 -1
- package/dist/frameworks/queue/projectSemaphore.d.ts +26 -0
- package/dist/frameworks/queue/projectSemaphore.d.ts.map +1 -0
- package/dist/frameworks/queue/projectSemaphore.js +79 -0
- package/dist/frameworks/queue/projectSemaphore.js.map +1 -0
- package/dist/frameworks/settings/runtimeSettings.d.ts +3 -0
- package/dist/frameworks/settings/runtimeSettings.d.ts.map +1 -1
- package/dist/frameworks/settings/runtimeSettings.js +14 -0
- package/dist/frameworks/settings/runtimeSettings.js.map +1 -1
- package/dist/main/dependencies.d.ts +4 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +8 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +32 -3
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +69 -1
- package/dist/main/server.js.map +1 -1
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.d.ts +2 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.d.ts.map +1 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.js +4 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.js.map +1 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.schema.d.ts +7 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.schema.d.ts.map +1 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.schema.js +10 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.schema.js.map +1 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.d.ts +18 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.d.ts.map +1 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.js +28 -0
- package/dist/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.js.map +1 -0
- package/dist/modules/cli-configuration/entities/repositoriesList/repositoriesList.gateway.d.ts +9 -0
- package/dist/modules/cli-configuration/entities/repositoriesList/repositoriesList.gateway.d.ts.map +1 -0
- package/dist/modules/cli-configuration/entities/repositoriesList/repositoriesList.gateway.js +2 -0
- package/dist/modules/cli-configuration/entities/repositoriesList/repositoriesList.gateway.js.map +1 -0
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.d.ts +1 -0
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.d.ts.map +1 -1
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.js +26 -0
- package/dist/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.js.map +1 -1
- package/dist/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.d.ts +8 -0
- package/dist/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.d.ts.map +1 -0
- package/dist/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.js +14 -0
- package/dist/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.js.map +1 -0
- package/dist/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.d.ts +26 -0
- package/dist/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.d.ts.map +1 -0
- package/dist/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.js +24 -0
- package/dist/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.js.map +1 -0
- package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.d.ts +2 -1
- package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.d.ts.map +1 -1
- package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.js +29 -5
- package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.js.map +1 -1
- package/dist/modules/review-execution/entities/job/jobHistory.gateway.d.ts +10 -0
- package/dist/modules/review-execution/entities/job/jobHistory.gateway.d.ts.map +1 -0
- package/dist/modules/review-execution/entities/job/jobHistory.gateway.js +2 -0
- package/dist/modules/review-execution/entities/job/jobHistory.gateway.js.map +1 -0
- package/dist/modules/review-execution/entities/job/jobRecord.guard.d.ts +13 -0
- package/dist/modules/review-execution/entities/job/jobRecord.guard.d.ts.map +1 -0
- package/dist/modules/review-execution/entities/job/jobRecord.guard.js +4 -0
- package/dist/modules/review-execution/entities/job/jobRecord.guard.js.map +1 -0
- package/dist/modules/review-execution/entities/job/jobRecord.schema.d.ts +33 -0
- package/dist/modules/review-execution/entities/job/jobRecord.schema.d.ts.map +1 -0
- package/dist/modules/review-execution/entities/job/jobRecord.schema.js +15 -0
- package/dist/modules/review-execution/entities/job/jobRecord.schema.js.map +1 -0
- package/dist/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.d.ts +19 -0
- package/dist/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.js +120 -0
- package/dist/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.js.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.d.ts +17 -0
- package/dist/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.d.ts.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.js +11 -0
- package/dist/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.js.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.d.ts +18 -0
- package/dist/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.d.ts.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.js +58 -0
- package/dist/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.js.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.d.ts +16 -0
- package/dist/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.d.ts.map +1 -0
- package/dist/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.js +12 -0
- package/dist/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.js.map +1 -0
- package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.d.ts +4 -0
- package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.d.ts.map +1 -1
- package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.js +2 -0
- package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.js.map +1 -1
- package/dist/modules/statistics-insights/interface-adapters/presenters/overview.presenter.d.ts +12 -0
- package/dist/modules/statistics-insights/interface-adapters/presenters/overview.presenter.d.ts.map +1 -1
- package/dist/modules/statistics-insights/interface-adapters/presenters/overview.presenter.js +8 -0
- package/dist/modules/statistics-insights/interface-adapters/presenters/overview.presenter.js.map +1 -1
- package/dist/modules/statistics-insights/services/fetchDiffStatsSafely.d.ts +5 -0
- package/dist/modules/statistics-insights/services/fetchDiffStatsSafely.d.ts.map +1 -0
- package/dist/modules/statistics-insights/services/fetchDiffStatsSafely.js +10 -0
- package/dist/modules/statistics-insights/services/fetchDiffStatsSafely.js.map +1 -0
- package/dist/modules/statistics-insights/services/statsService.d.ts +5 -0
- package/dist/modules/statistics-insights/services/statsService.d.ts.map +1 -1
- package/dist/modules/statistics-insights/services/statsService.js +5 -0
- package/dist/modules/statistics-insights/services/statsService.js.map +1 -1
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.d.ts +1 -1
- package/dist/modules/worktree-management/entities/gitCommand/gitCommand.gateway.d.ts.map +1 -1
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.d.ts +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktree.gateway.d.ts.map +1 -1
- package/dist/modules/worktree-management/entities/worktree/worktreeHealth.schema.d.ts +44 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealth.schema.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealth.schema.js +31 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealth.schema.js.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealthProbe.gateway.d.ts +20 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealthProbe.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealthProbe.gateway.js +2 -0
- package/dist/modules/worktree-management/entities/worktree/worktreeHealthProbe.gateway.js.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.d.ts +6 -0
- package/dist/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.d.ts.map +1 -1
- package/dist/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.js +52 -1
- package/dist/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.js.map +1 -1
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.d.ts.map +1 -1
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.js +5 -1
- package/dist/modules/worktree-management/interface-adapters/gateways/worktree.fileSystem.gateway.js.map +1 -1
- package/dist/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.d.ts +14 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.js +97 -0
- package/dist/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.js.map +1 -0
- package/dist/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.d.ts +20 -0
- package/dist/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.d.ts.map +1 -1
- package/dist/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.js +58 -0
- package/dist/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.js.map +1 -1
- package/dist/modules/worktree-management/services/forceCleanupLock.d.ts +10 -0
- package/dist/modules/worktree-management/services/forceCleanupLock.d.ts.map +1 -0
- package/dist/modules/worktree-management/services/forceCleanupLock.js +14 -0
- package/dist/modules/worktree-management/services/forceCleanupLock.js.map +1 -0
- package/dist/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.d.ts +13 -0
- package/dist/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.d.ts.map +1 -0
- package/dist/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.js +35 -0
- package/dist/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.js.map +1 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.d.ts +1 -0
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.d.ts.map +1 -1
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.js +2 -1
- package/dist/modules/worktree-management/usecases/removeWorktree.usecase.js.map +1 -1
- package/dist/tests/acceptance/175-worktree-failure-visibility.acceptance.test.d.ts +12 -0
- package/dist/tests/acceptance/175-worktree-failure-visibility.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/175-worktree-failure-visibility.acceptance.test.js +293 -0
- package/dist/tests/acceptance/175-worktree-failure-visibility.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/176-job-history-persistence.acceptance.test.d.ts +13 -0
- package/dist/tests/acceptance/176-job-history-persistence.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/176-job-history-persistence.acceptance.test.js +261 -0
- package/dist/tests/acceptance/176-job-history-persistence.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/186-per-project-concurrency-cap.acceptance.test.d.ts +16 -0
- package/dist/tests/acceptance/186-per-project-concurrency-cap.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/186-per-project-concurrency-cap.acceptance.test.js +391 -0
- package/dist/tests/acceptance/186-per-project-concurrency-cap.acceptance.test.js.map +1 -0
- package/dist/tests/acceptance/47-capture-git-diff-stats.acceptance.test.d.ts +18 -0
- package/dist/tests/acceptance/47-capture-git-diff-stats.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/47-capture-git-diff-stats.acceptance.test.js +221 -0
- package/dist/tests/acceptance/47-capture-git-diff-stats.acceptance.test.js.map +1 -0
- package/dist/tests/factories/config.factory.d.ts.map +1 -1
- package/dist/tests/factories/config.factory.js +1 -0
- package/dist/tests/factories/config.factory.js.map +1 -1
- package/dist/tests/factories/jobRecord.factory.d.ts +5 -0
- package/dist/tests/factories/jobRecord.factory.d.ts.map +1 -0
- package/dist/tests/factories/jobRecord.factory.js +18 -0
- package/dist/tests/factories/jobRecord.factory.js.map +1 -0
- package/dist/tests/factories/projectConcurrencyCap.factory.d.ts +5 -0
- package/dist/tests/factories/projectConcurrencyCap.factory.d.ts.map +1 -0
- package/dist/tests/factories/projectConcurrencyCap.factory.js +8 -0
- package/dist/tests/factories/projectConcurrencyCap.factory.js.map +1 -0
- package/dist/tests/factories/worktreeHealth.factory.d.ts +22 -0
- package/dist/tests/factories/worktreeHealth.factory.d.ts.map +1 -0
- package/dist/tests/factories/worktreeHealth.factory.js +53 -0
- package/dist/tests/factories/worktreeHealth.factory.js.map +1 -0
- package/dist/tests/stubs/jobHistory.stub.d.ts +13 -0
- package/dist/tests/stubs/jobHistory.stub.d.ts.map +1 -0
- package/dist/tests/stubs/jobHistory.stub.js +63 -0
- package/dist/tests/stubs/jobHistory.stub.js.map +1 -0
- package/dist/tests/stubs/queueCapacityPort.stub.d.ts +8 -0
- package/dist/tests/stubs/queueCapacityPort.stub.d.ts.map +1 -0
- package/dist/tests/stubs/queueCapacityPort.stub.js +11 -0
- package/dist/tests/stubs/queueCapacityPort.stub.js.map +1 -0
- package/dist/tests/stubs/repositoriesListGateway.stub.d.ts +7 -0
- package/dist/tests/stubs/repositoriesListGateway.stub.d.ts.map +1 -0
- package/dist/tests/stubs/repositoriesListGateway.stub.js +10 -0
- package/dist/tests/stubs/repositoriesListGateway.stub.js.map +1 -0
- package/dist/tests/stubs/worktreeHealthProbe.stub.d.ts +11 -0
- package/dist/tests/stubs/worktreeHealthProbe.stub.d.ts.map +1 -0
- package/dist/tests/stubs/worktreeHealthProbe.stub.js +26 -0
- package/dist/tests/stubs/worktreeHealthProbe.stub.js.map +1 -0
- package/dist/tests/units/cli/cli.integration.test.js +6 -4
- package/dist/tests/units/cli/cli.integration.test.js.map +1 -1
- package/dist/tests/units/dashboard/modules/headerCapacityBadge.test.d.ts +2 -0
- package/dist/tests/units/dashboard/modules/headerCapacityBadge.test.d.ts.map +1 -0
- package/dist/tests/units/dashboard/modules/headerCapacityBadge.test.js +55 -0
- package/dist/tests/units/dashboard/modules/headerCapacityBadge.test.js.map +1 -0
- package/dist/tests/units/dashboard/modules/notifications.test.js +17 -0
- package/dist/tests/units/dashboard/modules/notifications.test.js.map +1 -1
- package/dist/tests/units/dashboard/modules/settingsModal.test.js +7 -0
- package/dist/tests/units/dashboard/modules/settingsModal.test.js.map +1 -1
- package/dist/tests/units/dashboard/modules/worktreePanel.test.js +123 -1
- package/dist/tests/units/dashboard/modules/worktreePanel.test.js.map +1 -1
- package/dist/tests/units/frameworks/config/configLoader.test.js +28 -0
- package/dist/tests/units/frameworks/config/configLoader.test.js.map +1 -1
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.js +125 -0
- package/dist/tests/units/frameworks/queue/pQueueAdapter.test.js.map +1 -1
- package/dist/tests/units/frameworks/queue/projectSemaphore.test.d.ts +2 -0
- package/dist/tests/units/frameworks/queue/projectSemaphore.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/queue/projectSemaphore.test.js +92 -0
- package/dist/tests/units/frameworks/queue/projectSemaphore.test.js.map +1 -0
- package/dist/tests/units/frameworks/settings/runtimeSettings.test.js +34 -2
- package/dist/tests/units/frameworks/settings/runtimeSettings.test.js.map +1 -1
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.test.d.ts +2 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.test.d.ts.map +1 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.test.js +22 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.test.js.map +1 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.test.d.ts +2 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.test.js +85 -0
- package/dist/tests/units/modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.test.js.map +1 -0
- package/dist/tests/units/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.test.js +91 -0
- package/dist/tests/units/modules/cli-configuration/interface-adapters/controllers/http/projectConfig.routes.test.js.map +1 -1
- package/dist/tests/units/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.test.js +29 -0
- package/dist/tests/units/modules/cli-configuration/interface-adapters/gateways/repositoriesList.runtimeConfig.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.test.js +126 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.test.js +78 -0
- package/dist/tests/units/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.test.js.map +1 -1
- package/dist/tests/units/modules/review-execution/entities/job/jobRecord.guard.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/entities/job/jobRecord.guard.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/entities/job/jobRecord.guard.test.js +48 -0
- package/dist/tests/units/modules/review-execution/entities/job/jobRecord.guard.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.test.js +134 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.test.js +38 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.test.js +126 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.test.js +42 -0
- package/dist/tests/units/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.test.js +28 -0
- package/dist/tests/units/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.test.js.map +1 -1
- package/dist/tests/units/modules/statistics-insights/interface-adapters/presenters/overview.presenter.test.js +39 -0
- package/dist/tests/units/modules/statistics-insights/interface-adapters/presenters/overview.presenter.test.js.map +1 -1
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktreeHealth.schema.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktreeHealth.schema.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktreeHealth.schema.test.js +50 -0
- package/dist/tests/units/modules/worktree-management/entities/worktree/worktreeHealth.schema.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.test.js +106 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/controllers/http/worktreeOverview.routes.test.js.map +1 -1
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.test.js +114 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/gateways/worktreeHealthProbe.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.test.js +140 -0
- package/dist/tests/units/modules/worktree-management/interface-adapters/presenters/worktreePanel.presenter.test.js.map +1 -1
- package/dist/tests/units/modules/worktree-management/services/forceCleanupLock.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/services/forceCleanupLock.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/services/forceCleanupLock.test.js +29 -0
- package/dist/tests/units/modules/worktree-management/services/forceCleanupLock.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.test.js +124 -0
- package/dist/tests/units/modules/worktree-management/usecases/detectDegradedWorktrees.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.js +27 -0
- package/dist/tests/units/modules/worktree-management/usecases/removeWorktree.usecase.test.js.map +1 -1
- package/dist/tests/units/services/statsService.summary.test.d.ts +2 -0
- package/dist/tests/units/services/statsService.summary.test.d.ts.map +1 -0
- package/dist/tests/units/services/statsService.summary.test.js +43 -0
- package/dist/tests/units/services/statsService.summary.test.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SPEC-47 — Capture Git Diff Stats (Commits, Additions, Deletions)
|
|
3
|
+
*
|
|
4
|
+
* Outer-loop acceptance test (SDD): exercises the production
|
|
5
|
+
* fetchDiffStatsSafely helper + the stats service + the tracking use case.
|
|
6
|
+
* The wiring inside claudeInvoker.ts is exercised by its own unit tests.
|
|
7
|
+
*
|
|
8
|
+
* Scenarios from docs/specs/47-capture-git-diff-stats.md:
|
|
9
|
+
* 1. Successful diff stats capture on GitHub review (nominal)
|
|
10
|
+
* 2. Successful diff stats capture on GitLab review (nominal)
|
|
11
|
+
* 3. Diff stats fetch failure does not block the review
|
|
12
|
+
* 4. Backward compatibility — old reviews without diff stats
|
|
13
|
+
* 5. Aggregated diff stats in project stats
|
|
14
|
+
* 6. Followup reviews also capture diff stats
|
|
15
|
+
* 7. Zero-diff merge request
|
|
16
|
+
*/
|
|
17
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
18
|
+
import { mkdirSync, rmSync, existsSync, writeFileSync } from 'node:fs';
|
|
19
|
+
import { join } from 'node:path';
|
|
20
|
+
import { tmpdir } from 'node:os';
|
|
21
|
+
import { pino } from 'pino';
|
|
22
|
+
import { addReviewStats, loadProjectStats, getStatsSummary, } from '../../modules/statistics-insights/services/statsService.js';
|
|
23
|
+
import { fetchDiffStatsSafely } from '../../modules/statistics-insights/services/fetchDiffStatsSafely.js';
|
|
24
|
+
import { RecordReviewCompletionUseCase } from '../../modules/tracking/usecases/tracking/recordReviewCompletion.usecase.js';
|
|
25
|
+
import { InMemoryReviewRequestTrackingGateway } from '../../tests/stubs/reviewRequestTracking.stub.js';
|
|
26
|
+
import { StubDiffStatsFetchGateway } from '../../tests/stubs/diffStatsFetch.stub.js';
|
|
27
|
+
import { DiffStatsFactory } from '../../tests/factories/diffStats.factory.js';
|
|
28
|
+
import { TrackedMrFactory } from '../../tests/factories/trackedMr.factory.js';
|
|
29
|
+
const REVIEW_OUTPUT = '[REVIEW_STATS:blocking=1:warnings=2:suggestions=3:score=7.5]';
|
|
30
|
+
let projectCounter = 0;
|
|
31
|
+
describe('Acceptance — SPEC-47: Capture git diff stats', () => {
|
|
32
|
+
let projectPath;
|
|
33
|
+
let logger;
|
|
34
|
+
beforeEach(() => {
|
|
35
|
+
projectCounter += 1;
|
|
36
|
+
projectPath = join(tmpdir(), `reviewflow-spec-47-${projectCounter}`);
|
|
37
|
+
mkdirSync(join(projectPath, '.claude', 'reviews'), { recursive: true });
|
|
38
|
+
logger = pino({ level: 'silent' });
|
|
39
|
+
});
|
|
40
|
+
afterEach(() => {
|
|
41
|
+
if (existsSync(projectPath)) {
|
|
42
|
+
rmSync(projectPath, { recursive: true, force: true });
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
describe('Scenario 1: Successful diff stats capture on GitHub review (nominal)', () => {
|
|
46
|
+
it('records diff stats on both ReviewStats and ReviewEvent', () => {
|
|
47
|
+
const diffStatsGateway = new StubDiffStatsFetchGateway();
|
|
48
|
+
diffStatsGateway.setResponse(42, { commitsCount: 3, additions: 150, deletions: 30 });
|
|
49
|
+
const fetched = fetchDiffStatsSafely(diffStatsGateway, projectPath, 42, logger);
|
|
50
|
+
const reviewStats = addReviewStats(projectPath, 42, 60_000, REVIEW_OUTPUT, 'reviewer', fetched);
|
|
51
|
+
expect(reviewStats.diffStats).toEqual({
|
|
52
|
+
commitsCount: 3,
|
|
53
|
+
additions: 150,
|
|
54
|
+
deletions: 30,
|
|
55
|
+
});
|
|
56
|
+
const tracking = new InMemoryReviewRequestTrackingGateway();
|
|
57
|
+
tracking.create(projectPath, TrackedMrFactory.create({ id: 'gh-42', mrNumber: 42, platform: 'github' }));
|
|
58
|
+
const recordCompletion = new RecordReviewCompletionUseCase(tracking);
|
|
59
|
+
const result = recordCompletion.execute({
|
|
60
|
+
projectPath,
|
|
61
|
+
mrId: 'gh-42',
|
|
62
|
+
reviewData: {
|
|
63
|
+
type: 'review',
|
|
64
|
+
durationMs: 60_000,
|
|
65
|
+
score: 7.5,
|
|
66
|
+
blocking: 1,
|
|
67
|
+
warnings: 2,
|
|
68
|
+
diffStats: fetched,
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
expect(result?.reviews[0]?.diffStats).toEqual({
|
|
72
|
+
commitsCount: 3,
|
|
73
|
+
additions: 150,
|
|
74
|
+
deletions: 30,
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
describe('Scenario 2: Successful diff stats capture on GitLab review (nominal)', () => {
|
|
79
|
+
it('records diff stats matching the fetched values', () => {
|
|
80
|
+
const diffStatsGateway = new StubDiffStatsFetchGateway();
|
|
81
|
+
diffStatsGateway.setResponse(42, { commitsCount: 5, additions: 200, deletions: 45 });
|
|
82
|
+
const fetched = fetchDiffStatsSafely(diffStatsGateway, projectPath, 42, logger);
|
|
83
|
+
const reviewStats = addReviewStats(projectPath, 42, 90_000, REVIEW_OUTPUT, 'reviewer', fetched);
|
|
84
|
+
expect(reviewStats.diffStats).toEqual({
|
|
85
|
+
commitsCount: 5,
|
|
86
|
+
additions: 200,
|
|
87
|
+
deletions: 45,
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
describe('Scenario 3: Diff stats fetch failure does not block the review', () => {
|
|
92
|
+
it('persists ReviewStats with diffStats=null, does not throw, and logs a warning', () => {
|
|
93
|
+
const diffStatsGateway = new StubDiffStatsFetchGateway();
|
|
94
|
+
diffStatsGateway.setFailure(42);
|
|
95
|
+
const warnSpy = vi.spyOn(logger, 'warn');
|
|
96
|
+
const fetched = fetchDiffStatsSafely(diffStatsGateway, projectPath, 42, logger);
|
|
97
|
+
expect(fetched).toBeNull();
|
|
98
|
+
expect(warnSpy).toHaveBeenCalledOnce();
|
|
99
|
+
const reviewStats = addReviewStats(projectPath, 42, 60_000, REVIEW_OUTPUT, 'reviewer', fetched);
|
|
100
|
+
expect(reviewStats.diffStats).toBeNull();
|
|
101
|
+
expect(reviewStats.mrNumber).toBe(42);
|
|
102
|
+
expect(reviewStats.score).toBe(7.5);
|
|
103
|
+
expect(reviewStats.blocking).toBe(1);
|
|
104
|
+
expect(reviewStats.warnings).toBe(2);
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
describe('Scenario 4: Backward compatibility — old reviews without diffStats', () => {
|
|
108
|
+
it('loads legacy stats.json without diffStats fields without crashing', () => {
|
|
109
|
+
const legacyStats = {
|
|
110
|
+
totalReviews: 2,
|
|
111
|
+
totalDuration: 120_000,
|
|
112
|
+
averageScore: 7,
|
|
113
|
+
averageDuration: 60_000,
|
|
114
|
+
totalBlocking: 1,
|
|
115
|
+
totalWarnings: 3,
|
|
116
|
+
reviews: [
|
|
117
|
+
{
|
|
118
|
+
id: 'legacy-1',
|
|
119
|
+
timestamp: '2024-01-01T10:00:00Z',
|
|
120
|
+
mrNumber: 1,
|
|
121
|
+
duration: 60_000,
|
|
122
|
+
score: 7,
|
|
123
|
+
blocking: 0,
|
|
124
|
+
warnings: 1,
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
id: 'legacy-2',
|
|
128
|
+
timestamp: '2024-01-02T10:00:00Z',
|
|
129
|
+
mrNumber: 2,
|
|
130
|
+
duration: 60_000,
|
|
131
|
+
score: 7,
|
|
132
|
+
blocking: 1,
|
|
133
|
+
warnings: 2,
|
|
134
|
+
},
|
|
135
|
+
],
|
|
136
|
+
lastUpdated: '2024-01-02T10:00:00Z',
|
|
137
|
+
};
|
|
138
|
+
writeFileSync(join(projectPath, '.claude', 'reviews', 'stats.json'), JSON.stringify(legacyStats, null, 2), 'utf-8');
|
|
139
|
+
const loaded = loadProjectStats(projectPath);
|
|
140
|
+
expect(loaded.totalReviews).toBe(2);
|
|
141
|
+
expect(loaded.reviews).toHaveLength(2);
|
|
142
|
+
expect(loaded.reviews[0]?.diffStats).toBeUndefined();
|
|
143
|
+
const newReview = addReviewStats(projectPath, 3, 60_000, REVIEW_OUTPUT, 'reviewer', null);
|
|
144
|
+
expect(newReview.diffStats).toBeNull();
|
|
145
|
+
const after = loadProjectStats(projectPath);
|
|
146
|
+
expect(after.totalReviews).toBe(3);
|
|
147
|
+
expect(after.averageAdditions ?? null).toBeNull();
|
|
148
|
+
expect(after.averageDeletions ?? null).toBeNull();
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
describe('Scenario 5: Aggregated diff stats in project stats', () => {
|
|
152
|
+
it('averages exclude null entries and totals reflect only diff-bearing reviews', () => {
|
|
153
|
+
addReviewStats(projectPath, 1, 60_000, REVIEW_OUTPUT, 'reviewer', DiffStatsFactory.create({ commitsCount: 2, additions: 100, deletions: 20 }));
|
|
154
|
+
addReviewStats(projectPath, 2, 60_000, REVIEW_OUTPUT, 'reviewer', DiffStatsFactory.create({ commitsCount: 1, additions: 50, deletions: 10 }));
|
|
155
|
+
addReviewStats(projectPath, 3, 60_000, REVIEW_OUTPUT, 'reviewer', null);
|
|
156
|
+
const stats = loadProjectStats(projectPath);
|
|
157
|
+
expect(stats.totalAdditions).toBe(150);
|
|
158
|
+
expect(stats.totalDeletions).toBe(30);
|
|
159
|
+
expect(stats.averageAdditions).toBe(75);
|
|
160
|
+
expect(stats.averageDeletions).toBe(15);
|
|
161
|
+
expect(stats.diffStatsReviewCount).toBe(2);
|
|
162
|
+
const summary = getStatsSummary(stats);
|
|
163
|
+
expect(summary.totalAdditions).toBe(150);
|
|
164
|
+
expect(summary.totalDeletions).toBe(30);
|
|
165
|
+
expect(summary.totalLinesReviewed).toBe(180);
|
|
166
|
+
expect(summary.averageAdditions).toBe('75.0');
|
|
167
|
+
expect(summary.averageDeletions).toBe('15.0');
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
describe('Scenario 6: Followup reviews also capture diff stats', () => {
|
|
171
|
+
it('records diffStats on both initial review and followup ReviewEvent', () => {
|
|
172
|
+
const tracking = new InMemoryReviewRequestTrackingGateway();
|
|
173
|
+
tracking.create(projectPath, TrackedMrFactory.create({ id: 'mr-42', mrNumber: 42 }));
|
|
174
|
+
const recordCompletion = new RecordReviewCompletionUseCase(tracking);
|
|
175
|
+
recordCompletion.execute({
|
|
176
|
+
projectPath,
|
|
177
|
+
mrId: 'mr-42',
|
|
178
|
+
reviewData: {
|
|
179
|
+
type: 'review',
|
|
180
|
+
durationMs: 60_000,
|
|
181
|
+
score: 8,
|
|
182
|
+
blocking: 0,
|
|
183
|
+
warnings: 1,
|
|
184
|
+
diffStats: DiffStatsFactory.create({ commitsCount: 2, additions: 100, deletions: 20 }),
|
|
185
|
+
},
|
|
186
|
+
});
|
|
187
|
+
const after = recordCompletion.execute({
|
|
188
|
+
projectPath,
|
|
189
|
+
mrId: 'mr-42',
|
|
190
|
+
reviewData: {
|
|
191
|
+
type: 'followup',
|
|
192
|
+
durationMs: 30_000,
|
|
193
|
+
score: 9,
|
|
194
|
+
blocking: 0,
|
|
195
|
+
warnings: 0,
|
|
196
|
+
diffStats: DiffStatsFactory.create({ commitsCount: 4, additions: 180, deletions: 35 }),
|
|
197
|
+
},
|
|
198
|
+
});
|
|
199
|
+
expect(after?.reviews).toHaveLength(2);
|
|
200
|
+
const [first, second] = after?.reviews ?? [];
|
|
201
|
+
expect(first?.type).toBe('review');
|
|
202
|
+
expect(first?.diffStats).toEqual({ commitsCount: 2, additions: 100, deletions: 20 });
|
|
203
|
+
expect(second?.type).toBe('followup');
|
|
204
|
+
expect(second?.diffStats).toEqual({ commitsCount: 4, additions: 180, deletions: 35 });
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
describe('Scenario 7: Zero-diff merge request', () => {
|
|
208
|
+
it('persists zero values as-is (not coerced to null)', () => {
|
|
209
|
+
const zeroDiff = { commitsCount: 1, additions: 0, deletions: 0 };
|
|
210
|
+
const reviewStats = addReviewStats(projectPath, 42, 60_000, REVIEW_OUTPUT, 'reviewer', zeroDiff);
|
|
211
|
+
expect(reviewStats.diffStats).toEqual({ commitsCount: 1, additions: 0, deletions: 0 });
|
|
212
|
+
const stats = loadProjectStats(projectPath);
|
|
213
|
+
expect(stats.diffStatsReviewCount).toBe(1);
|
|
214
|
+
expect(stats.totalAdditions).toBe(0);
|
|
215
|
+
expect(stats.totalDeletions).toBe(0);
|
|
216
|
+
expect(stats.averageAdditions).toBe(0);
|
|
217
|
+
expect(stats.averageDeletions).toBe(0);
|
|
218
|
+
});
|
|
219
|
+
});
|
|
220
|
+
});
|
|
221
|
+
//# sourceMappingURL=47-capture-git-diff-stats.acceptance.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"47-capture-git-diff-stats.acceptance.test.js","sourceRoot":"","sources":["../../../src/tests/acceptance/47-capture-git-diff-stats.acceptance.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/config.factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAEvE,wBAAgB,oBAAoB,CAClC,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,GACpC,gBAAgB,CAUlB;AAED,wBAAgB,gBAAgB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,
|
|
1
|
+
{"version":3,"file":"config.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/config.factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAEvE,wBAAgB,oBAAoB,CAClC,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,GACpC,gBAAgB,CAUlB;AAED,wBAAgB,gBAAgB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAgBpE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/config.factory.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,oBAAoB,CAClC,SAAqC;IAErC,OAAO;QACL,IAAI,EAAE,WAAW;QACjB,QAAQ,EAAE,QAAQ;QAClB,SAAS,EAAE,8BAA8B;QACzC,SAAS,EAAE,gBAAgB;QAC3B,KAAK,EAAE,aAAa;QACpB,OAAO,EAAE,IAAI;QACb,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,SAA2B;IAC1D,OAAO;QACL,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QACtB,IAAI,EAAE;YACJ,cAAc,EAAE,WAAW;YAC3B,cAAc,EAAE,cAAc;SAC/B;QACD,KAAK,EAAE;YACL,aAAa,EAAE,CAAC;YAChB,qBAAqB,EAAE,KAAK;
|
|
1
|
+
{"version":3,"file":"config.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/config.factory.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,oBAAoB,CAClC,SAAqC;IAErC,OAAO;QACL,IAAI,EAAE,WAAW;QACjB,QAAQ,EAAE,QAAQ;QAClB,SAAS,EAAE,8BAA8B;QACzC,SAAS,EAAE,gBAAgB;QAC3B,KAAK,EAAE,aAAa;QACpB,OAAO,EAAE,IAAI;QACb,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,SAA2B;IAC1D,OAAO;QACL,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QACtB,IAAI,EAAE;YACJ,cAAc,EAAE,WAAW;YAC3B,cAAc,EAAE,cAAc;SAC/B;QACD,KAAK,EAAE;YACL,aAAa,EAAE,CAAC;YAChB,qBAAqB,EAAE,KAAK;YAC5B,uBAAuB,EAAE,CAAC;SAC3B;QACD,YAAY,EAAE,CAAC,oBAAoB,EAAE,CAAC;QACtC,WAAW,EAAE,WAAW;QACxB,GAAG,SAAS;KACb,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/jobRecord.factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6DAA6D,CAAC;AAE7F,eAAO,MAAM,gBAAgB;uBACT,OAAO,CAAC,SAAS,CAAC,GAAQ,SAAS;CAetD,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export const JobRecordFactory = {
|
|
2
|
+
create(overrides = {}) {
|
|
3
|
+
return {
|
|
4
|
+
jobId: 'gitlab:test-org/test-project:42',
|
|
5
|
+
platform: 'gitlab',
|
|
6
|
+
projectPath: 'test-org/test-project',
|
|
7
|
+
mergeRequestId: 42,
|
|
8
|
+
jobType: 'review',
|
|
9
|
+
startedAt: '2026-05-25T10:00:00.000Z',
|
|
10
|
+
completedAt: '2026-05-25T10:05:00.000Z',
|
|
11
|
+
durationMs: 300000,
|
|
12
|
+
status: 'success',
|
|
13
|
+
exitReason: null,
|
|
14
|
+
...overrides,
|
|
15
|
+
};
|
|
16
|
+
},
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=jobRecord.factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/jobRecord.factory.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,MAAM,CAAC,YAAgC,EAAE;QACvC,OAAO;YACL,KAAK,EAAE,iCAAiC;YACxC,QAAQ,EAAE,QAAQ;YAClB,WAAW,EAAE,uBAAuB;YACpC,cAAc,EAAE,EAAE;YAClB,OAAO,EAAE,QAAQ;YACjB,SAAS,EAAE,0BAA0B;YACrC,WAAW,EAAE,0BAA0B;YACvC,UAAU,EAAE,MAAM;YAClB,MAAM,EAAE,SAAS;YACjB,UAAU,EAAE,IAAI;YAChB,GAAG,SAAS;SACb,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { type ProjectConcurrencyCap } from '../../modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.js';
|
|
2
|
+
export declare class ProjectConcurrencyCapFactory {
|
|
3
|
+
static create(value?: number): ProjectConcurrencyCap;
|
|
4
|
+
}
|
|
5
|
+
//# sourceMappingURL=projectConcurrencyCap.factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projectConcurrencyCap.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/projectConcurrencyCap.factory.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,KAAK,qBAAqB,EAC3B,MAAM,iGAAiG,CAAC;AAEzG,qBAAa,4BAA4B;IACvC,MAAM,CAAC,MAAM,CAAC,KAAK,GAAE,MAAwC,GAAG,qBAAqB;CAGtF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { projectConcurrencyCapGuard } from '../../modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.guard.js';
|
|
2
|
+
import { DEFAULT_PROJECT_CONCURRENCY_CAP, } from '../../modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.js';
|
|
3
|
+
export class ProjectConcurrencyCapFactory {
|
|
4
|
+
static create(value = DEFAULT_PROJECT_CONCURRENCY_CAP) {
|
|
5
|
+
return projectConcurrencyCapGuard.parse(value);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=projectConcurrencyCap.factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projectConcurrencyCap.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/projectConcurrencyCap.factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,2FAA2F,CAAC;AACvI,OAAO,EACL,+BAA+B,GAEhC,MAAM,iGAAiG,CAAC;AAEzG,MAAM,OAAO,4BAA4B;IACvC,MAAM,CAAC,MAAM,CAAC,QAAgB,+BAA+B;QAC3D,OAAO,0BAA0B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { WorktreeHealth } from '../../modules/worktree-management/entities/worktree/worktreeHealth.schema.js';
|
|
2
|
+
export declare class WorktreeHealthFactory {
|
|
3
|
+
static healthy(): WorktreeHealth;
|
|
4
|
+
static stale(overrides?: {
|
|
5
|
+
ageMs?: number;
|
|
6
|
+
thresholdMs?: number;
|
|
7
|
+
detectedAt?: Date;
|
|
8
|
+
}): WorktreeHealth;
|
|
9
|
+
static orphanLock(overrides?: {
|
|
10
|
+
lockPath?: string;
|
|
11
|
+
lockAgeMs?: number;
|
|
12
|
+
detectedAt?: Date;
|
|
13
|
+
}): WorktreeHealth;
|
|
14
|
+
static unresolvedConflict(overrides?: {
|
|
15
|
+
detectedAt?: Date;
|
|
16
|
+
}): WorktreeHealth;
|
|
17
|
+
static missingArtifacts(overrides?: {
|
|
18
|
+
expectedPath?: string;
|
|
19
|
+
detectedAt?: Date;
|
|
20
|
+
}): WorktreeHealth;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=worktreeHealth.factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeHealth.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/worktreeHealth.factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,cAAc,EACf,MAAM,0EAA0E,CAAC;AASlF,qBAAa,qBAAqB;IAChC,MAAM,CAAC,OAAO,IAAI,cAAc;IAIhC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,IAAI,CAAA;KAAE,GAAG,cAAc;IAarG,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;QAC5B,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,IAAI,CAAC;KACnB,GAAG,cAAc;IAalB,MAAM,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,IAAI,CAAA;KAAE,GAAG,cAAc;IAQ5E,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC,EAAE;QAAE,YAAY,CAAC,EAAE,MAAM,CAAC;QAAC,UAAU,CAAC,EAAE,IAAI,CAAA;KAAE,GAAG,cAAc;CAUlG"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
const DEFAULT_DETECTED_AT = new Date('2026-05-23T12:00:00.000Z');
|
|
2
|
+
const DEFAULT_STALE_THRESHOLD_MS = 24 * 60 * 60 * 1000;
|
|
3
|
+
const DEFAULT_STALE_AGE_MS = 26 * 60 * 60 * 1000;
|
|
4
|
+
const DEFAULT_LOCK_AGE_MS = 2 * 60 * 60 * 1000;
|
|
5
|
+
const DEFAULT_LOCK_PATH = '/main/.git/worktrees/example/index.lock';
|
|
6
|
+
const DEFAULT_NODE_MODULES_PATH = '/tmp/worktrees/example/node_modules';
|
|
7
|
+
export class WorktreeHealthFactory {
|
|
8
|
+
static healthy() {
|
|
9
|
+
return { status: 'healthy' };
|
|
10
|
+
}
|
|
11
|
+
static stale(overrides) {
|
|
12
|
+
const reason = {
|
|
13
|
+
kind: 'stale',
|
|
14
|
+
ageMs: overrides?.ageMs ?? DEFAULT_STALE_AGE_MS,
|
|
15
|
+
thresholdMs: overrides?.thresholdMs ?? DEFAULT_STALE_THRESHOLD_MS,
|
|
16
|
+
};
|
|
17
|
+
return {
|
|
18
|
+
status: 'degraded',
|
|
19
|
+
reason,
|
|
20
|
+
detectedAt: overrides?.detectedAt ?? DEFAULT_DETECTED_AT,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
static orphanLock(overrides) {
|
|
24
|
+
const reason = {
|
|
25
|
+
kind: 'orphan-git-lock',
|
|
26
|
+
lockPath: overrides?.lockPath ?? DEFAULT_LOCK_PATH,
|
|
27
|
+
lockAgeMs: overrides?.lockAgeMs ?? DEFAULT_LOCK_AGE_MS,
|
|
28
|
+
};
|
|
29
|
+
return {
|
|
30
|
+
status: 'degraded',
|
|
31
|
+
reason,
|
|
32
|
+
detectedAt: overrides?.detectedAt ?? DEFAULT_DETECTED_AT,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
static unresolvedConflict(overrides) {
|
|
36
|
+
return {
|
|
37
|
+
status: 'degraded',
|
|
38
|
+
reason: { kind: 'unresolved-conflict' },
|
|
39
|
+
detectedAt: overrides?.detectedAt ?? DEFAULT_DETECTED_AT,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
static missingArtifacts(overrides) {
|
|
43
|
+
return {
|
|
44
|
+
status: 'degraded',
|
|
45
|
+
reason: {
|
|
46
|
+
kind: 'missing-build-artifacts',
|
|
47
|
+
expectedPath: overrides?.expectedPath ?? DEFAULT_NODE_MODULES_PATH,
|
|
48
|
+
},
|
|
49
|
+
detectedAt: overrides?.detectedAt ?? DEFAULT_DETECTED_AT,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=worktreeHealth.factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeHealth.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/worktreeHealth.factory.ts"],"names":[],"mappings":"AAKA,MAAM,mBAAmB,GAAG,IAAI,IAAI,CAAC,0BAA0B,CAAC,CAAC;AACjE,MAAM,0BAA0B,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AACvD,MAAM,oBAAoB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AACjD,MAAM,mBAAmB,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AAC/C,MAAM,iBAAiB,GAAG,yCAAyC,CAAC;AACpE,MAAM,yBAAyB,GAAG,qCAAqC,CAAC;AAExE,MAAM,OAAO,qBAAqB;IAChC,MAAM,CAAC,OAAO;QACZ,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IAC/B,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,SAAuE;QAClF,MAAM,MAAM,GAAmB;YAC7B,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,SAAS,EAAE,KAAK,IAAI,oBAAoB;YAC/C,WAAW,EAAE,SAAS,EAAE,WAAW,IAAI,0BAA0B;SAClE,CAAC;QACF,OAAO;YACL,MAAM,EAAE,UAAU;YAClB,MAAM;YACN,UAAU,EAAE,SAAS,EAAE,UAAU,IAAI,mBAAmB;SACzD,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,SAIjB;QACC,MAAM,MAAM,GAAmB;YAC7B,IAAI,EAAE,iBAAiB;YACvB,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI,iBAAiB;YAClD,SAAS,EAAE,SAAS,EAAE,SAAS,IAAI,mBAAmB;SACvD,CAAC;QACF,OAAO;YACL,MAAM,EAAE,UAAU;YAClB,MAAM;YACN,UAAU,EAAE,SAAS,EAAE,UAAU,IAAI,mBAAmB;SACzD,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,kBAAkB,CAAC,SAAiC;QACzD,OAAO;YACL,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE,EAAE,IAAI,EAAE,qBAAqB,EAAE;YACvC,UAAU,EAAE,SAAS,EAAE,UAAU,IAAI,mBAAmB;SACzD,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,gBAAgB,CAAC,SAAwD;QAC9E,OAAO;YACL,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE;gBACN,IAAI,EAAE,yBAAyB;gBAC/B,YAAY,EAAE,SAAS,EAAE,YAAY,IAAI,yBAAyB;aACnE;YACD,UAAU,EAAE,SAAS,EAAE,UAAU,IAAI,mBAAmB;SACzD,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { JobHistoryGateway, PruneJobHistoryResult } from '../../modules/review-execution/entities/job/jobHistory.gateway.js';
|
|
2
|
+
import type { JobRecord } from '../../modules/review-execution/entities/job/jobRecord.schema.js';
|
|
3
|
+
export declare class StubJobHistoryGateway implements JobHistoryGateway {
|
|
4
|
+
private readonly buckets;
|
|
5
|
+
failOnAppend: boolean;
|
|
6
|
+
appendCount: number;
|
|
7
|
+
lastAppended: JobRecord | null;
|
|
8
|
+
appendRecord(record: JobRecord): Promise<void>;
|
|
9
|
+
loadRecordsWithinWindow(retentionDays: number, now: Date): Promise<JobRecord[]>;
|
|
10
|
+
deleteRecordsOutsideWindow(retentionDays: number, now: Date): Promise<PruneJobHistoryResult>;
|
|
11
|
+
prepopulate(record: JobRecord): void;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=jobHistory.stub.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/jobHistory.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,+DAA+D,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6DAA6D,CAAC;AAiB7F,qBAAa,qBAAsB,YAAW,iBAAiB;IAC7D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkC;IACnD,YAAY,UAAS;IACrB,WAAW,SAAK;IAChB,YAAY,EAAE,SAAS,GAAG,IAAI,CAAQ;IAEvC,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAY9C,uBAAuB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAY/E,0BAA0B,CAC9B,aAAa,EAAE,MAAM,EACrB,GAAG,EAAE,IAAI,GACR,OAAO,CAAC,qBAAqB,CAAC;IAcjC,WAAW,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI;CAMrC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
function fileNameForRecord(record) {
|
|
2
|
+
return `${record.completedAt.slice(0, 10)}.jsonl`;
|
|
3
|
+
}
|
|
4
|
+
function fileNameToDate(filename) {
|
|
5
|
+
const datePart = filename.replace(/\.jsonl$/, '');
|
|
6
|
+
const parsed = new Date(`${datePart}T00:00:00.000Z`);
|
|
7
|
+
return Number.isNaN(parsed.getTime()) ? null : parsed;
|
|
8
|
+
}
|
|
9
|
+
function thresholdFromRetention(retentionDays, now) {
|
|
10
|
+
const ms = retentionDays * 24 * 60 * 60 * 1000;
|
|
11
|
+
return new Date(now.getTime() - ms);
|
|
12
|
+
}
|
|
13
|
+
export class StubJobHistoryGateway {
|
|
14
|
+
buckets = new Map();
|
|
15
|
+
failOnAppend = false;
|
|
16
|
+
appendCount = 0;
|
|
17
|
+
lastAppended = null;
|
|
18
|
+
async appendRecord(record) {
|
|
19
|
+
this.appendCount += 1;
|
|
20
|
+
if (this.failOnAppend) {
|
|
21
|
+
throw new Error('stub append failure');
|
|
22
|
+
}
|
|
23
|
+
this.lastAppended = record;
|
|
24
|
+
const filename = fileNameForRecord(record);
|
|
25
|
+
const list = this.buckets.get(filename) ?? [];
|
|
26
|
+
list.push(record);
|
|
27
|
+
this.buckets.set(filename, list);
|
|
28
|
+
}
|
|
29
|
+
async loadRecordsWithinWindow(retentionDays, now) {
|
|
30
|
+
const threshold = thresholdFromRetention(retentionDays, now);
|
|
31
|
+
const collected = [];
|
|
32
|
+
for (const [filename, records] of this.buckets.entries()) {
|
|
33
|
+
const fileDate = fileNameToDate(filename);
|
|
34
|
+
if (!fileDate)
|
|
35
|
+
continue;
|
|
36
|
+
if (fileDate < threshold)
|
|
37
|
+
continue;
|
|
38
|
+
collected.push(...records);
|
|
39
|
+
}
|
|
40
|
+
return collected;
|
|
41
|
+
}
|
|
42
|
+
async deleteRecordsOutsideWindow(retentionDays, now) {
|
|
43
|
+
const threshold = thresholdFromRetention(retentionDays, now);
|
|
44
|
+
const deletedFilenames = [];
|
|
45
|
+
for (const filename of Array.from(this.buckets.keys())) {
|
|
46
|
+
const fileDate = fileNameToDate(filename);
|
|
47
|
+
if (!fileDate)
|
|
48
|
+
continue;
|
|
49
|
+
if (fileDate < threshold) {
|
|
50
|
+
deletedFilenames.push(filename);
|
|
51
|
+
this.buckets.delete(filename);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return { deletedFilenames };
|
|
55
|
+
}
|
|
56
|
+
prepopulate(record) {
|
|
57
|
+
const filename = fileNameForRecord(record);
|
|
58
|
+
const list = this.buckets.get(filename) ?? [];
|
|
59
|
+
list.push(record);
|
|
60
|
+
this.buckets.set(filename, list);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=jobHistory.stub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/jobHistory.stub.ts"],"names":[],"mappings":"AAMA,SAAS,iBAAiB,CAAC,MAAiB;IAC1C,OAAO,GAAG,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC;AACpD,CAAC;AAED,SAAS,cAAc,CAAC,QAAgB;IACtC,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAClD,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,GAAG,QAAQ,gBAAgB,CAAC,CAAC;IACrD,OAAO,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;AACxD,CAAC;AAED,SAAS,sBAAsB,CAAC,aAAqB,EAAE,GAAS;IAC9D,MAAM,EAAE,GAAG,aAAa,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;IAC/C,OAAO,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;AACtC,CAAC;AAED,MAAM,OAAO,qBAAqB;IACf,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;IACnD,YAAY,GAAG,KAAK,CAAC;IACrB,WAAW,GAAG,CAAC,CAAC;IAChB,YAAY,GAAqB,IAAI,CAAC;IAE7C,KAAK,CAAC,YAAY,CAAC,MAAiB;QAClC,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC;QACtB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC3B,MAAM,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,aAAqB,EAAE,GAAS;QAC5D,MAAM,SAAS,GAAG,sBAAsB,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;QAC7D,MAAM,SAAS,GAAgB,EAAE,CAAC;QAClC,KAAK,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;YACzD,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC1C,IAAI,CAAC,QAAQ;gBAAE,SAAS;YACxB,IAAI,QAAQ,GAAG,SAAS;gBAAE,SAAS;YACnC,SAAS,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;QAC7B,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,0BAA0B,CAC9B,aAAqB,EACrB,GAAS;QAET,MAAM,SAAS,GAAG,sBAAsB,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;QAC7D,MAAM,gBAAgB,GAAa,EAAE,CAAC;QACtC,KAAK,MAAM,QAAQ,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;YACvD,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC1C,IAAI,CAAC,QAAQ;gBAAE,SAAS;YACxB,IAAI,QAAQ,GAAG,SAAS,EAAE,CAAC;gBACzB,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAChC,CAAC;QACH,CAAC;QACD,OAAO,EAAE,gBAAgB,EAAE,CAAC;IAC9B,CAAC;IAED,WAAW,CAAC,MAAiB;QAC3B,MAAM,QAAQ,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { QueueCapacityPort } from '../../modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.js';
|
|
2
|
+
export declare class StubQueueCapacityPort implements QueueCapacityPort {
|
|
3
|
+
globalConcurrency: number | null;
|
|
4
|
+
projectCaps: Map<string, number>;
|
|
5
|
+
setGlobalConcurrency(value: number): void;
|
|
6
|
+
setProjectConcurrencyCap(projectPath: string, cap: number): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=queueCapacityPort.stub.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queueCapacityPort.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/queueCapacityPort.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,0FAA0F,CAAC;AAElI,qBAAa,qBAAsB,YAAW,iBAAiB;IAC7D,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAQ;IACxC,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IAE7C,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIzC,wBAAwB,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI;CAGjE"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export class StubQueueCapacityPort {
|
|
2
|
+
globalConcurrency = null;
|
|
3
|
+
projectCaps = new Map();
|
|
4
|
+
setGlobalConcurrency(value) {
|
|
5
|
+
this.globalConcurrency = value;
|
|
6
|
+
}
|
|
7
|
+
setProjectConcurrencyCap(projectPath, cap) {
|
|
8
|
+
this.projectCaps.set(projectPath, cap);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=queueCapacityPort.stub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queueCapacityPort.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/queueCapacityPort.stub.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,qBAAqB;IAChC,iBAAiB,GAAkB,IAAI,CAAC;IACxC,WAAW,GAAwB,IAAI,GAAG,EAAE,CAAC;IAE7C,oBAAoB,CAAC,KAAa;QAChC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAED,wBAAwB,CAAC,WAAmB,EAAE,GAAW;QACvD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;IACzC,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { DeclaredRepository, RepositoriesListGateway } from '../../modules/cli-configuration/entities/repositoriesList/repositoriesList.gateway.js';
|
|
2
|
+
export declare class StubRepositoriesListGateway implements RepositoriesListGateway {
|
|
3
|
+
private repositories;
|
|
4
|
+
set(repositories: DeclaredRepository[]): void;
|
|
5
|
+
list(): DeclaredRepository[];
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=repositoriesListGateway.stub.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositoriesListGateway.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/repositoriesListGateway.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,uBAAuB,EACxB,MAAM,mFAAmF,CAAC;AAE3F,qBAAa,2BAA4B,YAAW,uBAAuB;IACzE,OAAO,CAAC,YAAY,CAA4B;IAEhD,GAAG,CAAC,YAAY,EAAE,kBAAkB,EAAE,GAAG,IAAI;IAI7C,IAAI,IAAI,kBAAkB,EAAE;CAG7B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export class StubRepositoriesListGateway {
|
|
2
|
+
repositories = [];
|
|
3
|
+
set(repositories) {
|
|
4
|
+
this.repositories = repositories.map((repository) => ({ ...repository }));
|
|
5
|
+
}
|
|
6
|
+
list() {
|
|
7
|
+
return this.repositories.map((repository) => ({ ...repository }));
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=repositoriesListGateway.stub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositoriesListGateway.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/repositoriesListGateway.stub.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,2BAA2B;IAC9B,YAAY,GAAyB,EAAE,CAAC;IAEhD,GAAG,CAAC,YAAkC;QACpC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,UAAU,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,UAAU,EAAE,CAAC,CAAC,CAAC;IACpE,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { HealthSignals, WorktreeHealthProbeGateway } from '../../modules/worktree-management/entities/worktree/worktreeHealthProbe.gateway.js';
|
|
2
|
+
import type { WorktreeEntry } from '../../modules/worktree-management/entities/worktree/worktree.schema.js';
|
|
3
|
+
export declare class StubWorktreeHealthProbeGateway implements WorktreeHealthProbeGateway {
|
|
4
|
+
private readonly signalsByPath;
|
|
5
|
+
private defaultSignals;
|
|
6
|
+
readonly probedPaths: string[];
|
|
7
|
+
setSignals(path: string, signals: HealthSignals): void;
|
|
8
|
+
setDefault(signals: HealthSignals): void;
|
|
9
|
+
probe(entry: WorktreeEntry): Promise<HealthSignals>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=worktreeHealthProbe.stub.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeHealthProbe.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/worktreeHealthProbe.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,0BAA0B,EAC3B,MAAM,gFAAgF,CAAC;AACxF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oEAAoE,CAAC;AAExG,qBAAa,8BAA+B,YAAW,0BAA0B;IAC/E,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAyC;IACvE,OAAO,CAAC,cAAc,CAA8B;IACpD,QAAQ,CAAC,WAAW,EAAE,MAAM,EAAE,CAAM;IAEpC,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,GAAG,IAAI;IAItD,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI;IAIlC,KAAK,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;CAY1D"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export class StubWorktreeHealthProbeGateway {
|
|
2
|
+
signalsByPath = new Map();
|
|
3
|
+
defaultSignals = null;
|
|
4
|
+
probedPaths = [];
|
|
5
|
+
setSignals(path, signals) {
|
|
6
|
+
this.signalsByPath.set(path, signals);
|
|
7
|
+
}
|
|
8
|
+
setDefault(signals) {
|
|
9
|
+
this.defaultSignals = signals;
|
|
10
|
+
}
|
|
11
|
+
async probe(entry) {
|
|
12
|
+
this.probedPaths.push(entry.path);
|
|
13
|
+
const direct = this.signalsByPath.get(entry.path);
|
|
14
|
+
if (direct)
|
|
15
|
+
return direct;
|
|
16
|
+
if (this.defaultSignals !== null)
|
|
17
|
+
return this.defaultSignals;
|
|
18
|
+
return {
|
|
19
|
+
mtime: entry.mtime,
|
|
20
|
+
orphanLock: null,
|
|
21
|
+
unresolvedConflict: false,
|
|
22
|
+
missingBuildArtifacts: { missing: false, expectedPath: '' },
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=worktreeHealthProbe.stub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worktreeHealthProbe.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/worktreeHealthProbe.stub.ts"],"names":[],"mappings":"AAMA,MAAM,OAAO,8BAA8B;IACxB,aAAa,GAA+B,IAAI,GAAG,EAAE,CAAC;IAC/D,cAAc,GAAyB,IAAI,CAAC;IAC3C,WAAW,GAAa,EAAE,CAAC;IAEpC,UAAU,CAAC,IAAY,EAAE,OAAsB;QAC7C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACxC,CAAC;IAED,UAAU,CAAC,OAAsB;QAC/B,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,KAAoB;QAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClD,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAC1B,IAAI,IAAI,CAAC,cAAc,KAAK,IAAI;YAAE,OAAO,IAAI,CAAC,cAAc,CAAC;QAC7D,OAAO;YACL,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,UAAU,EAAE,IAAI;YAChB,kBAAkB,EAAE,KAAK;YACzB,qBAAqB,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE,EAAE;SAC5D,CAAC;IACJ,CAAC;CACF"}
|