reviewflow 3.32.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 +7 -0
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +52 -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/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/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/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/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 @@
|
|
|
1
|
+
{"version":3,"file":"gitlabIdempotency.controller.test.js","sourceRoot":"","sources":["../../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inMemoryIdempotencyStore.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { InMemoryIdempotencyStore } from '../../../../../../modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js';
|
|
3
|
+
function createClock(start) {
|
|
4
|
+
let current = start;
|
|
5
|
+
return {
|
|
6
|
+
now: () => current,
|
|
7
|
+
advance: (ms) => {
|
|
8
|
+
current += ms;
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
describe('InMemoryIdempotencyStore', () => {
|
|
13
|
+
it('records a new key as absent (returns true on first call)', async () => {
|
|
14
|
+
const store = new InMemoryIdempotencyStore({ ttlMs: 1000, clock: () => 0 });
|
|
15
|
+
const firstResult = await store.recordIfAbsent('event-1');
|
|
16
|
+
expect(firstResult).toBe(true);
|
|
17
|
+
});
|
|
18
|
+
it('reports an already-present key (returns false on immediate second call)', async () => {
|
|
19
|
+
const store = new InMemoryIdempotencyStore({ ttlMs: 1000, clock: () => 0 });
|
|
20
|
+
await store.recordIfAbsent('event-1');
|
|
21
|
+
const secondResult = await store.recordIfAbsent('event-1');
|
|
22
|
+
expect(secondResult).toBe(false);
|
|
23
|
+
});
|
|
24
|
+
it('treats distinct keys independently', async () => {
|
|
25
|
+
const store = new InMemoryIdempotencyStore({ ttlMs: 1000, clock: () => 0 });
|
|
26
|
+
const first = await store.recordIfAbsent('event-1');
|
|
27
|
+
const second = await store.recordIfAbsent('event-2');
|
|
28
|
+
expect(first).toBe(true);
|
|
29
|
+
expect(second).toBe(true);
|
|
30
|
+
});
|
|
31
|
+
it('keeps a key blocked while still within the TTL window', async () => {
|
|
32
|
+
const clock = createClock(0);
|
|
33
|
+
const store = new InMemoryIdempotencyStore({ ttlMs: 1000, clock: clock.now });
|
|
34
|
+
await store.recordIfAbsent('event-1');
|
|
35
|
+
clock.advance(999);
|
|
36
|
+
const withinWindow = await store.recordIfAbsent('event-1');
|
|
37
|
+
expect(withinWindow).toBe(false);
|
|
38
|
+
});
|
|
39
|
+
it('re-accepts a key after the TTL window elapses', async () => {
|
|
40
|
+
const clock = createClock(0);
|
|
41
|
+
const store = new InMemoryIdempotencyStore({ ttlMs: 1000, clock: clock.now });
|
|
42
|
+
await store.recordIfAbsent('event-1');
|
|
43
|
+
clock.advance(1001);
|
|
44
|
+
const afterWindow = await store.recordIfAbsent('event-1');
|
|
45
|
+
expect(afterWindow).toBe(true);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=inMemoryIdempotencyStore.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inMemoryIdempotencyStore.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,gGAAgG,CAAC;AAE1I,SAAS,WAAW,CAAC,KAAa;IAChC,IAAI,OAAO,GAAG,KAAK,CAAC;IACpB,OAAO;QACL,GAAG,EAAE,GAAG,EAAE,CAAC,OAAO;QAClB,OAAO,EAAE,CAAC,EAAU,EAAE,EAAE;YACtB,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;KACF,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,EAAE,CAAC,0DAA0D,EAAE,KAAK,IAAI,EAAE;QACxE,MAAM,KAAK,GAAG,IAAI,wBAAwB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAE5E,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAE1D,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EAAE,KAAK,IAAI,EAAE;QACvF,MAAM,KAAK,GAAG,IAAI,wBAAwB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAE5E,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACtC,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAE3D,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,KAAK,GAAG,IAAI,wBAAwB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAE5E,MAAM,KAAK,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAErD,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACrE,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,KAAK,GAAG,IAAI,wBAAwB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAE9E,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACtC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACnB,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAE3D,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAC7B,MAAM,KAAK,GAAG,IAAI,wBAAwB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAE9E,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACtC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACpB,MAAM,WAAW,GAAG,MAAM,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAE1D,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientIpResolver.forwardedFor.gateway.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { ForwardedForClientIpResolver } from '../../../../../../modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js';
|
|
3
|
+
describe('ForwardedForClientIpResolver', () => {
|
|
4
|
+
it('returns null and never reads forwardedFor when the socket is not trusted', () => {
|
|
5
|
+
const resolver = new ForwardedForClientIpResolver();
|
|
6
|
+
const resolved = resolver.resolve({
|
|
7
|
+
socketTrusted: false,
|
|
8
|
+
forwardedFor: '10.20.30.40, 127.0.0.1',
|
|
9
|
+
});
|
|
10
|
+
expect(resolved).toBeNull();
|
|
11
|
+
});
|
|
12
|
+
it('resolves the leftmost forwarded address once the socket is trusted', () => {
|
|
13
|
+
const resolver = new ForwardedForClientIpResolver();
|
|
14
|
+
const resolved = resolver.resolve({
|
|
15
|
+
socketTrusted: true,
|
|
16
|
+
forwardedFor: '10.20.30.40, 127.0.0.1',
|
|
17
|
+
});
|
|
18
|
+
expect(resolved).toBe('10.20.30.40');
|
|
19
|
+
});
|
|
20
|
+
it('returns null when trusted but no forwarded address is present', () => {
|
|
21
|
+
const resolver = new ForwardedForClientIpResolver();
|
|
22
|
+
const resolved = resolver.resolve({
|
|
23
|
+
socketTrusted: true,
|
|
24
|
+
forwardedFor: null,
|
|
25
|
+
});
|
|
26
|
+
expect(resolved).toBeNull();
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=clientIpResolver.forwardedFor.gateway.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clientIpResolver.forwardedFor.gateway.test.js","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,4BAA4B,EAAE,MAAM,+GAA+G,CAAC;AAE7J,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,EAAE,CAAC,0EAA0E,EAAE,GAAG,EAAE;QAClF,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,KAAK;YACpB,YAAY,EAAE,wBAAwB;SACvC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC5E,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,IAAI;YACnB,YAAY,EAAE,wBAAwB;SACvC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,QAAQ,GAAG,IAAI,4BAA4B,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,aAAa,EAAE,IAAI;YACnB,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transportGuard.middleware.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.ts"],"names":[],"mappings":""}
|
|
@@ -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":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,oGAAoG,CAAC;AAC9I,OAAO,EAAE,4BAA4B,EAAE,MAAM,+GAA+G,CAAC;AAG7J,MAAM,WAAW,GAAG,WAAW,CAAC;AAEhC,MAAM,MAAM,GAAyB;IACnC,iBAAiB,EAAE,WAAW;IAC9B,iBAAiB,EAAE,CAAC,eAAe,CAAC;CACrC,CAAC;AAOF,MAAM,YAAY;IAChB,UAAU,GAAkB,IAAI,CAAC;IACjC,IAAI,GAAG,KAAK,CAAC;IAEb,IAAI,CAAC,MAAc;QACjB,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI;QACF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AAED,SAAS,YAAY,CAAC,YAAqF,EAAE;IAC3G,OAAO;QACL,MAAM,EAAE,EAAE,aAAa,EAAE,SAAS,CAAC,aAAa,IAAI,WAAW,EAAE;QACjE,OAAO,EAAE;YACP,mBAAmB,EAAE,SAAS,CAAC,KAAK,IAAI,OAAO;YAC/C,iBAAiB,EAAE,SAAS,CAAC,YAAY,IAAI,wBAAwB;SACtE;KACF,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,gCAAgC,EAAE,GAAG,EAAE;IAC9C,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;QAC3E,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,OAAO,GAAG,YAAY,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,wBAAwB,CACtB,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,4BAA4B,EAAE,EAAE,EACpG,MAAM,CACP,CAAC;QAEF,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC;QACpC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC5E,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,OAAO,GAAG,YAAY,CAAC,EAAE,aAAa,EAAE,aAAa,EAAE,CAAC,CAAC;QAC/D,MAAM,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,wBAAwB,CACtB,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,4BAA4B,EAAE,EAAE,EACpG,MAAM,CACP,CAAC;QAEF,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,OAAO,GAAG,YAAY,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,wBAAwB,CACtB,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,4BAA4B,EAAE,EAAE,EACpG,MAAM,CACP,CAAC;QAEF,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mEAAmE,EAAE,GAAG,EAAE;QAC3E,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,MAAM,OAAO,GAAG,YAAY,CAAC,EAAE,YAAY,EAAE,aAAa,EAAE,CAAC,CAAC;QAC9D,MAAM,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,wBAAwB,CACtB,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,4BAA4B,EAAE,EAAE,EACpG,MAAM,CACP,CAAC;QAEF,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -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":"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"}
|
|
@@ -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"}
|