reviewflow 3.12.0 → 3.13.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 +7 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts +29 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +201 -268
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- package/dist/frameworks/claude/streamJsonParser.d.ts +1 -38
- package/dist/frameworks/claude/streamJsonParser.d.ts.map +1 -1
- package/dist/frameworks/claude/streamJsonParser.js +16 -88
- package/dist/frameworks/claude/streamJsonParser.js.map +1 -1
- package/dist/frameworks/claude/timers/claudeInvocationTimers.d.ts +14 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.d.ts.map +1 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.js +23 -0
- package/dist/frameworks/claude/timers/claudeInvocationTimers.js.map +1 -0
- package/dist/main/dependencies.d.ts +2 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +2 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +3 -0
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +16 -0
- package/dist/main/server.js.map +1 -1
- package/dist/mcp/mcpServerStdio.d.ts.map +1 -1
- package/dist/mcp/mcpServerStdio.js +10 -1
- package/dist/mcp/mcpServerStdio.js.map +1 -1
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.js +7 -0
- package/dist/modules/claude-invocation/entities/billingState/billingState.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.d.ts +4 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/billingState/environment.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts +52 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts +11 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.js +4 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.js +29 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.js.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts +38 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js +27 -0
- package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.d.ts +10 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.js +14 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.d.ts +10 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js +11 -0
- package/dist/modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.d.ts +8 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.js +7 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.guard.js.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.d.ts +28 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.js +9 -0
- package/dist/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.schema.js.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.d.ts +6 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js +2 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.d.ts +16 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.d.ts.map +1 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js +8 -0
- package/dist/modules/claude-invocation/entities/supervisorHealth/supervisorHealth.schema.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.d.ts +10 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.js +32 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts +25 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js +102 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.js +11 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.d.ts +34 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.js +131 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.d.ts +10 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.js +24 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.d.ts +12 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.js +25 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.d.ts +8 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.d.ts.map +1 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.js +18 -0
- package/dist/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.d.ts +15 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.js +12 -0
- package/dist/modules/claude-invocation/usecases/auditBilling.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.d.ts +16 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js +64 -0
- package/dist/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.d.ts +10 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.js +12 -0
- package/dist/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.d.ts +15 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js +25 -0
- package/dist/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.d.ts +34 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js +32 -0
- package/dist/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.d.ts +20 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.js +17 -0
- package/dist/modules/claude-invocation/usecases/retrieveReviewReport.usecase.js.map +1 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts +41 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.d.ts.map +1 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js +88 -0
- package/dist/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js.map +1 -0
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.d.ts +2 -0
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.d.ts.map +1 -1
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.js +4 -1
- package/dist/modules/review-execution/usecases/mcp/setPhase.usecase.js.map +1 -1
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts +2 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.js +238 -0
- package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.js.map +1 -0
- package/dist/tests/factories/claudeSession.factory.d.ts +5 -0
- package/dist/tests/factories/claudeSession.factory.d.ts.map +1 -0
- package/dist/tests/factories/claudeSession.factory.js +17 -0
- package/dist/tests/factories/claudeSession.factory.js.map +1 -0
- package/dist/tests/factories/sessionCompletion.factory.d.ts +5 -0
- package/dist/tests/factories/sessionCompletion.factory.d.ts.map +1 -0
- package/dist/tests/factories/sessionCompletion.factory.js +11 -0
- package/dist/tests/factories/sessionCompletion.factory.js.map +1 -0
- package/dist/tests/integration/claudeInvocation.integration.test.d.ts +2 -0
- package/dist/tests/integration/claudeInvocation.integration.test.d.ts.map +1 -0
- package/dist/tests/integration/claudeInvocation.integration.test.js +147 -0
- package/dist/tests/integration/claudeInvocation.integration.test.js.map +1 -0
- package/dist/tests/stubs/billingState.stub.d.ts +10 -0
- package/dist/tests/stubs/billingState.stub.d.ts.map +1 -0
- package/dist/tests/stubs/billingState.stub.js +32 -0
- package/dist/tests/stubs/billingState.stub.js.map +1 -0
- package/dist/tests/stubs/claudeSession.stub.d.ts +23 -0
- package/dist/tests/stubs/claudeSession.stub.d.ts.map +1 -0
- package/dist/tests/stubs/claudeSession.stub.js +55 -0
- package/dist/tests/stubs/claudeSession.stub.js.map +1 -0
- package/dist/tests/stubs/environment.stub.d.ts +7 -0
- package/dist/tests/stubs/environment.stub.d.ts.map +1 -0
- package/dist/tests/stubs/environment.stub.js +10 -0
- package/dist/tests/stubs/environment.stub.js.map +1 -0
- package/dist/tests/stubs/mcpCompletion.stub.d.ts +13 -0
- package/dist/tests/stubs/mcpCompletion.stub.d.ts.map +1 -0
- package/dist/tests/stubs/mcpCompletion.stub.js +29 -0
- package/dist/tests/stubs/mcpCompletion.stub.js.map +1 -0
- package/dist/tests/stubs/reviewReport.stub.d.ts +11 -0
- package/dist/tests/stubs/reviewReport.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewReport.stub.js +21 -0
- package/dist/tests/stubs/reviewReport.stub.js.map +1 -0
- package/dist/tests/stubs/supervisorHealth.stub.d.ts +8 -0
- package/dist/tests/stubs/supervisorHealth.stub.d.ts.map +1 -0
- package/dist/tests/stubs/supervisorHealth.stub.js +18 -0
- package/dist/tests/stubs/supervisorHealth.stub.js.map +1 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.d.ts +2 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.d.ts.map +1 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.js +89 -0
- package/dist/tests/units/architecture/noClaudePInProduction.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.js +30 -0
- package/dist/tests/units/frameworks/claude/buildSpawnEnv.test.js.map +1 -0
- package/dist/tests/units/frameworks/claude/streamJsonParser.test.js +15 -72
- package/dist/tests/units/frameworks/claude/streamJsonParser.test.js.map +1 -1
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.d.ts +2 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.js +66 -0
- package/dist/tests/units/frameworks/claude/timers/claudeInvocationTimers.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.js +51 -0
- package/dist/tests/units/modules/claude-invocation/entities/claudeSession/claudeSession.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.js +28 -0
- package/dist/tests/units/modules/claude-invocation/entities/retrySchedule/retrySchedule.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.js +27 -0
- package/dist/tests/units/modules/claude-invocation/entities/sessionCompletion/sessionCompletion.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.js +40 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/billingState.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.js +188 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/claudeSession.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.js +17 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/environment.process.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.js +119 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.js +39 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/mcpCompletion.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.js +64 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/reviewReport.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.js +32 -0
- package/dist/tests/units/modules/claude-invocation/interface-adapters/gateways/supervisorHealth.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.js +33 -0
- package/dist/tests/units/modules/claude-invocation/usecases/auditBilling.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.js +53 -0
- package/dist/tests/units/modules/claude-invocation/usecases/awaitSessionCompletion.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.js +31 -0
- package/dist/tests/units/modules/claude-invocation/usecases/checkSupervisorHealth.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.js +17 -0
- package/dist/tests/units/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js +97 -0
- package/dist/tests/units/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.js +49 -0
- package/dist/tests/units/modules/claude-invocation/usecases/retrieveReviewReport.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js +171 -0
- package/dist/tests/units/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js +21 -0
- package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
2
|
+
import type { SessionId } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
3
|
+
export interface CleanupClaudeSessionInput {
|
|
4
|
+
sessionId: SessionId;
|
|
5
|
+
}
|
|
6
|
+
export interface CleanupClaudeSessionDependencies {
|
|
7
|
+
sessionGateway: ClaudeSessionGateway;
|
|
8
|
+
}
|
|
9
|
+
export interface CleanupClaudeSessionResult {
|
|
10
|
+
stopped: boolean;
|
|
11
|
+
removed: boolean;
|
|
12
|
+
warnings: string[];
|
|
13
|
+
}
|
|
14
|
+
export declare function cleanupClaudeSession(input: CleanupClaudeSessionInput, deps: CleanupClaudeSessionDependencies): Promise<CleanupClaudeSessionResult>;
|
|
15
|
+
//# sourceMappingURL=cleanupClaudeSession.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupClaudeSession.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6EAA6E,CAAC;AACxH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,4EAA4E,CAAC;AAE5G,MAAM,WAAW,yBAAyB;IACxC,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,MAAM,WAAW,gCAAgC;IAC/C,cAAc,EAAE,oBAAoB,CAAC;CACtC;AAED,MAAM,WAAW,0BAA0B;IACzC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,yBAAyB,EAChC,IAAI,EAAE,gCAAgC,GACrC,OAAO,CAAC,0BAA0B,CAAC,CA0BrC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export async function cleanupClaudeSession(input, deps) {
|
|
2
|
+
const warnings = [];
|
|
3
|
+
const stopResult = await deps.sessionGateway.stop(input.sessionId).catch(error => {
|
|
4
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
5
|
+
warnings.push(`stop failed: ${message}`);
|
|
6
|
+
return { success: false, warning: message };
|
|
7
|
+
});
|
|
8
|
+
if (!stopResult.success && stopResult.warning) {
|
|
9
|
+
warnings.push(`stop: ${stopResult.warning}`);
|
|
10
|
+
}
|
|
11
|
+
const removeResult = await deps.sessionGateway.remove(input.sessionId).catch(error => {
|
|
12
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
13
|
+
warnings.push(`remove failed: ${message}`);
|
|
14
|
+
return { success: false, warning: message };
|
|
15
|
+
});
|
|
16
|
+
if (!removeResult.success && removeResult.warning) {
|
|
17
|
+
warnings.push(`remove: ${removeResult.warning}`);
|
|
18
|
+
}
|
|
19
|
+
return {
|
|
20
|
+
stopped: stopResult.success,
|
|
21
|
+
removed: removeResult.success,
|
|
22
|
+
warnings,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=cleanupClaudeSession.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupClaudeSession.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/cleanupClaudeSession.usecase.ts"],"names":[],"mappings":"AAiBA,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,KAAgC,EAChC,IAAsC;IAEtC,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QAC/E,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,QAAQ,CAAC,IAAI,CAAC,gBAAgB,OAAO,EAAE,CAAC,CAAC;QACzC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IACH,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QAC9C,QAAQ,CAAC,IAAI,CAAC,SAAS,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QACnF,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACvE,QAAQ,CAAC,IAAI,CAAC,kBAAkB,OAAO,EAAE,CAAC,CAAC;QAC3C,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IACH,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;QAClD,QAAQ,CAAC,IAAI,CAAC,WAAW,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,OAAO;QACL,OAAO,EAAE,UAAU,CAAC,OAAO;QAC3B,OAAO,EAAE,YAAY,CAAC,OAAO;QAC7B,QAAQ;KACT,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { BillingStateGateway } from '../../../modules/claude-invocation/entities/billingState/billingState.gateway.js';
|
|
2
|
+
import type { EnvironmentGateway } from '../../../modules/claude-invocation/entities/billingState/environment.gateway.js';
|
|
3
|
+
import type { ClaudeDispatchFlags, ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
4
|
+
import type { ClaudeSession, ClaudeSessionJobType } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
5
|
+
export interface DispatchClaudeSessionInput {
|
|
6
|
+
jobId: string;
|
|
7
|
+
jobType: ClaudeSessionJobType;
|
|
8
|
+
prompt: string;
|
|
9
|
+
flags: ClaudeDispatchFlags;
|
|
10
|
+
localPath: string;
|
|
11
|
+
mergeRequestId: string;
|
|
12
|
+
}
|
|
13
|
+
export interface DispatchClaudeSessionDependencies {
|
|
14
|
+
sessionGateway: ClaudeSessionGateway;
|
|
15
|
+
environment: EnvironmentGateway;
|
|
16
|
+
billingState: BillingStateGateway;
|
|
17
|
+
now: () => Date;
|
|
18
|
+
}
|
|
19
|
+
export type DispatchClaudeSessionResult = {
|
|
20
|
+
status: 'dispatched';
|
|
21
|
+
session: ClaudeSession;
|
|
22
|
+
} | {
|
|
23
|
+
status: 'rate-limited';
|
|
24
|
+
rawStderr: string;
|
|
25
|
+
} | {
|
|
26
|
+
status: 'billing-regression-prevented';
|
|
27
|
+
} | {
|
|
28
|
+
status: 'paused';
|
|
29
|
+
} | {
|
|
30
|
+
status: 'failed';
|
|
31
|
+
rawStderr: string;
|
|
32
|
+
};
|
|
33
|
+
export declare function dispatchClaudeSession(input: DispatchClaudeSessionInput, deps: DispatchClaudeSessionDependencies): Promise<DispatchClaudeSessionResult>;
|
|
34
|
+
//# sourceMappingURL=dispatchClaudeSession.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatchClaudeSession.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2EAA2E,CAAC;AACrH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,6EAA6E,CAAC;AAIrF,OAAO,KAAK,EACV,aAAa,EACb,oBAAoB,EACrB,MAAM,4EAA4E,CAAC;AAEpF,MAAM,WAAW,0BAA0B;IACzC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,oBAAoB,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,mBAAmB,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,iCAAiC;IAChD,cAAc,EAAE,oBAAoB,CAAC;IACrC,WAAW,EAAE,kBAAkB,CAAC;IAChC,YAAY,EAAE,mBAAmB,CAAC;IAClC,GAAG,EAAE,MAAM,IAAI,CAAC;CACjB;AAED,MAAM,MAAM,2BAA2B,GACnC;IAAE,MAAM,EAAE,YAAY,CAAC;IAAC,OAAO,EAAE,aAAa,CAAA;CAAE,GAChD;IAAE,MAAM,EAAE,cAAc,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,GAC7C;IAAE,MAAM,EAAE,8BAA8B,CAAA;CAAE,GAC1C;IAAE,MAAM,EAAE,QAAQ,CAAA;CAAE,GACpB;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC;AAE5C,wBAAsB,qBAAqB,CACzC,KAAK,EAAE,0BAA0B,EACjC,IAAI,EAAE,iCAAiC,GACtC,OAAO,CAAC,2BAA2B,CAAC,CAmCtC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createClaudeSession, } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.js';
|
|
2
|
+
export async function dispatchClaudeSession(input, deps) {
|
|
3
|
+
if (deps.environment.hasAnthropicApiKey()) {
|
|
4
|
+
return { status: 'billing-regression-prevented' };
|
|
5
|
+
}
|
|
6
|
+
if (deps.billingState.read().dispatchPaused) {
|
|
7
|
+
return { status: 'paused' };
|
|
8
|
+
}
|
|
9
|
+
const result = await deps.sessionGateway.dispatch({
|
|
10
|
+
prompt: input.prompt,
|
|
11
|
+
flags: input.flags,
|
|
12
|
+
localPath: input.localPath,
|
|
13
|
+
jobId: input.jobId,
|
|
14
|
+
jobType: input.jobType,
|
|
15
|
+
});
|
|
16
|
+
if (result.status === 'rate-limited') {
|
|
17
|
+
return { status: 'rate-limited', rawStderr: result.rawStderr };
|
|
18
|
+
}
|
|
19
|
+
if (result.status === 'failed') {
|
|
20
|
+
return { status: 'failed', rawStderr: result.rawStderr };
|
|
21
|
+
}
|
|
22
|
+
const session = createClaudeSession({
|
|
23
|
+
sessionId: result.sessionId,
|
|
24
|
+
jobId: input.jobId,
|
|
25
|
+
jobType: input.jobType,
|
|
26
|
+
localPath: input.localPath,
|
|
27
|
+
mergeRequestId: input.mergeRequestId,
|
|
28
|
+
dispatchedAt: deps.now(),
|
|
29
|
+
});
|
|
30
|
+
return { status: 'dispatched', session };
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=dispatchClaudeSession.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatchClaudeSession.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/dispatchClaudeSession.usecase.ts"],"names":[],"mappings":"AAMA,OAAO,EACL,mBAAmB,GACpB,MAAM,qEAAqE,CAAC;AA6B7E,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,KAAiC,EACjC,IAAuC;IAEvC,IAAI,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC1C,OAAO,EAAE,MAAM,EAAE,8BAA8B,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,cAAc,EAAE,CAAC;QAC5C,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;QAChD,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;KACvB,CAAC,CAAC;IAEH,IAAI,MAAM,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;QACrC,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;IACjE,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QAC/B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;IAC3D,CAAC;IAED,MAAM,OAAO,GAAG,mBAAmB,CAAC;QAClC,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,YAAY,EAAE,IAAI,CAAC,GAAG,EAAE;KACzB,CAAC,CAAC;IAEH,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,CAAC;AAC3C,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { ClaudeSession } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
2
|
+
import type { ReviewReportGateway } from '../../../modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js';
|
|
3
|
+
export interface RetrieveReviewReportInput {
|
|
4
|
+
session: ClaudeSession;
|
|
5
|
+
today: Date;
|
|
6
|
+
mergeRequestNumber: number;
|
|
7
|
+
}
|
|
8
|
+
export interface RetrieveReviewReportDependencies {
|
|
9
|
+
reportGateway: ReviewReportGateway;
|
|
10
|
+
}
|
|
11
|
+
export type RetrieveReviewReportResult = {
|
|
12
|
+
status: 'found';
|
|
13
|
+
content: string;
|
|
14
|
+
path: string;
|
|
15
|
+
} | {
|
|
16
|
+
status: 'missing';
|
|
17
|
+
expectedPath: string;
|
|
18
|
+
};
|
|
19
|
+
export declare function retrieveReviewReport(input: RetrieveReviewReportInput, deps: RetrieveReviewReportDependencies): RetrieveReviewReportResult;
|
|
20
|
+
//# sourceMappingURL=retrieveReviewReport.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retrieveReviewReport.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/retrieveReviewReport.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4EAA4E,CAAC;AAChH,OAAO,KAAK,EACV,mBAAmB,EAEpB,MAAM,gFAAgF,CAAC;AAExF,MAAM,WAAW,yBAAyB;IACxC,OAAO,EAAE,aAAa,CAAC;IACvB,KAAK,EAAE,IAAI,CAAC;IACZ,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,gCAAgC;IAC/C,aAAa,EAAE,mBAAmB,CAAC;CACpC;AAED,MAAM,MAAM,0BAA0B,GAClC;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAClD;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC;AAMhD,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,yBAAyB,EAChC,IAAI,EAAE,gCAAgC,GACrC,0BAA0B,CAa5B"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
function formatIsoDate(today) {
|
|
2
|
+
return today.toISOString().slice(0, 10);
|
|
3
|
+
}
|
|
4
|
+
export function retrieveReviewReport(input, deps) {
|
|
5
|
+
const location = {
|
|
6
|
+
localPath: input.session.localPath,
|
|
7
|
+
isoDate: formatIsoDate(input.today),
|
|
8
|
+
mergeRequestNumber: input.mergeRequestNumber,
|
|
9
|
+
jobType: input.session.jobType,
|
|
10
|
+
};
|
|
11
|
+
const found = deps.reportGateway.read(location);
|
|
12
|
+
if (found) {
|
|
13
|
+
return { status: 'found', content: found.content, path: found.path };
|
|
14
|
+
}
|
|
15
|
+
return { status: 'missing', expectedPath: deps.reportGateway.buildPath(location) };
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=retrieveReviewReport.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retrieveReviewReport.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/retrieveReviewReport.usecase.ts"],"names":[],"mappings":"AAoBA,SAAS,aAAa,CAAC,KAAW;IAChC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,KAAgC,EAChC,IAAsC;IAEtC,MAAM,QAAQ,GAAyB;QACrC,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,SAAS;QAClC,OAAO,EAAE,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC;QACnC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;QAC5C,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO;KAC/B,CAAC;IAEF,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChD,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;IACvE,CAAC;IACD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;AACrF,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { BillingStateGateway } from '../../../modules/claude-invocation/entities/billingState/billingState.gateway.js';
|
|
2
|
+
import type { EnvironmentGateway } from '../../../modules/claude-invocation/entities/billingState/environment.gateway.js';
|
|
3
|
+
import type { ClaudeDispatchFlags, ClaudeSessionGateway } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.gateway.js';
|
|
4
|
+
import type { ClaudeSessionJobType } from '../../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
5
|
+
import type { McpCompletionBridge } from '../../../modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js';
|
|
6
|
+
import type { ReviewReportGateway } from '../../../modules/claude-invocation/entities/sessionCompletion/reviewReport.gateway.js';
|
|
7
|
+
export interface RunClaudeReviewJobInput {
|
|
8
|
+
jobId: string;
|
|
9
|
+
jobType: ClaudeSessionJobType;
|
|
10
|
+
prompt: string;
|
|
11
|
+
flags: ClaudeDispatchFlags;
|
|
12
|
+
localPath: string;
|
|
13
|
+
mergeRequestId: string;
|
|
14
|
+
mergeRequestNumber: number;
|
|
15
|
+
attempt: number;
|
|
16
|
+
signal?: AbortSignal;
|
|
17
|
+
}
|
|
18
|
+
export interface RunClaudeReviewJobDependencies {
|
|
19
|
+
sessionGateway: ClaudeSessionGateway;
|
|
20
|
+
completionBridge: McpCompletionBridge;
|
|
21
|
+
reportGateway: ReviewReportGateway;
|
|
22
|
+
billingState: BillingStateGateway;
|
|
23
|
+
environment: EnvironmentGateway;
|
|
24
|
+
now: () => Date;
|
|
25
|
+
timeoutMs: number;
|
|
26
|
+
pollIntervalMs: number;
|
|
27
|
+
}
|
|
28
|
+
export type RunClaudeReviewJobResult = {
|
|
29
|
+
status: 'completed';
|
|
30
|
+
reportPath: string;
|
|
31
|
+
content: string;
|
|
32
|
+
} | {
|
|
33
|
+
status: 'failed';
|
|
34
|
+
reason: string;
|
|
35
|
+
} | {
|
|
36
|
+
status: 'retry';
|
|
37
|
+
delayMs: number;
|
|
38
|
+
attempt: number;
|
|
39
|
+
};
|
|
40
|
+
export declare function runClaudeReviewJob(input: RunClaudeReviewJobInput, deps: RunClaudeReviewJobDependencies): Promise<RunClaudeReviewJobResult>;
|
|
41
|
+
//# sourceMappingURL=runClaudeReviewJob.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runClaudeReviewJob.usecase.d.ts","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2EAA2E,CAAC;AACrH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AACnH,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACrB,MAAM,6EAA6E,CAAC;AACrF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,4EAA4E,CAAC;AACvH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iFAAiF,CAAC;AAE3H,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gFAAgF,CAAC;AAO1H,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,oBAAoB,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,mBAAmB,CAAC;IAC3B,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB;AAED,MAAM,WAAW,8BAA8B;IAC7C,cAAc,EAAE,oBAAoB,CAAC;IACrC,gBAAgB,EAAE,mBAAmB,CAAC;IACtC,aAAa,EAAE,mBAAmB,CAAC;IACnC,YAAY,EAAE,mBAAmB,CAAC;IAClC,WAAW,EAAE,kBAAkB,CAAC;IAChC,GAAG,EAAE,MAAM,IAAI,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,MAAM,wBAAwB,GAChC;IAAE,MAAM,EAAE,WAAW,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAC5D;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACpC;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC;AAE1D,wBAAsB,kBAAkB,CACtC,KAAK,EAAE,uBAAuB,EAC9B,IAAI,EAAE,8BAA8B,GACnC,OAAO,CAAC,wBAAwB,CAAC,CA2GnC"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { planRetry } from '../../../modules/claude-invocation/entities/retrySchedule/retrySchedule.valueObject.js';
|
|
2
|
+
import { dispatchClaudeSession } from '../../../modules/claude-invocation/usecases/dispatchClaudeSession.usecase.js';
|
|
3
|
+
import { awaitSessionCompletion } from '../../../modules/claude-invocation/usecases/awaitSessionCompletion.usecase.js';
|
|
4
|
+
import { retrieveReviewReport } from '../../../modules/claude-invocation/usecases/retrieveReviewReport.usecase.js';
|
|
5
|
+
import { cleanupClaudeSession } from '../../../modules/claude-invocation/usecases/cleanupClaudeSession.usecase.js';
|
|
6
|
+
export async function runClaudeReviewJob(input, deps) {
|
|
7
|
+
if (input.signal?.aborted) {
|
|
8
|
+
return { status: 'failed', reason: 'cancelled' };
|
|
9
|
+
}
|
|
10
|
+
const dispatchResult = await dispatchClaudeSession({
|
|
11
|
+
jobId: input.jobId,
|
|
12
|
+
jobType: input.jobType,
|
|
13
|
+
prompt: input.prompt,
|
|
14
|
+
flags: input.flags,
|
|
15
|
+
localPath: input.localPath,
|
|
16
|
+
mergeRequestId: input.mergeRequestId,
|
|
17
|
+
}, {
|
|
18
|
+
sessionGateway: deps.sessionGateway,
|
|
19
|
+
environment: deps.environment,
|
|
20
|
+
billingState: deps.billingState,
|
|
21
|
+
now: deps.now,
|
|
22
|
+
});
|
|
23
|
+
if (dispatchResult.status === 'billing-regression-prevented') {
|
|
24
|
+
return { status: 'failed', reason: 'billing-regression-prevented' };
|
|
25
|
+
}
|
|
26
|
+
if (dispatchResult.status === 'paused') {
|
|
27
|
+
return { status: 'failed', reason: 'dispatch-paused' };
|
|
28
|
+
}
|
|
29
|
+
if (dispatchResult.status === 'rate-limited') {
|
|
30
|
+
const retry = planRetry(input.attempt);
|
|
31
|
+
if (retry.status === 'give-up') {
|
|
32
|
+
return { status: 'failed', reason: 'rate-limited-give-up' };
|
|
33
|
+
}
|
|
34
|
+
return { status: 'retry', delayMs: retry.delayMs, attempt: retry.nextAttempt };
|
|
35
|
+
}
|
|
36
|
+
if (dispatchResult.status === 'failed') {
|
|
37
|
+
return { status: 'failed', reason: `dispatch-failed: ${dispatchResult.rawStderr}` };
|
|
38
|
+
}
|
|
39
|
+
const { session } = dispatchResult;
|
|
40
|
+
const abortListener = input.signal
|
|
41
|
+
? () => {
|
|
42
|
+
void deps.sessionGateway.stop(session.sessionId);
|
|
43
|
+
deps.completionBridge.publish(input.jobId, {
|
|
44
|
+
source: 'mcp',
|
|
45
|
+
outcome: 'stopped',
|
|
46
|
+
reason: 'cancelled',
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
: null;
|
|
50
|
+
if (input.signal && abortListener) {
|
|
51
|
+
input.signal.addEventListener('abort', abortListener);
|
|
52
|
+
}
|
|
53
|
+
let completion;
|
|
54
|
+
try {
|
|
55
|
+
completion = await awaitSessionCompletion({
|
|
56
|
+
session,
|
|
57
|
+
timeoutMs: deps.timeoutMs,
|
|
58
|
+
pollIntervalMs: deps.pollIntervalMs,
|
|
59
|
+
}, {
|
|
60
|
+
sessionGateway: deps.sessionGateway,
|
|
61
|
+
completionBridge: deps.completionBridge,
|
|
62
|
+
now: deps.now,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
finally {
|
|
66
|
+
if (input.signal && abortListener) {
|
|
67
|
+
input.signal.removeEventListener('abort', abortListener);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
await cleanupClaudeSession({ sessionId: session.sessionId }, { sessionGateway: deps.sessionGateway });
|
|
71
|
+
if (completion.source === 'timeout') {
|
|
72
|
+
return { status: 'failed', reason: 'timeout' };
|
|
73
|
+
}
|
|
74
|
+
if (completion.outcome !== 'completed') {
|
|
75
|
+
const reasonSuffix = completion.reason !== null ? `: ${completion.reason}` : '';
|
|
76
|
+
return { status: 'failed', reason: `outcome-${completion.outcome}${reasonSuffix}` };
|
|
77
|
+
}
|
|
78
|
+
const report = retrieveReviewReport({
|
|
79
|
+
session,
|
|
80
|
+
today: deps.now(),
|
|
81
|
+
mergeRequestNumber: input.mergeRequestNumber,
|
|
82
|
+
}, { reportGateway: deps.reportGateway });
|
|
83
|
+
if (report.status === 'missing') {
|
|
84
|
+
return { status: 'failed', reason: 'report-missing' };
|
|
85
|
+
}
|
|
86
|
+
return { status: 'completed', reportPath: report.path, content: report.content };
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=runClaudeReviewJob.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runClaudeReviewJob.usecase.js","sourceRoot":"","sources":["../../../../src/modules/claude-invocation/usecases/runClaudeReviewJob.usecase.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,SAAS,EAAE,MAAM,iFAAiF,CAAC;AAC5G,OAAO,EAAE,qBAAqB,EAAE,MAAM,uEAAuE,CAAC;AAC9G,OAAO,EAAE,sBAAsB,EAAE,MAAM,wEAAwE,CAAC;AAChH,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAC5G,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AA8B5G,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,KAA8B,EAC9B,IAAoC;IAEpC,IAAI,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;QAC1B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;IACnD,CAAC;IAED,MAAM,cAAc,GAAG,MAAM,qBAAqB,CAChD;QACE,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;KACrC,EACD;QACE,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,WAAW,EAAE,IAAI,CAAC,WAAW;QAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;QAC/B,GAAG,EAAE,IAAI,CAAC,GAAG;KACd,CACF,CAAC;IAEF,IAAI,cAAc,CAAC,MAAM,KAAK,8BAA8B,EAAE,CAAC;QAC7D,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,8BAA8B,EAAE,CAAC;IACtE,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,iBAAiB,EAAE,CAAC;IACzD,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,cAAc,EAAE,CAAC;QAC7C,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,sBAAsB,EAAE,CAAC;QAC9D,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC;IACjF,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,oBAAoB,cAAc,CAAC,SAAS,EAAE,EAAE,CAAC;IACtF,CAAC;IAED,MAAM,EAAE,OAAO,EAAE,GAAG,cAAc,CAAC;IAEnC,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM;QAChC,CAAC,CAAC,GAAS,EAAE;YACT,KAAK,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACjD,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE;gBACzC,MAAM,EAAE,KAAK;gBACb,OAAO,EAAE,SAAS;gBAClB,MAAM,EAAE,WAAW;aACpB,CAAC,CAAC;QACL,CAAC;QACH,CAAC,CAAC,IAAI,CAAC;IAET,IAAI,KAAK,CAAC,MAAM,IAAI,aAAa,EAAE,CAAC;QAClC,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,UAA6B,CAAC;IAClC,IAAI,CAAC;QACH,UAAU,GAAG,MAAM,sBAAsB,CACvC;YACE,OAAO;YACP,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,EACD;YACE,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CACF,CAAC;IACJ,CAAC;YAAS,CAAC;QACT,IAAI,KAAK,CAAC,MAAM,IAAI,aAAa,EAAE,CAAC;YAClC,KAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAED,MAAM,oBAAoB,CACxB,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,EAAE,EAChC,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,CACxC,CAAC;IAEF,IAAI,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QACpC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;IACjD,CAAC;IAED,IAAI,UAAU,CAAC,OAAO,KAAK,WAAW,EAAE,CAAC;QACvC,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAChF,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,UAAU,CAAC,OAAO,GAAG,YAAY,EAAE,EAAE,CAAC;IACtF,CAAC;IAED,MAAM,MAAM,GAAG,oBAAoB,CACjC;QACE,OAAO;QACP,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE;QACjB,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;KAC7C,EACD,EAAE,aAAa,EAAE,IAAI,CAAC,aAAa,EAAE,CACtC,CAAC;IAEF,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAChC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC;IACxD,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;AACnF,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { McpCompletionBridge } from "../../../../modules/claude-invocation/entities/sessionCompletion/mcpCompletion.gateway.js";
|
|
1
2
|
import type { ReviewProgressGateway } from "../../entities/progress/progress.gateway.js";
|
|
2
3
|
import type { ReviewPhase } from "../../entities/progress/progress.type.js";
|
|
3
4
|
export type SetPhaseResult = {
|
|
@@ -10,6 +11,7 @@ export type SetPhaseResult = {
|
|
|
10
11
|
};
|
|
11
12
|
export interface SetPhaseDependencies {
|
|
12
13
|
progressGateway: ReviewProgressGateway;
|
|
14
|
+
completionBridge?: McpCompletionBridge;
|
|
13
15
|
}
|
|
14
16
|
export declare function setPhase(jobId: string, phase: ReviewPhase, deps: SetPhaseDependencies): SetPhaseResult;
|
|
15
17
|
//# sourceMappingURL=setPhase.usecase.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setPhase.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/mcp/setPhase.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AACzF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AAE5E,MAAM,MAAM,cAAc,GACvB;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,KAAK,EAAE,WAAW,CAAC;IAAC,eAAe,EAAE,MAAM,CAAA;CAAE,GAC9D;IAAE,OAAO,EAAE,KAAK,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAErC,MAAM,WAAW,oBAAoB;IACpC,eAAe,EAAE,qBAAqB,CAAC;CACvC;AAED,wBAAgB,QAAQ,CACvB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,WAAW,EAClB,IAAI,EAAE,oBAAoB,GACxB,cAAc,
|
|
1
|
+
{"version":3,"file":"setPhase.usecase.d.ts","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/mcp/setPhase.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iFAAiF,CAAC;AAC3H,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AACzF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0CAA0C,CAAC;AAE5E,MAAM,MAAM,cAAc,GACvB;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,KAAK,EAAE,WAAW,CAAC;IAAC,eAAe,EAAE,MAAM,CAAA;CAAE,GAC9D;IAAE,OAAO,EAAE,KAAK,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAErC,MAAM,WAAW,oBAAoB;IACpC,eAAe,EAAE,qBAAqB,CAAC;IACvC,gBAAgB,CAAC,EAAE,mBAAmB,CAAC;CACvC;AAED,wBAAgB,QAAQ,CACvB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,WAAW,EAClB,IAAI,EAAE,oBAAoB,GACxB,cAAc,CAqBhB"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export function setPhase(jobId, phase, deps) {
|
|
2
|
-
const { progressGateway } = deps;
|
|
2
|
+
const { progressGateway, completionBridge } = deps;
|
|
3
3
|
const progress = progressGateway.setPhase(jobId, phase);
|
|
4
4
|
if (!progress) {
|
|
5
5
|
return {
|
|
@@ -7,6 +7,9 @@ export function setPhase(jobId, phase, deps) {
|
|
|
7
7
|
error: `Job not found: ${jobId}`,
|
|
8
8
|
};
|
|
9
9
|
}
|
|
10
|
+
if (phase === "completed" && completionBridge) {
|
|
11
|
+
completionBridge.publish(jobId, { source: "mcp", outcome: "completed", reason: null });
|
|
12
|
+
}
|
|
10
13
|
return {
|
|
11
14
|
success: true,
|
|
12
15
|
phase: progress.currentPhase,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setPhase.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/mcp/setPhase.usecase.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setPhase.usecase.js","sourceRoot":"","sources":["../../../../../src/modules/review-execution/usecases/mcp/setPhase.usecase.ts"],"names":[],"mappings":"AAaA,MAAM,UAAU,QAAQ,CACvB,KAAa,EACb,KAAkB,EAClB,IAA0B;IAE1B,MAAM,EAAE,eAAe,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC;IAEnD,MAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAExD,IAAI,CAAC,QAAQ,EAAE,CAAC;QACf,OAAO;YACN,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,kBAAkB,KAAK,EAAE;SAChC,CAAC;IACH,CAAC;IAED,IAAI,KAAK,KAAK,WAAW,IAAI,gBAAgB,EAAE,CAAC;QAC/C,gBAAgB,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACxF,CAAC;IAED,OAAO;QACN,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,QAAQ,CAAC,YAAY;QAC5B,eAAe,EAAE,QAAQ,CAAC,eAAe;KACzC,CAAC;AACH,CAAC"}
|
package/dist/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"169-migrate-claude-invocation-to-bg-mode.acceptance.test.d.ts","sourceRoot":"","sources":["../../../src/tests/acceptance/169-migrate-claude-invocation-to-bg-mode.acceptance.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
2
|
+
import { runClaudeReviewJob } from '../../modules/claude-invocation/usecases/runClaudeReviewJob.usecase.js';
|
|
3
|
+
import { StubClaudeSessionGateway } from '../../tests/stubs/claudeSession.stub.js';
|
|
4
|
+
import { StubMcpCompletionBridge } from '../../tests/stubs/mcpCompletion.stub.js';
|
|
5
|
+
import { StubReviewReportGateway } from '../../tests/stubs/reviewReport.stub.js';
|
|
6
|
+
import { StubBillingStateGateway } from '../../tests/stubs/billingState.stub.js';
|
|
7
|
+
import { StubSupervisorHealthGateway } from '../../tests/stubs/supervisorHealth.stub.js';
|
|
8
|
+
import { StubEnvironmentGateway } from '../../tests/stubs/environment.stub.js';
|
|
9
|
+
import { auditBilling } from '../../modules/claude-invocation/usecases/auditBilling.usecase.js';
|
|
10
|
+
import { checkSupervisorHealth } from '../../modules/claude-invocation/usecases/checkSupervisorHealth.usecase.js';
|
|
11
|
+
import { parseSessionId } from '../../modules/claude-invocation/entities/claudeSession/claudeSession.schema.js';
|
|
12
|
+
function createContext() {
|
|
13
|
+
const sessionGateway = new StubClaudeSessionGateway();
|
|
14
|
+
const completionBridge = new StubMcpCompletionBridge();
|
|
15
|
+
const reportGateway = new StubReviewReportGateway();
|
|
16
|
+
const billingState = new StubBillingStateGateway();
|
|
17
|
+
const supervisorHealth = new StubSupervisorHealthGateway();
|
|
18
|
+
const environment = new StubEnvironmentGateway();
|
|
19
|
+
const deps = {
|
|
20
|
+
sessionGateway,
|
|
21
|
+
completionBridge,
|
|
22
|
+
reportGateway,
|
|
23
|
+
billingState,
|
|
24
|
+
environment,
|
|
25
|
+
now: () => new Date('2026-05-22T10:00:00Z'),
|
|
26
|
+
timeoutMs: 15 * 60 * 1000,
|
|
27
|
+
pollIntervalMs: 30_000,
|
|
28
|
+
};
|
|
29
|
+
return {
|
|
30
|
+
sessionGateway,
|
|
31
|
+
completionBridge,
|
|
32
|
+
reportGateway,
|
|
33
|
+
billingState,
|
|
34
|
+
supervisorHealth,
|
|
35
|
+
environment,
|
|
36
|
+
deps,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
const baseInput = {
|
|
40
|
+
jobId: 'gitlab:owner/repo:42',
|
|
41
|
+
jobType: 'review',
|
|
42
|
+
prompt: '/review-front 42',
|
|
43
|
+
flags: {
|
|
44
|
+
model: 'claude-opus-4-7',
|
|
45
|
+
mcpConfigJson: '{}',
|
|
46
|
+
systemPrompt: 'system',
|
|
47
|
+
allowedTools: 'Read,Bash',
|
|
48
|
+
disallowedTools: 'EnterPlanMode',
|
|
49
|
+
permissionMode: 'bypassPermissions',
|
|
50
|
+
},
|
|
51
|
+
localPath: '/tmp/project',
|
|
52
|
+
mergeRequestId: 'gitlab-owner/repo-42',
|
|
53
|
+
mergeRequestNumber: 42,
|
|
54
|
+
attempt: 0,
|
|
55
|
+
};
|
|
56
|
+
describe('SPEC-169: Migrate Claude invocation to --bg mode (acceptance)', () => {
|
|
57
|
+
beforeEach(() => {
|
|
58
|
+
vi.useFakeTimers();
|
|
59
|
+
vi.setSystemTime(new Date('2026-05-22T10:00:00Z'));
|
|
60
|
+
});
|
|
61
|
+
describe('Scenario 1: Webhook triggers review dispatched via --bg', () => {
|
|
62
|
+
it('spawns claude --bg with the configured flags and captures the session ID', async () => {
|
|
63
|
+
const context = createContext();
|
|
64
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('7c5dcf5d') });
|
|
65
|
+
context.completionBridge.scheduleCompletion(baseInput.jobId, {
|
|
66
|
+
source: 'mcp',
|
|
67
|
+
outcome: 'completed',
|
|
68
|
+
reason: null,
|
|
69
|
+
});
|
|
70
|
+
context.reportGateway.setReport({
|
|
71
|
+
content: '# Review report',
|
|
72
|
+
path: '/tmp/project/.claude/reviews/2026-05-22-MR-42-review.md',
|
|
73
|
+
});
|
|
74
|
+
const runPromise = runClaudeReviewJob(baseInput, context.deps);
|
|
75
|
+
await vi.runAllTimersAsync();
|
|
76
|
+
const result = await runPromise;
|
|
77
|
+
expect(result.status).toBe('completed');
|
|
78
|
+
const calls = context.sessionGateway.dispatchCalls;
|
|
79
|
+
expect(calls).toHaveLength(1);
|
|
80
|
+
expect(calls[0]?.flags.permissionMode).toBe('bypassPermissions');
|
|
81
|
+
expect(JSON.stringify(calls[0])).not.toContain('-p ');
|
|
82
|
+
expect(JSON.stringify(calls[0])).not.toContain('--print');
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
describe('Scenario 2: Completion via MCP primary signal', () => {
|
|
86
|
+
it('reads the report from the conventional path, then stops and removes the session', async () => {
|
|
87
|
+
const context = createContext();
|
|
88
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('abc12345') });
|
|
89
|
+
context.completionBridge.scheduleCompletion(baseInput.jobId, {
|
|
90
|
+
source: 'mcp',
|
|
91
|
+
outcome: 'completed',
|
|
92
|
+
reason: null,
|
|
93
|
+
});
|
|
94
|
+
context.reportGateway.setReport({
|
|
95
|
+
content: '# Review content',
|
|
96
|
+
path: '/tmp/project/.claude/reviews/2026-05-22-MR-42-review.md',
|
|
97
|
+
});
|
|
98
|
+
const runPromise = runClaudeReviewJob(baseInput, context.deps);
|
|
99
|
+
await vi.runAllTimersAsync();
|
|
100
|
+
const result = await runPromise;
|
|
101
|
+
expect(result.status).toBe('completed');
|
|
102
|
+
if (result.status === 'completed') {
|
|
103
|
+
expect(result.content).toBe('# Review content');
|
|
104
|
+
}
|
|
105
|
+
expect(context.sessionGateway.stopCalls).toContain('abc12345');
|
|
106
|
+
expect(context.sessionGateway.removeCalls).toContain('abc12345');
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
describe('Scenario 3: Completion via polling fallback', () => {
|
|
110
|
+
it('detects completion through claude agents --json when MCP stays silent', async () => {
|
|
111
|
+
const context = createContext();
|
|
112
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('poll0001') });
|
|
113
|
+
context.sessionGateway.scheduleAgentCompletion('poll0001', 'completed', 1);
|
|
114
|
+
context.reportGateway.setReport({
|
|
115
|
+
content: '# Polled report',
|
|
116
|
+
path: '/tmp/project/.claude/reviews/2026-05-22-MR-42-review.md',
|
|
117
|
+
});
|
|
118
|
+
const runPromise = runClaudeReviewJob(baseInput, context.deps);
|
|
119
|
+
await vi.runAllTimersAsync();
|
|
120
|
+
const result = await runPromise;
|
|
121
|
+
expect(result.status).toBe('completed');
|
|
122
|
+
expect(context.sessionGateway.stopCalls).toContain('poll0001');
|
|
123
|
+
expect(context.sessionGateway.removeCalls).toContain('poll0001');
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
describe('Scenario 4: Hard timeout reached without completion signal', () => {
|
|
127
|
+
it('marks the job failed with reason "timeout" after 15 minutes', async () => {
|
|
128
|
+
const context = createContext();
|
|
129
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('time0001') });
|
|
130
|
+
let nowMs = new Date('2026-05-22T10:00:00Z').getTime();
|
|
131
|
+
const deps = { ...context.deps, now: () => new Date(nowMs) };
|
|
132
|
+
const runPromise = runClaudeReviewJob(baseInput, deps);
|
|
133
|
+
await Promise.resolve();
|
|
134
|
+
await Promise.resolve();
|
|
135
|
+
await Promise.resolve();
|
|
136
|
+
nowMs += 16 * 60 * 1000;
|
|
137
|
+
await vi.advanceTimersByTimeAsync(16 * 60 * 1000);
|
|
138
|
+
const result = await runPromise;
|
|
139
|
+
expect(result.status).toBe('failed');
|
|
140
|
+
if (result.status === 'failed') {
|
|
141
|
+
expect(result.reason).toBe('timeout');
|
|
142
|
+
}
|
|
143
|
+
expect(context.sessionGateway.stopCalls).toContain('time0001');
|
|
144
|
+
expect(context.sessionGateway.removeCalls).toContain('time0001');
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
describe('Scenario 5: Report file missing after completion', () => {
|
|
148
|
+
it('fails the job with reason "report-missing" and still runs cleanup', async () => {
|
|
149
|
+
const context = createContext();
|
|
150
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('rep00001') });
|
|
151
|
+
context.completionBridge.scheduleCompletion(baseInput.jobId, {
|
|
152
|
+
source: 'mcp',
|
|
153
|
+
outcome: 'completed',
|
|
154
|
+
reason: null,
|
|
155
|
+
});
|
|
156
|
+
context.reportGateway.setReport(null);
|
|
157
|
+
const runPromise = runClaudeReviewJob(baseInput, context.deps);
|
|
158
|
+
await vi.runAllTimersAsync();
|
|
159
|
+
const result = await runPromise;
|
|
160
|
+
expect(result.status).toBe('failed');
|
|
161
|
+
if (result.status === 'failed') {
|
|
162
|
+
expect(result.reason).toBe('report-missing');
|
|
163
|
+
}
|
|
164
|
+
expect(context.sessionGateway.stopCalls).toContain('rep00001');
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
describe('Scenario 6: Rate limit error on dispatch', () => {
|
|
168
|
+
it('returns a retry signal with exponential backoff', async () => {
|
|
169
|
+
const context = createContext();
|
|
170
|
+
context.sessionGateway.setDispatchResult({ status: 'rate-limited', rawStderr: '429 Too Many Requests' });
|
|
171
|
+
const result = await runClaudeReviewJob(baseInput, context.deps);
|
|
172
|
+
expect(result.status).toBe('retry');
|
|
173
|
+
if (result.status === 'retry') {
|
|
174
|
+
expect(result.delayMs).toBe(60_000);
|
|
175
|
+
expect(result.attempt).toBe(1);
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
});
|
|
179
|
+
describe('Scenario 7: Supervisor down detection', () => {
|
|
180
|
+
it('records supervisor down status when daemon is unreachable', async () => {
|
|
181
|
+
const context = createContext();
|
|
182
|
+
context.sessionGateway.setDaemonStatus({ reachable: false, reason: 'connection refused' });
|
|
183
|
+
const health = await checkSupervisorHealth({
|
|
184
|
+
sessionGateway: context.sessionGateway,
|
|
185
|
+
supervisorHealthGateway: context.supervisorHealth,
|
|
186
|
+
now: () => new Date('2026-05-22T10:00:00Z'),
|
|
187
|
+
});
|
|
188
|
+
expect(health.status).toBe('down');
|
|
189
|
+
expect(context.supervisorHealth.read().status).toBe('down');
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
describe('Scenario 8: Billing regression detected pre-dispatch', () => {
|
|
193
|
+
it('aborts dispatch when ANTHROPIC_API_KEY is present in the environment', async () => {
|
|
194
|
+
const context = createContext();
|
|
195
|
+
context.environment.setHasAnthropicApiKey(true);
|
|
196
|
+
const result = await runClaudeReviewJob(baseInput, context.deps);
|
|
197
|
+
expect(result.status).toBe('failed');
|
|
198
|
+
if (result.status === 'failed') {
|
|
199
|
+
expect(result.reason).toBe('billing-regression-prevented');
|
|
200
|
+
}
|
|
201
|
+
expect(context.sessionGateway.dispatchCalls).toHaveLength(0);
|
|
202
|
+
});
|
|
203
|
+
});
|
|
204
|
+
describe('Scenario 9: Periodic billing audit detects API consumption', () => {
|
|
205
|
+
it('pauses the dispatch queue when usage indicates API-pool consumption', async () => {
|
|
206
|
+
const context = createContext();
|
|
207
|
+
context.sessionGateway.setUsage({ usesApiPool: true, raw: 'API tokens used: 12345' });
|
|
208
|
+
const result = await auditBilling({
|
|
209
|
+
sessionGateway: context.sessionGateway,
|
|
210
|
+
billingStateGateway: context.billingState,
|
|
211
|
+
now: () => new Date('2026-05-22T10:00:00Z'),
|
|
212
|
+
});
|
|
213
|
+
expect(result.regression).toBe(true);
|
|
214
|
+
expect(context.billingState.read().dispatchPaused).toBe(true);
|
|
215
|
+
});
|
|
216
|
+
});
|
|
217
|
+
describe('Scenario 10: Followup job uses same --bg dispatch path', () => {
|
|
218
|
+
it('runs the followup through the same use case with jobType="followup"', async () => {
|
|
219
|
+
const context = createContext();
|
|
220
|
+
context.sessionGateway.setDispatchResult({ status: 'dispatched', sessionId: parseSessionId('foll0001') });
|
|
221
|
+
context.completionBridge.scheduleCompletion(baseInput.jobId, {
|
|
222
|
+
source: 'mcp',
|
|
223
|
+
outcome: 'completed',
|
|
224
|
+
reason: null,
|
|
225
|
+
});
|
|
226
|
+
context.reportGateway.setReport({
|
|
227
|
+
content: '# Followup report',
|
|
228
|
+
path: '/tmp/project/.claude/reviews/2026-05-22-MR-42-followup.md',
|
|
229
|
+
});
|
|
230
|
+
const runPromise = runClaudeReviewJob({ ...baseInput, jobType: 'followup' }, context.deps);
|
|
231
|
+
await vi.runAllTimersAsync();
|
|
232
|
+
const result = await runPromise;
|
|
233
|
+
expect(result.status).toBe('completed');
|
|
234
|
+
expect(context.reportGateway.lastReadJobType).toBe('followup');
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
});
|
|
238
|
+
//# sourceMappingURL=169-migrate-claude-invocation-to-bg-mode.acceptance.test.js.map
|