reviewflow 3.31.0 → 3.33.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 +20 -0
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +55 -2
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +5 -1
- package/dist/main/server.js.map +1 -1
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.d.ts +8 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.d.ts.map +1 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.js +2 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.gateway.js.map +1 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.d.ts +8 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.d.ts.map +1 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.js +4 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.guard.js.map +1 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.d.ts +17 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.d.ts.map +1 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.js +11 -0
- package/dist/modules/ember-chat/entities/emberMemory/emberMemory.schema.js.map +1 -0
- package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.d.ts +2 -0
- package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.d.ts.map +1 -1
- package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.js +7 -1
- package/dist/modules/ember-chat/interface-adapters/controllers/http/emberChat.routes.js.map +1 -1
- package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.d.ts +22 -0
- package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.d.ts.map +1 -0
- package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.js +55 -0
- package/dist/modules/ember-chat/interface-adapters/gateways/emberMemory.fileSystem.gateway.js.map +1 -0
- package/dist/modules/ember-chat/services/emberSystemPrompt.d.ts +2 -0
- package/dist/modules/ember-chat/services/emberSystemPrompt.d.ts.map +1 -1
- package/dist/modules/ember-chat/services/emberSystemPrompt.js +41 -8
- package/dist/modules/ember-chat/services/emberSystemPrompt.js.map +1 -1
- package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.d.ts +2 -0
- package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.d.ts.map +1 -1
- package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.js +32 -2
- package/dist/modules/ember-chat/usecases/askEmber/askEmber.usecase.js.map +1 -1
- package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.d.ts +7 -0
- package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.d.ts.map +1 -0
- package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.js +4 -0
- package/dist/modules/ember-chat/usecases/clearEmberMemory/clearEmberMemory.usecase.js.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts +3 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js +9 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts +28 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js +2 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts +11 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js +70 -0
- package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts +5 -0
- package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js +2 -0
- package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js.map +1 -0
- package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts +9 -0
- package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/executorToken/executorCapability.js +10 -0
- package/dist/modules/platform-integration/entities/executorToken/executorCapability.js.map +1 -0
- package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts +4 -0
- package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js +2 -0
- package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js.map +1 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts +27 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts +13 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js +2 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js.map +1 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js +21 -0
- package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js.map +1 -0
- package/dist/modules/platform-integration/entities/transport/cidr.d.ts +2 -0
- package/dist/modules/platform-integration/entities/transport/cidr.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/transport/cidr.js +36 -0
- package/dist/modules/platform-integration/entities/transport/cidr.js.map +1 -0
- package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts +8 -0
- package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js +2 -0
- package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js.map +1 -0
- package/dist/modules/platform-integration/entities/transport/transportContext.d.ts +16 -0
- package/dist/modules/platform-integration/entities/transport/transportContext.d.ts.map +1 -0
- package/dist/modules/platform-integration/entities/transport/transportContext.js +2 -0
- package/dist/modules/platform-integration/entities/transport/transportContext.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js +4 -4
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js +112 -18
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts +25 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js +26 -0
- package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts +14 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js +34 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts +14 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js +27 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts +9 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js +14 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts +31 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js +83 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts +17 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js +17 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +6 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js +28 -1
- package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -1
- package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts +5 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts.map +1 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js +16 -0
- package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js.map +1 -0
- package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts +9 -0
- package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts.map +1 -0
- package/dist/modules/platform-integration/services/autoExecutorActionFilter.js +33 -0
- package/dist/modules/platform-integration/services/autoExecutorActionFilter.js.map +1 -0
- package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts +23 -0
- package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts.map +1 -0
- package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js +21 -0
- package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js.map +1 -0
- package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts +21 -0
- package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts.map +1 -0
- package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js +39 -0
- package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js.map +1 -0
- package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts +17 -0
- package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts.map +1 -0
- package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js +23 -0
- package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js.map +1 -0
- package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts +3 -0
- package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts.map +1 -0
- package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js +18 -0
- package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js.map +1 -0
- package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts +9 -0
- package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts.map +1 -0
- package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js +11 -0
- package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js.map +1 -0
- package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts +13 -0
- package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts.map +1 -0
- package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js +2 -0
- package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js.map +1 -0
- package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts +14 -0
- package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts.map +1 -0
- package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js +31 -0
- package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js.map +1 -0
- package/dist/modules/review-execution/services/constrainActionSurface.d.ts +19 -0
- package/dist/modules/review-execution/services/constrainActionSurface.d.ts.map +1 -0
- package/dist/modules/review-execution/services/constrainActionSurface.js +49 -0
- package/dist/modules/review-execution/services/constrainActionSurface.js.map +1 -0
- package/dist/modules/review-execution/services/contextActionsExecutor.d.ts +2 -1
- package/dist/modules/review-execution/services/contextActionsExecutor.d.ts.map +1 -1
- package/dist/modules/review-execution/services/contextActionsExecutor.js +20 -2
- package/dist/modules/review-execution/services/contextActionsExecutor.js.map +1 -1
- package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts +30 -0
- package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts.map +1 -0
- package/dist/modules/review-execution/services/dispatchConstrainedActions.js +20 -0
- package/dist/modules/review-execution/services/dispatchConstrainedActions.js.map +1 -0
- package/dist/modules/review-execution/services/publicOutputExecutor.d.ts +10 -0
- package/dist/modules/review-execution/services/publicOutputExecutor.d.ts.map +1 -0
- package/dist/modules/review-execution/services/publicOutputExecutor.js +27 -0
- package/dist/modules/review-execution/services/publicOutputExecutor.js.map +1 -0
- package/dist/modules/review-execution/services/resolveThreadInventory.d.ts +19 -0
- package/dist/modules/review-execution/services/resolveThreadInventory.d.ts.map +1 -0
- package/dist/modules/review-execution/services/resolveThreadInventory.js +39 -0
- package/dist/modules/review-execution/services/resolveThreadInventory.js.map +1 -0
- package/dist/modules/review-execution/services/threadActionsExecutor.d.ts +11 -1
- package/dist/modules/review-execution/services/threadActionsExecutor.d.ts.map +1 -1
- package/dist/modules/review-execution/services/threadActionsExecutor.js +24 -2
- package/dist/modules/review-execution/services/threadActionsExecutor.js.map +1 -1
- package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts +6 -0
- package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts.map +1 -1
- package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js +2 -1
- package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js.map +1 -1
- package/dist/security/gitlabWebhookTokenSource.d.ts +9 -0
- package/dist/security/gitlabWebhookTokenSource.d.ts.map +1 -0
- package/dist/security/gitlabWebhookTokenSource.js +15 -0
- package/dist/security/gitlabWebhookTokenSource.js.map +1 -0
- package/dist/security/transportGuardConfig.d.ts +16 -0
- package/dist/security/transportGuardConfig.d.ts.map +1 -0
- package/dist/security/transportGuardConfig.js +38 -0
- package/dist/security/transportGuardConfig.js.map +1 -0
- package/dist/security/verifier.d.ts +9 -2
- package/dist/security/verifier.d.ts.map +1 -1
- package/dist/security/verifier.js +27 -10
- package/dist/security/verifier.js.map +1 -1
- package/dist/tests/acceptance/190-ember-live-answers-subscription.acceptance.test.js +7 -0
- package/dist/tests/acceptance/190-ember-live-answers-subscription.acceptance.test.js.map +1 -1
- package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.d.ts +2 -0
- package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.d.ts.map +1 -0
- package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.js +261 -0
- package/dist/tests/acceptance/192-ember-ondemand-grounding-and-memory.acceptance.test.js.map +1 -0
- package/dist/tests/factories/emberMemory.factory.d.ts +8 -0
- package/dist/tests/factories/emberMemory.factory.d.ts.map +1 -0
- package/dist/tests/factories/emberMemory.factory.js +19 -0
- package/dist/tests/factories/emberMemory.factory.js.map +1 -0
- package/dist/tests/factories/transportContext.factory.d.ts +5 -0
- package/dist/tests/factories/transportContext.factory.d.ts.map +1 -0
- package/dist/tests/factories/transportContext.factory.js +14 -0
- package/dist/tests/factories/transportContext.factory.js.map +1 -0
- package/dist/tests/stubs/egressScan.stub.d.ts +16 -0
- package/dist/tests/stubs/egressScan.stub.d.ts.map +1 -0
- package/dist/tests/stubs/egressScan.stub.js +28 -0
- package/dist/tests/stubs/egressScan.stub.js.map +1 -0
- package/dist/tests/stubs/emberMemory.stub.d.ts +25 -0
- package/dist/tests/stubs/emberMemory.stub.d.ts.map +1 -0
- package/dist/tests/stubs/emberMemory.stub.js +61 -0
- package/dist/tests/stubs/emberMemory.stub.js.map +1 -0
- package/dist/tests/stubs/idempotencyStore.stub.d.ts +9 -0
- package/dist/tests/stubs/idempotencyStore.stub.d.ts.map +1 -0
- package/dist/tests/stubs/idempotencyStore.stub.js +19 -0
- package/dist/tests/stubs/idempotencyStore.stub.js.map +1 -0
- package/dist/tests/stubs/memberAccess.stub.d.ts +24 -0
- package/dist/tests/stubs/memberAccess.stub.d.ts.map +1 -0
- package/dist/tests/stubs/memberAccess.stub.js +28 -0
- package/dist/tests/stubs/memberAccess.stub.js.map +1 -0
- package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts +2 -0
- package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts.map +1 -0
- package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js +136 -0
- package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +114 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js +116 -0
- package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/ember-chat/controllers/emberChat.routes.test.js +14 -0
- package/dist/tests/units/modules/ember-chat/controllers/emberChat.routes.test.js.map +1 -1
- package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.d.ts +2 -0
- package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.d.ts.map +1 -0
- package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.js +51 -0
- package/dist/tests/units/modules/ember-chat/entities/emberMemory.guard.test.js.map +1 -0
- package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.js +82 -0
- package/dist/tests/units/modules/ember-chat/gateways/emberMemory.fileSystem.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/ember-chat/services/emberSystemPrompt.test.js +74 -2
- package/dist/tests/units/modules/ember-chat/services/emberSystemPrompt.test.js.map +1 -1
- package/dist/tests/units/modules/ember-chat/usecases/askEmber.usecase.test.js +56 -1
- package/dist/tests/units/modules/ember-chat/usecases/askEmber.usecase.test.js.map +1 -1
- package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.js +14 -0
- package/dist/tests/units/modules/ember-chat/usecases/clearEmberMemory.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js +69 -0
- package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js +28 -0
- package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js +18 -0
- package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js +13 -0
- package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js +105 -0
- package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js +85 -0
- package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js +216 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js +48 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js +29 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js +66 -0
- package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js +38 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js +40 -0
- package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js +76 -0
- package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js +120 -0
- package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js +33 -0
- package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts +2 -0
- package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js +69 -0
- package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js +26 -0
- package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js +44 -0
- package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js +29 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js +115 -0
- package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js +52 -0
- package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js +124 -0
- package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts +2 -0
- package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts.map +1 -0
- package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js +67 -0
- package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js.map +1 -0
- package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js +42 -0
- package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js.map +1 -1
- package/dist/tests/units/security/gitlabTokenRotation.test.d.ts +2 -0
- package/dist/tests/units/security/gitlabTokenRotation.test.d.ts.map +1 -0
- package/dist/tests/units/security/gitlabTokenRotation.test.js +39 -0
- package/dist/tests/units/security/gitlabTokenRotation.test.js.map +1 -0
- package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts +2 -0
- package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts.map +1 -0
- package/dist/tests/units/security/noSpoofableTransportGuard.test.js +30 -0
- package/dist/tests/units/security/noSpoofableTransportGuard.test.js.map +1 -0
- package/dist/tests/units/security/transportGuardConfig.test.d.ts +2 -0
- package/dist/tests/units/security/transportGuardConfig.test.d.ts.map +1 -0
- package/dist/tests/units/security/transportGuardConfig.test.js +38 -0
- package/dist/tests/units/security/transportGuardConfig.test.js.map +1 -0
- package/dist/tests/units/security/verifier.test.js +33 -2
- package/dist/tests/units/security/verifier.test.js.map +1 -1
- package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts +2 -0
- package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts.map +1 -0
- package/dist/tests/units/services/contextActionsExecutor.egress.test.js +117 -0
- package/dist/tests/units/services/contextActionsExecutor.egress.test.js.map +1 -0
- package/dist/tests/units/services/contextActionsExecutor.test.js +24 -31
- package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -1
- package/dist/tests/units/services/publicOutputExecutor.test.d.ts +2 -0
- package/dist/tests/units/services/publicOutputExecutor.test.d.ts.map +1 -0
- package/dist/tests/units/services/publicOutputExecutor.test.js +72 -0
- package/dist/tests/units/services/publicOutputExecutor.test.js.map +1 -0
- package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts +2 -0
- package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts.map +1 -0
- package/dist/tests/units/services/threadActionsExecutor.egress.test.js +113 -0
- package/dist/tests/units/services/threadActionsExecutor.egress.test.js.map +1 -0
- package/dist/tests/units/services/threadActionsExecutor.test.js +32 -96
- package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { transportGuardMiddleware } from '../../../../../../modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js';
|
|
3
|
+
import { ForwardedForClientIpResolver } from '../../../../../../modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js';
|
|
4
|
+
const TRUSTED_HOP = '127.0.0.1';
|
|
5
|
+
const config = {
|
|
6
|
+
trustedHopAddress: TRUSTED_HOP,
|
|
7
|
+
allowedCidrRanges: ['10.20.30.0/24'],
|
|
8
|
+
};
|
|
9
|
+
class FakeResponse {
|
|
10
|
+
statusCode = null;
|
|
11
|
+
sent = false;
|
|
12
|
+
code(status) {
|
|
13
|
+
this.statusCode = status;
|
|
14
|
+
return this;
|
|
15
|
+
}
|
|
16
|
+
send() {
|
|
17
|
+
this.sent = true;
|
|
18
|
+
return this;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function buildRequest(overrides = {}) {
|
|
22
|
+
return {
|
|
23
|
+
socket: { remoteAddress: overrides.remoteAddress ?? TRUSTED_HOP },
|
|
24
|
+
headers: {
|
|
25
|
+
'x-forwarded-proto': overrides.proto ?? 'https',
|
|
26
|
+
'x-forwarded-for': overrides.forwardedFor ?? '10.20.30.40, 127.0.0.1',
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
describe('transportGuardMiddleware (AC5)', () => {
|
|
31
|
+
it('calls next on a fully valid transport and never sends a rejection', () => {
|
|
32
|
+
let nextCalled = false;
|
|
33
|
+
const request = buildRequest();
|
|
34
|
+
const reply = new FakeResponse();
|
|
35
|
+
transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
|
|
36
|
+
expect(nextCalled).toBe(true);
|
|
37
|
+
expect(reply.statusCode).toBeNull();
|
|
38
|
+
expect(reply.sent).toBe(false);
|
|
39
|
+
});
|
|
40
|
+
it('rejects with 403 and never calls next when the socket is untrusted', () => {
|
|
41
|
+
let nextCalled = false;
|
|
42
|
+
const request = buildRequest({ remoteAddress: '203.0.113.7' });
|
|
43
|
+
const reply = new FakeResponse();
|
|
44
|
+
transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
|
|
45
|
+
expect(nextCalled).toBe(false);
|
|
46
|
+
expect(reply.statusCode).toBe(403);
|
|
47
|
+
expect(reply.sent).toBe(true);
|
|
48
|
+
});
|
|
49
|
+
it('rejects with 403 when the forwarded protocol is not https', () => {
|
|
50
|
+
let nextCalled = false;
|
|
51
|
+
const request = buildRequest({ proto: 'http' });
|
|
52
|
+
const reply = new FakeResponse();
|
|
53
|
+
transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
|
|
54
|
+
expect(nextCalled).toBe(false);
|
|
55
|
+
expect(reply.statusCode).toBe(403);
|
|
56
|
+
});
|
|
57
|
+
it('rejects with 403 when the resolved client ip is off the allowlist', () => {
|
|
58
|
+
let nextCalled = false;
|
|
59
|
+
const request = buildRequest({ forwardedFor: '192.168.1.1' });
|
|
60
|
+
const reply = new FakeResponse();
|
|
61
|
+
transportGuardMiddleware({ request, reply, next: () => { nextCalled = true; }, resolver: new ForwardedForClientIpResolver() }, config);
|
|
62
|
+
expect(nextCalled).toBe(false);
|
|
63
|
+
expect(reply.statusCode).toBe(403);
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
//# sourceMappingURL=transportGuard.middleware.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transportGuard.middleware.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"autoExecutorActionFilter.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.ts"],"names":[],"mappings":""}
|
package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { filterAutoExecutorActions, capabilityForAction, } from '../../../../../modules/platform-integration/services/autoExecutorActionFilter.js';
|
|
3
|
+
describe('auto executor action filter (AC6/AC7)', () => {
|
|
4
|
+
it('maps each action type to its required capability (AC5)', () => {
|
|
5
|
+
expect(capabilityForAction({ type: 'FETCH_THREADS' })).toBe('readMr');
|
|
6
|
+
expect(capabilityForAction({ type: 'POST_COMMENT', body: 'x' })).toBe('postComment');
|
|
7
|
+
expect(capabilityForAction({ type: 'THREAD_REPLY', threadId: '1', message: 'x' })).toBe('postComment');
|
|
8
|
+
expect(capabilityForAction({ type: 'POST_INLINE_COMMENT', filePath: 'a', line: 1, body: 'x' })).toBe('postComment');
|
|
9
|
+
expect(capabilityForAction({ type: 'THREAD_RESOLVE', threadId: '1' })).toBe('threadResolve');
|
|
10
|
+
expect(capabilityForAction({ type: 'ADD_LABEL', label: 'x' })).toBe('addLabel');
|
|
11
|
+
});
|
|
12
|
+
it('AC6: drops THREAD_RESOLVE from the auto action set', () => {
|
|
13
|
+
const actions = [
|
|
14
|
+
{ type: 'POST_COMMENT', body: 'hello' },
|
|
15
|
+
{ type: 'THREAD_RESOLVE', threadId: '42' },
|
|
16
|
+
];
|
|
17
|
+
const { allowed, dropped } = filterAutoExecutorActions(actions);
|
|
18
|
+
expect(allowed).toEqual([{ type: 'POST_COMMENT', body: 'hello' }]);
|
|
19
|
+
expect(dropped).toEqual([{ type: 'THREAD_RESOLVE', threadId: '42' }]);
|
|
20
|
+
});
|
|
21
|
+
it('AC7: keeps POST_COMMENT and FETCH_THREADS, drops THREAD_RESOLVE, no throw', () => {
|
|
22
|
+
const actions = [
|
|
23
|
+
{ type: 'POST_COMMENT', body: 'one' },
|
|
24
|
+
{ type: 'THREAD_RESOLVE', threadId: '7' },
|
|
25
|
+
{ type: 'FETCH_THREADS' },
|
|
26
|
+
];
|
|
27
|
+
const { allowed, dropped } = filterAutoExecutorActions(actions);
|
|
28
|
+
expect(allowed).toEqual([{ type: 'POST_COMMENT', body: 'one' }, { type: 'FETCH_THREADS' }]);
|
|
29
|
+
expect(dropped).toEqual([{ type: 'THREAD_RESOLVE', threadId: '7' }]);
|
|
30
|
+
});
|
|
31
|
+
it('AC6: drops ADD_LABEL since it exceeds the read+postComment set', () => {
|
|
32
|
+
const actions = [{ type: 'ADD_LABEL', label: 'reviewed' }];
|
|
33
|
+
const { allowed, dropped } = filterAutoExecutorActions(actions);
|
|
34
|
+
expect(allowed).toEqual([]);
|
|
35
|
+
expect(dropped).toEqual([{ type: 'ADD_LABEL', label: 'reviewed' }]);
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=autoExecutorActionFilter.test.js.map
|
package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"autoExecutorActionFilter.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"autoExecutorCapabilityGate.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.ts"],"names":[],"mappings":""}
|
package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { EXECUTOR_CAPABILITY_TABLE, AUTO_EXECUTOR_CAPABILITIES, } from '../../../../../modules/platform-integration/entities/executorToken/executorCapability.js';
|
|
3
|
+
import { capabilityForAction, filterAutoExecutorActions, } from '../../../../../modules/platform-integration/services/autoExecutorActionFilter.js';
|
|
4
|
+
import { reviewActionSchema } from '../../../../../modules/review-execution/entities/reviewAction/reviewAction.schema.js';
|
|
5
|
+
// AC8 — merge-blocking privilege contract gate.
|
|
6
|
+
// This structural test pins the production auto-executor capability set to exactly
|
|
7
|
+
// {readMr, postComment}. Re-wiring revoke/THREAD_RESOLVE into the auto path, or
|
|
8
|
+
// widening the token's capability set, turns this red.
|
|
9
|
+
describe('auto executor capability gate (AC8)', () => {
|
|
10
|
+
it('freezes the auto capability set to exactly {readMr, postComment}', () => {
|
|
11
|
+
expect([...AUTO_EXECUTOR_CAPABILITIES].sort()).toEqual(['postComment', 'readMr']);
|
|
12
|
+
});
|
|
13
|
+
it('keeps threadResolve and revoke declared as non-auto in the source-of-truth table', () => {
|
|
14
|
+
expect(EXECUTOR_CAPABILITY_TABLE.threadResolve.autoPath).toBe(false);
|
|
15
|
+
expect(EXECUTOR_CAPABILITY_TABLE.revoke.autoPath).toBe(false);
|
|
16
|
+
});
|
|
17
|
+
it('lets every parseable review action verb through the production filter only if its capability is auto', () => {
|
|
18
|
+
const sampleByType = {
|
|
19
|
+
FETCH_THREADS: { type: 'FETCH_THREADS' },
|
|
20
|
+
POST_COMMENT: { type: 'POST_COMMENT', body: 'b' },
|
|
21
|
+
THREAD_REPLY: { type: 'THREAD_REPLY', threadId: '1', message: 'm' },
|
|
22
|
+
POST_INLINE_COMMENT: { type: 'POST_INLINE_COMMENT', filePath: 'f', line: 1, body: 'b' },
|
|
23
|
+
THREAD_RESOLVE: { type: 'THREAD_RESOLVE', threadId: '1' },
|
|
24
|
+
ADD_LABEL: { type: 'ADD_LABEL', label: 'l' },
|
|
25
|
+
};
|
|
26
|
+
const allUnionTypes = reviewActionSchema.options.map(option => option.shape.type.value);
|
|
27
|
+
// Guard: the gate must cover every verb the schema can parse.
|
|
28
|
+
expect(Object.keys(sampleByType).sort()).toEqual([...allUnionTypes].sort());
|
|
29
|
+
const actions = Object.values(sampleByType);
|
|
30
|
+
const { allowed, dropped } = filterAutoExecutorActions(actions);
|
|
31
|
+
const autoVerbs = ['FETCH_THREADS', 'POST_COMMENT', 'THREAD_REPLY', 'POST_INLINE_COMMENT'];
|
|
32
|
+
const nonAutoVerbs = ['THREAD_RESOLVE', 'ADD_LABEL'];
|
|
33
|
+
expect(allowed.map(a => a.type).sort()).toEqual([...autoVerbs].sort());
|
|
34
|
+
expect(dropped.map(a => a.type).sort()).toEqual([...nonAutoVerbs].sort());
|
|
35
|
+
for (const action of allowed) {
|
|
36
|
+
expect(['readMr', 'postComment']).toContain(capabilityForAction(action));
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=autoExecutorCapabilityGate.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"autoExecutorCapabilityGate.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.ts"],"names":[],"mappings":"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"}
|
package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pinnedThreadFetchTarget.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.ts"],"names":[],"mappings":""}
|
package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { resolvePinnedThreadFetchTarget } from '../../../../../modules/platform-integration/services/pinnedThreadFetchTarget.js';
|
|
3
|
+
class RecordingThreadFetch {
|
|
4
|
+
calls = [];
|
|
5
|
+
fetchThreads = (projectPath, mrNumber) => {
|
|
6
|
+
this.calls.push({ projectPath, mrNumber });
|
|
7
|
+
return [];
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
describe('pinned thread-fetch target provenance (AC9)', () => {
|
|
11
|
+
it('resolves the validated pair when project is configured and mrNumber matches the gated MR', () => {
|
|
12
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
13
|
+
payloadProjectPath: 'group/proj',
|
|
14
|
+
payloadMrNumber: 5,
|
|
15
|
+
findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
|
|
16
|
+
gatedMrNumber: 5,
|
|
17
|
+
});
|
|
18
|
+
expect(target).toEqual({ projectPath: 'group/proj', mrNumber: 5 });
|
|
19
|
+
});
|
|
20
|
+
it('fails closed (null) when projectPath is not in the registry', () => {
|
|
21
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
22
|
+
payloadProjectPath: 'attacker/unknown',
|
|
23
|
+
payloadMrNumber: 5,
|
|
24
|
+
findRepository: () => null,
|
|
25
|
+
gatedMrNumber: 5,
|
|
26
|
+
});
|
|
27
|
+
expect(target).toBeNull();
|
|
28
|
+
});
|
|
29
|
+
it('fails closed (null) when payload mrNumber differs from the gated MR', () => {
|
|
30
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
31
|
+
payloadProjectPath: 'group/proj',
|
|
32
|
+
payloadMrNumber: 999,
|
|
33
|
+
findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
|
|
34
|
+
gatedMrNumber: 5,
|
|
35
|
+
});
|
|
36
|
+
expect(target).toBeNull();
|
|
37
|
+
});
|
|
38
|
+
it('AC9(1): unrecognized project means fetchThreads is never called', () => {
|
|
39
|
+
const fetch = new RecordingThreadFetch();
|
|
40
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
41
|
+
payloadProjectPath: 'attacker/unknown',
|
|
42
|
+
payloadMrNumber: 5,
|
|
43
|
+
findRepository: () => null,
|
|
44
|
+
gatedMrNumber: 5,
|
|
45
|
+
});
|
|
46
|
+
if (target)
|
|
47
|
+
fetch.fetchThreads(target.projectPath, target.mrNumber);
|
|
48
|
+
expect(fetch.calls).toHaveLength(0);
|
|
49
|
+
});
|
|
50
|
+
it('AC9(2): forged mrNumber never retargets fetchThreads at the foreign MR', () => {
|
|
51
|
+
const fetch = new RecordingThreadFetch();
|
|
52
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
53
|
+
payloadProjectPath: 'group/proj',
|
|
54
|
+
payloadMrNumber: 999,
|
|
55
|
+
findRepository: () => ({ projectPath: 'group/proj', localPath: '/repo' }),
|
|
56
|
+
gatedMrNumber: 5,
|
|
57
|
+
});
|
|
58
|
+
if (target)
|
|
59
|
+
fetch.fetchThreads(target.projectPath, target.mrNumber);
|
|
60
|
+
expect(fetch.calls.find(c => c.mrNumber === 999)).toBeUndefined();
|
|
61
|
+
expect(fetch.calls).toHaveLength(0);
|
|
62
|
+
});
|
|
63
|
+
it('uses the configured projectPath, never the raw payload, to fetch', () => {
|
|
64
|
+
const fetch = new RecordingThreadFetch();
|
|
65
|
+
const target = resolvePinnedThreadFetchTarget({
|
|
66
|
+
payloadProjectPath: 'group/proj',
|
|
67
|
+
payloadMrNumber: 5,
|
|
68
|
+
findRepository: () => ({ projectPath: 'group/proj-canonical', localPath: '/repo' }),
|
|
69
|
+
gatedMrNumber: 5,
|
|
70
|
+
});
|
|
71
|
+
if (target)
|
|
72
|
+
fetch.fetchThreads(target.projectPath, target.mrNumber);
|
|
73
|
+
expect(fetch.calls).toEqual([{ projectPath: 'group/proj-canonical', mrNumber: 5 }]);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
//# sourceMappingURL=pinnedThreadFetchTarget.test.js.map
|
package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pinnedThreadFetchTarget.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,8BAA8B,EAAE,MAAM,oEAAoE,CAAA;AAEnH,MAAM,oBAAoB;IACR,KAAK,GAAqD,EAAE,CAAA;IAC5E,YAAY,GAAG,CAAC,WAAmB,EAAE,QAAgB,EAAE,EAAE;QACvD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAA;QAC1C,OAAO,EAAE,CAAA;IACX,CAAC,CAAA;CACF;AAED,QAAQ,CAAC,6CAA6C,EAAE,GAAG,EAAE;IAC3D,EAAE,CAAC,0FAA0F,EAAE,GAAG,EAAE;QAClG,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,YAAY;YAChC,eAAe,EAAE,CAAC;YAClB,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC;YACzE,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QAEF,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAA;IACpE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,kBAAkB;YACtC,eAAe,EAAE,CAAC;YAClB,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI;YAC1B,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QAEF,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAA;IAC3B,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;QAC7E,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,YAAY;YAChC,eAAe,EAAE,GAAG;YACpB,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC;YACzE,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QAEF,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,CAAA;IAC3B,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,iEAAiE,EAAE,GAAG,EAAE;QACzE,MAAM,KAAK,GAAG,IAAI,oBAAoB,EAAE,CAAA;QACxC,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,kBAAkB;YACtC,eAAe,EAAE,CAAC;YAClB,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI;YAC1B,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QACF,IAAI,MAAM;YAAE,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;QAEnE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wEAAwE,EAAE,GAAG,EAAE;QAChF,MAAM,KAAK,GAAG,IAAI,oBAAoB,EAAE,CAAA;QACxC,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,YAAY;YAChC,eAAe,EAAE,GAAG;YACpB,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC;YACzE,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QACF,IAAI,MAAM;YAAE,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;QAEnE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,CAAA;QACjE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,kEAAkE,EAAE,GAAG,EAAE;QAC1E,MAAM,KAAK,GAAG,IAAI,oBAAoB,EAAE,CAAA;QACxC,MAAM,MAAM,GAAG,8BAA8B,CAAC;YAC5C,kBAAkB,EAAE,YAAY;YAChC,eAAe,EAAE,CAAC;YAClB,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,sBAAsB,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC;YACnF,aAAa,EAAE,CAAC;SACjB,CAAC,CAAA;QACF,IAAI,MAAM;YAAE,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;QAEnE,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,EAAE,sBAAsB,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IACrF,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scopedExecutorEnvironment.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.ts"],"names":[],"mappings":""}
|
package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { buildScopedExecutorEnvironment, ENV_ALLOWLIST, MissingExecutorTokenError, } from '../../../../../modules/platform-integration/services/scopedExecutorEnvironment.js';
|
|
3
|
+
class RecordingFileWriter {
|
|
4
|
+
writes = [];
|
|
5
|
+
write(path, contents) {
|
|
6
|
+
this.writes.push({ path, contents });
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
const TOKEN = 'glpat-service-token-xyz';
|
|
10
|
+
const TEMP_ROOT = '/tmp/reviewflow-executor-abc123';
|
|
11
|
+
describe('scoped executor environment (AC1/AC2/AC3/AC4)', () => {
|
|
12
|
+
it('AC1: throws fail-closed when the service token is absent', () => {
|
|
13
|
+
const fileWriter = new RecordingFileWriter();
|
|
14
|
+
expect(() => buildScopedExecutorEnvironment({
|
|
15
|
+
parentEnv: { PATH: '/usr/bin' },
|
|
16
|
+
isolatedDir: TEMP_ROOT,
|
|
17
|
+
fileWriter,
|
|
18
|
+
})).toThrow(MissingExecutorTokenError);
|
|
19
|
+
expect(fileWriter.writes).toHaveLength(0);
|
|
20
|
+
});
|
|
21
|
+
it('AC1: throws fail-closed when the service token is empty', () => {
|
|
22
|
+
const fileWriter = new RecordingFileWriter();
|
|
23
|
+
expect(() => buildScopedExecutorEnvironment({
|
|
24
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: ' ' },
|
|
25
|
+
isolatedDir: TEMP_ROOT,
|
|
26
|
+
fileWriter,
|
|
27
|
+
})).toThrow(MissingExecutorTokenError);
|
|
28
|
+
expect(fileWriter.writes).toHaveLength(0);
|
|
29
|
+
});
|
|
30
|
+
it('AC1: returns a configured environment when the token is present', () => {
|
|
31
|
+
const fileWriter = new RecordingFileWriter();
|
|
32
|
+
const result = buildScopedExecutorEnvironment({
|
|
33
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
34
|
+
isolatedDir: TEMP_ROOT,
|
|
35
|
+
fileWriter,
|
|
36
|
+
});
|
|
37
|
+
expect(result.env).toBeDefined();
|
|
38
|
+
expect(fileWriter.writes).toHaveLength(1);
|
|
39
|
+
});
|
|
40
|
+
it('AC2: child env keyset is a subset of the declared allowlist', () => {
|
|
41
|
+
const fileWriter = new RecordingFileWriter();
|
|
42
|
+
const { env } = buildScopedExecutorEnvironment({
|
|
43
|
+
parentEnv: {
|
|
44
|
+
REVIEWFLOW_EXECUTOR_TOKEN: TOKEN,
|
|
45
|
+
PATH: '/usr/bin',
|
|
46
|
+
LANG: 'en_US.UTF-8',
|
|
47
|
+
AMBIENT_ADMIN_TOKEN: 'canary',
|
|
48
|
+
},
|
|
49
|
+
isolatedDir: TEMP_ROOT,
|
|
50
|
+
fileWriter,
|
|
51
|
+
});
|
|
52
|
+
for (const key of Object.keys(env)) {
|
|
53
|
+
expect(ENV_ALLOWLIST).toContain(key);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
it('AC2: a parent canary secret is absent from the child env', () => {
|
|
57
|
+
const fileWriter = new RecordingFileWriter();
|
|
58
|
+
const { env } = buildScopedExecutorEnvironment({
|
|
59
|
+
parentEnv: {
|
|
60
|
+
REVIEWFLOW_EXECUTOR_TOKEN: TOKEN,
|
|
61
|
+
PATH: '/usr/bin',
|
|
62
|
+
AMBIENT_ADMIN_TOKEN: 'canary',
|
|
63
|
+
},
|
|
64
|
+
isolatedDir: TEMP_ROOT,
|
|
65
|
+
fileWriter,
|
|
66
|
+
});
|
|
67
|
+
expect('AMBIENT_ADMIN_TOKEN' in env).toBe(false);
|
|
68
|
+
});
|
|
69
|
+
it('AC3: no child env value equals the token string', () => {
|
|
70
|
+
const fileWriter = new RecordingFileWriter();
|
|
71
|
+
const { env } = buildScopedExecutorEnvironment({
|
|
72
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
73
|
+
isolatedDir: TEMP_ROOT,
|
|
74
|
+
fileWriter,
|
|
75
|
+
});
|
|
76
|
+
for (const value of Object.values(env)) {
|
|
77
|
+
expect(value).not.toBe(TOKEN);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
it('AC3: the token appears only in the rendered config-file contents', () => {
|
|
81
|
+
const fileWriter = new RecordingFileWriter();
|
|
82
|
+
buildScopedExecutorEnvironment({
|
|
83
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
84
|
+
isolatedDir: TEMP_ROOT,
|
|
85
|
+
fileWriter,
|
|
86
|
+
});
|
|
87
|
+
expect(fileWriter.writes[0]?.contents).toContain(TOKEN);
|
|
88
|
+
});
|
|
89
|
+
it('AC4: HOME and GLAB_CONFIG_DIR resolve under the isolated temp root', () => {
|
|
90
|
+
const fileWriter = new RecordingFileWriter();
|
|
91
|
+
const { env } = buildScopedExecutorEnvironment({
|
|
92
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
93
|
+
isolatedDir: TEMP_ROOT,
|
|
94
|
+
fileWriter,
|
|
95
|
+
});
|
|
96
|
+
expect(env.HOME?.startsWith(TEMP_ROOT)).toBe(true);
|
|
97
|
+
expect(env.GLAB_CONFIG_DIR?.startsWith(TEMP_ROOT)).toBe(true);
|
|
98
|
+
});
|
|
99
|
+
it('AC4: the config file is written under GLAB_CONFIG_DIR/glab-cli/config.yml', () => {
|
|
100
|
+
const fileWriter = new RecordingFileWriter();
|
|
101
|
+
const { env } = buildScopedExecutorEnvironment({
|
|
102
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
103
|
+
isolatedDir: TEMP_ROOT,
|
|
104
|
+
fileWriter,
|
|
105
|
+
});
|
|
106
|
+
expect(fileWriter.writes[0]?.path).toBe(`${env.GLAB_CONFIG_DIR}/glab-cli/config.yml`);
|
|
107
|
+
});
|
|
108
|
+
it('AC4: every written path stays under the isolated temp root', () => {
|
|
109
|
+
const fileWriter = new RecordingFileWriter();
|
|
110
|
+
buildScopedExecutorEnvironment({
|
|
111
|
+
parentEnv: { REVIEWFLOW_EXECUTOR_TOKEN: TOKEN, PATH: '/usr/bin' },
|
|
112
|
+
isolatedDir: TEMP_ROOT,
|
|
113
|
+
fileWriter,
|
|
114
|
+
});
|
|
115
|
+
for (const write of fileWriter.writes) {
|
|
116
|
+
expect(write.path.startsWith(TEMP_ROOT)).toBe(true);
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
//# sourceMappingURL=scopedExecutorEnvironment.test.js.map
|
package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scopedExecutorEnvironment.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.ts"],"names":[],"mappings":"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"}
|
package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isTrustedActor.usecase.test.d.ts","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
2
|
+
import { IsTrustedActorUseCase } from '../../../../../modules/platform-integration/usecases/isTrustedActor.usecase.js';
|
|
3
|
+
import { StubMemberAccessGateway } from '../../../../../tests/stubs/memberAccess.stub.js';
|
|
4
|
+
import { MEMBER_ACCESS_LEVELS } from '../../../../../modules/platform-integration/entities/memberAccess/memberAccess.js';
|
|
5
|
+
describe('IsTrustedActorUseCase', () => {
|
|
6
|
+
let gateway;
|
|
7
|
+
let useCase;
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
gateway = new StubMemberAccessGateway();
|
|
10
|
+
useCase = new IsTrustedActorUseCase(gateway);
|
|
11
|
+
});
|
|
12
|
+
it('trusts a Developer+ actor', async () => {
|
|
13
|
+
gateway.setAccess('alice', MEMBER_ACCESS_LEVELS.developer);
|
|
14
|
+
const trusted = await useCase.execute({ username: 'alice', projectPath: 'org/project' });
|
|
15
|
+
expect(trusted).toBe(true);
|
|
16
|
+
expect(gateway.calls).toEqual([{ projectPath: 'org/project', username: 'alice' }]);
|
|
17
|
+
});
|
|
18
|
+
it('does not trust an actor below Developer', async () => {
|
|
19
|
+
gateway.setAccess('bob', MEMBER_ACCESS_LEVELS.reporter);
|
|
20
|
+
const trusted = await useCase.execute({ username: 'bob', projectPath: 'org/project' });
|
|
21
|
+
expect(trusted).toBe(false);
|
|
22
|
+
});
|
|
23
|
+
it('does not trust an unknown username (fail-closed)', async () => {
|
|
24
|
+
const trusted = await useCase.execute({ username: 'stranger', projectPath: 'org/project' });
|
|
25
|
+
expect(trusted).toBe(false);
|
|
26
|
+
});
|
|
27
|
+
it('does not trust when the gateway throws (fail-closed)', async () => {
|
|
28
|
+
gateway.setShouldFail(true);
|
|
29
|
+
const trusted = await useCase.execute({ username: 'alice', projectPath: 'org/project' });
|
|
30
|
+
expect(trusted).toBe(false);
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=isTrustedActor.usecase.test.js.map
|
package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isTrustedActor.usecase.test.js","sourceRoot":"","sources":["../../../../../../src/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,mEAAmE,CAAC;AAC1G,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAE5G,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,IAAI,OAAgC,CAAC;IACrC,IAAI,OAA8B,CAAC;IAEnC,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAI,uBAAuB,EAAE,CAAC;QACxC,OAAO,GAAG,IAAI,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAE3D,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEzF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;IACrF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAExD,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEvF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;QAChE,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAE5F,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sDAAsD,EAAE,KAAK,IAAI,EAAE;QACpE,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAE5B,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;QAEzF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evaluateTransport.usecase.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { evaluateTransport } from '../../../../../../modules/platform-integration/usecases/transport/evaluateTransport.usecase.js';
|
|
3
|
+
import { TransportContextFactory } from '../../../../../../tests/factories/transportContext.factory.js';
|
|
4
|
+
describe('evaluateTransport', () => {
|
|
5
|
+
describe('AC1 - untrusted socket', () => {
|
|
6
|
+
it('rejects with 403 when the direct socket address is not the trusted hop, ignoring headers', () => {
|
|
7
|
+
const context = TransportContextFactory.valid({
|
|
8
|
+
directSocketAddress: '203.0.113.7',
|
|
9
|
+
forwardedProto: 'https',
|
|
10
|
+
resolvedClientIp: '10.20.30.40',
|
|
11
|
+
});
|
|
12
|
+
const decision = evaluateTransport(context);
|
|
13
|
+
expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'untrusted-socket' });
|
|
14
|
+
});
|
|
15
|
+
it('does not consult the protocol or client ip once the socket fails', () => {
|
|
16
|
+
const context = TransportContextFactory.valid({
|
|
17
|
+
directSocketAddress: '203.0.113.7',
|
|
18
|
+
forwardedProto: 'http',
|
|
19
|
+
resolvedClientIp: null,
|
|
20
|
+
allowedCidrRanges: [],
|
|
21
|
+
});
|
|
22
|
+
const decision = evaluateTransport(context);
|
|
23
|
+
expect(decision.kind).toBe('reject');
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
describe('AC2 - non-https', () => {
|
|
27
|
+
it('rejects with 403 when the forwarded protocol is not https', () => {
|
|
28
|
+
const context = TransportContextFactory.valid({ forwardedProto: 'http' });
|
|
29
|
+
const decision = evaluateTransport(context);
|
|
30
|
+
expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'non-https' });
|
|
31
|
+
});
|
|
32
|
+
it('rejects with 403 when no forwarded protocol is present', () => {
|
|
33
|
+
const context = TransportContextFactory.valid({ forwardedProto: null });
|
|
34
|
+
const decision = evaluateTransport(context);
|
|
35
|
+
expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'non-https' });
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
describe('AC3 - allowlisted, https, hop-trusted', () => {
|
|
39
|
+
it('accepts a fully valid transport context', () => {
|
|
40
|
+
const context = TransportContextFactory.valid();
|
|
41
|
+
const decision = evaluateTransport(context);
|
|
42
|
+
expect(decision).toEqual({ kind: 'accept' });
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
describe('AC4 - off-allowlist', () => {
|
|
46
|
+
it('rejects with 403 when the resolved client ip is outside every configured range', () => {
|
|
47
|
+
const context = TransportContextFactory.valid({
|
|
48
|
+
resolvedClientIp: '192.168.1.1',
|
|
49
|
+
allowedCidrRanges: ['10.20.30.0/24'],
|
|
50
|
+
});
|
|
51
|
+
const decision = evaluateTransport(context);
|
|
52
|
+
expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'off-allowlist' });
|
|
53
|
+
});
|
|
54
|
+
it('rejects with 403 when the client ip could not be resolved', () => {
|
|
55
|
+
const context = TransportContextFactory.valid({ resolvedClientIp: null });
|
|
56
|
+
const decision = evaluateTransport(context);
|
|
57
|
+
expect(decision).toEqual({ kind: 'reject', status: 403, reason: 'off-allowlist' });
|
|
58
|
+
});
|
|
59
|
+
it('accepts when the resolved client ip falls inside one of several ranges', () => {
|
|
60
|
+
const context = TransportContextFactory.valid({
|
|
61
|
+
resolvedClientIp: '172.16.5.9',
|
|
62
|
+
allowedCidrRanges: ['10.0.0.0/8', '172.16.0.0/12'],
|
|
63
|
+
});
|
|
64
|
+
const decision = evaluateTransport(context);
|
|
65
|
+
expect(decision).toEqual({ kind: 'accept' });
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
//# sourceMappingURL=evaluateTransport.usecase.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evaluateTransport.usecase.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actionProvenance.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.ts"],"names":[],"mappings":""}
|
package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { resolveProvenance } from '../../../../../../modules/review-execution/entities/actionProvenance/actionProvenance.js';
|
|
2
|
+
describe('resolveProvenance (AC-1 fail-closed provenance)', () => {
|
|
3
|
+
const nonCanonical = [
|
|
4
|
+
undefined,
|
|
5
|
+
null,
|
|
6
|
+
'',
|
|
7
|
+
'TRUSTED',
|
|
8
|
+
'trusted ',
|
|
9
|
+
' trusted',
|
|
10
|
+
'Trusted',
|
|
11
|
+
'untrusted',
|
|
12
|
+
'admin',
|
|
13
|
+
{},
|
|
14
|
+
0,
|
|
15
|
+
true,
|
|
16
|
+
];
|
|
17
|
+
for (const input of nonCanonical) {
|
|
18
|
+
it(`resolves non-canonical input ${JSON.stringify(input)} to untrusted`, () => {
|
|
19
|
+
expect(resolveProvenance(input)).toBe('untrusted');
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
it('resolves the exact canonical token "trusted" to trusted', () => {
|
|
23
|
+
expect(resolveProvenance('trusted')).toBe('trusted');
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=actionProvenance.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"actionProvenance.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0EAA0E,CAAA;AAE5G,QAAQ,CAAC,iDAAiD,EAAE,GAAG,EAAE;IAC/D,MAAM,YAAY,GAAc;QAC9B,SAAS;QACT,IAAI;QACJ,EAAE;QACF,SAAS;QACT,UAAU;QACV,UAAU;QACV,SAAS;QACT,WAAW;QACX,OAAO;QACP,EAAE;QACF,CAAC;QACD,IAAI;KACL,CAAA;IAED,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;QACjC,EAAE,CAAC,gCAAgC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,EAAE,GAAG,EAAE;YAC5E,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACpD,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACtD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threadInventory.gitlab.gateway.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.ts"],"names":[],"mappings":""}
|