reviewflow 3.32.0 → 3.34.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.
Files changed (392) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/dist/main/routes.d.ts.map +1 -1
  3. package/dist/main/routes.js +56 -5
  4. package/dist/main/routes.js.map +1 -1
  5. package/dist/main/server.d.ts.map +1 -1
  6. package/dist/main/server.js +5 -1
  7. package/dist/main/server.js.map +1 -1
  8. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.guard.d.ts +1 -1
  9. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts +2 -0
  10. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.d.ts.map +1 -1
  11. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js +1 -1
  12. package/dist/modules/claude-invocation/entities/claudeSession/claudeSession.schema.js.map +1 -1
  13. package/dist/modules/{ember-chat/interface-adapters/gateways/emberStreamJson.parser.d.ts → claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.d.ts} +1 -1
  14. package/dist/modules/claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.d.ts.map +1 -0
  15. package/dist/modules/{ember-chat/interface-adapters/gateways/emberStreamJson.parser.js → claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.js} +1 -1
  16. package/dist/modules/claude-invocation/interface-adapters/gateways/transcriptStreamJson.parser.js.map +1 -0
  17. package/dist/modules/ember-chat/interface-adapters/gateways/emberAnswerTransport.claude.gateway.js +1 -1
  18. package/dist/modules/ember-chat/interface-adapters/gateways/emberAnswerTransport.claude.gateway.js.map +1 -1
  19. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts +3 -0
  20. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.d.ts.map +1 -0
  21. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js +9 -0
  22. package/dist/modules/platform-integration/entities/egressScan/egressScan.defaults.js.map +1 -0
  23. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts +28 -0
  24. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.d.ts.map +1 -0
  25. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js +2 -0
  26. package/dist/modules/platform-integration/entities/egressScan/egressScan.gateway.js.map +1 -0
  27. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts +11 -0
  28. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.d.ts.map +1 -0
  29. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js +70 -0
  30. package/dist/modules/platform-integration/entities/egressScan/egressScan.scanner.js.map +1 -0
  31. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts +5 -0
  32. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.d.ts.map +1 -0
  33. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js +2 -0
  34. package/dist/modules/platform-integration/entities/egressScan/egressTrace.gateway.js.map +1 -0
  35. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts +9 -0
  36. package/dist/modules/platform-integration/entities/executorToken/executorCapability.d.ts.map +1 -0
  37. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js +10 -0
  38. package/dist/modules/platform-integration/entities/executorToken/executorCapability.js.map +1 -0
  39. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts +4 -0
  40. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.d.ts.map +1 -0
  41. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js +2 -0
  42. package/dist/modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js.map +1 -0
  43. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts +27 -0
  44. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.d.ts.map +1 -0
  45. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts +13 -0
  46. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.d.ts.map +1 -0
  47. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js +2 -0
  48. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.gateway.js.map +1 -0
  49. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js +21 -0
  50. package/dist/modules/platform-integration/entities/memberAccess/memberAccess.js.map +1 -0
  51. package/dist/modules/platform-integration/entities/transport/cidr.d.ts +2 -0
  52. package/dist/modules/platform-integration/entities/transport/cidr.d.ts.map +1 -0
  53. package/dist/modules/platform-integration/entities/transport/cidr.js +36 -0
  54. package/dist/modules/platform-integration/entities/transport/cidr.js.map +1 -0
  55. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts +8 -0
  56. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.d.ts.map +1 -0
  57. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js +2 -0
  58. package/dist/modules/platform-integration/entities/transport/clientIpResolver.gateway.js.map +1 -0
  59. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts +16 -0
  60. package/dist/modules/platform-integration/entities/transport/transportContext.d.ts.map +1 -0
  61. package/dist/modules/platform-integration/entities/transport/transportContext.js +2 -0
  62. package/dist/modules/platform-integration/entities/transport/transportContext.js.map +1 -0
  63. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
  64. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js +4 -4
  65. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
  66. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -1
  67. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
  68. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js +112 -18
  69. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
  70. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts +25 -0
  71. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.d.ts.map +1 -0
  72. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js +26 -0
  73. package/dist/modules/platform-integration/interface-adapters/controllers/webhook/transportGuard.middleware.js.map +1 -0
  74. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts +14 -0
  75. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.d.ts.map +1 -0
  76. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js +34 -0
  77. package/dist/modules/platform-integration/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.js.map +1 -0
  78. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts +14 -0
  79. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.d.ts.map +1 -0
  80. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js +27 -0
  81. package/dist/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.gateway.js.map +1 -0
  82. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts +9 -0
  83. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.d.ts.map +1 -0
  84. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js +14 -0
  85. package/dist/modules/platform-integration/interface-adapters/gateways/loggerEgressTrace.gateway.js.map +1 -0
  86. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts +31 -0
  87. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.d.ts.map +1 -0
  88. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js +83 -0
  89. package/dist/modules/platform-integration/interface-adapters/gateways/memberAccess.gitlab.cli.gateway.js.map +1 -0
  90. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts +17 -0
  91. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.d.ts.map +1 -0
  92. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js +17 -0
  93. package/dist/modules/platform-integration/interface-adapters/gateways/scopedGitLabExecutor.js.map +1 -0
  94. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +6 -0
  95. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -1
  96. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js +28 -1
  97. package/dist/modules/platform-integration/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -1
  98. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts +5 -0
  99. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.d.ts.map +1 -0
  100. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js +16 -0
  101. package/dist/modules/platform-integration/interface-adapters/gateways/transport/clientIpResolver.forwardedFor.gateway.js.map +1 -0
  102. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts +9 -0
  103. package/dist/modules/platform-integration/services/autoExecutorActionFilter.d.ts.map +1 -0
  104. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js +33 -0
  105. package/dist/modules/platform-integration/services/autoExecutorActionFilter.js.map +1 -0
  106. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts +23 -0
  107. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.d.ts.map +1 -0
  108. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js +21 -0
  109. package/dist/modules/platform-integration/services/pinnedThreadFetchTarget.js.map +1 -0
  110. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts +21 -0
  111. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.d.ts.map +1 -0
  112. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js +39 -0
  113. package/dist/modules/platform-integration/services/scopedExecutorEnvironment.js.map +1 -0
  114. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts +17 -0
  115. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.d.ts.map +1 -0
  116. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js +23 -0
  117. package/dist/modules/platform-integration/usecases/isTrustedActor.usecase.js.map +1 -0
  118. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts +3 -0
  119. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.d.ts.map +1 -0
  120. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js +18 -0
  121. package/dist/modules/platform-integration/usecases/transport/evaluateTransport.usecase.js.map +1 -0
  122. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts +9 -0
  123. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.d.ts.map +1 -0
  124. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js +11 -0
  125. package/dist/modules/review-execution/entities/actionProvenance/actionProvenance.js.map +1 -0
  126. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts +13 -0
  127. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.d.ts.map +1 -0
  128. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js +2 -0
  129. package/dist/modules/review-execution/entities/threadInventory/threadInventory.gateway.js.map +1 -0
  130. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts +14 -0
  131. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.d.ts.map +1 -0
  132. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js +31 -0
  133. package/dist/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.js.map +1 -0
  134. package/dist/modules/review-execution/services/constrainActionSurface.d.ts +19 -0
  135. package/dist/modules/review-execution/services/constrainActionSurface.d.ts.map +1 -0
  136. package/dist/modules/review-execution/services/constrainActionSurface.js +49 -0
  137. package/dist/modules/review-execution/services/constrainActionSurface.js.map +1 -0
  138. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts +2 -1
  139. package/dist/modules/review-execution/services/contextActionsExecutor.d.ts.map +1 -1
  140. package/dist/modules/review-execution/services/contextActionsExecutor.js +20 -2
  141. package/dist/modules/review-execution/services/contextActionsExecutor.js.map +1 -1
  142. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts +30 -0
  143. package/dist/modules/review-execution/services/dispatchConstrainedActions.d.ts.map +1 -0
  144. package/dist/modules/review-execution/services/dispatchConstrainedActions.js +20 -0
  145. package/dist/modules/review-execution/services/dispatchConstrainedActions.js.map +1 -0
  146. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts +10 -0
  147. package/dist/modules/review-execution/services/publicOutputExecutor.d.ts.map +1 -0
  148. package/dist/modules/review-execution/services/publicOutputExecutor.js +27 -0
  149. package/dist/modules/review-execution/services/publicOutputExecutor.js.map +1 -0
  150. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts +19 -0
  151. package/dist/modules/review-execution/services/resolveThreadInventory.d.ts.map +1 -0
  152. package/dist/modules/review-execution/services/resolveThreadInventory.js +39 -0
  153. package/dist/modules/review-execution/services/resolveThreadInventory.js.map +1 -0
  154. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts +11 -1
  155. package/dist/modules/review-execution/services/threadActionsExecutor.d.ts.map +1 -1
  156. package/dist/modules/review-execution/services/threadActionsExecutor.js +24 -2
  157. package/dist/modules/review-execution/services/threadActionsExecutor.js.map +1 -1
  158. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts +6 -0
  159. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.d.ts.map +1 -1
  160. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js +2 -1
  161. package/dist/modules/review-execution/usecases/gateClaudeInvocation.usecase.js.map +1 -1
  162. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.d.ts +13 -0
  163. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.d.ts.map +1 -0
  164. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.js +2 -0
  165. package/dist/modules/statistics-insights/entities/insight/aiInsightsSession.gateway.js.map +1 -0
  166. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.d.ts +4 -2
  167. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.d.ts.map +1 -1
  168. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.js +6 -4
  169. package/dist/modules/statistics-insights/interface-adapters/controllers/http/insights.routes.js.map +1 -1
  170. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.d.ts +31 -0
  171. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.d.ts.map +1 -0
  172. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.js +105 -0
  173. package/dist/modules/statistics-insights/interface-adapters/gateways/aiInsightsSession.claude.gateway.js.map +1 -0
  174. package/dist/modules/statistics-insights/usecases/insights/{generateAiInsights.usecase.d.ts → generateAiInsightsViaSession.usecase.d.ts} +7 -13
  175. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.d.ts.map +1 -0
  176. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.js +49 -0
  177. package/dist/modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.js.map +1 -0
  178. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.d.ts +3 -0
  179. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.d.ts.map +1 -0
  180. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.js +20 -0
  181. package/dist/modules/statistics-insights/usecases/insights/parseAiInsightsResponse.js.map +1 -0
  182. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.d.ts +12 -0
  183. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.d.ts.map +1 -0
  184. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.js +14 -0
  185. package/dist/modules/statistics-insights/usecases/insights/persistAiInsights.usecase.js.map +1 -0
  186. package/dist/security/gitlabWebhookTokenSource.d.ts +9 -0
  187. package/dist/security/gitlabWebhookTokenSource.d.ts.map +1 -0
  188. package/dist/security/gitlabWebhookTokenSource.js +15 -0
  189. package/dist/security/gitlabWebhookTokenSource.js.map +1 -0
  190. package/dist/security/transportGuardConfig.d.ts +16 -0
  191. package/dist/security/transportGuardConfig.d.ts.map +1 -0
  192. package/dist/security/transportGuardConfig.js +38 -0
  193. package/dist/security/transportGuardConfig.js.map +1 -0
  194. package/dist/security/verifier.d.ts +9 -2
  195. package/dist/security/verifier.d.ts.map +1 -1
  196. package/dist/security/verifier.js +27 -10
  197. package/dist/security/verifier.js.map +1 -1
  198. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.d.ts +2 -0
  199. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.d.ts.map +1 -0
  200. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.js +121 -0
  201. package/dist/tests/acceptance/191-team-insights-bg-migration.acceptance.test.js.map +1 -0
  202. package/dist/tests/factories/transportContext.factory.d.ts +5 -0
  203. package/dist/tests/factories/transportContext.factory.d.ts.map +1 -0
  204. package/dist/tests/factories/transportContext.factory.js +14 -0
  205. package/dist/tests/factories/transportContext.factory.js.map +1 -0
  206. package/dist/tests/stubs/aiInsightsSession.stub.d.ts +8 -0
  207. package/dist/tests/stubs/aiInsightsSession.stub.d.ts.map +1 -0
  208. package/dist/tests/stubs/aiInsightsSession.stub.js +15 -0
  209. package/dist/tests/stubs/aiInsightsSession.stub.js.map +1 -0
  210. package/dist/tests/stubs/egressScan.stub.d.ts +16 -0
  211. package/dist/tests/stubs/egressScan.stub.d.ts.map +1 -0
  212. package/dist/tests/stubs/egressScan.stub.js +28 -0
  213. package/dist/tests/stubs/egressScan.stub.js.map +1 -0
  214. package/dist/tests/stubs/idempotencyStore.stub.d.ts +9 -0
  215. package/dist/tests/stubs/idempotencyStore.stub.d.ts.map +1 -0
  216. package/dist/tests/stubs/idempotencyStore.stub.js +19 -0
  217. package/dist/tests/stubs/idempotencyStore.stub.js.map +1 -0
  218. package/dist/tests/stubs/memberAccess.stub.d.ts +24 -0
  219. package/dist/tests/stubs/memberAccess.stub.d.ts.map +1 -0
  220. package/dist/tests/stubs/memberAccess.stub.js +28 -0
  221. package/dist/tests/stubs/memberAccess.stub.js.map +1 -0
  222. package/dist/tests/units/architecture/noClaudePInProduction.test.js +0 -1
  223. package/dist/tests/units/architecture/noClaudePInProduction.test.js.map +1 -1
  224. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts +2 -0
  225. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.d.ts.map +1 -0
  226. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js +136 -0
  227. package/dist/tests/units/entities/egressScan/egressScan.scanner.test.js.map +1 -0
  228. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js +6 -4
  229. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js.map +1 -1
  230. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +114 -0
  231. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
  232. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts +2 -0
  233. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.d.ts.map +1 -0
  234. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js +116 -0
  235. package/dist/tests/units/interface-adapters/gateways/egressScanned.noteCommentPost.gateway.test.js.map +1 -0
  236. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.d.ts +2 -0
  237. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.d.ts.map +1 -0
  238. package/dist/tests/units/modules/{ember-chat/gateways/emberStreamJson.parser.test.js → claude-invocation/gateways/transcriptStreamJson.parser.test.js} +2 -2
  239. package/dist/tests/units/modules/claude-invocation/gateways/transcriptStreamJson.parser.test.js.map +1 -0
  240. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts +2 -0
  241. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.d.ts.map +1 -0
  242. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js +69 -0
  243. package/dist/tests/units/modules/platform-integration/controllers/gitlabProcessorProvenance.test.js.map +1 -0
  244. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts +2 -0
  245. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.d.ts.map +1 -0
  246. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js +28 -0
  247. package/dist/tests/units/modules/platform-integration/entities/executorCapability.test.js.map +1 -0
  248. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts +2 -0
  249. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.d.ts.map +1 -0
  250. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js +18 -0
  251. package/dist/tests/units/modules/platform-integration/entities/memberAccess/memberAccess.test.js.map +1 -0
  252. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts +2 -0
  253. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.d.ts.map +1 -0
  254. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js +13 -0
  255. package/dist/tests/units/modules/platform-integration/gateways/defaultGitLabExecutor.test.js.map +1 -0
  256. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts +2 -0
  257. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.d.ts.map +1 -0
  258. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js +105 -0
  259. package/dist/tests/units/modules/platform-integration/gateways/memberAccess.gitlab.cli.gateway.test.js.map +1 -0
  260. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts +2 -0
  261. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.d.ts.map +1 -0
  262. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js +85 -0
  263. package/dist/tests/units/modules/platform-integration/gateways/scopedGitLabExecutor.test.js.map +1 -0
  264. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts +2 -0
  265. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.d.ts.map +1 -0
  266. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js +216 -0
  267. package/dist/tests/units/modules/platform-integration/interface-adapters/controllers/webhook/gitlabIdempotency.controller.test.js.map +1 -0
  268. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts +2 -0
  269. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.d.ts.map +1 -0
  270. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js +48 -0
  271. package/dist/tests/units/modules/platform-integration/interface-adapters/gateways/inMemoryIdempotencyStore.test.js.map +1 -0
  272. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts +2 -0
  273. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.d.ts.map +1 -0
  274. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js +29 -0
  275. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/clientIpResolver.forwardedFor.gateway.test.js.map +1 -0
  276. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts +2 -0
  277. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.d.ts.map +1 -0
  278. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js +66 -0
  279. package/dist/tests/units/modules/platform-integration/interface-adapters/transport/transportGuard.middleware.test.js.map +1 -0
  280. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts +2 -0
  281. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.d.ts.map +1 -0
  282. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js +38 -0
  283. package/dist/tests/units/modules/platform-integration/services/autoExecutorActionFilter.test.js.map +1 -0
  284. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts +2 -0
  285. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.d.ts.map +1 -0
  286. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js +40 -0
  287. package/dist/tests/units/modules/platform-integration/services/autoExecutorCapabilityGate.test.js.map +1 -0
  288. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts +2 -0
  289. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.d.ts.map +1 -0
  290. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js +76 -0
  291. package/dist/tests/units/modules/platform-integration/services/pinnedThreadFetchTarget.test.js.map +1 -0
  292. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts +2 -0
  293. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.d.ts.map +1 -0
  294. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js +120 -0
  295. package/dist/tests/units/modules/platform-integration/services/scopedExecutorEnvironment.test.js.map +1 -0
  296. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts +2 -0
  297. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.d.ts.map +1 -0
  298. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js +33 -0
  299. package/dist/tests/units/modules/platform-integration/usecases/isTrustedActor.usecase.test.js.map +1 -0
  300. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts +2 -0
  301. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.d.ts.map +1 -0
  302. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js +69 -0
  303. package/dist/tests/units/modules/platform-integration/usecases/transport/evaluateTransport.usecase.test.js.map +1 -0
  304. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts +2 -0
  305. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.d.ts.map +1 -0
  306. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js +26 -0
  307. package/dist/tests/units/modules/review-execution/entities/actionProvenance/actionProvenance.test.js.map +1 -0
  308. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts +2 -0
  309. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.d.ts.map +1 -0
  310. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js +44 -0
  311. package/dist/tests/units/modules/review-execution/interface-adapters/gateways/threadInventory.gitlab.gateway.test.js.map +1 -0
  312. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts +2 -0
  313. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.d.ts.map +1 -0
  314. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js +29 -0
  315. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.parity.test.js.map +1 -0
  316. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts +2 -0
  317. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.d.ts.map +1 -0
  318. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js +115 -0
  319. package/dist/tests/units/modules/review-execution/services/constrainActionSurface.test.js.map +1 -0
  320. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts +2 -0
  321. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.d.ts.map +1 -0
  322. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js +52 -0
  323. package/dist/tests/units/modules/review-execution/services/contextActionsExecutor.autopath.test.js.map +1 -0
  324. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts +2 -0
  325. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.d.ts.map +1 -0
  326. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js +124 -0
  327. package/dist/tests/units/modules/review-execution/services/dispatchConstrainedActions.test.js.map +1 -0
  328. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts +2 -0
  329. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.d.ts.map +1 -0
  330. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js +67 -0
  331. package/dist/tests/units/modules/review-execution/services/resolveThreadInventory.test.js.map +1 -0
  332. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js +42 -0
  333. package/dist/tests/units/modules/review-execution/usecases/gateClaudeInvocation.usecase.test.js.map +1 -1
  334. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts +2 -0
  335. package/dist/tests/units/security/gitlabTokenRotation.test.d.ts.map +1 -0
  336. package/dist/tests/units/security/gitlabTokenRotation.test.js +39 -0
  337. package/dist/tests/units/security/gitlabTokenRotation.test.js.map +1 -0
  338. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts +2 -0
  339. package/dist/tests/units/security/noSpoofableTransportGuard.test.d.ts.map +1 -0
  340. package/dist/tests/units/security/noSpoofableTransportGuard.test.js +30 -0
  341. package/dist/tests/units/security/noSpoofableTransportGuard.test.js.map +1 -0
  342. package/dist/tests/units/security/transportGuardConfig.test.d.ts +2 -0
  343. package/dist/tests/units/security/transportGuardConfig.test.d.ts.map +1 -0
  344. package/dist/tests/units/security/transportGuardConfig.test.js +38 -0
  345. package/dist/tests/units/security/transportGuardConfig.test.js.map +1 -0
  346. package/dist/tests/units/security/verifier.test.js +33 -2
  347. package/dist/tests/units/security/verifier.test.js.map +1 -1
  348. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts +2 -0
  349. package/dist/tests/units/services/contextActionsExecutor.egress.test.d.ts.map +1 -0
  350. package/dist/tests/units/services/contextActionsExecutor.egress.test.js +117 -0
  351. package/dist/tests/units/services/contextActionsExecutor.egress.test.js.map +1 -0
  352. package/dist/tests/units/services/contextActionsExecutor.test.js +24 -31
  353. package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -1
  354. package/dist/tests/units/services/publicOutputExecutor.test.d.ts +2 -0
  355. package/dist/tests/units/services/publicOutputExecutor.test.d.ts.map +1 -0
  356. package/dist/tests/units/services/publicOutputExecutor.test.js +72 -0
  357. package/dist/tests/units/services/publicOutputExecutor.test.js.map +1 -0
  358. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts +2 -0
  359. package/dist/tests/units/services/threadActionsExecutor.egress.test.d.ts.map +1 -0
  360. package/dist/tests/units/services/threadActionsExecutor.egress.test.js +113 -0
  361. package/dist/tests/units/services/threadActionsExecutor.egress.test.js.map +1 -0
  362. package/dist/tests/units/services/threadActionsExecutor.test.js +32 -96
  363. package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -1
  364. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.d.ts +2 -0
  365. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.d.ts.map +1 -0
  366. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.js +114 -0
  367. package/dist/tests/units/usecases/insights/generateAiInsightsViaSession.usecase.test.js.map +1 -0
  368. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.d.ts +2 -0
  369. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.d.ts.map +1 -0
  370. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.js +45 -0
  371. package/dist/tests/units/usecases/insights/parseAiInsightsResponse.test.js.map +1 -0
  372. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.d.ts +2 -0
  373. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.d.ts.map +1 -0
  374. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.js +87 -0
  375. package/dist/tests/units/usecases/insights/persistAiInsights.usecase.test.js.map +1 -0
  376. package/package.json +9 -2
  377. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts +0 -3
  378. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts.map +0 -1
  379. package/dist/frameworks/claude/claudeInsightsInvoker.js +0 -58
  380. package/dist/frameworks/claude/claudeInsightsInvoker.js.map +0 -1
  381. package/dist/modules/ember-chat/interface-adapters/gateways/emberStreamJson.parser.d.ts.map +0 -1
  382. package/dist/modules/ember-chat/interface-adapters/gateways/emberStreamJson.parser.js.map +0 -1
  383. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.d.ts.map +0 -1
  384. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.js +0 -65
  385. package/dist/modules/statistics-insights/usecases/insights/generateAiInsights.usecase.js.map +0 -1
  386. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.d.ts +0 -2
  387. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.d.ts.map +0 -1
  388. package/dist/tests/units/modules/ember-chat/gateways/emberStreamJson.parser.test.js.map +0 -1
  389. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts +0 -2
  390. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts.map +0 -1
  391. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js +0 -253
  392. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js.map +0 -1
@@ -0,0 +1,121 @@
1
+ import { describe, it, expect, beforeEach } from 'vitest';
2
+ import { readdirSync, readFileSync, existsSync } from 'node:fs';
3
+ import { join } from 'node:path';
4
+ import { generateAiInsightsViaSession } from '../../modules/statistics-insights/usecases/insights/generateAiInsightsViaSession.usecase.js';
5
+ import { InMemoryStatsGateway } from '../../tests/stubs/stats.stub.js';
6
+ import { InMemoryReviewFileGateway } from '../../tests/stubs/reviewFile.stub.js';
7
+ import { InMemoryReviewRequestTrackingGateway } from '../../tests/stubs/reviewRequestTracking.stub.js';
8
+ import { StubEnvironmentGateway } from '../../tests/stubs/environment.stub.js';
9
+ import { StubAiInsightsSessionGateway } from '../../tests/stubs/aiInsightsSession.stub.js';
10
+ import { createStubLogger } from '../../tests/stubs/logger.stub.js';
11
+ import { ProjectStatsFactory, ReviewStatsFactory } from '../../tests/factories/projectStats.factory.js';
12
+ const validAiResult = {
13
+ developers: [
14
+ {
15
+ developerName: 'alice',
16
+ title: 'Le Chirurgien du Code',
17
+ titleExplanation: 'Precise and methodical',
18
+ strengths: ['Excellent test coverage'],
19
+ weaknesses: ['Slow review turnaround'],
20
+ recommendations: ['Automate repetitive checks'],
21
+ summary: 'Alice is a meticulous developer.',
22
+ },
23
+ ],
24
+ team: {
25
+ summary: 'A well-balanced team.',
26
+ strengths: ['Strong testing culture'],
27
+ weaknesses: ['Documentation gaps'],
28
+ recommendations: ['Establish review guidelines'],
29
+ dynamics: 'Good team dynamics.',
30
+ },
31
+ generatedAt: '2026-03-15T10:00:00Z',
32
+ };
33
+ describe('SPEC-191: Team AI Insights migrated to --bg subscription billing', () => {
34
+ let statsGateway;
35
+ let reviewFileGateway;
36
+ let reviewRequestTrackingGateway;
37
+ let environment;
38
+ let session;
39
+ function input() {
40
+ return {
41
+ projectPath: '/test/project',
42
+ statsGateway,
43
+ reviewFileGateway,
44
+ reviewRequestTrackingGateway,
45
+ logger: createStubLogger(),
46
+ session,
47
+ environment,
48
+ language: 'fr',
49
+ };
50
+ }
51
+ function seedReviews() {
52
+ const reviews = [
53
+ ReviewStatsFactory.create({ id: 'r1', assignedBy: 'alice', mrNumber: 1, score: 8 }),
54
+ ];
55
+ statsGateway.saveProjectStats('/test/project', ProjectStatsFactory.withReviews(reviews));
56
+ }
57
+ beforeEach(() => {
58
+ statsGateway = new InMemoryStatsGateway();
59
+ reviewFileGateway = new InMemoryReviewFileGateway();
60
+ reviewRequestTrackingGateway = new InMemoryReviewRequestTrackingGateway();
61
+ environment = new StubEnvironmentGateway();
62
+ session = new StubAiInsightsSessionGateway();
63
+ });
64
+ it('nominal: generates insights via a --bg session with identical content', async () => {
65
+ seedReviews();
66
+ session.setResult({ status: 'completed', answer: JSON.stringify(validAiResult) });
67
+ const result = await generateAiInsightsViaSession(input());
68
+ expect(session.runCalls).toHaveLength(1);
69
+ expect(result.developers[0].developerName).toBe('alice');
70
+ expect(result.team.summary).toBe('A well-balanced team.');
71
+ });
72
+ it('answer read from transcript: parses the completed session answer into insights', async () => {
73
+ seedReviews();
74
+ session.setResult({ status: 'completed', answer: JSON.stringify(validAiResult) });
75
+ const result = await generateAiInsightsViaSession(input());
76
+ expect(result.generatedAt).toBeDefined();
77
+ });
78
+ it('no stats: rejects with the French no-stats message', async () => {
79
+ await expect(generateAiInsightsViaSession(input())).rejects.toThrow('Aucune statistique de review disponible pour ce projet');
80
+ });
81
+ it('not logged in: rejects with the French subscription-required message', async () => {
82
+ seedReviews();
83
+ session.setResult({ status: 'unavailable', reason: 'dispatch-failed' });
84
+ await expect(generateAiInsightsViaSession(input())).rejects.toThrow('Impossible de générer les insights — connexion à l\'abonnement Claude requise');
85
+ });
86
+ it('api key present: refuses before dispatch with the subscription-only message', async () => {
87
+ seedReviews();
88
+ environment.setHasAnthropicApiKey(true);
89
+ await expect(generateAiInsightsViaSession(input())).rejects.toThrow("Impossible de générer les insights — l'abonnement Claude est requis, pas de clé API");
90
+ expect(session.runCalls).toHaveLength(0);
91
+ });
92
+ it('timeout: rejects with the French timeout message', async () => {
93
+ seedReviews();
94
+ session.setResult({ status: 'timed-out' });
95
+ await expect(generateAiInsightsViaSession(input())).rejects.toThrow('La génération des insights a expiré');
96
+ });
97
+ it('no remaining -p: no production insights code invokes claude -p / --print', () => {
98
+ const insightsDir = join(process.cwd(), 'src', 'modules', 'statistics-insights');
99
+ const offenders = [];
100
+ const walk = (dir) => {
101
+ for (const entry of readdirSync(dir, { withFileTypes: true })) {
102
+ const full = join(dir, entry.name);
103
+ if (entry.isDirectory()) {
104
+ walk(full);
105
+ continue;
106
+ }
107
+ if (!entry.name.endsWith('.ts') || full.includes('/tests/')) {
108
+ continue;
109
+ }
110
+ const content = readFileSync(full, 'utf-8');
111
+ if (/['"]--print['"]/.test(content) || /['"]-p['"]/.test(content)) {
112
+ offenders.push(full);
113
+ }
114
+ }
115
+ };
116
+ walk(insightsDir);
117
+ expect(offenders).toEqual([]);
118
+ expect(existsSync(join(process.cwd(), 'src', 'frameworks', 'claude', 'claudeInsightsInvoker.ts'))).toBe(false);
119
+ });
120
+ });
121
+ //# sourceMappingURL=191-team-insights-bg-migration.acceptance.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"191-team-insights-bg-migration.acceptance.test.js","sourceRoot":"","sources":["../../../src/tests/acceptance/191-team-insights-bg-migration.acceptance.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { TransportContext } from '../../modules/platform-integration/entities/transport/transportContext.js';
2
+ export declare class TransportContextFactory {
3
+ static valid(overrides?: Partial<TransportContext>): TransportContext;
4
+ }
5
+ //# sourceMappingURL=transportContext.factory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transportContext.factory.d.ts","sourceRoot":"","sources":["../../../src/tests/factories/transportContext.factory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uEAAuE,CAAC;AAI9G,qBAAa,uBAAuB;IAClC,MAAM,CAAC,KAAK,CAAC,SAAS,GAAE,OAAO,CAAC,gBAAgB,CAAM,GAAG,gBAAgB;CAU1E"}
@@ -0,0 +1,14 @@
1
+ const TRUSTED_HOP = '127.0.0.1';
2
+ export class TransportContextFactory {
3
+ static valid(overrides = {}) {
4
+ return {
5
+ directSocketAddress: TRUSTED_HOP,
6
+ trustedHopAddress: TRUSTED_HOP,
7
+ forwardedProto: 'https',
8
+ resolvedClientIp: '10.20.30.40',
9
+ allowedCidrRanges: ['10.20.30.0/24'],
10
+ ...overrides,
11
+ };
12
+ }
13
+ }
14
+ //# sourceMappingURL=transportContext.factory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transportContext.factory.js","sourceRoot":"","sources":["../../../src/tests/factories/transportContext.factory.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,GAAG,WAAW,CAAC;AAEhC,MAAM,OAAO,uBAAuB;IAClC,MAAM,CAAC,KAAK,CAAC,YAAuC,EAAE;QACpD,OAAO;YACL,mBAAmB,EAAE,WAAW;YAChC,iBAAiB,EAAE,WAAW;YAC9B,cAAc,EAAE,OAAO;YACvB,gBAAgB,EAAE,aAAa;YAC/B,iBAAiB,EAAE,CAAC,eAAe,CAAC;YACpC,GAAG,SAAS;SACb,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,8 @@
1
+ import type { AiInsightsSessionGateway, AiInsightsSessionResult } from '../../modules/statistics-insights/entities/insight/aiInsightsSession.gateway.js';
2
+ export declare class StubAiInsightsSessionGateway implements AiInsightsSessionGateway {
3
+ runCalls: string[];
4
+ private result;
5
+ setResult(result: AiInsightsSessionResult): void;
6
+ run(prompt: string): Promise<AiInsightsSessionResult>;
7
+ }
8
+ //# sourceMappingURL=aiInsightsSession.stub.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aiInsightsSession.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/aiInsightsSession.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,wBAAwB,EACxB,uBAAuB,EACxB,MAAM,6EAA6E,CAAC;AAErF,qBAAa,4BAA6B,YAAW,wBAAwB;IAC3E,QAAQ,EAAE,MAAM,EAAE,CAAM;IAExB,OAAO,CAAC,MAAM,CAGZ;IAEF,SAAS,CAAC,MAAM,EAAE,uBAAuB,GAAG,IAAI;IAI1C,GAAG,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC;CAI5D"}
@@ -0,0 +1,15 @@
1
+ export class StubAiInsightsSessionGateway {
2
+ runCalls = [];
3
+ result = {
4
+ status: 'completed',
5
+ answer: '{}',
6
+ };
7
+ setResult(result) {
8
+ this.result = result;
9
+ }
10
+ async run(prompt) {
11
+ this.runCalls.push(prompt);
12
+ return this.result;
13
+ }
14
+ }
15
+ //# sourceMappingURL=aiInsightsSession.stub.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aiInsightsSession.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/aiInsightsSession.stub.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,4BAA4B;IACvC,QAAQ,GAAa,EAAE,CAAC;IAEhB,MAAM,GAA4B;QACxC,MAAM,EAAE,WAAW;QACnB,MAAM,EAAE,IAAI;KACb,CAAC;IAEF,SAAS,CAAC,MAA+B;QACvC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,MAAc;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC3B,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1,16 @@
1
+ import type { EgressScanGateway, EgressScanInput, EgressScanResult } from '../../modules/platform-integration/entities/egressScan/egressScan.gateway.js';
2
+ import type { EgressTraceGateway } from '../../modules/platform-integration/entities/egressScan/egressTrace.gateway.js';
3
+ import type { EgressScanTrace } from '../../modules/platform-integration/entities/egressScan/egressScan.gateway.js';
4
+ export declare class StubEgressScanGateway implements EgressScanGateway {
5
+ readonly calls: EgressScanInput[];
6
+ private result;
7
+ private shouldFail;
8
+ setResult(result: EgressScanResult): void;
9
+ setShouldFail(shouldFail: boolean): void;
10
+ scan(input: EgressScanInput): EgressScanResult;
11
+ }
12
+ export declare class StubEgressTraceGateway implements EgressTraceGateway {
13
+ readonly traces: EgressScanTrace[];
14
+ record(trace: EgressScanTrace): void;
15
+ }
16
+ //# sourceMappingURL=egressScan.stub.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/egressScan.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,eAAe,EACf,gBAAgB,EACjB,MAAM,0EAA0E,CAAC;AAClF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,2EAA2E,CAAC;AACpH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,0EAA0E,CAAC;AAEhH,qBAAa,qBAAsB,YAAW,iBAAiB;IAC7D,QAAQ,CAAC,KAAK,EAAE,eAAe,EAAE,CAAM;IACvC,OAAO,CAAC,MAAM,CAAiC;IAC/C,OAAO,CAAC,UAAU,CAAS;IAE3B,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI;IAIzC,aAAa,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAIxC,IAAI,CAAC,KAAK,EAAE,eAAe,GAAG,gBAAgB;CAU/C;AAED,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,QAAQ,CAAC,MAAM,EAAE,eAAe,EAAE,CAAM;IAExC,MAAM,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI;CAGrC"}
@@ -0,0 +1,28 @@
1
+ export class StubEgressScanGateway {
2
+ calls = [];
3
+ result = null;
4
+ shouldFail = false;
5
+ setResult(result) {
6
+ this.result = result;
7
+ }
8
+ setShouldFail(shouldFail) {
9
+ this.shouldFail = shouldFail;
10
+ }
11
+ scan(input) {
12
+ this.calls.push(input);
13
+ if (this.shouldFail) {
14
+ throw new Error('scanner failure');
15
+ }
16
+ if (this.result === null) {
17
+ return { decision: 'pass', body: input.body };
18
+ }
19
+ return this.result;
20
+ }
21
+ }
22
+ export class StubEgressTraceGateway {
23
+ traces = [];
24
+ record(trace) {
25
+ this.traces.push(trace);
26
+ }
27
+ }
28
+ //# sourceMappingURL=egressScan.stub.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/egressScan.stub.ts"],"names":[],"mappings":"AAQA,MAAM,OAAO,qBAAqB;IACvB,KAAK,GAAsB,EAAE,CAAC;IAC/B,MAAM,GAA4B,IAAI,CAAC;IACvC,UAAU,GAAG,KAAK,CAAC;IAE3B,SAAS,CAAC,MAAwB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,aAAa,CAAC,UAAmB;QAC/B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED,IAAI,CAAC,KAAsB;QACzB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;QACrC,CAAC;QACD,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;YACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QAChD,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF;AAED,MAAM,OAAO,sBAAsB;IACxB,MAAM,GAAsB,EAAE,CAAC;IAExC,MAAM,CAAC,KAAsB;QAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;CACF"}
@@ -0,0 +1,9 @@
1
+ import type { IdempotencyStore } from '../../modules/platform-integration/entities/idempotency/idempotencyStore.gateway.js';
2
+ export declare class StubIdempotencyStore implements IdempotencyStore {
3
+ readonly recordedKeys: string[];
4
+ private readonly present;
5
+ recordIfAbsent(eventKey: string): Promise<boolean>;
6
+ get entryCount(): number;
7
+ has(eventKey: string): boolean;
8
+ }
9
+ //# sourceMappingURL=idempotencyStore.stub.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idempotencyStore.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/idempotencyStore.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iFAAiF,CAAC;AAExH,qBAAa,oBAAqB,YAAW,gBAAgB;IAC3D,QAAQ,CAAC,YAAY,EAAE,MAAM,EAAE,CAAM;IACrC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAqB;IAEvC,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IASxD,IAAI,UAAU,IAAI,MAAM,CAEvB;IAED,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;CAG/B"}
@@ -0,0 +1,19 @@
1
+ export class StubIdempotencyStore {
2
+ recordedKeys = [];
3
+ present = new Set();
4
+ async recordIfAbsent(eventKey) {
5
+ this.recordedKeys.push(eventKey);
6
+ if (this.present.has(eventKey)) {
7
+ return false;
8
+ }
9
+ this.present.add(eventKey);
10
+ return true;
11
+ }
12
+ get entryCount() {
13
+ return this.present.size;
14
+ }
15
+ has(eventKey) {
16
+ return this.present.has(eventKey);
17
+ }
18
+ }
19
+ //# sourceMappingURL=idempotencyStore.stub.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idempotencyStore.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/idempotencyStore.stub.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,oBAAoB;IACtB,YAAY,GAAa,EAAE,CAAC;IACpB,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;IAE7C,KAAK,CAAC,cAAc,CAAC,QAAgB;QACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC/B,OAAO,KAAK,CAAC;QACf,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;IAC3B,CAAC;IAED,GAAG,CAAC,QAAgB;QAClB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;CACF"}
@@ -0,0 +1,24 @@
1
+ import type { MemberAccessGateway } from '../../modules/platform-integration/entities/memberAccess/memberAccess.gateway.js';
2
+ import type { ResolvedAccessLevel } from '../../modules/platform-integration/entities/memberAccess/memberAccess.js';
3
+ export interface MemberAccessResolveCall {
4
+ projectPath: string;
5
+ username: string;
6
+ }
7
+ /**
8
+ * Recording stub for MemberAccessGateway (Detroit style — no vi.fn).
9
+ *
10
+ * Returns a fixed access level per username via `setAccess`. Unknown usernames
11
+ * resolve fail-closed to `null`. `setShouldFail(true)` makes every resolve throw,
12
+ * exercising the fail-closed boundary (SPEC-197 AC4). All calls are recorded so
13
+ * tests can assert call counts and args (AC6: gateway never called when the token
14
+ * verifier rejects).
15
+ */
16
+ export declare class StubMemberAccessGateway implements MemberAccessGateway {
17
+ readonly calls: MemberAccessResolveCall[];
18
+ private accessByUsername;
19
+ private shouldFail;
20
+ setAccess(username: string, accessLevel: ResolvedAccessLevel): void;
21
+ setShouldFail(shouldFail: boolean): void;
22
+ resolve(projectPath: string, username: string): Promise<ResolvedAccessLevel>;
23
+ }
24
+ //# sourceMappingURL=memberAccess.stub.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.stub.d.ts","sourceRoot":"","sources":["../../../src/tests/stubs/memberAccess.stub.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,8EAA8E,CAAC;AACxH,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,sEAAsE,CAAC;AAEhH,MAAM,WAAW,uBAAuB;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;;;;;;;GAQG;AACH,qBAAa,uBAAwB,YAAW,mBAAmB;IACjE,SAAgB,KAAK,EAAE,uBAAuB,EAAE,CAAM;IACtD,OAAO,CAAC,gBAAgB,CAA0C;IAClE,OAAO,CAAC,UAAU,CAAS;IAE3B,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,mBAAmB,GAAG,IAAI;IAInE,aAAa,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAIlC,OAAO,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC;CAOnF"}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Recording stub for MemberAccessGateway (Detroit style — no vi.fn).
3
+ *
4
+ * Returns a fixed access level per username via `setAccess`. Unknown usernames
5
+ * resolve fail-closed to `null`. `setShouldFail(true)` makes every resolve throw,
6
+ * exercising the fail-closed boundary (SPEC-197 AC4). All calls are recorded so
7
+ * tests can assert call counts and args (AC6: gateway never called when the token
8
+ * verifier rejects).
9
+ */
10
+ export class StubMemberAccessGateway {
11
+ calls = [];
12
+ accessByUsername = new Map();
13
+ shouldFail = false;
14
+ setAccess(username, accessLevel) {
15
+ this.accessByUsername.set(username, accessLevel);
16
+ }
17
+ setShouldFail(shouldFail) {
18
+ this.shouldFail = shouldFail;
19
+ }
20
+ async resolve(projectPath, username) {
21
+ this.calls.push({ projectPath, username });
22
+ if (this.shouldFail) {
23
+ throw new Error('Membership lookup failed (stub)');
24
+ }
25
+ return this.accessByUsername.get(username) ?? null;
26
+ }
27
+ }
28
+ //# sourceMappingURL=memberAccess.stub.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memberAccess.stub.js","sourceRoot":"","sources":["../../../src/tests/stubs/memberAccess.stub.ts"],"names":[],"mappings":"AAQA;;;;;;;;GAQG;AACH,MAAM,OAAO,uBAAuB;IAClB,KAAK,GAA8B,EAAE,CAAC;IAC9C,gBAAgB,GAAG,IAAI,GAAG,EAA+B,CAAC;IAC1D,UAAU,GAAG,KAAK,CAAC;IAE3B,SAAS,CAAC,QAAgB,EAAE,WAAgC;QAC1D,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;IACnD,CAAC;IAED,aAAa,CAAC,UAAmB;QAC/B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,WAAmB,EAAE,QAAgB;QACjD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC3C,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QACD,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC;IACrD,CAAC;CACF"}
@@ -4,7 +4,6 @@ import { join } from 'node:path';
4
4
  const SRC_ROOT = join(process.cwd(), 'src');
5
5
  const ALLOWED_PATHS = [
6
6
  'src/cli/parseCliArgs.ts',
7
- 'src/frameworks/claude/claudeInsightsInvoker.ts',
8
7
  'src/tests/units/architecture/noClaudePInProduction.test.ts',
9
8
  ];
10
9
  // Files allowed to mention StreamJsonParser / ProgressParser by name. Both
@@ -1 +1 @@
1
- {"version":3,"file":"noClaudePInProduction.test.js","sourceRoot":"","sources":["../../../../src/tests/units/architecture/noClaudePInProduction.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"noClaudePInProduction.test.js","sourceRoot":"","sources":["../../../../src/tests/units/architecture/noClaudePInProduction.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=egressScan.scanner.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.scanner.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/egressScan/egressScan.scanner.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,136 @@
1
+ import { createEgressScanner } from '../../../../modules/platform-integration/entities/egressScan/egressScan.scanner.js';
2
+ const baseConfig = {
3
+ secretShapeMode: 'redact',
4
+ lengthMode: 'redact',
5
+ outOfScopeMode: 'redact',
6
+ maxBodyLength: 100,
7
+ redactionMarker: '[REDACTED]',
8
+ truncationMarker: '…[TRUNCATED]',
9
+ };
10
+ const SECRET = 'glpat-abcdefghij1234567890';
11
+ describe('createEgressScanner', () => {
12
+ describe('secret-shape scan (AC2)', () => {
13
+ it('passes a clean body unchanged in any mode', () => {
14
+ const scanner = createEgressScanner(baseConfig);
15
+ const result = scanner.scan({
16
+ body: 'Looks good to me, nicely done.',
17
+ channel: 'postComment',
18
+ projectPath: 'group/project',
19
+ });
20
+ expect(result.decision).toBe('pass');
21
+ if (result.decision === 'pass') {
22
+ expect(result.body).toBe('Looks good to me, nicely done.');
23
+ }
24
+ });
25
+ it('redacts a secret shape with the fixed marker in redact mode', () => {
26
+ const scanner = createEgressScanner(baseConfig);
27
+ const result = scanner.scan({
28
+ body: `token is ${SECRET} here`,
29
+ channel: 'postComment',
30
+ projectPath: 'group/project',
31
+ });
32
+ expect(result.decision).toBe('redact');
33
+ if (result.decision === 'redact') {
34
+ expect(result.body).toBe('token is [REDACTED] here');
35
+ expect(result.body).not.toContain(SECRET);
36
+ expect(result.trace.matchCategoryCounts['secret-shape']).toBe(1);
37
+ }
38
+ });
39
+ it('blocks a secret shape in block mode and emits no body', () => {
40
+ const scanner = createEgressScanner({ ...baseConfig, secretShapeMode: 'block' });
41
+ const result = scanner.scan({
42
+ body: `token is ${SECRET} here`,
43
+ channel: 'postComment',
44
+ projectPath: 'group/project',
45
+ });
46
+ expect(result.decision).toBe('block');
47
+ if (result.decision === 'block') {
48
+ expect(result.trace.matchCategoryCounts['secret-shape']).toBe(1);
49
+ }
50
+ });
51
+ it('passes a secret shape untouched in allow mode', () => {
52
+ const scanner = createEgressScanner({ ...baseConfig, secretShapeMode: 'allow' });
53
+ const result = scanner.scan({
54
+ body: `token is ${SECRET} here`,
55
+ channel: 'postComment',
56
+ projectPath: 'group/project',
57
+ });
58
+ expect(result.decision).toBe('pass');
59
+ });
60
+ });
61
+ describe('length cap (AC3)', () => {
62
+ it('truncates a body over the cap with the truncation marker in redact mode', () => {
63
+ const scanner = createEgressScanner({ ...baseConfig, maxBodyLength: 20 });
64
+ const result = scanner.scan({
65
+ body: 'x'.repeat(100),
66
+ channel: 'postComment',
67
+ projectPath: 'group/project',
68
+ });
69
+ expect(result.decision).toBe('redact');
70
+ if (result.decision === 'redact') {
71
+ expect(result.body.length).toBeLessThanOrEqual(20);
72
+ expect(result.body.endsWith('…[TRUNCATED]')).toBe(true);
73
+ expect(result.trace.matchCategoryCounts['length-cap']).toBe(1);
74
+ }
75
+ });
76
+ it('blocks a body over the cap in block mode', () => {
77
+ const scanner = createEgressScanner({ ...baseConfig, lengthMode: 'block', maxBodyLength: 20 });
78
+ const result = scanner.scan({
79
+ body: 'x'.repeat(100),
80
+ channel: 'postComment',
81
+ projectPath: 'group/project',
82
+ });
83
+ expect(result.decision).toBe('block');
84
+ });
85
+ });
86
+ describe('out-of-scope reference scan (AC4)', () => {
87
+ it('passes an in-scope project reference', () => {
88
+ const scanner = createEgressScanner(baseConfig);
89
+ const result = scanner.scan({
90
+ body: 'See group/project/src/index.ts for details',
91
+ channel: 'postComment',
92
+ projectPath: 'group/project',
93
+ });
94
+ expect(result.decision).toBe('pass');
95
+ });
96
+ it('redacts a foreign project reference in redact mode', () => {
97
+ const scanner = createEgressScanner(baseConfig);
98
+ const result = scanner.scan({
99
+ body: 'Compare with foreign/secret-repo internals',
100
+ channel: 'postComment',
101
+ projectPath: 'group/project',
102
+ });
103
+ expect(result.decision).toBe('redact');
104
+ if (result.decision === 'redact') {
105
+ expect(result.body).not.toContain('foreign/secret-repo');
106
+ expect(result.trace.matchCategoryCounts['out-of-scope']).toBe(1);
107
+ }
108
+ });
109
+ it('blocks a foreign project reference in block mode', () => {
110
+ const scanner = createEgressScanner({ ...baseConfig, outOfScopeMode: 'block' });
111
+ const result = scanner.scan({
112
+ body: 'Compare with foreign/secret-repo internals',
113
+ channel: 'postComment',
114
+ projectPath: 'group/project',
115
+ });
116
+ expect(result.decision).toBe('block');
117
+ });
118
+ });
119
+ describe('trace metadata carries no secret (AC6)', () => {
120
+ it('never embeds the matched secret value in the trace', () => {
121
+ const scanner = createEgressScanner(baseConfig);
122
+ const result = scanner.scan({
123
+ body: `token ${SECRET}`,
124
+ channel: 'THREAD_REPLY',
125
+ projectPath: 'group/project',
126
+ });
127
+ expect(result.decision).toBe('redact');
128
+ if (result.decision === 'redact') {
129
+ expect(JSON.stringify(result.trace)).not.toContain(SECRET);
130
+ expect(result.trace.channel).toBe('THREAD_REPLY');
131
+ expect(result.trace.mode).toBe('redact');
132
+ }
133
+ });
134
+ });
135
+ });
136
+ //# sourceMappingURL=egressScan.scanner.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"egressScan.scanner.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/egressScan/egressScan.scanner.test.ts"],"names":[],"mappings":"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"}
@@ -7,6 +7,8 @@ import { InMemoryReviewFileGateway } from '../../../../../tests/stubs/reviewFile
7
7
  import { InMemoryReviewRequestTrackingGateway } from '../../../../../tests/stubs/reviewRequestTracking.stub.js';
8
8
  import { createStubLogger } from '../../../../../tests/stubs/logger.stub.js';
9
9
  import { ProjectStatsFactory, ReviewStatsFactory } from '../../../../../tests/factories/projectStats.factory.js';
10
+ import { StubAiInsightsSessionGateway } from '../../../../../tests/stubs/aiInsightsSession.stub.js';
11
+ import { StubEnvironmentGateway } from '../../../../../tests/stubs/environment.stub.js';
10
12
  const validAiResult = {
11
13
  developers: [
12
14
  {
@@ -28,9 +30,6 @@ const validAiResult = {
28
30
  },
29
31
  generatedAt: '2026-03-15T10:00:00Z',
30
32
  };
31
- function createSuccessfulClaudeInvoker() {
32
- return async () => JSON.stringify(validAiResult);
33
- }
34
33
  describe('insights routes', () => {
35
34
  let app;
36
35
  let statsGateway;
@@ -43,13 +42,16 @@ describe('insights routes', () => {
43
42
  insightsGateway = new InMemoryInsightsGateway();
44
43
  reviewFileGateway = new InMemoryReviewFileGateway();
45
44
  reviewRequestTrackingGateway = new InMemoryReviewRequestTrackingGateway();
45
+ const session = new StubAiInsightsSessionGateway();
46
+ session.setResult({ status: 'completed', answer: JSON.stringify(validAiResult) });
46
47
  await app.register(insightsRoutes, {
47
48
  statsGateway,
48
49
  insightsGateway,
49
50
  reviewFileGateway,
50
51
  reviewRequestTrackingGateway,
51
52
  logger: createStubLogger(),
52
- claudeInvoker: createSuccessfulClaudeInvoker(),
53
+ session,
54
+ environment: new StubEnvironmentGateway(),
53
55
  language: 'fr',
54
56
  });
55
57
  await app.ready();