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 @@
|
|
|
1
|
+
{"version":3,"file":"recomputeGlobalConcurrency.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/cli-configuration/usecases/projectConfig/recomputeGlobalConcurrency.usecase.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,+BAA+B,EAC/B,8BAA8B,GAC/B,MAAM,iGAAiG,CAAC;AAqBzG,MAAM,OAAO,iCAAiC;IAGf;IAA7B,YAA6B,YAAoD;QAApD,iBAAY,GAAZ,YAAY,CAAwC;IAAG,CAAC;IAErF,OAAO,CAAC,MAAuC;QAC7C,MAAM,EAAE,uBAAuB,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC;QAC/F,MAAM,YAAY,GAAG,uBAAuB,CAAC,IAAI,EAAE,CAAC;QACpD,MAAM,cAAc,GAAyC,EAAE,CAAC;QAEhE,KAAK,MAAM,UAAU,IAAI,YAAY,EAAE,CAAC;YACtC,MAAM,UAAU,GAAG,oBAAoB,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YACnE,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,KAAK,IAAI;gBACpC,CAAC,CAAC,8BAA8B,CAAC,UAAU,CAAC,MAAM,CAAC;gBACnD,CAAC,CAAC,+BAA+B,CAAC;YACpC,cAAc,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;YACzD,iBAAiB,CAAC,wBAAwB,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QACxE,CAAC;QAED,MAAM,aAAa,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QAChF,iBAAiB,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC;QAEnE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,CAAC;IAC3C,CAAC;CACF"}
|
package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.d.ts
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type { ProjectConfig } from '../../../../config/projectConfig.js';
|
|
2
2
|
import type { ProjectConfigGateway } from '../../../../modules/cli-configuration/entities/projectConfig/projectConfig.gateway.js';
|
|
3
3
|
import type { UseCase } from '../../../../shared/foundation/usecase.base.js';
|
|
4
|
-
export declare const EDITABLE_PROJECT_CONFIG_KEYS: readonly ["language", "defaultModel", "reviewSkill", "reviewFollowupSkill", "externalLink", "qualityThreshold"];
|
|
4
|
+
export declare const EDITABLE_PROJECT_CONFIG_KEYS: readonly ["language", "defaultModel", "reviewSkill", "reviewFollowupSkill", "externalLink", "qualityThreshold", "maxConcurrentReviews"];
|
|
5
5
|
export declare const EXTERNAL_LINK_PATTERN: RegExp;
|
|
6
6
|
export type ProjectConfigPatch = Partial<Pick<ProjectConfig, 'language' | 'defaultModel' | 'reviewSkill' | 'reviewFollowupSkill' | 'externalLink'>> & {
|
|
7
7
|
qualityThreshold?: number | null;
|
|
8
|
+
maxConcurrentReviews?: number | null;
|
|
8
9
|
};
|
|
9
10
|
export interface UpdateProjectConfigInput {
|
|
10
11
|
path: string;
|
package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateProjectConfig.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;
|
|
1
|
+
{"version":3,"file":"updateProjectConfig.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AAExH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;AAEnE,eAAO,MAAM,4BAA4B,yIAQ/B,CAAC;AAEX,eAAO,MAAM,qBAAqB,QAAkB,CAAC;AAQrD,MAAM,MAAM,kBAAkB,GAAG,OAAO,CACtC,IAAI,CAAC,aAAa,EAAE,UAAU,GAAG,cAAc,GAAG,aAAa,GAAG,qBAAqB,GAAG,cAAc,CAAC,CAC1G,GAAG;IACF,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,oBAAoB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACtC,CAAC;AAEF,MAAM,WAAW,wBAAwB;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,kBAAkB,CAAC;CAC3B;AAED,MAAM,MAAM,yBAAyB,GACjC;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,aAAa,CAAA;CAAE,GAC5C;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACrC;IAAE,MAAM,EAAE,WAAW,CAAA;CAAE,GACvB;IAAE,MAAM,EAAE,WAAW,CAAA;CAAE,GACvB;IAAE,MAAM,EAAE,UAAU,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AA0F3C,qBAAa,0BACX,YAAW,OAAO,CAAC,wBAAwB,EAAE,yBAAyB,CAAC;IAGrE,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC;gBADV,OAAO,EAAE,oBAAoB,EAC7B,SAAS,CAAC,GAAE,CAAC,MAAM,EAAE,aAAa,KAAK,IAAI,aAAA;IAG9D,OAAO,CAAC,KAAK,EAAE,wBAAwB,GAAG,yBAAyB;CAgDpE"}
|
package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { validateProjectConcurrencyCap } from '../../../../modules/cli-configuration/entities/projectConcurrencyCap/projectConcurrencyCap.valueObject.js';
|
|
1
2
|
export const EDITABLE_PROJECT_CONFIG_KEYS = [
|
|
2
3
|
'language',
|
|
3
4
|
'defaultModel',
|
|
@@ -5,6 +6,7 @@ export const EDITABLE_PROJECT_CONFIG_KEYS = [
|
|
|
5
6
|
'reviewFollowupSkill',
|
|
6
7
|
'externalLink',
|
|
7
8
|
'qualityThreshold',
|
|
9
|
+
'maxConcurrentReviews',
|
|
8
10
|
];
|
|
9
11
|
export const EXTERNAL_LINK_PATTERN = /^https:\/\/.+/;
|
|
10
12
|
const FORBIDDEN_SCHEME_PATTERN = /^[a-zA-Z][a-zA-Z0-9+.-]*:/;
|
|
@@ -52,7 +54,7 @@ function isSupportedModel(value) {
|
|
|
52
54
|
return typeof value === 'string' && SUPPORTED_MODEL_VALUES.includes(value);
|
|
53
55
|
}
|
|
54
56
|
function mergeConfig(current, patch) {
|
|
55
|
-
|
|
57
|
+
let merged = { ...current };
|
|
56
58
|
if (patch.language !== undefined && isSupportedLanguage(patch.language)) {
|
|
57
59
|
merged.language = patch.language;
|
|
58
60
|
}
|
|
@@ -68,16 +70,29 @@ function mergeConfig(current, patch) {
|
|
|
68
70
|
if (Object.prototype.hasOwnProperty.call(patch, 'externalLink')) {
|
|
69
71
|
if (patch.externalLink === undefined || patch.externalLink === '') {
|
|
70
72
|
const { externalLink: _omitted, ...withoutLink } = merged;
|
|
71
|
-
|
|
73
|
+
merged = withoutLink;
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
merged.externalLink = patch.externalLink;
|
|
72
77
|
}
|
|
73
|
-
merged.externalLink = patch.externalLink;
|
|
74
78
|
}
|
|
75
79
|
if (Object.prototype.hasOwnProperty.call(patch, 'qualityThreshold')) {
|
|
76
80
|
if (patch.qualityThreshold === null || patch.qualityThreshold === undefined) {
|
|
77
81
|
const { qualityThreshold: _omitted, ...withoutThreshold } = merged;
|
|
78
|
-
|
|
82
|
+
merged = withoutThreshold;
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
merged.qualityThreshold = patch.qualityThreshold;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
if (Object.prototype.hasOwnProperty.call(patch, 'maxConcurrentReviews')) {
|
|
89
|
+
if (patch.maxConcurrentReviews === null || patch.maxConcurrentReviews === undefined) {
|
|
90
|
+
const { maxConcurrentReviews: _omitted, ...withoutCap } = merged;
|
|
91
|
+
merged = withoutCap;
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
merged.maxConcurrentReviews = patch.maxConcurrentReviews;
|
|
79
95
|
}
|
|
80
|
-
merged.qualityThreshold = patch.qualityThreshold;
|
|
81
96
|
}
|
|
82
97
|
return merged;
|
|
83
98
|
}
|
|
@@ -102,6 +117,15 @@ export class UpdateProjectConfigUseCase {
|
|
|
102
117
|
return { status: 'invalid', reason: thresholdValidation.reason };
|
|
103
118
|
}
|
|
104
119
|
}
|
|
120
|
+
if (Object.prototype.hasOwnProperty.call(sanitized, 'maxConcurrentReviews')) {
|
|
121
|
+
const raw = sanitized.maxConcurrentReviews;
|
|
122
|
+
if (raw !== null) {
|
|
123
|
+
const capValidation = validateProjectConcurrencyCap(raw);
|
|
124
|
+
if (!capValidation.ok) {
|
|
125
|
+
return { status: 'invalid', reason: capValidation.reason };
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
105
129
|
const readResult = this.gateway.read(input.path);
|
|
106
130
|
if (readResult.status === 'not-found') {
|
|
107
131
|
return { status: 'not-found' };
|
package/dist/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateProjectConfig.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"updateProjectConfig.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/cli-configuration/usecases/projectConfig/updateProjectConfig.usecase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { JobRecord } from '../../../../modules/review-execution/entities/job/jobRecord.schema.js';
|
|
2
|
+
export interface PruneJobHistoryResult {
|
|
3
|
+
deletedFilenames: string[];
|
|
4
|
+
}
|
|
5
|
+
export interface JobHistoryGateway {
|
|
6
|
+
appendRecord(record: JobRecord): Promise<void>;
|
|
7
|
+
loadRecordsWithinWindow(retentionDays: number, now: Date): Promise<JobRecord[]>;
|
|
8
|
+
deleteRecordsOutsideWindow(retentionDays: number, now: Date): Promise<PruneJobHistoryResult>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=jobHistory.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.gateway.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobHistory.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6DAA6D,CAAC;AAE7F,MAAM,WAAW,qBAAqB;IACpC,gBAAgB,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,MAAM,WAAW,iBAAiB;IAChC,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/C,uBAAuB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;IAChF,0BAA0B,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC;CAC9F"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.gateway.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobHistory.gateway.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare const jobRecordGuard: import("../../../../shared/foundation/guard.base.js").Guard<{
|
|
2
|
+
jobId: string;
|
|
3
|
+
platform: "github" | "gitlab";
|
|
4
|
+
projectPath: string;
|
|
5
|
+
mergeRequestId: number;
|
|
6
|
+
jobType: "review" | "followup";
|
|
7
|
+
startedAt: string;
|
|
8
|
+
completedAt: string;
|
|
9
|
+
durationMs: number;
|
|
10
|
+
status: "failed" | "success" | "timeout" | "killed";
|
|
11
|
+
exitReason: string | null;
|
|
12
|
+
}>;
|
|
13
|
+
//# sourceMappingURL=jobRecord.guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.guard.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobRecord.guard.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,cAAc;;;;;;;;;;;EAAuD,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { createGuard } from '../../../../shared/foundation/guard.base.js';
|
|
2
|
+
import { jobRecordSchema, } from '../../../../modules/review-execution/entities/job/jobRecord.schema.js';
|
|
3
|
+
export const jobRecordGuard = createGuard(jobRecordSchema, 'jobRecord');
|
|
4
|
+
//# sourceMappingURL=jobRecord.guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.guard.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobRecord.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,OAAO,EACL,eAAe,GAEhB,MAAM,6DAA6D,CAAC;AAErE,MAAM,CAAC,MAAM,cAAc,GAAG,WAAW,CAAY,eAAe,EAAE,WAAW,CAAC,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export declare const jobRecordStatusSchema: z.ZodEnum<{
|
|
3
|
+
failed: "failed";
|
|
4
|
+
success: "success";
|
|
5
|
+
timeout: "timeout";
|
|
6
|
+
killed: "killed";
|
|
7
|
+
}>;
|
|
8
|
+
export declare const jobRecordSchema: z.ZodObject<{
|
|
9
|
+
jobId: z.ZodString;
|
|
10
|
+
platform: z.ZodEnum<{
|
|
11
|
+
github: "github";
|
|
12
|
+
gitlab: "gitlab";
|
|
13
|
+
}>;
|
|
14
|
+
projectPath: z.ZodString;
|
|
15
|
+
mergeRequestId: z.ZodNumber;
|
|
16
|
+
jobType: z.ZodEnum<{
|
|
17
|
+
review: "review";
|
|
18
|
+
followup: "followup";
|
|
19
|
+
}>;
|
|
20
|
+
startedAt: z.ZodString;
|
|
21
|
+
completedAt: z.ZodString;
|
|
22
|
+
durationMs: z.ZodNumber;
|
|
23
|
+
status: z.ZodEnum<{
|
|
24
|
+
failed: "failed";
|
|
25
|
+
success: "success";
|
|
26
|
+
timeout: "timeout";
|
|
27
|
+
killed: "killed";
|
|
28
|
+
}>;
|
|
29
|
+
exitReason: z.ZodNullable<z.ZodString>;
|
|
30
|
+
}, z.core.$strip>;
|
|
31
|
+
export type JobRecordStatus = z.infer<typeof jobRecordStatusSchema>;
|
|
32
|
+
export type JobRecord = z.infer<typeof jobRecordSchema>;
|
|
33
|
+
//# sourceMappingURL=jobRecord.schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.schema.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobRecord.schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,qBAAqB;;;;;EAAqD,CAAC;AAExF,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;iBAW1B,CAAC;AAEH,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AACpE,MAAM,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,eAAe,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export const jobRecordStatusSchema = z.enum(['success', 'failed', 'killed', 'timeout']);
|
|
3
|
+
export const jobRecordSchema = z.object({
|
|
4
|
+
jobId: z.string().min(1),
|
|
5
|
+
platform: z.enum(['gitlab', 'github']),
|
|
6
|
+
projectPath: z.string().min(1),
|
|
7
|
+
mergeRequestId: z.number().int().nonnegative(),
|
|
8
|
+
jobType: z.enum(['review', 'followup']),
|
|
9
|
+
startedAt: z.string().datetime(),
|
|
10
|
+
completedAt: z.string().datetime(),
|
|
11
|
+
durationMs: z.number().int().nonnegative(),
|
|
12
|
+
status: jobRecordStatusSchema,
|
|
13
|
+
exitReason: z.string().nullable(),
|
|
14
|
+
});
|
|
15
|
+
//# sourceMappingURL=jobRecord.schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobRecord.schema.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/entities/job/jobRecord.schema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;AAExF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACxB,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACtC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9B,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE;IAC9C,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;IACvC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAClC,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE;IAC1C,MAAM,EAAE,qBAAqB;IAC7B,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAClC,CAAC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { JobHistoryGateway, PruneJobHistoryResult } from '../../../../../modules/review-execution/entities/job/jobHistory.gateway.js';
|
|
3
|
+
import type { JobRecord } from '../../../../../modules/review-execution/entities/job/jobRecord.schema.js';
|
|
4
|
+
export interface JobHistoryFileSystemGatewayOptions {
|
|
5
|
+
rootDir?: string;
|
|
6
|
+
logger: Logger;
|
|
7
|
+
}
|
|
8
|
+
export declare class JobHistoryFileSystemGateway implements JobHistoryGateway {
|
|
9
|
+
private readonly rootDir;
|
|
10
|
+
private readonly logger;
|
|
11
|
+
constructor(options: JobHistoryFileSystemGatewayOptions);
|
|
12
|
+
private ensureRootDir;
|
|
13
|
+
appendRecord(record: JobRecord): Promise<void>;
|
|
14
|
+
loadRecordsWithinWindow(retentionDays: number, now: Date): Promise<JobRecord[]>;
|
|
15
|
+
deleteRecordsOutsideWindow(retentionDays: number, now: Date): Promise<PruneJobHistoryResult>;
|
|
16
|
+
private readFileRecords;
|
|
17
|
+
private parseLine;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=jobHistory.fileSystem.gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.fileSystem.gateway.d.ts","sourceRoot":"","sources":["../../../../../../src/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EACV,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,+DAA+D,CAAC;AAEvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6DAA6D,CAAC;AAI7F,MAAM,WAAW,kCAAkC;IACjD,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CAChB;AAsBD,qBAAa,2BAA4B,YAAW,iBAAiB;IACnE,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;gBAEpB,OAAO,EAAE,kCAAkC;IAKvD,OAAO,CAAC,aAAa;IAMf,YAAY,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAM9C,uBAAuB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAiB/E,0BAA0B,CAC9B,aAAa,EAAE,MAAM,EACrB,GAAG,EAAE,IAAI,GACR,OAAO,CAAC,qBAAqB,CAAC;YAqBnB,eAAe;IAoB7B,OAAO,CAAC,SAAS;CAelB"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { existsSync, mkdirSync } from 'node:fs';
|
|
2
|
+
import { appendFile, readdir, readFile, unlink } from 'node:fs/promises';
|
|
3
|
+
import { homedir } from 'node:os';
|
|
4
|
+
import { join } from 'node:path';
|
|
5
|
+
import { jobRecordGuard } from '../../../../../modules/review-execution/entities/job/jobRecord.guard.js';
|
|
6
|
+
const DATE_FILENAME_PATTERN = /^(\d{4}-\d{2}-\d{2})\.jsonl$/;
|
|
7
|
+
function defaultRootDir() {
|
|
8
|
+
return join(homedir(), '.claude-review', 'jobs');
|
|
9
|
+
}
|
|
10
|
+
function fileNameForCompletedAt(completedAt) {
|
|
11
|
+
return `${completedAt.slice(0, 10)}.jsonl`;
|
|
12
|
+
}
|
|
13
|
+
function fileDateFromName(filename) {
|
|
14
|
+
const match = filename.match(DATE_FILENAME_PATTERN);
|
|
15
|
+
if (!match)
|
|
16
|
+
return null;
|
|
17
|
+
const parsed = new Date(`${match[1]}T00:00:00.000Z`);
|
|
18
|
+
return Number.isNaN(parsed.getTime()) ? null : parsed;
|
|
19
|
+
}
|
|
20
|
+
function retentionThreshold(retentionDays, now) {
|
|
21
|
+
const ms = retentionDays * 24 * 60 * 60 * 1000;
|
|
22
|
+
return new Date(now.getTime() - ms);
|
|
23
|
+
}
|
|
24
|
+
export class JobHistoryFileSystemGateway {
|
|
25
|
+
rootDir;
|
|
26
|
+
logger;
|
|
27
|
+
constructor(options) {
|
|
28
|
+
this.rootDir = options.rootDir ?? defaultRootDir();
|
|
29
|
+
this.logger = options.logger;
|
|
30
|
+
}
|
|
31
|
+
ensureRootDir() {
|
|
32
|
+
if (!existsSync(this.rootDir)) {
|
|
33
|
+
mkdirSync(this.rootDir, { recursive: true });
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
async appendRecord(record) {
|
|
37
|
+
this.ensureRootDir();
|
|
38
|
+
const filePath = join(this.rootDir, fileNameForCompletedAt(record.completedAt));
|
|
39
|
+
await appendFile(filePath, `${JSON.stringify(record)}\n`, 'utf-8');
|
|
40
|
+
}
|
|
41
|
+
async loadRecordsWithinWindow(retentionDays, now) {
|
|
42
|
+
if (!existsSync(this.rootDir)) {
|
|
43
|
+
return [];
|
|
44
|
+
}
|
|
45
|
+
const threshold = retentionThreshold(retentionDays, now);
|
|
46
|
+
const entries = await readdir(this.rootDir);
|
|
47
|
+
const collected = [];
|
|
48
|
+
for (const entry of entries) {
|
|
49
|
+
const fileDate = fileDateFromName(entry);
|
|
50
|
+
if (!fileDate)
|
|
51
|
+
continue;
|
|
52
|
+
if (fileDate < threshold)
|
|
53
|
+
continue;
|
|
54
|
+
const records = await this.readFileRecords(join(this.rootDir, entry));
|
|
55
|
+
collected.push(...records);
|
|
56
|
+
}
|
|
57
|
+
return collected;
|
|
58
|
+
}
|
|
59
|
+
async deleteRecordsOutsideWindow(retentionDays, now) {
|
|
60
|
+
if (!existsSync(this.rootDir)) {
|
|
61
|
+
return { deletedFilenames: [] };
|
|
62
|
+
}
|
|
63
|
+
const threshold = retentionThreshold(retentionDays, now);
|
|
64
|
+
const entries = await readdir(this.rootDir);
|
|
65
|
+
const deletedFilenames = [];
|
|
66
|
+
for (const entry of entries) {
|
|
67
|
+
const fileDate = fileDateFromName(entry);
|
|
68
|
+
if (!fileDate)
|
|
69
|
+
continue;
|
|
70
|
+
if (fileDate >= threshold)
|
|
71
|
+
continue;
|
|
72
|
+
try {
|
|
73
|
+
await unlink(join(this.rootDir, entry));
|
|
74
|
+
deletedFilenames.push(entry);
|
|
75
|
+
}
|
|
76
|
+
catch {
|
|
77
|
+
// Best-effort: a file we cannot delete is left in place silently.
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return { deletedFilenames };
|
|
81
|
+
}
|
|
82
|
+
async readFileRecords(filePath) {
|
|
83
|
+
let raw;
|
|
84
|
+
try {
|
|
85
|
+
raw = await readFile(filePath, 'utf-8');
|
|
86
|
+
}
|
|
87
|
+
catch {
|
|
88
|
+
return [];
|
|
89
|
+
}
|
|
90
|
+
const lines = raw.split('\n');
|
|
91
|
+
const records = [];
|
|
92
|
+
for (let index = 0; index < lines.length; index += 1) {
|
|
93
|
+
const line = lines[index];
|
|
94
|
+
if (line.trim().length === 0)
|
|
95
|
+
continue;
|
|
96
|
+
const parsedRecord = this.parseLine(line, index + 1);
|
|
97
|
+
if (parsedRecord) {
|
|
98
|
+
records.push(parsedRecord);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return records;
|
|
102
|
+
}
|
|
103
|
+
parseLine(line, lineNumber) {
|
|
104
|
+
let raw;
|
|
105
|
+
try {
|
|
106
|
+
raw = JSON.parse(line);
|
|
107
|
+
}
|
|
108
|
+
catch {
|
|
109
|
+
this.logger.warn({ lineNumber }, `Ligne ${lineNumber} illisible, ignorée`);
|
|
110
|
+
return null;
|
|
111
|
+
}
|
|
112
|
+
const result = jobRecordGuard.safeParse(raw);
|
|
113
|
+
if (!result.success) {
|
|
114
|
+
this.logger.warn({ lineNumber }, `Ligne ${lineNumber} illisible, ignorée`);
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
return result.data;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=jobHistory.fileSystem.gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobHistory.fileSystem.gateway.js","sourceRoot":"","sources":["../../../../../../src/modules/review-execution/interface-adapters/gateways/fileSystem/jobHistory.fileSystem.gateway.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { JobHistoryGateway } from '../../../../modules/review-execution/entities/job/jobHistory.gateway.js';
|
|
3
|
+
import type { JobRecord } from '../../../../modules/review-execution/entities/job/jobRecord.schema.js';
|
|
4
|
+
export interface LoadRecentJobHistoryDependencies {
|
|
5
|
+
jobHistoryGateway: JobHistoryGateway;
|
|
6
|
+
logger: Logger;
|
|
7
|
+
}
|
|
8
|
+
export interface LoadRecentJobHistoryInput {
|
|
9
|
+
retentionDays: number;
|
|
10
|
+
now: () => Date;
|
|
11
|
+
}
|
|
12
|
+
export declare class LoadRecentJobHistoryUseCase {
|
|
13
|
+
private readonly deps;
|
|
14
|
+
constructor(deps: LoadRecentJobHistoryDependencies);
|
|
15
|
+
execute(input: LoadRecentJobHistoryInput): Promise<JobRecord[]>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=loadRecentJobHistory.usecase.d.ts.map
|
package/dist/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loadRecentJobHistory.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+DAA+D,CAAC;AACvG,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6DAA6D,CAAC;AAE7F,MAAM,WAAW,gCAAgC;IAC/C,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,yBAAyB;IACxC,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,qBAAa,2BAA2B;IAC1B,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,gCAAgC;IAE7D,OAAO,CAAC,KAAK,EAAE,yBAAyB,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;CAOtE"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export class LoadRecentJobHistoryUseCase {
|
|
2
|
+
deps;
|
|
3
|
+
constructor(deps) {
|
|
4
|
+
this.deps = deps;
|
|
5
|
+
}
|
|
6
|
+
async execute(input) {
|
|
7
|
+
const records = await this.deps.jobHistoryGateway.loadRecordsWithinWindow(input.retentionDays, input.now());
|
|
8
|
+
return [...records].sort((left, right) => right.completedAt.localeCompare(left.completedAt));
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=loadRecentJobHistory.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loadRecentJobHistory.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/loadRecentJobHistory.usecase.ts"],"names":[],"mappings":"AAcA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,IAAsC;QAAtC,SAAI,GAAJ,IAAI,CAAkC;IAAG,CAAC;IAEvE,KAAK,CAAC,OAAO,CAAC,KAAgC;QAC5C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,uBAAuB,CACvE,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,GAAG,EAAE,CACZ,CAAC;QACF,OAAO,CAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;IAC/F,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { JobStatus } from '../../../../frameworks/queue/pQueueAdapter.js';
|
|
3
|
+
import type { JobHistoryGateway } from '../../../../modules/review-execution/entities/job/jobHistory.gateway.js';
|
|
4
|
+
export interface PersistJobRecordDependencies {
|
|
5
|
+
jobHistoryGateway: JobHistoryGateway;
|
|
6
|
+
logger: Logger;
|
|
7
|
+
}
|
|
8
|
+
export interface PersistJobRecordInput {
|
|
9
|
+
jobStatus: JobStatus;
|
|
10
|
+
abortSignalAborted: boolean;
|
|
11
|
+
now: () => Date;
|
|
12
|
+
}
|
|
13
|
+
export declare class PersistJobRecordUseCase {
|
|
14
|
+
private readonly deps;
|
|
15
|
+
constructor(deps: PersistJobRecordDependencies);
|
|
16
|
+
execute(input: PersistJobRecordInput): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=persistJobRecord.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistJobRecord.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+DAA+D,CAAC;AAMvG,MAAM,WAAW,4BAA4B;IAC3C,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,qBAAqB;IACpC,SAAS,EAAE,SAAS,CAAC;IACrB,kBAAkB,EAAE,OAAO,CAAC;IAC5B,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAgDD,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,4BAA4B;IAEzD,OAAO,CAAC,KAAK,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;CAY3D"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
const CANCEL_PATTERN = /aborted|cancel|annul/i;
|
|
2
|
+
const TIMEOUT_PATTERN = /timeout/i;
|
|
3
|
+
function mapStatus(jobStatus, abortSignalAborted) {
|
|
4
|
+
if (jobStatus.status === 'completed' && !abortSignalAborted) {
|
|
5
|
+
return 'success';
|
|
6
|
+
}
|
|
7
|
+
const error = jobStatus.error ?? '';
|
|
8
|
+
if (abortSignalAborted || CANCEL_PATTERN.test(error)) {
|
|
9
|
+
return 'killed';
|
|
10
|
+
}
|
|
11
|
+
if (TIMEOUT_PATTERN.test(error)) {
|
|
12
|
+
return 'timeout';
|
|
13
|
+
}
|
|
14
|
+
return 'failed';
|
|
15
|
+
}
|
|
16
|
+
function toIso(date, fallback) {
|
|
17
|
+
if (date) {
|
|
18
|
+
return date.toISOString();
|
|
19
|
+
}
|
|
20
|
+
return fallback.toISOString();
|
|
21
|
+
}
|
|
22
|
+
function buildRecord(input) {
|
|
23
|
+
const { jobStatus, abortSignalAborted, now } = input;
|
|
24
|
+
const completedAtDate = jobStatus.completedAt ?? now();
|
|
25
|
+
const startedAtDate = jobStatus.startedAt ?? completedAtDate;
|
|
26
|
+
const durationMs = Math.max(0, completedAtDate.getTime() - startedAtDate.getTime());
|
|
27
|
+
const status = mapStatus(jobStatus, abortSignalAborted);
|
|
28
|
+
const exitReason = jobStatus.error && jobStatus.error.length > 0 ? jobStatus.error : null;
|
|
29
|
+
return {
|
|
30
|
+
jobId: jobStatus.job.id,
|
|
31
|
+
platform: jobStatus.job.platform,
|
|
32
|
+
projectPath: jobStatus.job.projectPath,
|
|
33
|
+
mergeRequestId: jobStatus.job.mrNumber,
|
|
34
|
+
jobType: jobStatus.job.jobType ?? 'review',
|
|
35
|
+
startedAt: toIso(jobStatus.startedAt, completedAtDate),
|
|
36
|
+
completedAt: toIso(jobStatus.completedAt, now()),
|
|
37
|
+
durationMs,
|
|
38
|
+
status,
|
|
39
|
+
exitReason,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export class PersistJobRecordUseCase {
|
|
43
|
+
deps;
|
|
44
|
+
constructor(deps) {
|
|
45
|
+
this.deps = deps;
|
|
46
|
+
}
|
|
47
|
+
async execute(input) {
|
|
48
|
+
const record = buildRecord(input);
|
|
49
|
+
try {
|
|
50
|
+
await this.deps.jobHistoryGateway.appendRecord(record);
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
const reason = error instanceof Error ? error.message : String(error);
|
|
54
|
+
this.deps.logger.warn({ jobId: record.jobId, error: reason }, `Échec persistance job ${record.jobId} : ${reason}`);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=persistJobRecord.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persistJobRecord.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/persistJobRecord.usecase.ts"],"names":[],"mappings":"AAmBA,MAAM,cAAc,GAAG,uBAAuB,CAAC;AAC/C,MAAM,eAAe,GAAG,UAAU,CAAC;AAEnC,SAAS,SAAS,CAAC,SAAoB,EAAE,kBAA2B;IAClE,IAAI,SAAS,CAAC,MAAM,KAAK,WAAW,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5D,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC;IACpC,IAAI,kBAAkB,IAAI,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACrD,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAChC,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,KAAK,CAAC,IAAsB,EAAE,QAAc;IACnD,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;IACD,OAAO,QAAQ,CAAC,WAAW,EAAE,CAAC;AAChC,CAAC;AAED,SAAS,WAAW,CAAC,KAA4B;IAC/C,MAAM,EAAE,SAAS,EAAE,kBAAkB,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC;IACrD,MAAM,eAAe,GAAG,SAAS,CAAC,WAAW,IAAI,GAAG,EAAE,CAAC;IACvD,MAAM,aAAa,GAAG,SAAS,CAAC,SAAS,IAAI,eAAe,CAAC;IAC7D,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,eAAe,CAAC,OAAO,EAAE,GAAG,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC;IACpF,MAAM,MAAM,GAAG,SAAS,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAC;IACxD,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;IAE1F,OAAO;QACL,KAAK,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE;QACvB,QAAQ,EAAE,SAAS,CAAC,GAAG,CAAC,QAAQ;QAChC,WAAW,EAAE,SAAS,CAAC,GAAG,CAAC,WAAW;QACtC,cAAc,EAAE,SAAS,CAAC,GAAG,CAAC,QAAQ;QACtC,OAAO,EAAE,SAAS,CAAC,GAAG,CAAC,OAAO,IAAI,QAAQ;QAC1C,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,eAAe,CAAC;QACtD,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC;QAChD,UAAU;QACV,MAAM;QACN,UAAU;KACX,CAAC;AACJ,CAAC;AAED,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,IAAkC;QAAlC,SAAI,GAAJ,IAAI,CAA8B;IAAG,CAAC;IAEnE,KAAK,CAAC,OAAO,CAAC,KAA4B;QACxC,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACzD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,MAAM,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACtE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CACnB,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,EACtC,yBAAyB,MAAM,CAAC,KAAK,MAAM,MAAM,EAAE,CACpD,CAAC;QACJ,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Logger } from 'pino';
|
|
2
|
+
import type { JobHistoryGateway, PruneJobHistoryResult } from '../../../../modules/review-execution/entities/job/jobHistory.gateway.js';
|
|
3
|
+
export interface PruneJobHistoryDependencies {
|
|
4
|
+
jobHistoryGateway: JobHistoryGateway;
|
|
5
|
+
logger: Logger;
|
|
6
|
+
}
|
|
7
|
+
export interface PruneJobHistoryInput {
|
|
8
|
+
retentionDays: number;
|
|
9
|
+
now: () => Date;
|
|
10
|
+
}
|
|
11
|
+
export declare class PruneJobHistoryUseCase {
|
|
12
|
+
private readonly deps;
|
|
13
|
+
constructor(deps: PruneJobHistoryDependencies);
|
|
14
|
+
execute(input: PruneJobHistoryInput): Promise<PruneJobHistoryResult>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=pruneJobHistory.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pruneJobHistory.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EACV,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,+DAA+D,CAAC;AAEvE,MAAM,WAAW,2BAA2B;IAC1C,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,qBAAa,sBAAsB;IACrB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,2BAA2B;IAExD,OAAO,CAAC,KAAK,EAAE,oBAAoB,GAAG,OAAO,CAAC,qBAAqB,CAAC;CAW3E"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export class PruneJobHistoryUseCase {
|
|
2
|
+
deps;
|
|
3
|
+
constructor(deps) {
|
|
4
|
+
this.deps = deps;
|
|
5
|
+
}
|
|
6
|
+
async execute(input) {
|
|
7
|
+
const result = await this.deps.jobHistoryGateway.deleteRecordsOutsideWindow(input.retentionDays, input.now());
|
|
8
|
+
this.deps.logger.info({ deletedCount: result.deletedFilenames.length }, 'Job history pruned');
|
|
9
|
+
return result;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=pruneJobHistory.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pruneJobHistory.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/jobHistory/pruneJobHistory.usecase.ts"],"names":[],"mappings":"AAgBA,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,IAAiC;QAAjC,SAAI,GAAJ,IAAI,CAA6B;IAAG,CAAC;IAElE,KAAK,CAAC,OAAO,CAAC,KAA2B;QACvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,0BAA0B,CACzE,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,GAAG,EAAE,CACZ,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CACnB,EAAE,YAAY,EAAE,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,EAChD,oBAAoB,CACrB,CAAC;QACF,OAAO,MAAM,CAAC;IAChB,CAAC;CACF"}
|
package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.d.ts
CHANGED
|
@@ -10,6 +10,10 @@ interface OverviewRoutesOptions {
|
|
|
10
10
|
statsGateway: StatsGateway;
|
|
11
11
|
reviewFileGateway: ReviewFileGateway;
|
|
12
12
|
projectConfigGateway?: ProjectConfigGateway;
|
|
13
|
+
getCapacity?: () => {
|
|
14
|
+
running: number;
|
|
15
|
+
max: number;
|
|
16
|
+
};
|
|
13
17
|
}
|
|
14
18
|
export declare const overviewRoutes: FastifyPluginAsync<OverviewRoutesOptions>;
|
|
15
19
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overview.routes.d.ts","sourceRoot":"","sources":["../../../../../../src/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+DAA+D,CAAC;AAClG,OAAO,KAAK,EAAE,iBAAiB,EAAkB,MAAM,kEAAkE,CAAC;AAE1H,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,EAEL,KAAK,sBAAsB,EAI5B,MAAM,mFAAmF,CAAC;AAE3F,UAAU,qBAAqB;IAC7B,eAAe,EAAE,MAAM,gBAAgB,EAAE,CAAC;IAC1C,aAAa,EAAE,MAAM,sBAAsB,EAAE,CAAC;IAC9C,YAAY,EAAE,YAAY,CAAC;IAC3B,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oBAAoB,CAAC,EAAE,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"overview.routes.d.ts","sourceRoot":"","sources":["../../../../../../src/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+DAA+D,CAAC;AAClG,OAAO,KAAK,EAAE,iBAAiB,EAAkB,MAAM,kEAAkE,CAAC;AAE1H,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,EAEL,KAAK,sBAAsB,EAI5B,MAAM,mFAAmF,CAAC;AAE3F,UAAU,qBAAqB;IAC7B,eAAe,EAAE,MAAM,gBAAgB,EAAE,CAAC;IAC1C,aAAa,EAAE,MAAM,sBAAsB,EAAE,CAAC;IAC9C,YAAY,EAAE,YAAY,CAAC;IAC3B,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oBAAoB,CAAC,EAAE,oBAAoB,CAAC;IAC5C,WAAW,CAAC,EAAE,MAAM;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;CACtD;AA2BD,eAAO,MAAM,cAAc,EAAE,kBAAkB,CAAC,qBAAqB,CAuCpE,CAAC"}
|
package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.js
CHANGED
|
@@ -41,12 +41,14 @@ export const overviewRoutes = async (fastify, options) => {
|
|
|
41
41
|
recentReviews.push(...reviews);
|
|
42
42
|
}
|
|
43
43
|
const projectConfigs = collectProjectConfigs(options.projectConfigGateway, repositories);
|
|
44
|
+
const capacity = options.getCapacity ? options.getCapacity() : { running: 0, max: 0 };
|
|
44
45
|
return presenter.present({
|
|
45
46
|
repositories,
|
|
46
47
|
activeJobs: options.getActiveJobs(),
|
|
47
48
|
projectStats,
|
|
48
49
|
recentReviews,
|
|
49
50
|
projectConfigs,
|
|
51
|
+
capacity,
|
|
50
52
|
});
|
|
51
53
|
});
|
|
52
54
|
};
|
package/dist/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overview.routes.js","sourceRoot":"","sources":["../../../../../../src/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,iBAAiB,GAKlB,MAAM,mFAAmF,CAAC;
|
|
1
|
+
{"version":3,"file":"overview.routes.js","sourceRoot":"","sources":["../../../../../../src/modules/statistics-insights/interface-adapters/controllers/http/overview.routes.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,iBAAiB,GAKlB,MAAM,mFAAmF,CAAC;AAW3F,SAAS,YAAY,CAAC,KAAmB;IACvC,OAAO;QACL,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,YAAY,EAAE,KAAK,CAAC,YAAY;QAChC,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,aAAa,EAAE,KAAK,CAAC,aAAa;QAClC,aAAa,EAAE,KAAK,CAAC,aAAa;KACnC,CAAC;AACJ,CAAC;AAED,SAAS,qBAAqB,CAC5B,OAAyC,EACzC,YAAgC;IAEhC,IAAI,CAAC,OAAO;QAAE,OAAO,SAAS,CAAC;IAC/B,MAAM,SAAS,GAAiD,EAAE,CAAC;IACnE,KAAK,MAAM,UAAU,IAAI,YAAY,EAAE,CAAC;QACtC,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,MAAM,CAAC,MAAM,KAAK,IAAI,IAAI,OAAO,MAAM,CAAC,MAAM,CAAC,YAAY,KAAK,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtH,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QACjF,CAAC;IACH,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAA8C,KAAK,EAC5E,OAAO,EACP,OAAO,EACP,EAAE;IACF,MAAM,SAAS,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAE1C,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;QACtC,MAAM,YAAY,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;QAC/C,MAAM,mBAAmB,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEpF,MAAM,YAAY,GAAgC,EAAE,CAAC;QACrD,MAAM,aAAa,GAAqB,EAAE,CAAC;QAE3C,KAAK,MAAM,UAAU,IAAI,mBAAmB,EAAE,CAAC;YAC7C,MAAM,KAAK,GAAG,OAAO,CAAC,YAAY,CAAC,gBAAgB,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YAC1E,IAAI,KAAK,EAAE,CAAC;gBACV,YAAY,CAAC,IAAI,CAAC;oBAChB,OAAO,EAAE,UAAU,CAAC,IAAI;oBACxB,IAAI,EAAE,UAAU,CAAC,SAAS;oBAC1B,KAAK;oBACL,OAAO,EAAE,YAAY,CAAC,KAAK,CAAC;iBAC7B,CAAC,CAAC;YACL,CAAC;YACD,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,iBAAiB,CAAC,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;YAClF,aAAa,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;QACjC,CAAC;QAED,MAAM,cAAc,GAAG,qBAAqB,CAAC,OAAO,CAAC,oBAAoB,EAAE,YAAY,CAAC,CAAC;QACzF,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC;QAEtF,OAAO,SAAS,CAAC,OAAO,CAAC;YACvB,YAAY;YACZ,UAAU,EAAE,OAAO,CAAC,aAAa,EAAE;YACnC,YAAY;YACZ,aAAa;YACb,cAAc;YACd,QAAQ;SACT,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC"}
|