reviewflow 3.6.0 → 3.8.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 (598) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/dist/config/projectConfig.d.ts +2 -0
  3. package/dist/config/projectConfig.d.ts.map +1 -1
  4. package/dist/config/projectConfig.js +17 -0
  5. package/dist/config/projectConfig.js.map +1 -1
  6. package/dist/entities/backfill/backfillProgress.d.ts +7 -0
  7. package/dist/entities/backfill/backfillProgress.d.ts.map +1 -0
  8. package/dist/entities/backfill/backfillProgress.js +2 -0
  9. package/dist/entities/backfill/backfillProgress.js.map +1 -0
  10. package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts +8 -0
  11. package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts.map +1 -0
  12. package/dist/entities/cleanup/retentionPolicy.valueObject.js +21 -0
  13. package/dist/entities/cleanup/retentionPolicy.valueObject.js.map +1 -0
  14. package/dist/entities/diffStats/diffStats.d.ts +6 -0
  15. package/dist/entities/diffStats/diffStats.d.ts.map +1 -0
  16. package/dist/entities/diffStats/diffStats.js +2 -0
  17. package/dist/entities/diffStats/diffStats.js.map +1 -0
  18. package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts +5 -0
  19. package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts.map +1 -0
  20. package/dist/entities/diffStats/diffStatsFetch.gateway.js +2 -0
  21. package/dist/entities/diffStats/diffStatsFetch.gateway.js.map +1 -0
  22. package/dist/entities/insight/aiInsight.d.ts +6 -0
  23. package/dist/entities/insight/aiInsight.d.ts.map +1 -0
  24. package/dist/entities/insight/aiInsight.js +2 -0
  25. package/dist/entities/insight/aiInsight.js.map +1 -0
  26. package/dist/entities/insight/aiInsight.schema.d.ts +55 -0
  27. package/dist/entities/insight/aiInsight.schema.d.ts.map +1 -0
  28. package/dist/entities/insight/aiInsight.schema.js +25 -0
  29. package/dist/entities/insight/aiInsight.schema.js.map +1 -0
  30. package/dist/entities/insight/developerInsight.d.ts +8 -0
  31. package/dist/entities/insight/developerInsight.d.ts.map +1 -0
  32. package/dist/entities/insight/developerInsight.guard.d.ts +221 -0
  33. package/dist/entities/insight/developerInsight.guard.d.ts.map +1 -0
  34. package/dist/entities/insight/developerInsight.guard.js +13 -0
  35. package/dist/entities/insight/developerInsight.guard.js.map +1 -0
  36. package/dist/entities/insight/developerInsight.js +2 -0
  37. package/dist/entities/insight/developerInsight.js.map +1 -0
  38. package/dist/entities/insight/developerInsight.schema.d.ts +157 -0
  39. package/dist/entities/insight/developerInsight.schema.d.ts.map +1 -0
  40. package/dist/entities/insight/developerInsight.schema.js +43 -0
  41. package/dist/entities/insight/developerInsight.schema.js.map +1 -0
  42. package/dist/entities/insight/developerTitle.d.ts +12 -0
  43. package/dist/entities/insight/developerTitle.d.ts.map +1 -0
  44. package/dist/entities/insight/developerTitle.js +11 -0
  45. package/dist/entities/insight/developerTitle.js.map +1 -0
  46. package/dist/entities/insight/insightCategory.d.ts +10 -0
  47. package/dist/entities/insight/insightCategory.d.ts.map +1 -0
  48. package/dist/entities/insight/insightCategory.js +4 -0
  49. package/dist/entities/insight/insightCategory.js.map +1 -0
  50. package/dist/entities/insight/insightTrend.d.ts +9 -0
  51. package/dist/entities/insight/insightTrend.d.ts.map +1 -0
  52. package/dist/entities/insight/insightTrend.js +4 -0
  53. package/dist/entities/insight/insightTrend.js.map +1 -0
  54. package/dist/entities/insight/insights.gateway.d.ts +6 -0
  55. package/dist/entities/insight/insights.gateway.d.ts.map +1 -0
  56. package/dist/entities/insight/insights.gateway.js +2 -0
  57. package/dist/entities/insight/insights.gateway.js.map +1 -0
  58. package/dist/entities/insight/persistedInsightsData.d.ts +5 -0
  59. package/dist/entities/insight/persistedInsightsData.d.ts.map +1 -0
  60. package/dist/entities/insight/persistedInsightsData.guard.d.ts +271 -0
  61. package/dist/entities/insight/persistedInsightsData.guard.d.ts.map +1 -0
  62. package/dist/entities/insight/persistedInsightsData.guard.js +13 -0
  63. package/dist/entities/insight/persistedInsightsData.guard.js.map +1 -0
  64. package/dist/entities/insight/persistedInsightsData.js +2 -0
  65. package/dist/entities/insight/persistedInsightsData.js.map +1 -0
  66. package/dist/entities/insight/persistedInsightsData.schema.d.ts +84 -0
  67. package/dist/entities/insight/persistedInsightsData.schema.d.ts.map +1 -0
  68. package/dist/entities/insight/persistedInsightsData.schema.js +40 -0
  69. package/dist/entities/insight/persistedInsightsData.schema.js.map +1 -0
  70. package/dist/entities/insight/teamInsight.d.ts +5 -0
  71. package/dist/entities/insight/teamInsight.d.ts.map +1 -0
  72. package/dist/entities/insight/teamInsight.guard.d.ts +71 -0
  73. package/dist/entities/insight/teamInsight.guard.d.ts.map +1 -0
  74. package/dist/entities/insight/teamInsight.guard.js +13 -0
  75. package/dist/entities/insight/teamInsight.guard.js.map +1 -0
  76. package/dist/entities/insight/teamInsight.js +2 -0
  77. package/dist/entities/insight/teamInsight.js.map +1 -0
  78. package/dist/entities/insight/teamInsight.schema.d.ts +31 -0
  79. package/dist/entities/insight/teamInsight.schema.d.ts.map +1 -0
  80. package/dist/entities/insight/teamInsight.schema.js +17 -0
  81. package/dist/entities/insight/teamInsight.schema.js.map +1 -0
  82. package/dist/entities/packageVersion/packageVersion.d.ts +21 -0
  83. package/dist/entities/packageVersion/packageVersion.d.ts.map +1 -0
  84. package/dist/entities/packageVersion/packageVersion.gateway.d.ts +4 -0
  85. package/dist/entities/packageVersion/packageVersion.gateway.d.ts.map +1 -0
  86. package/dist/entities/packageVersion/packageVersion.gateway.js +2 -0
  87. package/dist/entities/packageVersion/packageVersion.gateway.js.map +1 -0
  88. package/dist/entities/packageVersion/packageVersion.guard.d.ts +7 -0
  89. package/dist/entities/packageVersion/packageVersion.guard.d.ts.map +1 -0
  90. package/dist/entities/packageVersion/packageVersion.guard.js +13 -0
  91. package/dist/entities/packageVersion/packageVersion.guard.js.map +1 -0
  92. package/dist/entities/packageVersion/packageVersion.js +2 -0
  93. package/dist/entities/packageVersion/packageVersion.js.map +1 -0
  94. package/dist/entities/packageVersion/packageVersion.schema.d.ts +12 -0
  95. package/dist/entities/packageVersion/packageVersion.schema.d.ts.map +1 -0
  96. package/dist/entities/packageVersion/packageVersion.schema.js +11 -0
  97. package/dist/entities/packageVersion/packageVersion.schema.js.map +1 -0
  98. package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts +9 -0
  99. package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts.map +1 -0
  100. package/dist/entities/packageVersion/selfUpdateCommand.gateway.js +2 -0
  101. package/dist/entities/packageVersion/selfUpdateCommand.gateway.js.map +1 -0
  102. package/dist/entities/packageVersion/versionCache.gateway.d.ts +7 -0
  103. package/dist/entities/packageVersion/versionCache.gateway.d.ts.map +1 -0
  104. package/dist/entities/packageVersion/versionCache.gateway.js +2 -0
  105. package/dist/entities/packageVersion/versionCache.gateway.js.map +1 -0
  106. package/dist/entities/review/reviewFile.gateway.d.ts +18 -0
  107. package/dist/entities/review/reviewFile.gateway.d.ts.map +1 -0
  108. package/dist/entities/review/reviewFile.gateway.js +2 -0
  109. package/dist/entities/review/reviewFile.gateway.js.map +1 -0
  110. package/dist/entities/stats/projectStats.d.ts +39 -0
  111. package/dist/entities/stats/projectStats.d.ts.map +1 -0
  112. package/dist/entities/stats/projectStats.js +2 -0
  113. package/dist/entities/stats/projectStats.js.map +1 -0
  114. package/dist/entities/stats/recalculateBody.guard.d.ts +11 -0
  115. package/dist/entities/stats/recalculateBody.guard.d.ts.map +1 -0
  116. package/dist/entities/stats/recalculateBody.guard.js +9 -0
  117. package/dist/entities/stats/recalculateBody.guard.js.map +1 -0
  118. package/dist/entities/stats/stats.gateway.d.ts +7 -0
  119. package/dist/entities/stats/stats.gateway.d.ts.map +1 -0
  120. package/dist/entities/stats/stats.gateway.js +2 -0
  121. package/dist/entities/stats/stats.gateway.js.map +1 -0
  122. package/dist/entities/tracking/reviewEvent.d.ts +2 -0
  123. package/dist/entities/tracking/reviewEvent.d.ts.map +1 -1
  124. package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts +19 -0
  125. package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts.map +1 -0
  126. package/dist/entities/tracking/reviewRequestTracking.gateway.js +2 -0
  127. package/dist/entities/tracking/reviewRequestTracking.gateway.js.map +1 -0
  128. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts +3 -0
  129. package/dist/frameworks/claude/claudeInsightsInvoker.d.ts.map +1 -0
  130. package/dist/frameworks/claude/claudeInsightsInvoker.js +58 -0
  131. package/dist/frameworks/claude/claudeInsightsInvoker.js.map +1 -0
  132. package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
  133. package/dist/frameworks/claude/claudeInvoker.js +15 -1
  134. package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
  135. package/dist/frameworks/scheduler/cleanupScheduler.d.ts +16 -0
  136. package/dist/frameworks/scheduler/cleanupScheduler.d.ts.map +1 -0
  137. package/dist/frameworks/scheduler/cleanupScheduler.js +35 -0
  138. package/dist/frameworks/scheduler/cleanupScheduler.js.map +1 -0
  139. package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts +16 -0
  140. package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts.map +1 -0
  141. package/dist/interface-adapters/controllers/http/cleanup.routes.js +44 -0
  142. package/dist/interface-adapters/controllers/http/cleanup.routes.js.map +1 -0
  143. package/dist/interface-adapters/controllers/http/health.routes.d.ts +3 -1
  144. package/dist/interface-adapters/controllers/http/health.routes.d.ts.map +1 -1
  145. package/dist/interface-adapters/controllers/http/health.routes.js +5 -1
  146. package/dist/interface-adapters/controllers/http/health.routes.js.map +1 -1
  147. package/dist/interface-adapters/controllers/http/insights.routes.d.ts +20 -0
  148. package/dist/interface-adapters/controllers/http/insights.routes.d.ts.map +1 -0
  149. package/dist/interface-adapters/controllers/http/insights.routes.js +73 -0
  150. package/dist/interface-adapters/controllers/http/insights.routes.js.map +1 -0
  151. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts.map +1 -1
  152. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js +13 -2
  153. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js.map +1 -1
  154. package/dist/interface-adapters/controllers/http/settings.routes.d.ts.map +1 -1
  155. package/dist/interface-adapters/controllers/http/settings.routes.js +3 -0
  156. package/dist/interface-adapters/controllers/http/settings.routes.js.map +1 -1
  157. package/dist/interface-adapters/controllers/http/stats.routes.d.ts +20 -6
  158. package/dist/interface-adapters/controllers/http/stats.routes.d.ts.map +1 -1
  159. package/dist/interface-adapters/controllers/http/stats.routes.js +35 -2
  160. package/dist/interface-adapters/controllers/http/stats.routes.js.map +1 -1
  161. package/dist/interface-adapters/controllers/http/version.routes.d.ts +19 -0
  162. package/dist/interface-adapters/controllers/http/version.routes.d.ts.map +1 -0
  163. package/dist/interface-adapters/controllers/http/version.routes.js +21 -0
  164. package/dist/interface-adapters/controllers/http/version.routes.js.map +1 -0
  165. package/dist/interface-adapters/controllers/webhook/github.controller.d.ts +2 -0
  166. package/dist/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
  167. package/dist/interface-adapters/controllers/webhook/github.controller.js +9 -3
  168. package/dist/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
  169. package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts +2 -0
  170. package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
  171. package/dist/interface-adapters/controllers/webhook/gitlab.controller.js +17 -5
  172. package/dist/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
  173. package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts +10 -0
  174. package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts.map +1 -0
  175. package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js +26 -0
  176. package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js.map +1 -0
  177. package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts +10 -0
  178. package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts.map +1 -0
  179. package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js +28 -0
  180. package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js.map +1 -0
  181. package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts +7 -0
  182. package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts.map +1 -0
  183. package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js +33 -0
  184. package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js.map +1 -0
  185. package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts +7 -0
  186. package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts.map +1 -0
  187. package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js +47 -0
  188. package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js.map +1 -0
  189. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts +2 -2
  190. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts.map +1 -1
  191. package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts +7 -0
  192. package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts.map +1 -0
  193. package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js +25 -0
  194. package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js.map +1 -0
  195. package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts +1 -17
  196. package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -1
  197. package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts +12 -0
  198. package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts.map +1 -0
  199. package/dist/interface-adapters/gateways/reviewLogFile.gateway.js +2 -0
  200. package/dist/interface-adapters/gateways/reviewLogFile.gateway.js.map +1 -0
  201. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts +1 -18
  202. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts.map +1 -1
  203. package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts +20 -0
  204. package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts.map +1 -0
  205. package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js +58 -0
  206. package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js.map +1 -0
  207. package/dist/interface-adapters/gateways/stats.gateway.d.ts +1 -6
  208. package/dist/interface-adapters/gateways/stats.gateway.d.ts.map +1 -1
  209. package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts +12 -0
  210. package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts.map +1 -0
  211. package/dist/interface-adapters/gateways/versionCache.memory.gateway.js +22 -0
  212. package/dist/interface-adapters/gateways/versionCache.memory.gateway.js.map +1 -0
  213. package/dist/interface-adapters/presenters/insights.presenter.d.ts +41 -0
  214. package/dist/interface-adapters/presenters/insights.presenter.d.ts.map +1 -0
  215. package/dist/interface-adapters/presenters/insights.presenter.js +36 -0
  216. package/dist/interface-adapters/presenters/insights.presenter.js.map +1 -0
  217. package/dist/interface-adapters/views/dashboard/index.html +599 -40
  218. package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts +10 -0
  219. package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts.map +1 -0
  220. package/dist/interface-adapters/views/dashboard/modules/cleanup.js +45 -0
  221. package/dist/interface-adapters/views/dashboard/modules/cleanup.js.map +1 -0
  222. package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts +13 -0
  223. package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts.map +1 -0
  224. package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js +71 -0
  225. package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js.map +1 -0
  226. package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts +14 -0
  227. package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts.map +1 -0
  228. package/dist/interface-adapters/views/dashboard/modules/developerSheet.js +359 -0
  229. package/dist/interface-adapters/views/dashboard/modules/developerSheet.js.map +1 -0
  230. package/dist/interface-adapters/views/dashboard/modules/i18n.d.ts.map +1 -1
  231. package/dist/interface-adapters/views/dashboard/modules/i18n.js +296 -0
  232. package/dist/interface-adapters/views/dashboard/modules/i18n.js.map +1 -1
  233. package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts +7 -0
  234. package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts.map +1 -0
  235. package/dist/interface-adapters/views/dashboard/modules/insightsReport.js +509 -0
  236. package/dist/interface-adapters/views/dashboard/modules/insightsReport.js.map +1 -0
  237. package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts +25 -0
  238. package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts.map +1 -0
  239. package/dist/interface-adapters/views/dashboard/modules/mrSheet.js +414 -0
  240. package/dist/interface-adapters/views/dashboard/modules/mrSheet.js.map +1 -0
  241. package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts +40 -0
  242. package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts.map +1 -0
  243. package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js +106 -0
  244. package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js.map +1 -0
  245. package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts +35 -0
  246. package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts.map +1 -0
  247. package/dist/interface-adapters/views/dashboard/modules/statsCharts.js +476 -0
  248. package/dist/interface-adapters/views/dashboard/modules/statsCharts.js.map +1 -0
  249. package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts +13 -0
  250. package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts.map +1 -0
  251. package/dist/interface-adapters/views/dashboard/modules/teamTab.js +296 -0
  252. package/dist/interface-adapters/views/dashboard/modules/teamTab.js.map +1 -0
  253. package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts +16 -0
  254. package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts.map +1 -0
  255. package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js +54 -0
  256. package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js.map +1 -0
  257. package/dist/interface-adapters/views/dashboard/styles.css +1906 -0
  258. package/dist/main/dependencies.d.ts +4 -0
  259. package/dist/main/dependencies.d.ts.map +1 -1
  260. package/dist/main/dependencies.js +4 -0
  261. package/dist/main/dependencies.js.map +1 -1
  262. package/dist/main/routes.d.ts.map +1 -1
  263. package/dist/main/routes.js +68 -2
  264. package/dist/main/routes.js.map +1 -1
  265. package/dist/main/server.d.ts.map +1 -1
  266. package/dist/main/server.js +8 -0
  267. package/dist/main/server.js.map +1 -1
  268. package/dist/main/websocket.d.ts +2 -0
  269. package/dist/main/websocket.d.ts.map +1 -1
  270. package/dist/main/websocket.js +13 -0
  271. package/dist/main/websocket.js.map +1 -1
  272. package/dist/services/statsService.d.ts +8 -32
  273. package/dist/services/statsService.d.ts.map +1 -1
  274. package/dist/services/statsService.js +60 -36
  275. package/dist/services/statsService.js.map +1 -1
  276. package/dist/shared/foundation/commandExecutor.d.ts +2 -0
  277. package/dist/shared/foundation/commandExecutor.d.ts.map +1 -0
  278. package/dist/shared/foundation/commandExecutor.js +2 -0
  279. package/dist/shared/foundation/commandExecutor.js.map +1 -0
  280. package/dist/tests/factories/developerInsight.factory.d.ts +6 -0
  281. package/dist/tests/factories/developerInsight.factory.d.ts.map +1 -0
  282. package/dist/tests/factories/developerInsight.factory.js +61 -0
  283. package/dist/tests/factories/developerInsight.factory.js.map +1 -0
  284. package/dist/tests/factories/diffStats.factory.d.ts +5 -0
  285. package/dist/tests/factories/diffStats.factory.d.ts.map +1 -0
  286. package/dist/tests/factories/diffStats.factory.js +11 -0
  287. package/dist/tests/factories/diffStats.factory.js.map +1 -0
  288. package/dist/tests/factories/packageVersion.factory.d.ts +7 -0
  289. package/dist/tests/factories/packageVersion.factory.d.ts.map +1 -0
  290. package/dist/tests/factories/packageVersion.factory.js +18 -0
  291. package/dist/tests/factories/packageVersion.factory.js.map +1 -0
  292. package/dist/tests/factories/persistedInsightsData.factory.d.ts +11 -0
  293. package/dist/tests/factories/persistedInsightsData.factory.d.ts.map +1 -0
  294. package/dist/tests/factories/persistedInsightsData.factory.js +41 -0
  295. package/dist/tests/factories/persistedInsightsData.factory.js.map +1 -0
  296. package/dist/tests/factories/projectStats.factory.d.ts +3 -1
  297. package/dist/tests/factories/projectStats.factory.d.ts.map +1 -1
  298. package/dist/tests/factories/projectStats.factory.js +17 -3
  299. package/dist/tests/factories/projectStats.factory.js.map +1 -1
  300. package/dist/tests/factories/teamInsight.factory.d.ts +6 -0
  301. package/dist/tests/factories/teamInsight.factory.d.ts.map +1 -0
  302. package/dist/tests/factories/teamInsight.factory.js +35 -0
  303. package/dist/tests/factories/teamInsight.factory.js.map +1 -0
  304. package/dist/tests/stubs/diffStatsFetch.stub.d.ts +11 -0
  305. package/dist/tests/stubs/diffStatsFetch.stub.d.ts.map +1 -0
  306. package/dist/tests/stubs/diffStatsFetch.stub.js +19 -0
  307. package/dist/tests/stubs/diffStatsFetch.stub.js.map +1 -0
  308. package/dist/tests/stubs/insights.stub.d.ts +9 -0
  309. package/dist/tests/stubs/insights.stub.d.ts.map +1 -0
  310. package/dist/tests/stubs/insights.stub.js +13 -0
  311. package/dist/tests/stubs/insights.stub.js.map +1 -0
  312. package/dist/tests/stubs/packageVersion.stub.d.ts +7 -0
  313. package/dist/tests/stubs/packageVersion.stub.d.ts.map +1 -0
  314. package/dist/tests/stubs/packageVersion.stub.js +10 -0
  315. package/dist/tests/stubs/packageVersion.stub.js.map +1 -0
  316. package/dist/tests/stubs/reviewFile.stub.d.ts +1 -1
  317. package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -1
  318. package/dist/tests/stubs/reviewLogFile.stub.d.ts +15 -0
  319. package/dist/tests/stubs/reviewLogFile.stub.d.ts.map +1 -0
  320. package/dist/tests/stubs/reviewLogFile.stub.js +35 -0
  321. package/dist/tests/stubs/reviewLogFile.stub.js.map +1 -0
  322. package/dist/tests/stubs/reviewRequestTracking.stub.d.ts +1 -1
  323. package/dist/tests/stubs/reviewRequestTracking.stub.d.ts.map +1 -1
  324. package/dist/tests/stubs/selfUpdate.stub.d.ts +14 -0
  325. package/dist/tests/stubs/selfUpdate.stub.d.ts.map +1 -0
  326. package/dist/tests/stubs/selfUpdate.stub.js +20 -0
  327. package/dist/tests/stubs/selfUpdate.stub.js.map +1 -0
  328. package/dist/tests/stubs/stats.stub.d.ts +2 -2
  329. package/dist/tests/stubs/stats.stub.d.ts.map +1 -1
  330. package/dist/tests/stubs/versionCache.stub.d.ts +11 -0
  331. package/dist/tests/stubs/versionCache.stub.d.ts.map +1 -0
  332. package/dist/tests/stubs/versionCache.stub.js +18 -0
  333. package/dist/tests/stubs/versionCache.stub.js.map +1 -0
  334. package/dist/tests/units/config/projectConfig.test.js +60 -1
  335. package/dist/tests/units/config/projectConfig.test.js.map +1 -1
  336. package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts +2 -0
  337. package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts.map +1 -0
  338. package/dist/tests/units/entities/backfill/backfillProgress.test.js +40 -0
  339. package/dist/tests/units/entities/backfill/backfillProgress.test.js.map +1 -0
  340. package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts +2 -0
  341. package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts.map +1 -0
  342. package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js +47 -0
  343. package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js.map +1 -0
  344. package/dist/tests/units/entities/diffStats/diffStats.test.d.ts +2 -0
  345. package/dist/tests/units/entities/diffStats/diffStats.test.d.ts.map +1 -0
  346. package/dist/tests/units/entities/diffStats/diffStats.test.js +27 -0
  347. package/dist/tests/units/entities/diffStats/diffStats.test.js.map +1 -0
  348. package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts +2 -0
  349. package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts.map +1 -0
  350. package/dist/tests/units/entities/insight/aiInsight.schema.test.js +123 -0
  351. package/dist/tests/units/entities/insight/aiInsight.schema.test.js.map +1 -0
  352. package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts +2 -0
  353. package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts.map +1 -0
  354. package/dist/tests/units/entities/insight/developerInsight.schema.test.js +140 -0
  355. package/dist/tests/units/entities/insight/developerInsight.schema.test.js.map +1 -0
  356. package/dist/tests/units/entities/insight/developerTitle.test.d.ts +2 -0
  357. package/dist/tests/units/entities/insight/developerTitle.test.d.ts.map +1 -0
  358. package/dist/tests/units/entities/insight/developerTitle.test.js +23 -0
  359. package/dist/tests/units/entities/insight/developerTitle.test.js.map +1 -0
  360. package/dist/tests/units/entities/insight/insightCategory.test.d.ts +2 -0
  361. package/dist/tests/units/entities/insight/insightCategory.test.d.ts.map +1 -0
  362. package/dist/tests/units/entities/insight/insightCategory.test.js +16 -0
  363. package/dist/tests/units/entities/insight/insightCategory.test.js.map +1 -0
  364. package/dist/tests/units/entities/insight/insightTrend.test.d.ts +2 -0
  365. package/dist/tests/units/entities/insight/insightTrend.test.d.ts.map +1 -0
  366. package/dist/tests/units/entities/insight/insightTrend.test.js +16 -0
  367. package/dist/tests/units/entities/insight/insightTrend.test.js.map +1 -0
  368. package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts +2 -0
  369. package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts.map +1 -0
  370. package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js +160 -0
  371. package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js.map +1 -0
  372. package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts +2 -0
  373. package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts.map +1 -0
  374. package/dist/tests/units/entities/insight/teamInsight.schema.test.js +57 -0
  375. package/dist/tests/units/entities/insight/teamInsight.schema.test.js.map +1 -0
  376. package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts +2 -0
  377. package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts.map +1 -0
  378. package/dist/tests/units/entities/packageVersion/packageVersion.test.js +154 -0
  379. package/dist/tests/units/entities/packageVersion/packageVersion.test.js.map +1 -0
  380. package/dist/tests/units/factories/packageVersion.factory.test.d.ts +2 -0
  381. package/dist/tests/units/factories/packageVersion.factory.test.d.ts.map +1 -0
  382. package/dist/tests/units/factories/packageVersion.factory.test.js +37 -0
  383. package/dist/tests/units/factories/packageVersion.factory.test.js.map +1 -0
  384. package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts +2 -0
  385. package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts.map +1 -0
  386. package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js +74 -0
  387. package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js.map +1 -0
  388. package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts +2 -0
  389. package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts.map +1 -0
  390. package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js +62 -0
  391. package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js.map +1 -0
  392. package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts +2 -0
  393. package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts.map +1 -0
  394. package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js +96 -0
  395. package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js.map +1 -0
  396. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts +2 -0
  397. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts.map +1 -0
  398. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js +390 -0
  399. package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js.map +1 -0
  400. package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts +2 -0
  401. package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts.map +1 -0
  402. package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js +25 -0
  403. package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js.map +1 -0
  404. package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts +2 -0
  405. package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts.map +1 -0
  406. package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js +82 -0
  407. package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js.map +1 -0
  408. package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts +2 -0
  409. package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts.map +1 -0
  410. package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js +108 -0
  411. package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js.map +1 -0
  412. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +3 -0
  413. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -1
  414. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +1 -0
  415. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
  416. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts +2 -0
  417. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts.map +1 -0
  418. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js +63 -0
  419. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js.map +1 -0
  420. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts +2 -0
  421. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts.map +1 -0
  422. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js +94 -0
  423. package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js.map +1 -0
  424. package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts +2 -0
  425. package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts.map +1 -0
  426. package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js +117 -0
  427. package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js.map +1 -0
  428. package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts +2 -0
  429. package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts.map +1 -0
  430. package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js +42 -0
  431. package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js.map +1 -0
  432. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts +2 -0
  433. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts.map +1 -0
  434. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js +65 -0
  435. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js.map +1 -0
  436. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts +2 -0
  437. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts.map +1 -0
  438. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js +63 -0
  439. package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js.map +1 -0
  440. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js +2 -0
  441. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js.map +1 -1
  442. package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts +2 -0
  443. package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts.map +1 -0
  444. package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js +101 -0
  445. package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js.map +1 -0
  446. package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts +2 -0
  447. package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts.map +1 -0
  448. package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js +38 -0
  449. package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js.map +1 -0
  450. package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts +2 -0
  451. package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts.map +1 -0
  452. package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js +194 -0
  453. package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js.map +1 -0
  454. package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts +2 -0
  455. package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts.map +1 -0
  456. package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js +224 -0
  457. package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js.map +1 -0
  458. package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js +29 -0
  459. package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js.map +1 -1
  460. package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts +2 -0
  461. package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts.map +1 -0
  462. package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js +326 -0
  463. package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js.map +1 -0
  464. package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts +2 -0
  465. package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts.map +1 -0
  466. package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js +336 -0
  467. package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js.map +1 -0
  468. package/dist/tests/units/services/statsService.addReview.test.d.ts +2 -0
  469. package/dist/tests/units/services/statsService.addReview.test.d.ts.map +1 -0
  470. package/dist/tests/units/services/statsService.addReview.test.js +103 -0
  471. package/dist/tests/units/services/statsService.addReview.test.js.map +1 -0
  472. package/dist/tests/units/services/statsService.diffStats.test.d.ts +2 -0
  473. package/dist/tests/units/services/statsService.diffStats.test.d.ts.map +1 -0
  474. package/dist/tests/units/services/statsService.diffStats.test.js +61 -0
  475. package/dist/tests/units/services/statsService.diffStats.test.js.map +1 -0
  476. package/dist/tests/units/stubs/packageVersion.stub.test.d.ts +2 -0
  477. package/dist/tests/units/stubs/packageVersion.stub.test.d.ts.map +1 -0
  478. package/dist/tests/units/stubs/packageVersion.stub.test.js +20 -0
  479. package/dist/tests/units/stubs/packageVersion.stub.test.js.map +1 -0
  480. package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts +2 -0
  481. package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts.map +1 -0
  482. package/dist/tests/units/stubs/selfUpdate.stub.test.js +30 -0
  483. package/dist/tests/units/stubs/selfUpdate.stub.test.js.map +1 -0
  484. package/dist/tests/units/stubs/versionCache.stub.test.d.ts +2 -0
  485. package/dist/tests/units/stubs/versionCache.stub.test.d.ts.map +1 -0
  486. package/dist/tests/units/stubs/versionCache.stub.test.js +34 -0
  487. package/dist/tests/units/stubs/versionCache.stub.test.js.map +1 -0
  488. package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts +2 -0
  489. package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts.map +1 -0
  490. package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js +83 -0
  491. package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js.map +1 -0
  492. package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts +2 -0
  493. package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts.map +1 -0
  494. package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js +172 -0
  495. package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js.map +1 -0
  496. package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts +2 -0
  497. package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts.map +1 -0
  498. package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js +449 -0
  499. package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js.map +1 -0
  500. package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts +2 -0
  501. package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts.map +1 -0
  502. package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js +326 -0
  503. package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js.map +1 -0
  504. package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts +2 -0
  505. package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts.map +1 -0
  506. package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js +172 -0
  507. package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js.map +1 -0
  508. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts +2 -0
  509. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts.map +1 -0
  510. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js +253 -0
  511. package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js.map +1 -0
  512. package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts +2 -0
  513. package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts.map +1 -0
  514. package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js +160 -0
  515. package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js.map +1 -0
  516. package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts +2 -0
  517. package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts.map +1 -0
  518. package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js +125 -0
  519. package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js.map +1 -0
  520. package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts +2 -0
  521. package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts.map +1 -0
  522. package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js +186 -0
  523. package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js.map +1 -0
  524. package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts +2 -0
  525. package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts.map +1 -0
  526. package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js +130 -0
  527. package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js.map +1 -0
  528. package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts +2 -0
  529. package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts.map +1 -0
  530. package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js +138 -0
  531. package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js.map +1 -0
  532. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js +31 -2
  533. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js.map +1 -1
  534. package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts +2 -0
  535. package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts.map +1 -0
  536. package/dist/tests/units/usecases/version/checkVersion.usecase.test.js +63 -0
  537. package/dist/tests/units/usecases/version/checkVersion.usecase.test.js.map +1 -0
  538. package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts +2 -0
  539. package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts.map +1 -0
  540. package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js +26 -0
  541. package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js.map +1 -0
  542. package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts +13 -0
  543. package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts.map +1 -0
  544. package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js +41 -0
  545. package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js.map +1 -0
  546. package/dist/usecases/insights/buildAiInsightsPrompt.d.ts +12 -0
  547. package/dist/usecases/insights/buildAiInsightsPrompt.d.ts.map +1 -0
  548. package/dist/usecases/insights/buildAiInsightsPrompt.js +220 -0
  549. package/dist/usecases/insights/buildAiInsightsPrompt.js.map +1 -0
  550. package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts +4 -0
  551. package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts.map +1 -0
  552. package/dist/usecases/insights/computeDeveloperInsights.usecase.js +226 -0
  553. package/dist/usecases/insights/computeDeveloperInsights.usecase.js.map +1 -0
  554. package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts +12 -0
  555. package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts.map +1 -0
  556. package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js +340 -0
  557. package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js.map +1 -0
  558. package/dist/usecases/insights/computeTeamInsights.usecase.d.ts +4 -0
  559. package/dist/usecases/insights/computeTeamInsights.usecase.d.ts.map +1 -0
  560. package/dist/usecases/insights/computeTeamInsights.usecase.js +111 -0
  561. package/dist/usecases/insights/computeTeamInsights.usecase.js.map +1 -0
  562. package/dist/usecases/insights/generateAiInsights.usecase.d.ts +27 -0
  563. package/dist/usecases/insights/generateAiInsights.usecase.d.ts.map +1 -0
  564. package/dist/usecases/insights/generateAiInsights.usecase.js +65 -0
  565. package/dist/usecases/insights/generateAiInsights.usecase.js.map +1 -0
  566. package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts +18 -0
  567. package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts.map +1 -0
  568. package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js +56 -0
  569. package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js.map +1 -0
  570. package/dist/usecases/insights/insightLevelComputation.service.d.ts +41 -0
  571. package/dist/usecases/insights/insightLevelComputation.service.d.ts.map +1 -0
  572. package/dist/usecases/insights/insightLevelComputation.service.js +313 -0
  573. package/dist/usecases/insights/insightLevelComputation.service.js.map +1 -0
  574. package/dist/usecases/stats/backfillDiffStats.usecase.d.ts +18 -0
  575. package/dist/usecases/stats/backfillDiffStats.usecase.d.ts.map +1 -0
  576. package/dist/usecases/stats/backfillDiffStats.usecase.js +43 -0
  577. package/dist/usecases/stats/backfillDiffStats.usecase.js.map +1 -0
  578. package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts +7 -0
  579. package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts.map +1 -0
  580. package/dist/usecases/stats/recalculateProjectStats.usecase.js +47 -0
  581. package/dist/usecases/stats/recalculateProjectStats.usecase.js.map +1 -0
  582. package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts +22 -0
  583. package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts.map +1 -0
  584. package/dist/usecases/stats/recalculateWithBackfill.usecase.js +33 -0
  585. package/dist/usecases/stats/recalculateWithBackfill.usecase.js.map +1 -0
  586. package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts +2 -0
  587. package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts.map +1 -1
  588. package/dist/usecases/tracking/recordReviewCompletion.usecase.js +1 -0
  589. package/dist/usecases/tracking/recordReviewCompletion.usecase.js.map +1 -1
  590. package/dist/usecases/version/checkVersion.usecase.d.ts +13 -0
  591. package/dist/usecases/version/checkVersion.usecase.d.ts.map +1 -0
  592. package/dist/usecases/version/checkVersion.usecase.js +20 -0
  593. package/dist/usecases/version/checkVersion.usecase.js.map +1 -0
  594. package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts +7 -0
  595. package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts.map +1 -0
  596. package/dist/usecases/version/triggerSelfUpdate.usecase.js +12 -0
  597. package/dist/usecases/version/triggerSelfUpdate.usecase.js.map +1 -0
  598. package/package.json +1 -1
@@ -0,0 +1,140 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { developerInsightSchema } from '../../../../entities/insight/developerInsight.schema.js';
3
+ import { DeveloperInsightFactory } from '../../../../tests/factories/developerInsight.factory.js';
4
+ describe('DeveloperInsight schema', () => {
5
+ it('should validate a complete developer insight', () => {
6
+ const insight = DeveloperInsightFactory.create();
7
+ const result = developerInsightSchema.safeParse(insight);
8
+ expect(result.success).toBe(true);
9
+ });
10
+ it('should require a developer name', () => {
11
+ const insight = DeveloperInsightFactory.create();
12
+ const { developerName: _, ...withoutName } = insight;
13
+ const result = developerInsightSchema.safeParse(withoutName);
14
+ expect(result.success).toBe(false);
15
+ });
16
+ it('should validate category levels are between 1 and 10', () => {
17
+ const insight = DeveloperInsightFactory.create({
18
+ categoryLevels: {
19
+ quality: { level: 11, trend: 'stable' },
20
+ responsiveness: { level: 5, trend: 'stable' },
21
+ codeVolume: { level: 5, trend: 'stable' },
22
+ iteration: { level: 5, trend: 'stable' },
23
+ },
24
+ });
25
+ const result = developerInsightSchema.safeParse(insight);
26
+ expect(result.success).toBe(false);
27
+ });
28
+ it('should validate category levels minimum is 1', () => {
29
+ const insight = DeveloperInsightFactory.create({
30
+ categoryLevels: {
31
+ quality: { level: 0, trend: 'stable' },
32
+ responsiveness: { level: 5, trend: 'stable' },
33
+ codeVolume: { level: 5, trend: 'stable' },
34
+ iteration: { level: 5, trend: 'stable' },
35
+ },
36
+ });
37
+ const result = developerInsightSchema.safeParse(insight);
38
+ expect(result.success).toBe(false);
39
+ });
40
+ it('should validate trend values', () => {
41
+ const insight = DeveloperInsightFactory.create({
42
+ categoryLevels: {
43
+ quality: { level: 5, trend: 'invalid' },
44
+ responsiveness: { level: 5, trend: 'stable' },
45
+ codeVolume: { level: 5, trend: 'stable' },
46
+ iteration: { level: 5, trend: 'stable' },
47
+ },
48
+ });
49
+ const result = developerInsightSchema.safeParse(insight);
50
+ expect(result.success).toBe(false);
51
+ });
52
+ it('should validate title is a known developer title', () => {
53
+ const insight = DeveloperInsightFactory.create({
54
+ title: 'unknown',
55
+ });
56
+ const result = developerInsightSchema.safeParse(insight);
57
+ expect(result.success).toBe(false);
58
+ });
59
+ it('should accept insights with empty strengths and weaknesses', () => {
60
+ const insight = DeveloperInsightFactory.create({
61
+ strengths: [],
62
+ weaknesses: [],
63
+ });
64
+ const result = developerInsightSchema.safeParse(insight);
65
+ expect(result.success).toBe(true);
66
+ });
67
+ it('should validate overall level is between 1 and 10', () => {
68
+ const insight = DeveloperInsightFactory.create({
69
+ overallLevel: 11,
70
+ });
71
+ const result = developerInsightSchema.safeParse(insight);
72
+ expect(result.success).toBe(false);
73
+ });
74
+ it('should require review count', () => {
75
+ const insight = DeveloperInsightFactory.create();
76
+ const { reviewCount: _, ...withoutCount } = insight;
77
+ const result = developerInsightSchema.safeParse(withoutCount);
78
+ expect(result.success).toBe(false);
79
+ });
80
+ it('should accept null for top priority', () => {
81
+ const insight = DeveloperInsightFactory.create({
82
+ topPriority: null,
83
+ });
84
+ const result = developerInsightSchema.safeParse(insight);
85
+ expect(result.success).toBe(true);
86
+ });
87
+ it('should validate metrics field with raw developer numbers', () => {
88
+ const insight = DeveloperInsightFactory.create({
89
+ metrics: {
90
+ averageScore: 8.3,
91
+ averageBlocking: 0.1,
92
+ averageWarnings: 1.4,
93
+ averageDuration: 60000,
94
+ totalFollowups: null,
95
+ averageAdditions: 150,
96
+ averageDeletions: 30,
97
+ firstReviewQualityRate: 0.85,
98
+ },
99
+ });
100
+ const result = developerInsightSchema.safeParse(insight);
101
+ expect(result.success).toBe(true);
102
+ if (result.success) {
103
+ expect(result.data.metrics).toBeDefined();
104
+ expect(result.data.metrics.averageScore).toBe(8.3);
105
+ expect(result.data.metrics.averageBlocking).toBe(0.1);
106
+ expect(result.data.metrics.firstReviewQualityRate).toBe(0.85);
107
+ }
108
+ });
109
+ it('should validate insight descriptions with enriched context', () => {
110
+ const insight = DeveloperInsightFactory.create({
111
+ insightDescriptions: [
112
+ {
113
+ category: 'quality',
114
+ type: 'strength',
115
+ descriptionKey: 'insight.quality.highScore',
116
+ params: { score: 8.3, teamAverage: 7.5 },
117
+ },
118
+ ],
119
+ });
120
+ const result = developerInsightSchema.safeParse(insight);
121
+ expect(result.success).toBe(true);
122
+ if (result.success) {
123
+ expect(result.data.insightDescriptions).toHaveLength(1);
124
+ expect(result.data.insightDescriptions[0].category).toBe('quality');
125
+ expect(result.data.insightDescriptions[0].type).toBe('strength');
126
+ expect(result.data.insightDescriptions[0].descriptionKey).toBe('insight.quality.highScore');
127
+ }
128
+ });
129
+ it('should accept empty insight descriptions array', () => {
130
+ const insight = DeveloperInsightFactory.create({
131
+ insightDescriptions: [],
132
+ });
133
+ const result = developerInsightSchema.safeParse(insight);
134
+ expect(result.success).toBe(true);
135
+ if (result.success) {
136
+ expect(result.data.insightDescriptions).toEqual([]);
137
+ }
138
+ });
139
+ });
140
+ //# sourceMappingURL=developerInsight.schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"developerInsight.schema.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/developerInsight.schema.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=developerTitle.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"developerTitle.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/developerTitle.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,23 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { developerTitleSchema, DEVELOPER_TITLES } from '../../../../entities/insight/developerTitle.js';
3
+ describe('DeveloperTitle', () => {
4
+ it('should define six developer titles', () => {
5
+ expect(DEVELOPER_TITLES).toEqual([
6
+ 'architect',
7
+ 'firefighter',
8
+ 'workhorse',
9
+ 'sentinel',
10
+ 'polyvalent',
11
+ 'risingStar',
12
+ ]);
13
+ });
14
+ it('should validate a valid title', () => {
15
+ const result = developerTitleSchema.safeParse('architect');
16
+ expect(result.success).toBe(true);
17
+ });
18
+ it('should reject an invalid title', () => {
19
+ const result = developerTitleSchema.safeParse('wizard');
20
+ expect(result.success).toBe(false);
21
+ });
22
+ });
23
+ //# sourceMappingURL=developerTitle.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"developerTitle.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/developerTitle.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AAE9F,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC;YAC/B,WAAW;YACX,aAAa;YACb,WAAW;YACX,UAAU;YACV,YAAY;YACZ,YAAY;SACb,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,MAAM,GAAG,oBAAoB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAE3D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,MAAM,GAAG,oBAAoB,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAExD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=insightCategory.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insightCategory.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/insightCategory.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,16 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { insightCategorySchema, INSIGHT_CATEGORIES } from '../../../../entities/insight/insightCategory.js';
3
+ describe('InsightCategory', () => {
4
+ it('should define four insight categories', () => {
5
+ expect(INSIGHT_CATEGORIES).toEqual(['quality', 'responsiveness', 'codeVolume', 'iteration']);
6
+ });
7
+ it('should validate a valid category', () => {
8
+ const result = insightCategorySchema.safeParse('quality');
9
+ expect(result.success).toBe(true);
10
+ });
11
+ it('should reject an invalid category', () => {
12
+ const result = insightCategorySchema.safeParse('unknown');
13
+ expect(result.success).toBe(false);
14
+ });
15
+ });
16
+ //# sourceMappingURL=insightCategory.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insightCategory.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/insightCategory.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAElG,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,gBAAgB,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC,CAAC;IAC/F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,MAAM,GAAG,qBAAqB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE1D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,MAAM,GAAG,qBAAqB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE1D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=insightTrend.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insightTrend.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/insightTrend.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,16 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { insightTrendSchema, INSIGHT_TRENDS } from '../../../../entities/insight/insightTrend.js';
3
+ describe('InsightTrend', () => {
4
+ it('should define three trend values', () => {
5
+ expect(INSIGHT_TRENDS).toEqual(['improving', 'declining', 'stable']);
6
+ });
7
+ it('should validate a valid trend', () => {
8
+ const result = insightTrendSchema.safeParse('improving');
9
+ expect(result.success).toBe(true);
10
+ });
11
+ it('should reject an invalid trend', () => {
12
+ const result = insightTrendSchema.safeParse('unknown');
13
+ expect(result.success).toBe(false);
14
+ });
15
+ });
16
+ //# sourceMappingURL=insightTrend.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insightTrend.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/insightTrend.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AAExF,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,MAAM,GAAG,kBAAkB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAEzD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,MAAM,GAAG,kBAAkB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEvD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=persistedInsightsData.schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"persistedInsightsData.schema.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/persistedInsightsData.schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,160 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { persistedDeveloperMetricsSchema, persistedInsightsDataSchema, } from '../../../../entities/insight/persistedInsightsData.schema.js';
3
+ describe('persistedDeveloperMetricsSchema', () => {
4
+ it('should accept valid developer metrics', () => {
5
+ const validMetrics = {
6
+ developerName: 'alice',
7
+ totalReviews: 10,
8
+ totalScore: 75,
9
+ scoredReviewCount: 9,
10
+ totalBlocking: 5,
11
+ totalWarnings: 12,
12
+ totalSuggestions: 20,
13
+ totalDuration: 600000,
14
+ totalAdditions: 1500,
15
+ totalDeletions: 300,
16
+ diffStatsReviewCount: 8,
17
+ recentReviews: [],
18
+ };
19
+ const result = persistedDeveloperMetricsSchema.safeParse(validMetrics);
20
+ expect(result.success).toBe(true);
21
+ });
22
+ it('should reject metrics with missing developerName', () => {
23
+ const invalidMetrics = {
24
+ totalReviews: 10,
25
+ totalScore: 75,
26
+ scoredReviewCount: 9,
27
+ totalBlocking: 5,
28
+ totalWarnings: 12,
29
+ totalSuggestions: 20,
30
+ totalDuration: 600000,
31
+ totalAdditions: 1500,
32
+ totalDeletions: 300,
33
+ diffStatsReviewCount: 8,
34
+ recentReviews: [],
35
+ };
36
+ const result = persistedDeveloperMetricsSchema.safeParse(invalidMetrics);
37
+ expect(result.success).toBe(false);
38
+ });
39
+ it('should reject metrics with negative totalReviews', () => {
40
+ const invalidMetrics = {
41
+ developerName: 'alice',
42
+ totalReviews: -1,
43
+ totalScore: 75,
44
+ scoredReviewCount: 9,
45
+ totalBlocking: 5,
46
+ totalWarnings: 12,
47
+ totalSuggestions: 20,
48
+ totalDuration: 600000,
49
+ totalAdditions: 1500,
50
+ totalDeletions: 300,
51
+ diffStatsReviewCount: 8,
52
+ recentReviews: [],
53
+ };
54
+ const result = persistedDeveloperMetricsSchema.safeParse(invalidMetrics);
55
+ expect(result.success).toBe(false);
56
+ });
57
+ });
58
+ describe('persistedInsightsDataSchema', () => {
59
+ it('should accept valid persisted insights data', () => {
60
+ const validData = {
61
+ developers: [],
62
+ processedReviewIds: ['review-1', 'review-2'],
63
+ lastUpdated: '2024-01-15T10:00:00Z',
64
+ };
65
+ const result = persistedInsightsDataSchema.safeParse(validData);
66
+ expect(result.success).toBe(true);
67
+ });
68
+ it('should accept data with developer metrics', () => {
69
+ const validData = {
70
+ developers: [{
71
+ developerName: 'alice',
72
+ totalReviews: 10,
73
+ totalScore: 75,
74
+ scoredReviewCount: 9,
75
+ totalBlocking: 5,
76
+ totalWarnings: 12,
77
+ totalSuggestions: 20,
78
+ totalDuration: 600000,
79
+ totalAdditions: 1500,
80
+ totalDeletions: 300,
81
+ diffStatsReviewCount: 8,
82
+ recentReviews: [],
83
+ }],
84
+ processedReviewIds: ['review-1'],
85
+ lastUpdated: '2024-01-15T10:00:00Z',
86
+ };
87
+ const result = persistedInsightsDataSchema.safeParse(validData);
88
+ expect(result.success).toBe(true);
89
+ });
90
+ it('should reject data with missing lastUpdated', () => {
91
+ const invalidData = {
92
+ developers: [],
93
+ processedReviewIds: [],
94
+ };
95
+ const result = persistedInsightsDataSchema.safeParse(invalidData);
96
+ expect(result.success).toBe(false);
97
+ });
98
+ it('should reject non-string processedReviewIds', () => {
99
+ const invalidData = {
100
+ developers: [],
101
+ processedReviewIds: [123],
102
+ lastUpdated: '2024-01-15T10:00:00Z',
103
+ };
104
+ const result = persistedInsightsDataSchema.safeParse(invalidData);
105
+ expect(result.success).toBe(false);
106
+ });
107
+ it('should accept data with null aiInsights', () => {
108
+ const validData = {
109
+ developers: [],
110
+ processedReviewIds: [],
111
+ lastUpdated: '2024-01-15T10:00:00Z',
112
+ aiInsights: null,
113
+ };
114
+ const result = persistedInsightsDataSchema.safeParse(validData);
115
+ expect(result.success).toBe(true);
116
+ });
117
+ it('should accept data with valid aiInsights', () => {
118
+ const validData = {
119
+ developers: [],
120
+ processedReviewIds: [],
121
+ lastUpdated: '2024-01-15T10:00:00Z',
122
+ aiInsights: {
123
+ developers: [
124
+ {
125
+ developerName: 'alice',
126
+ title: 'Le Chirurgien du Code',
127
+ titleExplanation: 'Precise changes',
128
+ strengths: ['Testing'],
129
+ weaknesses: ['Speed'],
130
+ recommendations: ['Automate'],
131
+ summary: 'Alice is great.',
132
+ },
133
+ ],
134
+ team: {
135
+ summary: 'Good team.',
136
+ strengths: ['Quality'],
137
+ weaknesses: ['Velocity'],
138
+ recommendations: ['Pair programming'],
139
+ dynamics: 'Balanced.',
140
+ },
141
+ generatedAt: '2026-03-15T10:00:00Z',
142
+ },
143
+ };
144
+ const result = persistedInsightsDataSchema.safeParse(validData);
145
+ expect(result.success).toBe(true);
146
+ });
147
+ it('should default aiInsights to null when field is absent', () => {
148
+ const validData = {
149
+ developers: [],
150
+ processedReviewIds: [],
151
+ lastUpdated: '2024-01-15T10:00:00Z',
152
+ };
153
+ const result = persistedInsightsDataSchema.safeParse(validData);
154
+ expect(result.success).toBe(true);
155
+ if (result.success) {
156
+ expect(result.data.aiInsights).toBeNull();
157
+ }
158
+ });
159
+ });
160
+ //# sourceMappingURL=persistedInsightsData.schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"persistedInsightsData.schema.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/persistedInsightsData.schema.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=teamInsight.schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"teamInsight.schema.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/teamInsight.schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,57 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { teamInsightSchema } from '../../../../entities/insight/teamInsight.schema.js';
3
+ import { TeamInsightFactory } from '../../../../tests/factories/teamInsight.factory.js';
4
+ describe('TeamInsight schema', () => {
5
+ it('should validate a complete team insight', () => {
6
+ const insight = TeamInsightFactory.create();
7
+ const result = teamInsightSchema.safeParse(insight);
8
+ expect(result.success).toBe(true);
9
+ });
10
+ it('should require developer count', () => {
11
+ const insight = TeamInsightFactory.create();
12
+ const { developerCount: _, ...withoutCount } = insight;
13
+ const result = teamInsightSchema.safeParse(withoutCount);
14
+ expect(result.success).toBe(false);
15
+ });
16
+ it('should accept empty strengths and weaknesses arrays', () => {
17
+ const insight = TeamInsightFactory.create({
18
+ strengths: [],
19
+ weaknesses: [],
20
+ });
21
+ const result = teamInsightSchema.safeParse(insight);
22
+ expect(result.success).toBe(true);
23
+ });
24
+ it('should validate strengths contain valid categories', () => {
25
+ const insight = TeamInsightFactory.create({
26
+ strengths: ['invalid'],
27
+ });
28
+ const result = teamInsightSchema.safeParse(insight);
29
+ expect(result.success).toBe(false);
30
+ });
31
+ it('should validate average levels are between 1 and 10', () => {
32
+ const insight = TeamInsightFactory.create({
33
+ averageLevels: {
34
+ quality: 11,
35
+ responsiveness: 5,
36
+ codeVolume: 5,
37
+ iteration: 5,
38
+ },
39
+ });
40
+ const result = teamInsightSchema.safeParse(insight);
41
+ expect(result.success).toBe(false);
42
+ });
43
+ it('should accept empty tips array', () => {
44
+ const insight = TeamInsightFactory.create({
45
+ tips: [],
46
+ });
47
+ const result = teamInsightSchema.safeParse(insight);
48
+ expect(result.success).toBe(true);
49
+ });
50
+ it('should require total review count', () => {
51
+ const insight = TeamInsightFactory.create();
52
+ const { totalReviewCount: _, ...withoutTotal } = insight;
53
+ const result = teamInsightSchema.safeParse(withoutTotal);
54
+ expect(result.success).toBe(false);
55
+ });
56
+ });
57
+ //# sourceMappingURL=teamInsight.schema.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"teamInsight.schema.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/entities/insight/teamInsight.schema.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=packageVersion.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"packageVersion.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/entities/packageVersion/packageVersion.test.ts"],"names":[],"mappings":""}