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.
- package/CHANGELOG.md +40 -0
- package/dist/config/projectConfig.d.ts +2 -0
- package/dist/config/projectConfig.d.ts.map +1 -1
- package/dist/config/projectConfig.js +17 -0
- package/dist/config/projectConfig.js.map +1 -1
- package/dist/entities/backfill/backfillProgress.d.ts +7 -0
- package/dist/entities/backfill/backfillProgress.d.ts.map +1 -0
- package/dist/entities/backfill/backfillProgress.js +2 -0
- package/dist/entities/backfill/backfillProgress.js.map +1 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts +8 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.d.ts.map +1 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.js +21 -0
- package/dist/entities/cleanup/retentionPolicy.valueObject.js.map +1 -0
- package/dist/entities/diffStats/diffStats.d.ts +6 -0
- package/dist/entities/diffStats/diffStats.d.ts.map +1 -0
- package/dist/entities/diffStats/diffStats.js +2 -0
- package/dist/entities/diffStats/diffStats.js.map +1 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts +5 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.d.ts.map +1 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.js +2 -0
- package/dist/entities/diffStats/diffStatsFetch.gateway.js.map +1 -0
- package/dist/entities/insight/aiInsight.d.ts +6 -0
- package/dist/entities/insight/aiInsight.d.ts.map +1 -0
- package/dist/entities/insight/aiInsight.js +2 -0
- package/dist/entities/insight/aiInsight.js.map +1 -0
- package/dist/entities/insight/aiInsight.schema.d.ts +55 -0
- package/dist/entities/insight/aiInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/aiInsight.schema.js +25 -0
- package/dist/entities/insight/aiInsight.schema.js.map +1 -0
- package/dist/entities/insight/developerInsight.d.ts +8 -0
- package/dist/entities/insight/developerInsight.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.guard.d.ts +221 -0
- package/dist/entities/insight/developerInsight.guard.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.guard.js +13 -0
- package/dist/entities/insight/developerInsight.guard.js.map +1 -0
- package/dist/entities/insight/developerInsight.js +2 -0
- package/dist/entities/insight/developerInsight.js.map +1 -0
- package/dist/entities/insight/developerInsight.schema.d.ts +157 -0
- package/dist/entities/insight/developerInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/developerInsight.schema.js +43 -0
- package/dist/entities/insight/developerInsight.schema.js.map +1 -0
- package/dist/entities/insight/developerTitle.d.ts +12 -0
- package/dist/entities/insight/developerTitle.d.ts.map +1 -0
- package/dist/entities/insight/developerTitle.js +11 -0
- package/dist/entities/insight/developerTitle.js.map +1 -0
- package/dist/entities/insight/insightCategory.d.ts +10 -0
- package/dist/entities/insight/insightCategory.d.ts.map +1 -0
- package/dist/entities/insight/insightCategory.js +4 -0
- package/dist/entities/insight/insightCategory.js.map +1 -0
- package/dist/entities/insight/insightTrend.d.ts +9 -0
- package/dist/entities/insight/insightTrend.d.ts.map +1 -0
- package/dist/entities/insight/insightTrend.js +4 -0
- package/dist/entities/insight/insightTrend.js.map +1 -0
- package/dist/entities/insight/insights.gateway.d.ts +6 -0
- package/dist/entities/insight/insights.gateway.d.ts.map +1 -0
- package/dist/entities/insight/insights.gateway.js +2 -0
- package/dist/entities/insight/insights.gateway.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.d.ts +5 -0
- package/dist/entities/insight/persistedInsightsData.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.guard.d.ts +271 -0
- package/dist/entities/insight/persistedInsightsData.guard.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.guard.js +13 -0
- package/dist/entities/insight/persistedInsightsData.guard.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.js +2 -0
- package/dist/entities/insight/persistedInsightsData.js.map +1 -0
- package/dist/entities/insight/persistedInsightsData.schema.d.ts +84 -0
- package/dist/entities/insight/persistedInsightsData.schema.d.ts.map +1 -0
- package/dist/entities/insight/persistedInsightsData.schema.js +40 -0
- package/dist/entities/insight/persistedInsightsData.schema.js.map +1 -0
- package/dist/entities/insight/teamInsight.d.ts +5 -0
- package/dist/entities/insight/teamInsight.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.guard.d.ts +71 -0
- package/dist/entities/insight/teamInsight.guard.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.guard.js +13 -0
- package/dist/entities/insight/teamInsight.guard.js.map +1 -0
- package/dist/entities/insight/teamInsight.js +2 -0
- package/dist/entities/insight/teamInsight.js.map +1 -0
- package/dist/entities/insight/teamInsight.schema.d.ts +31 -0
- package/dist/entities/insight/teamInsight.schema.d.ts.map +1 -0
- package/dist/entities/insight/teamInsight.schema.js +17 -0
- package/dist/entities/insight/teamInsight.schema.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.d.ts +21 -0
- package/dist/entities/packageVersion/packageVersion.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.gateway.d.ts +4 -0
- package/dist/entities/packageVersion/packageVersion.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.gateway.js +2 -0
- package/dist/entities/packageVersion/packageVersion.gateway.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.guard.d.ts +7 -0
- package/dist/entities/packageVersion/packageVersion.guard.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.guard.js +13 -0
- package/dist/entities/packageVersion/packageVersion.guard.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.js +2 -0
- package/dist/entities/packageVersion/packageVersion.js.map +1 -0
- package/dist/entities/packageVersion/packageVersion.schema.d.ts +12 -0
- package/dist/entities/packageVersion/packageVersion.schema.d.ts.map +1 -0
- package/dist/entities/packageVersion/packageVersion.schema.js +11 -0
- package/dist/entities/packageVersion/packageVersion.schema.js.map +1 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts +9 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.js +2 -0
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.js.map +1 -0
- package/dist/entities/packageVersion/versionCache.gateway.d.ts +7 -0
- package/dist/entities/packageVersion/versionCache.gateway.d.ts.map +1 -0
- package/dist/entities/packageVersion/versionCache.gateway.js +2 -0
- package/dist/entities/packageVersion/versionCache.gateway.js.map +1 -0
- package/dist/entities/review/reviewFile.gateway.d.ts +18 -0
- package/dist/entities/review/reviewFile.gateway.d.ts.map +1 -0
- package/dist/entities/review/reviewFile.gateway.js +2 -0
- package/dist/entities/review/reviewFile.gateway.js.map +1 -0
- package/dist/entities/stats/projectStats.d.ts +39 -0
- package/dist/entities/stats/projectStats.d.ts.map +1 -0
- package/dist/entities/stats/projectStats.js +2 -0
- package/dist/entities/stats/projectStats.js.map +1 -0
- package/dist/entities/stats/recalculateBody.guard.d.ts +11 -0
- package/dist/entities/stats/recalculateBody.guard.d.ts.map +1 -0
- package/dist/entities/stats/recalculateBody.guard.js +9 -0
- package/dist/entities/stats/recalculateBody.guard.js.map +1 -0
- package/dist/entities/stats/stats.gateway.d.ts +7 -0
- package/dist/entities/stats/stats.gateway.d.ts.map +1 -0
- package/dist/entities/stats/stats.gateway.js +2 -0
- package/dist/entities/stats/stats.gateway.js.map +1 -0
- package/dist/entities/tracking/reviewEvent.d.ts +2 -0
- package/dist/entities/tracking/reviewEvent.d.ts.map +1 -1
- package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts +19 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.d.ts.map +1 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.js +2 -0
- package/dist/entities/tracking/reviewRequestTracking.gateway.js.map +1 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.d.ts +3 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.d.ts.map +1 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.js +58 -0
- package/dist/frameworks/claude/claudeInsightsInvoker.js.map +1 -0
- package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -1
- package/dist/frameworks/claude/claudeInvoker.js +15 -1
- package/dist/frameworks/claude/claudeInvoker.js.map +1 -1
- package/dist/frameworks/scheduler/cleanupScheduler.d.ts +16 -0
- package/dist/frameworks/scheduler/cleanupScheduler.d.ts.map +1 -0
- package/dist/frameworks/scheduler/cleanupScheduler.js +35 -0
- package/dist/frameworks/scheduler/cleanupScheduler.js.map +1 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts +16 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.js +44 -0
- package/dist/interface-adapters/controllers/http/cleanup.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/health.routes.d.ts +3 -1
- package/dist/interface-adapters/controllers/http/health.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/health.routes.js +5 -1
- package/dist/interface-adapters/controllers/http/health.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/insights.routes.d.ts +20 -0
- package/dist/interface-adapters/controllers/http/insights.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/insights.routes.js +73 -0
- package/dist/interface-adapters/controllers/http/insights.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js +13 -2
- package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/settings.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/settings.routes.js +3 -0
- package/dist/interface-adapters/controllers/http/settings.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts +20 -6
- package/dist/interface-adapters/controllers/http/stats.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/stats.routes.js +35 -2
- package/dist/interface-adapters/controllers/http/stats.routes.js.map +1 -1
- package/dist/interface-adapters/controllers/http/version.routes.d.ts +19 -0
- package/dist/interface-adapters/controllers/http/version.routes.d.ts.map +1 -0
- package/dist/interface-adapters/controllers/http/version.routes.js +21 -0
- package/dist/interface-adapters/controllers/http/version.routes.js.map +1 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts +2 -0
- package/dist/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/webhook/github.controller.js +9 -3
- package/dist/interface-adapters/controllers/webhook/github.controller.js.map +1 -1
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts +2 -0
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js +17 -5
- package/dist/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -1
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js +26 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.github.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts +10 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js +28 -0
- package/dist/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts +7 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js +33 -0
- package/dist/interface-adapters/gateways/fileSystem/insights.fileSystem.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js +47 -0
- package/dist/interface-adapters/gateways/fileSystem/reviewLogFile.fileSystem.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts +2 -2
- package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts +7 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js +25 -0
- package/dist/interface-adapters/gateways/packageVersion.npm.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts +1 -17
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts +12 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.js +2 -0
- package/dist/interface-adapters/gateways/reviewLogFile.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts +1 -18
- package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts +20 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js +58 -0
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js.map +1 -0
- package/dist/interface-adapters/gateways/stats.gateway.d.ts +1 -6
- package/dist/interface-adapters/gateways/stats.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts +12 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.d.ts.map +1 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.js +22 -0
- package/dist/interface-adapters/gateways/versionCache.memory.gateway.js.map +1 -0
- package/dist/interface-adapters/presenters/insights.presenter.d.ts +41 -0
- package/dist/interface-adapters/presenters/insights.presenter.d.ts.map +1 -0
- package/dist/interface-adapters/presenters/insights.presenter.js +36 -0
- package/dist/interface-adapters/presenters/insights.presenter.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/index.html +599 -40
- package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts +10 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.js +45 -0
- package/dist/interface-adapters/views/dashboard/modules/cleanup.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts +13 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js +71 -0
- package/dist/interface-adapters/views/dashboard/modules/collapsibleList.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts +14 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.js +359 -0
- package/dist/interface-adapters/views/dashboard/modules/developerSheet.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/i18n.d.ts.map +1 -1
- package/dist/interface-adapters/views/dashboard/modules/i18n.js +296 -0
- package/dist/interface-adapters/views/dashboard/modules/i18n.js.map +1 -1
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts +7 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.js +509 -0
- package/dist/interface-adapters/views/dashboard/modules/insightsReport.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts +25 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.js +414 -0
- package/dist/interface-adapters/views/dashboard/modules/mrSheet.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts +40 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js +106 -0
- package/dist/interface-adapters/views/dashboard/modules/sharedViewHelpers.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts +35 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.js +476 -0
- package/dist/interface-adapters/views/dashboard/modules/statsCharts.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts +13 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.js +296 -0
- package/dist/interface-adapters/views/dashboard/modules/teamTab.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts +16 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.d.ts.map +1 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js +54 -0
- package/dist/interface-adapters/views/dashboard/modules/versionUpdate.js.map +1 -0
- package/dist/interface-adapters/views/dashboard/styles.css +1906 -0
- package/dist/main/dependencies.d.ts +4 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +4 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +68 -2
- package/dist/main/routes.js.map +1 -1
- package/dist/main/server.d.ts.map +1 -1
- package/dist/main/server.js +8 -0
- package/dist/main/server.js.map +1 -1
- package/dist/main/websocket.d.ts +2 -0
- package/dist/main/websocket.d.ts.map +1 -1
- package/dist/main/websocket.js +13 -0
- package/dist/main/websocket.js.map +1 -1
- package/dist/services/statsService.d.ts +8 -32
- package/dist/services/statsService.d.ts.map +1 -1
- package/dist/services/statsService.js +60 -36
- package/dist/services/statsService.js.map +1 -1
- package/dist/shared/foundation/commandExecutor.d.ts +2 -0
- package/dist/shared/foundation/commandExecutor.d.ts.map +1 -0
- package/dist/shared/foundation/commandExecutor.js +2 -0
- package/dist/shared/foundation/commandExecutor.js.map +1 -0
- package/dist/tests/factories/developerInsight.factory.d.ts +6 -0
- package/dist/tests/factories/developerInsight.factory.d.ts.map +1 -0
- package/dist/tests/factories/developerInsight.factory.js +61 -0
- package/dist/tests/factories/developerInsight.factory.js.map +1 -0
- package/dist/tests/factories/diffStats.factory.d.ts +5 -0
- package/dist/tests/factories/diffStats.factory.d.ts.map +1 -0
- package/dist/tests/factories/diffStats.factory.js +11 -0
- package/dist/tests/factories/diffStats.factory.js.map +1 -0
- package/dist/tests/factories/packageVersion.factory.d.ts +7 -0
- package/dist/tests/factories/packageVersion.factory.d.ts.map +1 -0
- package/dist/tests/factories/packageVersion.factory.js +18 -0
- package/dist/tests/factories/packageVersion.factory.js.map +1 -0
- package/dist/tests/factories/persistedInsightsData.factory.d.ts +11 -0
- package/dist/tests/factories/persistedInsightsData.factory.d.ts.map +1 -0
- package/dist/tests/factories/persistedInsightsData.factory.js +41 -0
- package/dist/tests/factories/persistedInsightsData.factory.js.map +1 -0
- package/dist/tests/factories/projectStats.factory.d.ts +3 -1
- package/dist/tests/factories/projectStats.factory.d.ts.map +1 -1
- package/dist/tests/factories/projectStats.factory.js +17 -3
- package/dist/tests/factories/projectStats.factory.js.map +1 -1
- package/dist/tests/factories/teamInsight.factory.d.ts +6 -0
- package/dist/tests/factories/teamInsight.factory.d.ts.map +1 -0
- package/dist/tests/factories/teamInsight.factory.js +35 -0
- package/dist/tests/factories/teamInsight.factory.js.map +1 -0
- package/dist/tests/stubs/diffStatsFetch.stub.d.ts +11 -0
- package/dist/tests/stubs/diffStatsFetch.stub.d.ts.map +1 -0
- package/dist/tests/stubs/diffStatsFetch.stub.js +19 -0
- package/dist/tests/stubs/diffStatsFetch.stub.js.map +1 -0
- package/dist/tests/stubs/insights.stub.d.ts +9 -0
- package/dist/tests/stubs/insights.stub.d.ts.map +1 -0
- package/dist/tests/stubs/insights.stub.js +13 -0
- package/dist/tests/stubs/insights.stub.js.map +1 -0
- package/dist/tests/stubs/packageVersion.stub.d.ts +7 -0
- package/dist/tests/stubs/packageVersion.stub.d.ts.map +1 -0
- package/dist/tests/stubs/packageVersion.stub.js +10 -0
- package/dist/tests/stubs/packageVersion.stub.js.map +1 -0
- package/dist/tests/stubs/reviewFile.stub.d.ts +1 -1
- package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -1
- package/dist/tests/stubs/reviewLogFile.stub.d.ts +15 -0
- package/dist/tests/stubs/reviewLogFile.stub.d.ts.map +1 -0
- package/dist/tests/stubs/reviewLogFile.stub.js +35 -0
- package/dist/tests/stubs/reviewLogFile.stub.js.map +1 -0
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts +1 -1
- package/dist/tests/stubs/reviewRequestTracking.stub.d.ts.map +1 -1
- package/dist/tests/stubs/selfUpdate.stub.d.ts +14 -0
- package/dist/tests/stubs/selfUpdate.stub.d.ts.map +1 -0
- package/dist/tests/stubs/selfUpdate.stub.js +20 -0
- package/dist/tests/stubs/selfUpdate.stub.js.map +1 -0
- package/dist/tests/stubs/stats.stub.d.ts +2 -2
- package/dist/tests/stubs/stats.stub.d.ts.map +1 -1
- package/dist/tests/stubs/versionCache.stub.d.ts +11 -0
- package/dist/tests/stubs/versionCache.stub.d.ts.map +1 -0
- package/dist/tests/stubs/versionCache.stub.js +18 -0
- package/dist/tests/stubs/versionCache.stub.js.map +1 -0
- package/dist/tests/units/config/projectConfig.test.js +60 -1
- package/dist/tests/units/config/projectConfig.test.js.map +1 -1
- package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts +2 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.d.ts.map +1 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.js +40 -0
- package/dist/tests/units/entities/backfill/backfillProgress.test.js.map +1 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts +2 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.d.ts.map +1 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js +47 -0
- package/dist/tests/units/entities/cleanup/retentionPolicy.valueObject.test.js.map +1 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.d.ts +2 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.d.ts.map +1 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.js +27 -0
- package/dist/tests/units/entities/diffStats/diffStats.test.js.map +1 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.js +123 -0
- package/dist/tests/units/entities/insight/aiInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.js +140 -0
- package/dist/tests/units/entities/insight/developerInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/developerTitle.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/developerTitle.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/developerTitle.test.js +23 -0
- package/dist/tests/units/entities/insight/developerTitle.test.js.map +1 -0
- package/dist/tests/units/entities/insight/insightCategory.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/insightCategory.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/insightCategory.test.js +16 -0
- package/dist/tests/units/entities/insight/insightCategory.test.js.map +1 -0
- package/dist/tests/units/entities/insight/insightTrend.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/insightTrend.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/insightTrend.test.js +16 -0
- package/dist/tests/units/entities/insight/insightTrend.test.js.map +1 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js +160 -0
- package/dist/tests/units/entities/insight/persistedInsightsData.schema.test.js.map +1 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts +2 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.d.ts.map +1 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.js +57 -0
- package/dist/tests/units/entities/insight/teamInsight.schema.test.js.map +1 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts +2 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.d.ts.map +1 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.js +154 -0
- package/dist/tests/units/entities/packageVersion/packageVersion.test.js.map +1 -0
- package/dist/tests/units/factories/packageVersion.factory.test.d.ts +2 -0
- package/dist/tests/units/factories/packageVersion.factory.test.d.ts.map +1 -0
- package/dist/tests/units/factories/packageVersion.factory.test.js +37 -0
- package/dist/tests/units/factories/packageVersion.factory.test.js.map +1 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts +2 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.d.ts.map +1 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js +74 -0
- package/dist/tests/units/frameworks/scheduler/cleanupScheduler.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js +62 -0
- package/dist/tests/units/interface-adapters/controllers/http/cleanup.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js +96 -0
- package/dist/tests/units/interface-adapters/controllers/http/health.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js +390 -0
- package/dist/tests/units/interface-adapters/controllers/http/insights.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js +25 -0
- package/dist/tests/units/interface-adapters/controllers/http/settings.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js +82 -0
- package/dist/tests/units/interface-adapters/controllers/http/statsRecalculate.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js +108 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +3 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +1 -0
- package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js +63 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.github.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js +94 -0
- package/dist/tests/units/interface-adapters/gateways/diffStatsFetch.gitlab.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js +117 -0
- package/dist/tests/units/interface-adapters/gateways/insights.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js +42 -0
- package/dist/tests/units/interface-adapters/gateways/packageVersion.npm.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js +65 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.fileSystem.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js +63 -0
- package/dist/tests/units/interface-adapters/gateways/reviewLogFile.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js +2 -0
- package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js +101 -0
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js +38 -0
- package/dist/tests/units/interface-adapters/gateways/versionCache.memory.gateway.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js +194 -0
- package/dist/tests/units/interface-adapters/presenters/insights.presenter.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js +224 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js +29 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/i18n.test.js.map +1 -1
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js +326 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/insightsReport.test.js.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts +2 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.d.ts.map +1 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js +336 -0
- package/dist/tests/units/interface-adapters/views/dashboard/modules/teamTab.test.js.map +1 -0
- package/dist/tests/units/services/statsService.addReview.test.d.ts +2 -0
- package/dist/tests/units/services/statsService.addReview.test.d.ts.map +1 -0
- package/dist/tests/units/services/statsService.addReview.test.js +103 -0
- package/dist/tests/units/services/statsService.addReview.test.js.map +1 -0
- package/dist/tests/units/services/statsService.diffStats.test.d.ts +2 -0
- package/dist/tests/units/services/statsService.diffStats.test.d.ts.map +1 -0
- package/dist/tests/units/services/statsService.diffStats.test.js +61 -0
- package/dist/tests/units/services/statsService.diffStats.test.js.map +1 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.js +20 -0
- package/dist/tests/units/stubs/packageVersion.stub.test.js.map +1 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.js +30 -0
- package/dist/tests/units/stubs/selfUpdate.stub.test.js.map +1 -0
- package/dist/tests/units/stubs/versionCache.stub.test.d.ts +2 -0
- package/dist/tests/units/stubs/versionCache.stub.test.d.ts.map +1 -0
- package/dist/tests/units/stubs/versionCache.stub.test.js +34 -0
- package/dist/tests/units/stubs/versionCache.stub.test.js.map +1 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js +83 -0
- package/dist/tests/units/usecases/cleanup/cleanupExpiredReviews.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js +172 -0
- package/dist/tests/units/usecases/insights/buildAiInsightsPrompt.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js +449 -0
- package/dist/tests/units/usecases/insights/computeDeveloperInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js +326 -0
- package/dist/tests/units/usecases/insights/computeInsightsWithPersistence.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js +172 -0
- package/dist/tests/units/usecases/insights/computeTeamInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js +253 -0
- package/dist/tests/units/usecases/insights/generateAiInsights.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js +160 -0
- package/dist/tests/units/usecases/insights/getInsightsWithAiStatus.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts +2 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js +125 -0
- package/dist/tests/units/usecases/insights/insightLevelComputation.service.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js +186 -0
- package/dist/tests/units/usecases/stats/backfillDiffStats.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js +130 -0
- package/dist/tests/units/usecases/stats/recalculateProjectStats.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js +138 -0
- package/dist/tests/units/usecases/stats/recalculateWithBackfill.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js +31 -2
- package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js.map +1 -1
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.js +63 -0
- package/dist/tests/units/usecases/version/checkVersion.usecase.test.js.map +1 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts +2 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.d.ts.map +1 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js +26 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js.map +1 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts +13 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.d.ts.map +1 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js +41 -0
- package/dist/usecases/cleanup/cleanupExpiredReviews.usecase.js.map +1 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.d.ts +12 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.d.ts.map +1 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.js +220 -0
- package/dist/usecases/insights/buildAiInsightsPrompt.js.map +1 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts +4 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.js +226 -0
- package/dist/usecases/insights/computeDeveloperInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts +12 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js +340 -0
- package/dist/usecases/insights/computeInsightsWithPersistence.usecase.js.map +1 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.d.ts +4 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.js +111 -0
- package/dist/usecases/insights/computeTeamInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/generateAiInsights.usecase.d.ts +27 -0
- package/dist/usecases/insights/generateAiInsights.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/generateAiInsights.usecase.js +65 -0
- package/dist/usecases/insights/generateAiInsights.usecase.js.map +1 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts +18 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.d.ts.map +1 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js +56 -0
- package/dist/usecases/insights/getInsightsWithAiStatus.usecase.js.map +1 -0
- package/dist/usecases/insights/insightLevelComputation.service.d.ts +41 -0
- package/dist/usecases/insights/insightLevelComputation.service.d.ts.map +1 -0
- package/dist/usecases/insights/insightLevelComputation.service.js +313 -0
- package/dist/usecases/insights/insightLevelComputation.service.js.map +1 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.d.ts +18 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.js +43 -0
- package/dist/usecases/stats/backfillDiffStats.usecase.js.map +1 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts +7 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.js +47 -0
- package/dist/usecases/stats/recalculateProjectStats.usecase.js.map +1 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts +22 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.d.ts.map +1 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.js +33 -0
- package/dist/usecases/stats/recalculateWithBackfill.usecase.js.map +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts +2 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts.map +1 -1
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js +1 -0
- package/dist/usecases/tracking/recordReviewCompletion.usecase.js.map +1 -1
- package/dist/usecases/version/checkVersion.usecase.d.ts +13 -0
- package/dist/usecases/version/checkVersion.usecase.d.ts.map +1 -0
- package/dist/usecases/version/checkVersion.usecase.js +20 -0
- package/dist/usecases/version/checkVersion.usecase.js.map +1 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts +7 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.d.ts.map +1 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.js +12 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { checkVersion } from '../../../../usecases/version/checkVersion.usecase.js';
|
|
3
|
+
import { StubPackageVersionGateway } from '../../../../tests/stubs/packageVersion.stub.js';
|
|
4
|
+
import { StubVersionCache } from '../../../../tests/stubs/versionCache.stub.js';
|
|
5
|
+
import { PackageVersionFactory } from '../../../../tests/factories/packageVersion.factory.js';
|
|
6
|
+
describe('checkVersion usecase', () => {
|
|
7
|
+
it('should return cached result when cache is valid and not force refresh', async () => {
|
|
8
|
+
const cachedResult = PackageVersionFactory.createVersionCheckResult();
|
|
9
|
+
const cache = new StubVersionCache(cachedResult, false);
|
|
10
|
+
const gateway = new StubPackageVersionGateway('2.0.0');
|
|
11
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
12
|
+
expect(result).toEqual(cachedResult);
|
|
13
|
+
});
|
|
14
|
+
it('should fetch from gateway when cache is expired', async () => {
|
|
15
|
+
const cache = new StubVersionCache(null, true);
|
|
16
|
+
const gateway = new StubPackageVersionGateway('2.0.0');
|
|
17
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
18
|
+
expect(result.currentVersion).toBe('1.0.0');
|
|
19
|
+
expect(result.latestVersion).toBe('2.0.0');
|
|
20
|
+
expect(result.updateAvailable).toBe(true);
|
|
21
|
+
});
|
|
22
|
+
it('should fetch from gateway when forceRefresh is true', async () => {
|
|
23
|
+
const cachedResult = PackageVersionFactory.createVersionCheckResult({
|
|
24
|
+
latestVersion: '1.5.0',
|
|
25
|
+
updateAvailable: true,
|
|
26
|
+
});
|
|
27
|
+
const cache = new StubVersionCache(cachedResult, false);
|
|
28
|
+
const gateway = new StubPackageVersionGateway('3.0.0');
|
|
29
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: true }, { packageVersionGateway: gateway, cache });
|
|
30
|
+
expect(result.latestVersion).toBe('3.0.0');
|
|
31
|
+
expect(result.updateAvailable).toBe(true);
|
|
32
|
+
});
|
|
33
|
+
it('should set updateAvailable to true when versions differ', async () => {
|
|
34
|
+
const cache = new StubVersionCache(null, true);
|
|
35
|
+
const gateway = new StubPackageVersionGateway('2.0.0');
|
|
36
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
37
|
+
expect(result.updateAvailable).toBe(true);
|
|
38
|
+
});
|
|
39
|
+
it('should set updateAvailable to false when versions match', async () => {
|
|
40
|
+
const cache = new StubVersionCache(null, true);
|
|
41
|
+
const gateway = new StubPackageVersionGateway('1.0.0');
|
|
42
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
43
|
+
expect(result.updateAvailable).toBe(false);
|
|
44
|
+
});
|
|
45
|
+
it('should set updateAvailable to false when latestVersion is null', async () => {
|
|
46
|
+
const cache = new StubVersionCache(null, true);
|
|
47
|
+
const gateway = new StubPackageVersionGateway(null);
|
|
48
|
+
const result = await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
49
|
+
expect(result.latestVersion).toBeNull();
|
|
50
|
+
expect(result.updateAvailable).toBe(false);
|
|
51
|
+
});
|
|
52
|
+
it('should store result in cache after fetch', async () => {
|
|
53
|
+
const cache = new StubVersionCache(null, true);
|
|
54
|
+
const gateway = new StubPackageVersionGateway('2.0.0');
|
|
55
|
+
await checkVersion({ currentVersion: '1.0.0', forceRefresh: false }, { packageVersionGateway: gateway, cache });
|
|
56
|
+
const cached = cache.get();
|
|
57
|
+
expect(cached).not.toBeNull();
|
|
58
|
+
expect(cached?.currentVersion).toBe('1.0.0');
|
|
59
|
+
expect(cached?.latestVersion).toBe('2.0.0');
|
|
60
|
+
expect(cached?.updateAvailable).toBe(true);
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=checkVersion.usecase.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkVersion.usecase.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/usecases/version/checkVersion.usecase.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"triggerSelfUpdate.usecase.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/usecases/version/triggerSelfUpdate.usecase.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { triggerSelfUpdate } from '../../../../usecases/version/triggerSelfUpdate.usecase.js';
|
|
3
|
+
import { StubSelfUpdateCommand } from '../../../../tests/stubs/selfUpdate.stub.js';
|
|
4
|
+
describe('triggerSelfUpdate usecase', () => {
|
|
5
|
+
it('should return started when update succeeds', async () => {
|
|
6
|
+
const selfUpdateCommand = new StubSelfUpdateCommand(true);
|
|
7
|
+
const result = await triggerSelfUpdate({ selfUpdateCommand });
|
|
8
|
+
expect(result).toEqual({ status: 'started' });
|
|
9
|
+
});
|
|
10
|
+
it('should return failed with error message when update fails', async () => {
|
|
11
|
+
const selfUpdateCommand = new StubSelfUpdateCommand(false, 'npm update failed');
|
|
12
|
+
const result = await triggerSelfUpdate({ selfUpdateCommand });
|
|
13
|
+
expect(result).toEqual({ status: 'failed', error: 'npm update failed' });
|
|
14
|
+
});
|
|
15
|
+
it('should return failed with default error when no error message provided', async () => {
|
|
16
|
+
const selfUpdateCommand = new StubSelfUpdateCommand(false);
|
|
17
|
+
const result = await triggerSelfUpdate({ selfUpdateCommand });
|
|
18
|
+
expect(result).toEqual({ status: 'failed', error: 'Unknown error' });
|
|
19
|
+
});
|
|
20
|
+
it('should return permission-denied with command when permission is denied', async () => {
|
|
21
|
+
const selfUpdateCommand = new StubSelfUpdateCommand(false, 'EACCES', true);
|
|
22
|
+
const result = await triggerSelfUpdate({ selfUpdateCommand });
|
|
23
|
+
expect(result).toEqual({ status: 'permission-denied', command: 'sudo npm update -g reviewflow' });
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=triggerSelfUpdate.usecase.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"triggerSelfUpdate.usecase.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/usecases/version/triggerSelfUpdate.usecase.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iDAAiD,CAAA;AACnF,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AAExE,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,iBAAiB,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,CAAA;QAEzD,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAA;QAE7D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAA;IAC/C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;QACzE,MAAM,iBAAiB,GAAG,IAAI,qBAAqB,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAA;QAE/E,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAA;QAE7D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC,CAAA;IAC1E,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wEAAwE,EAAE,KAAK,IAAI,EAAE;QACtF,MAAM,iBAAiB,GAAG,IAAI,qBAAqB,CAAC,KAAK,CAAC,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAA;QAE7D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC,CAAA;IACtE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wEAAwE,EAAE,KAAK,IAAI,EAAE;QACtF,MAAM,iBAAiB,GAAG,IAAI,qBAAqB,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAA;QAE1E,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAA;QAE7D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,+BAA+B,EAAE,CAAC,CAAA;IACnG,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { ReviewFileGateway } from '../../interface-adapters/gateways/reviewFile.gateway.js';
|
|
2
|
+
import type { ReviewLogFileGateway } from '../../interface-adapters/gateways/reviewLogFile.gateway.js';
|
|
3
|
+
export interface CleanupResult {
|
|
4
|
+
deletedReviewFiles: string[];
|
|
5
|
+
deletedLogFiles: string[];
|
|
6
|
+
totalDeletedCount: number;
|
|
7
|
+
}
|
|
8
|
+
export interface CleanupDependencies {
|
|
9
|
+
reviewFileGateway: ReviewFileGateway;
|
|
10
|
+
reviewLogFileGateway: ReviewLogFileGateway;
|
|
11
|
+
}
|
|
12
|
+
export declare function cleanupExpiredReviews(projectPath: string, retentionDays: number, dependencies: CleanupDependencies, now?: Date): Promise<CleanupResult>;
|
|
13
|
+
//# sourceMappingURL=cleanupExpiredReviews.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupExpiredReviews.usecase.d.ts","sourceRoot":"","sources":["../../../src/usecases/cleanup/cleanupExpiredReviews.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qDAAqD,CAAC;AAC7F,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,wDAAwD,CAAC;AAGnG,MAAM,WAAW,aAAa;IAC5B,kBAAkB,EAAE,MAAM,EAAE,CAAC;IAC7B,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,mBAAmB;IAClC,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,oBAAoB,EAAE,oBAAoB,CAAC;CAC5C;AAED,wBAAsB,qBAAqB,CACzC,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,mBAAmB,EACjC,GAAG,GAAE,IAAiB,GACrB,OAAO,CAAC,aAAa,CAAC,CAuBxB"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { RetentionPolicy } from '../../entities/cleanup/retentionPolicy.valueObject.js';
|
|
2
|
+
export async function cleanupExpiredReviews(projectPath, retentionDays, dependencies, now = new Date()) {
|
|
3
|
+
const { reviewFileGateway, reviewLogFileGateway } = dependencies;
|
|
4
|
+
const retentionPolicy = RetentionPolicy.create(retentionDays);
|
|
5
|
+
const deletedReviewFiles = await deleteExpiredReviewFiles(projectPath, retentionPolicy, reviewFileGateway, now);
|
|
6
|
+
const deletedLogFiles = await deleteExpiredLogFiles(projectPath, retentionPolicy, reviewLogFileGateway, now);
|
|
7
|
+
return {
|
|
8
|
+
deletedReviewFiles,
|
|
9
|
+
deletedLogFiles,
|
|
10
|
+
totalDeletedCount: deletedReviewFiles.length + deletedLogFiles.length,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
async function deleteExpiredReviewFiles(projectPath, retentionPolicy, reviewFileGateway, now) {
|
|
14
|
+
const reviews = await reviewFileGateway.listReviews(projectPath);
|
|
15
|
+
const deletedFiles = [];
|
|
16
|
+
for (const review of reviews) {
|
|
17
|
+
const fileDate = new Date(review.date);
|
|
18
|
+
if (retentionPolicy.isExpired(fileDate, now)) {
|
|
19
|
+
const deleted = await reviewFileGateway.deleteReview(projectPath, review.filename);
|
|
20
|
+
if (deleted) {
|
|
21
|
+
deletedFiles.push(review.filename);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return deletedFiles;
|
|
26
|
+
}
|
|
27
|
+
async function deleteExpiredLogFiles(projectPath, retentionPolicy, reviewLogFileGateway, now) {
|
|
28
|
+
const logFiles = await reviewLogFileGateway.listLogFiles(projectPath);
|
|
29
|
+
const deletedFiles = [];
|
|
30
|
+
for (const logFile of logFiles) {
|
|
31
|
+
const fileDate = new Date(logFile.mtime);
|
|
32
|
+
if (retentionPolicy.isExpired(fileDate, now)) {
|
|
33
|
+
const deleted = await reviewLogFileGateway.deleteLogFile(projectPath, logFile.filename);
|
|
34
|
+
if (deleted) {
|
|
35
|
+
deletedFiles.push(logFile.filename);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return deletedFiles;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=cleanupExpiredReviews.usecase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleanupExpiredReviews.usecase.js","sourceRoot":"","sources":["../../../src/usecases/cleanup/cleanupExpiredReviews.usecase.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,mDAAmD,CAAC;AAapF,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,WAAmB,EACnB,aAAqB,EACrB,YAAiC,EACjC,MAAY,IAAI,IAAI,EAAE;IAEtB,MAAM,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,GAAG,YAAY,CAAC;IACjE,MAAM,eAAe,GAAG,eAAe,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAE9D,MAAM,kBAAkB,GAAG,MAAM,wBAAwB,CACvD,WAAW,EACX,eAAe,EACf,iBAAiB,EACjB,GAAG,CACJ,CAAC;IAEF,MAAM,eAAe,GAAG,MAAM,qBAAqB,CACjD,WAAW,EACX,eAAe,EACf,oBAAoB,EACpB,GAAG,CACJ,CAAC;IAEF,OAAO;QACL,kBAAkB;QAClB,eAAe;QACf,iBAAiB,EAAE,kBAAkB,CAAC,MAAM,GAAG,eAAe,CAAC,MAAM;KACtE,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,wBAAwB,CACrC,WAAmB,EACnB,eAAgC,EAChC,iBAAoC,EACpC,GAAS;IAET,MAAM,OAAO,GAAG,MAAM,iBAAiB,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACjE,MAAM,YAAY,GAAa,EAAE,CAAC;IAElC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,eAAe,CAAC,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC;YAC7C,MAAM,OAAO,GAAG,MAAM,iBAAiB,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;YACnF,IAAI,OAAO,EAAE,CAAC;gBACZ,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACrC,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC;AAED,KAAK,UAAU,qBAAqB,CAClC,WAAmB,EACnB,eAAgC,EAChC,oBAA0C,EAC1C,GAAS;IAET,MAAM,QAAQ,GAAG,MAAM,oBAAoB,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;IACtE,MAAM,YAAY,GAAa,EAAE,CAAC;IAElC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACzC,IAAI,eAAe,CAAC,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC;YAC7C,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,aAAa,CAAC,WAAW,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;YACxF,IAAI,OAAO,EAAE,CAAC;gBACZ,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YACtC,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ReviewStats } from '../../entities/stats/projectStats.js';
|
|
2
|
+
import type { TrackedMr } from '../../entities/tracking/trackedMr.js';
|
|
3
|
+
import type { Language } from '../../entities/language/language.schema.js';
|
|
4
|
+
interface BuildAiInsightsPromptInput {
|
|
5
|
+
reviews: ReviewStats[];
|
|
6
|
+
reviewContents: Map<string, string>;
|
|
7
|
+
trackedMrs: TrackedMr[];
|
|
8
|
+
language: Language;
|
|
9
|
+
}
|
|
10
|
+
export declare function buildAiInsightsPrompt(input: BuildAiInsightsPromptInput): string;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=buildAiInsightsPrompt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildAiInsightsPrompt.d.ts","sourceRoot":"","sources":["../../../src/usecases/insights/buildAiInsightsPrompt.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAClE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wCAAwC,CAAC;AAQvE,UAAU,0BAA0B;IAClC,OAAO,EAAE,WAAW,EAAE,CAAC;IACvB,cAAc,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,QAAQ,EAAE,QAAQ,CAAC;CACpB;AA6LD,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,GAAG,MAAM,CAyE/E"}
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
const REVIEW_EXCERPTS_LIMIT = 5;
|
|
2
|
+
const EXCERPT_CHAR_LIMIT = 1500;
|
|
3
|
+
function groupReviewsByDeveloper(reviews) {
|
|
4
|
+
const grouped = new Map();
|
|
5
|
+
for (const review of reviews) {
|
|
6
|
+
if (!review.assignedBy)
|
|
7
|
+
continue;
|
|
8
|
+
const existing = grouped.get(review.assignedBy);
|
|
9
|
+
if (existing) {
|
|
10
|
+
existing.push(review);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
grouped.set(review.assignedBy, [review]);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return grouped;
|
|
17
|
+
}
|
|
18
|
+
function groupTrackedMrsByDeveloper(trackedMrs) {
|
|
19
|
+
const grouped = new Map();
|
|
20
|
+
for (const trackedMr of trackedMrs) {
|
|
21
|
+
const username = trackedMr.assignment.username;
|
|
22
|
+
const existing = grouped.get(username);
|
|
23
|
+
if (existing) {
|
|
24
|
+
existing.push(trackedMr);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
grouped.set(username, [trackedMr]);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
return grouped;
|
|
31
|
+
}
|
|
32
|
+
function computeAverageScore(reviews) {
|
|
33
|
+
const scored = reviews.filter((review) => review.score !== null);
|
|
34
|
+
if (scored.length === 0)
|
|
35
|
+
return 'N/A';
|
|
36
|
+
const average = scored.reduce((sum, review) => sum + (review.score ?? 0), 0) / scored.length;
|
|
37
|
+
return average.toFixed(1);
|
|
38
|
+
}
|
|
39
|
+
function computeAverageBlocking(reviews) {
|
|
40
|
+
if (reviews.length === 0)
|
|
41
|
+
return '0';
|
|
42
|
+
const average = reviews.reduce((sum, review) => sum + review.blocking, 0) / reviews.length;
|
|
43
|
+
return average.toFixed(1);
|
|
44
|
+
}
|
|
45
|
+
function computeAverageWarnings(reviews) {
|
|
46
|
+
if (reviews.length === 0)
|
|
47
|
+
return '0';
|
|
48
|
+
const average = reviews.reduce((sum, review) => sum + review.warnings, 0) / reviews.length;
|
|
49
|
+
return average.toFixed(1);
|
|
50
|
+
}
|
|
51
|
+
function formatDuration(milliseconds) {
|
|
52
|
+
const minutes = Math.round(milliseconds / 60000);
|
|
53
|
+
if (minutes < 60)
|
|
54
|
+
return `${minutes}min`;
|
|
55
|
+
const hours = Math.floor(minutes / 60);
|
|
56
|
+
const remainingMinutes = minutes % 60;
|
|
57
|
+
return `${hours}h ${remainingMinutes}min`;
|
|
58
|
+
}
|
|
59
|
+
function computeFirstPassQualityRate(reviews) {
|
|
60
|
+
const scored = reviews.filter((review) => review.score !== null);
|
|
61
|
+
if (scored.length === 0)
|
|
62
|
+
return 'N/A';
|
|
63
|
+
const highQuality = scored.filter((review) => (review.score ?? 0) >= 7);
|
|
64
|
+
const rate = (highQuality.length / scored.length) * 100;
|
|
65
|
+
return `${rate.toFixed(0)}%`;
|
|
66
|
+
}
|
|
67
|
+
function extractReviewExcerpt(content) {
|
|
68
|
+
const sections = [];
|
|
69
|
+
// Extract executive summary table
|
|
70
|
+
const summaryMatch = content.match(/## Synth[èe]se Ex[ée]cutive[\s\S]*?(?=\n## )/);
|
|
71
|
+
if (summaryMatch) {
|
|
72
|
+
sections.push(summaryMatch[0].trim());
|
|
73
|
+
}
|
|
74
|
+
// Extract score line
|
|
75
|
+
const scoreMatch = content.match(/\*\*Score Global\s*:.*?\*\*/);
|
|
76
|
+
if (scoreMatch) {
|
|
77
|
+
sections.push(scoreMatch[0]);
|
|
78
|
+
}
|
|
79
|
+
// Extract blocking corrections titles only
|
|
80
|
+
const blockingSection = content.match(/## Corrections? (?:Importantes?|Bloquantes?)[\s\S]*?(?=\n## )/g);
|
|
81
|
+
if (blockingSection) {
|
|
82
|
+
for (const section of blockingSection) {
|
|
83
|
+
const titles = section.match(/^### \d+\..+$/gm);
|
|
84
|
+
if (titles) {
|
|
85
|
+
sections.push('Corrections: ' + titles.join(', '));
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
// Extract positive observations titles
|
|
90
|
+
const positiveSection = content.match(/## Constats? Positifs?[\s\S]*?(?=\n## |$)/);
|
|
91
|
+
if (positiveSection) {
|
|
92
|
+
const titles = positiveSection[0].match(/^### \d+\..+$/gm);
|
|
93
|
+
if (titles) {
|
|
94
|
+
sections.push('Points positifs: ' + titles.join(', '));
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
const excerpt = sections.join('\n');
|
|
98
|
+
return excerpt.substring(0, EXCERPT_CHAR_LIMIT);
|
|
99
|
+
}
|
|
100
|
+
function buildDeveloperSection(developer, reviewContents) {
|
|
101
|
+
const { name, reviews, trackedMrs } = developer;
|
|
102
|
+
const sortedReviews = [...reviews].sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime());
|
|
103
|
+
const averageScore = computeAverageScore(reviews);
|
|
104
|
+
const averageBlocking = computeAverageBlocking(reviews);
|
|
105
|
+
const averageWarnings = computeAverageWarnings(reviews);
|
|
106
|
+
const averageDuration = reviews.length > 0
|
|
107
|
+
? formatDuration(reviews.reduce((sum, review) => sum + review.duration, 0) / reviews.length)
|
|
108
|
+
: 'N/A';
|
|
109
|
+
const firstPassRate = computeFirstPassQualityRate(reviews);
|
|
110
|
+
const totalAdditions = reviews.reduce((sum, review) => sum + (review.diffStats?.additions ?? 0), 0);
|
|
111
|
+
const totalDeletions = reviews.reduce((sum, review) => sum + (review.diffStats?.deletions ?? 0), 0);
|
|
112
|
+
let section = `### Developer: ${name} (${reviews.length} reviews)\n`;
|
|
113
|
+
section += `- Average score: ${averageScore}/10\n`;
|
|
114
|
+
section += `- Average blocking issues: ${averageBlocking}/review\n`;
|
|
115
|
+
section += `- Average warnings: ${averageWarnings}/review\n`;
|
|
116
|
+
section += `- Average review duration: ${averageDuration}\n`;
|
|
117
|
+
section += `- First-pass quality rate: ${firstPassRate} (reviews scoring >= 7 on first try)\n`;
|
|
118
|
+
section += `- Total additions: ${totalAdditions}, deletions: ${totalDeletions}\n`;
|
|
119
|
+
const reviewExcerpts = [];
|
|
120
|
+
for (let index = 0; index < Math.min(sortedReviews.length, REVIEW_EXCERPTS_LIMIT); index++) {
|
|
121
|
+
const review = sortedReviews[index];
|
|
122
|
+
const mrKey = String(review.mrNumber);
|
|
123
|
+
const content = reviewContents.get(mrKey);
|
|
124
|
+
if (content) {
|
|
125
|
+
const excerpt = extractReviewExcerpt(content);
|
|
126
|
+
if (excerpt.length > 0) {
|
|
127
|
+
reviewExcerpts.push(`--- MR ${review.mrNumber} (score: ${review.score ?? 'N/A'}) ---\n${excerpt}`);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
if (reviewExcerpts.length > 0) {
|
|
132
|
+
section += `\nRecent review excerpts:\n${reviewExcerpts.join('\n\n')}\n`;
|
|
133
|
+
}
|
|
134
|
+
if (trackedMrs.length > 0) {
|
|
135
|
+
const totalMrReviews = trackedMrs.reduce((sum, mr) => sum + mr.totalReviews, 0);
|
|
136
|
+
const totalFollowups = trackedMrs.reduce((sum, mr) => sum + mr.totalFollowups, 0);
|
|
137
|
+
const approvedFirst = trackedMrs.filter((mr) => mr.totalReviews <= 1 && mr.state === 'approved').length;
|
|
138
|
+
section += `\n### MR Lifecycle for ${name}:\n`;
|
|
139
|
+
section += `- Total MRs: ${trackedMrs.length}\n`;
|
|
140
|
+
section += `- Total reviews across MRs: ${totalMrReviews}\n`;
|
|
141
|
+
section += `- Total followups: ${totalFollowups}\n`;
|
|
142
|
+
section += `- MRs approved on first review: ${approvedFirst}\n`;
|
|
143
|
+
}
|
|
144
|
+
return section;
|
|
145
|
+
}
|
|
146
|
+
function buildTeamSection(reviews, developerCount) {
|
|
147
|
+
const averageScore = computeAverageScore(reviews);
|
|
148
|
+
const averageBlocking = computeAverageBlocking(reviews);
|
|
149
|
+
let section = '### Team Statistics:\n';
|
|
150
|
+
section += `- Team average score: ${averageScore}/10\n`;
|
|
151
|
+
section += `- Team average blocking: ${averageBlocking}/review\n`;
|
|
152
|
+
section += `- Total reviews: ${reviews.length}\n`;
|
|
153
|
+
section += `- Developers: ${developerCount}\n`;
|
|
154
|
+
return section;
|
|
155
|
+
}
|
|
156
|
+
export function buildAiInsightsPrompt(input) {
|
|
157
|
+
const { reviews, reviewContents, trackedMrs, language } = input;
|
|
158
|
+
const reviewsByDeveloper = groupReviewsByDeveloper(reviews);
|
|
159
|
+
const trackedMrsByDeveloper = groupTrackedMrsByDeveloper(trackedMrs);
|
|
160
|
+
const developerSections = [];
|
|
161
|
+
for (const [name, developerReviews] of reviewsByDeveloper) {
|
|
162
|
+
const developerTrackedMrs = trackedMrsByDeveloper.get(name) ?? [];
|
|
163
|
+
const section = buildDeveloperSection({ name, reviews: developerReviews, trackedMrs: developerTrackedMrs }, reviewContents);
|
|
164
|
+
developerSections.push(section);
|
|
165
|
+
}
|
|
166
|
+
const teamSection = buildTeamSection(reviews, reviewsByDeveloper.size);
|
|
167
|
+
const developerNames = Array.from(reviewsByDeveloper.keys());
|
|
168
|
+
const prompt = `You are a senior engineering manager analyzing code review data for a development team.
|
|
169
|
+
Analyze this data and produce structured insights.
|
|
170
|
+
|
|
171
|
+
## Data
|
|
172
|
+
|
|
173
|
+
${developerSections.join('\n\n')}
|
|
174
|
+
|
|
175
|
+
${teamSection}
|
|
176
|
+
|
|
177
|
+
## MANDATORY OUTPUT FORMAT
|
|
178
|
+
|
|
179
|
+
You MUST return a valid JSON object matching this EXACT schema. Every field is REQUIRED and non-empty.
|
|
180
|
+
|
|
181
|
+
\`\`\`json
|
|
182
|
+
{
|
|
183
|
+
"developers": [
|
|
184
|
+
${developerNames.map(name => `{
|
|
185
|
+
"developerName": "${name}",
|
|
186
|
+
"title": "<string: creative title in ${language === 'fr' ? 'French' : 'English'}, e.g. 'Le Chirurgien du Code'>",
|
|
187
|
+
"titleExplanation": "<string: one sentence why this title fits, with data reference>",
|
|
188
|
+
"strengths": ["<string: concrete strength with numbers>", "<at least 1 item>"],
|
|
189
|
+
"weaknesses": ["<string: concrete weakness with numbers>", "<at least 1 item>"],
|
|
190
|
+
"recommendations": ["<string: actionable recommendation>", "<at least 1 item>"],
|
|
191
|
+
"summary": "<string: 2-3 sentences profiling coding style and quality>"
|
|
192
|
+
}`).join(',\n ')}
|
|
193
|
+
],
|
|
194
|
+
"team": {
|
|
195
|
+
"summary": "<string: 2-3 sentences about team dynamics>",
|
|
196
|
+
"strengths": ["<string: team strength>", "<at least 1 item>"],
|
|
197
|
+
"weaknesses": ["<string: team weakness>", "<at least 1 item>"],
|
|
198
|
+
"recommendations": ["<string: team recommendation>", "<at least 1 item>"],
|
|
199
|
+
"dynamics": "<string: analysis of team balance, complementary skills, knowledge gaps>"
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
\`\`\`
|
|
203
|
+
|
|
204
|
+
## RULES (violations = invalid output)
|
|
205
|
+
|
|
206
|
+
1. Language: ALL text in ${language === 'fr' ? 'French' : 'English'}
|
|
207
|
+
2. Every developer listed above MUST appear in "developers" array with EXACT username
|
|
208
|
+
3. "strengths", "weaknesses", "recommendations" arrays must each have AT LEAST 1 item
|
|
209
|
+
4. Reference specific data points: scores, percentages, blocking counts, durations
|
|
210
|
+
5. Be direct and honest -- do not sugarcoat weaknesses
|
|
211
|
+
6. Titles must be creative and unique per developer (no two developers share the same title)
|
|
212
|
+
7. Recommendations must be actionable (NOT "improve quality" but "review architecture before implementation to reduce the 1.3 blocking issues/review")
|
|
213
|
+
8. "summary" must mention the developer's average score and key characteristic
|
|
214
|
+
|
|
215
|
+
## OUTPUT
|
|
216
|
+
|
|
217
|
+
Return ONLY the JSON object. No markdown fences. No explanation before or after. No trailing text.`;
|
|
218
|
+
return prompt;
|
|
219
|
+
}
|
|
220
|
+
//# sourceMappingURL=buildAiInsightsPrompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildAiInsightsPrompt.js","sourceRoot":"","sources":["../../../src/usecases/insights/buildAiInsightsPrompt.ts"],"names":[],"mappings":"AAiBA,MAAM,qBAAqB,GAAG,CAAC,CAAC;AAChC,MAAM,kBAAkB,GAAG,IAAI,CAAC;AAEhC,SAAS,uBAAuB,CAAC,OAAsB;IACrD,MAAM,OAAO,GAAG,IAAI,GAAG,EAAyB,CAAC;IAEjD,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,UAAU;YAAE,SAAS;QAEjC,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAChD,IAAI,QAAQ,EAAE,CAAC;YACb,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,0BAA0B,CAAC,UAAuB;IACzD,MAAM,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;IAE/C,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC;QAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACvC,IAAI,QAAQ,EAAE,CAAC;YACb,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,mBAAmB,CAAC,OAAsB;IACjD,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC;IACjE,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACtC,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC;IAC7F,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAsB;IACpD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAC;IACrC,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAC3F,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAsB;IACpD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,GAAG,CAAC;IACrC,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAC3F,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;AAC5B,CAAC;AAED,SAAS,cAAc,CAAC,YAAoB;IAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,CAAC;IACjD,IAAI,OAAO,GAAG,EAAE;QAAE,OAAO,GAAG,OAAO,KAAK,CAAC;IACzC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC;IACvC,MAAM,gBAAgB,GAAG,OAAO,GAAG,EAAE,CAAC;IACtC,OAAO,GAAG,KAAK,KAAK,gBAAgB,KAAK,CAAC;AAC5C,CAAC;AAED,SAAS,2BAA2B,CAAC,OAAsB;IACzD,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC;IACjE,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACtC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACxE,MAAM,IAAI,GAAG,CAAC,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC;IACxD,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;AAC/B,CAAC;AAED,SAAS,oBAAoB,CAAC,OAAe;IAC3C,MAAM,QAAQ,GAAa,EAAE,CAAC;IAE9B,kCAAkC;IAClC,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,8CAA8C,CAAC,CAAC;IACnF,IAAI,YAAY,EAAE,CAAC;QACjB,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,qBAAqB;IACrB,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;IAChE,IAAI,UAAU,EAAE,CAAC;QACf,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC;IAED,2CAA2C;IAC3C,MAAM,eAAe,GAAG,OAAO,CAAC,KAAK,CAAC,gEAAgE,CAAC,CAAC;IACxG,IAAI,eAAe,EAAE,CAAC;QACpB,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE,CAAC;YACtC,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;YAChD,IAAI,MAAM,EAAE,CAAC;gBACX,QAAQ,CAAC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YACrD,CAAC;QACH,CAAC;IACH,CAAC;IAED,uCAAuC;IACvC,MAAM,eAAe,GAAG,OAAO,CAAC,KAAK,CAAC,2CAA2C,CAAC,CAAC;IACnF,IAAI,eAAe,EAAE,CAAC;QACpB,MAAM,MAAM,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAC3D,IAAI,MAAM,EAAE,CAAC;YACX,QAAQ,CAAC,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,OAAO,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,kBAAkB,CAAC,CAAC;AAClD,CAAC;AAED,SAAS,qBAAqB,CAC5B,SAAwB,EACxB,cAAmC;IAEnC,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,SAAS,CAAC;IAEhD,MAAM,aAAa,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CACrC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAC5E,CAAC;IAEF,MAAM,YAAY,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAClD,MAAM,eAAe,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,eAAe,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;IACxD,MAAM,eAAe,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC;QACxC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;QAC5F,CAAC,CAAC,KAAK,CAAC;IACV,MAAM,aAAa,GAAG,2BAA2B,CAAC,OAAO,CAAC,CAAC;IAC3D,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,CAAC,EAAE,CAAC,CAC7D,CAAC;IACF,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,IAAI,CAAC,CAAC,EAAE,CAAC,CAC7D,CAAC;IAEF,IAAI,OAAO,GAAG,kBAAkB,IAAI,KAAK,OAAO,CAAC,MAAM,aAAa,CAAC;IACrE,OAAO,IAAI,oBAAoB,YAAY,OAAO,CAAC;IACnD,OAAO,IAAI,8BAA8B,eAAe,WAAW,CAAC;IACpE,OAAO,IAAI,uBAAuB,eAAe,WAAW,CAAC;IAC7D,OAAO,IAAI,8BAA8B,eAAe,IAAI,CAAC;IAC7D,OAAO,IAAI,8BAA8B,aAAa,wCAAwC,CAAC;IAC/F,OAAO,IAAI,sBAAsB,cAAc,gBAAgB,cAAc,IAAI,CAAC;IAElF,MAAM,cAAc,GAAa,EAAE,CAAC;IACpC,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,MAAM,EAAE,qBAAqB,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;QAC3F,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;QACpC,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,OAAO,GAAG,oBAAoB,CAAC,OAAO,CAAC,CAAC;YAC9C,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvB,cAAc,CAAC,IAAI,CAAC,UAAU,MAAM,CAAC,QAAQ,YAAY,MAAM,CAAC,KAAK,IAAI,KAAK,UAAU,OAAO,EAAE,CAAC,CAAC;YACrG,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC9B,OAAO,IAAI,8BAA8B,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;IAC3E,CAAC;IAED,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1B,MAAM,cAAc,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAChF,MAAM,cAAc,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QAClF,MAAM,aAAa,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,YAAY,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;QAExG,OAAO,IAAI,0BAA0B,IAAI,KAAK,CAAC;QAC/C,OAAO,IAAI,gBAAgB,UAAU,CAAC,MAAM,IAAI,CAAC;QACjD,OAAO,IAAI,+BAA+B,cAAc,IAAI,CAAC;QAC7D,OAAO,IAAI,sBAAsB,cAAc,IAAI,CAAC;QACpD,OAAO,IAAI,mCAAmC,aAAa,IAAI,CAAC;IAClE,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,gBAAgB,CAAC,OAAsB,EAAE,cAAsB;IACtE,MAAM,YAAY,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAClD,MAAM,eAAe,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC;IAExD,IAAI,OAAO,GAAG,wBAAwB,CAAC;IACvC,OAAO,IAAI,yBAAyB,YAAY,OAAO,CAAC;IACxD,OAAO,IAAI,4BAA4B,eAAe,WAAW,CAAC;IAClE,OAAO,IAAI,oBAAoB,OAAO,CAAC,MAAM,IAAI,CAAC;IAClD,OAAO,IAAI,iBAAiB,cAAc,IAAI,CAAC;IAE/C,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,KAAiC;IACrE,MAAM,EAAE,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;IAEhE,MAAM,kBAAkB,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;IAC5D,MAAM,qBAAqB,GAAG,0BAA0B,CAAC,UAAU,CAAC,CAAC;IAErE,MAAM,iBAAiB,GAAa,EAAE,CAAC;IAEvC,KAAK,MAAM,CAAC,IAAI,EAAE,gBAAgB,CAAC,IAAI,kBAAkB,EAAE,CAAC;QAC1D,MAAM,mBAAmB,GAAG,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAClE,MAAM,OAAO,GAAG,qBAAqB,CACnC,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,mBAAmB,EAAE,EACpE,cAAc,CACf,CAAC;QACF,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,MAAM,WAAW,GAAG,gBAAgB,CAAC,OAAO,EAAE,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAEvE,MAAM,cAAc,GAAG,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC;IAE7D,MAAM,MAAM,GAAG;;;;;EAKf,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC;;EAE9B,WAAW;;;;;;;;;MASP,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;0BACP,IAAI;6CACe,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;;;;MAM/E,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;;;;;;;;;;;;;;2BAcI,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;;;;;;;;;mGAWgC,CAAC;IAElG,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ReviewStats } from '../../entities/stats/projectStats.js';
|
|
2
|
+
import type { DeveloperInsight } from '../../entities/insight/developerInsight.js';
|
|
3
|
+
export declare function computeDeveloperInsights(reviews: ReviewStats[]): DeveloperInsight[];
|
|
4
|
+
//# sourceMappingURL=computeDeveloperInsights.usecase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"computeDeveloperInsights.usecase.d.ts","sourceRoot":"","sources":["../../../src/usecases/insights/computeDeveloperInsights.usecase.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,KAAK,EAAE,gBAAgB,EAAsC,MAAM,wCAAwC,CAAC;AAoBnH,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,WAAW,EAAE,GAAG,gBAAgB,EAAE,CAyBnF"}
|