reviewflow 3.7.0 → 3.8.1
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 +19 -0
- package/README.md +28 -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 +3 -0
- package/dist/entities/packageVersion/packageVersion.d.ts.map +1 -1
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts +2 -1
- package/dist/entities/packageVersion/selfUpdateCommand.gateway.d.ts.map +1 -1
- 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 +3 -0
- package/dist/entities/stats/projectStats.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/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/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/version.routes.d.ts +1 -0
- package/dist/interface-adapters/controllers/http/version.routes.d.ts.map +1 -1
- package/dist/interface-adapters/controllers/http/version.routes.js +4 -1
- package/dist/interface-adapters/controllers/http/version.routes.js.map +1 -1
- 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/reviewFile.gateway.d.ts +1 -17
- package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -1
- 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 +3 -2
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.d.ts.map +1 -1
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js +29 -15
- package/dist/interface-adapters/gateways/selfUpdate.cli.gateway.js.map +1 -1
- 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 +242 -2
- 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 +201 -1
- 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/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/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/styles.css +967 -0
- package/dist/main/dependencies.d.ts +2 -0
- package/dist/main/dependencies.d.ts.map +1 -1
- package/dist/main/dependencies.js +2 -0
- package/dist/main/dependencies.js.map +1 -1
- package/dist/main/routes.d.ts.map +1 -1
- package/dist/main/routes.js +13 -0
- package/dist/main/routes.js.map +1 -1
- package/dist/services/statsService.d.ts.map +1 -1
- package/dist/services/statsService.js +46 -27
- package/dist/services/statsService.js.map +1 -1
- 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/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/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/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/reviewFile.stub.d.ts +1 -1
- package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -1
- 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 +4 -2
- package/dist/tests/stubs/selfUpdate.stub.d.ts.map +1 -1
- package/dist/tests/stubs/selfUpdate.stub.js +6 -4
- package/dist/tests/stubs/selfUpdate.stub.js.map +1 -1
- 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/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/version.routes.test.js +25 -0
- package/dist/tests/units/interface-adapters/controllers/http/version.routes.test.js.map +1 -1
- 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/selfUpdate.cli.gateway.test.js +84 -16
- package/dist/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.js.map +1 -1
- 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/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/version/triggerSelfUpdate.usecase.test.js +5 -0
- package/dist/tests/units/usecases/version/triggerSelfUpdate.usecase.test.js.map +1 -1
- 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/version/triggerSelfUpdate.usecase.d.ts.map +1 -1
- package/dist/usecases/version/triggerSelfUpdate.usecase.js +3 -0
- package/dist/usecases/version/triggerSelfUpdate.usecase.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import { mkdirSync, rmSync, existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { tmpdir } from 'node:os';
|
|
5
|
+
import { FileSystemInsightsGateway } from '../../../../interface-adapters/gateways/fileSystem/insights.fileSystem.js';
|
|
6
|
+
describe('FileSystemInsightsGateway', () => {
|
|
7
|
+
let gateway;
|
|
8
|
+
let temporaryDirectory;
|
|
9
|
+
beforeEach(() => {
|
|
10
|
+
gateway = new FileSystemInsightsGateway();
|
|
11
|
+
temporaryDirectory = join(tmpdir(), `insights-test-${Date.now()}`);
|
|
12
|
+
mkdirSync(temporaryDirectory, { recursive: true });
|
|
13
|
+
});
|
|
14
|
+
afterEach(() => {
|
|
15
|
+
if (existsSync(temporaryDirectory)) {
|
|
16
|
+
rmSync(temporaryDirectory, { recursive: true, force: true });
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
describe('loadPersistedInsights', () => {
|
|
20
|
+
it('should return null when file does not exist', () => {
|
|
21
|
+
const result = gateway.loadPersistedInsights(temporaryDirectory);
|
|
22
|
+
expect(result).toBeNull();
|
|
23
|
+
});
|
|
24
|
+
it('should load valid persisted insights data from file', () => {
|
|
25
|
+
const insightsData = {
|
|
26
|
+
developers: [],
|
|
27
|
+
processedReviewIds: ['review-1'],
|
|
28
|
+
lastUpdated: '2024-01-15T10:00:00Z',
|
|
29
|
+
aiInsights: null,
|
|
30
|
+
reviewCountAtAiGeneration: 0,
|
|
31
|
+
};
|
|
32
|
+
const insightsPath = join(temporaryDirectory, '.claude', 'reviews', 'insights.json');
|
|
33
|
+
mkdirSync(join(temporaryDirectory, '.claude', 'reviews'), { recursive: true });
|
|
34
|
+
writeFileSync(insightsPath, JSON.stringify(insightsData), 'utf-8');
|
|
35
|
+
const result = gateway.loadPersistedInsights(temporaryDirectory);
|
|
36
|
+
expect(result).toEqual(insightsData);
|
|
37
|
+
});
|
|
38
|
+
it('should return null when file contains invalid JSON', () => {
|
|
39
|
+
const insightsPath = join(temporaryDirectory, '.claude', 'reviews', 'insights.json');
|
|
40
|
+
mkdirSync(join(temporaryDirectory, '.claude', 'reviews'), { recursive: true });
|
|
41
|
+
writeFileSync(insightsPath, 'not valid json', 'utf-8');
|
|
42
|
+
const result = gateway.loadPersistedInsights(temporaryDirectory);
|
|
43
|
+
expect(result).toBeNull();
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
describe('savePersistedInsights', () => {
|
|
47
|
+
it('should save persisted insights data to file', () => {
|
|
48
|
+
const insightsData = {
|
|
49
|
+
developers: [{
|
|
50
|
+
developerName: 'alice',
|
|
51
|
+
totalReviews: 10,
|
|
52
|
+
totalScore: 75,
|
|
53
|
+
scoredReviewCount: 9,
|
|
54
|
+
totalBlocking: 5,
|
|
55
|
+
totalWarnings: 12,
|
|
56
|
+
totalSuggestions: 20,
|
|
57
|
+
totalDuration: 600000,
|
|
58
|
+
totalAdditions: 1500,
|
|
59
|
+
totalDeletions: 300,
|
|
60
|
+
diffStatsReviewCount: 8,
|
|
61
|
+
recentReviews: [],
|
|
62
|
+
}],
|
|
63
|
+
processedReviewIds: ['review-1'],
|
|
64
|
+
lastUpdated: '2024-01-15T10:00:00Z',
|
|
65
|
+
aiInsights: null,
|
|
66
|
+
reviewCountAtAiGeneration: 0,
|
|
67
|
+
};
|
|
68
|
+
gateway.savePersistedInsights(temporaryDirectory, insightsData);
|
|
69
|
+
const insightsPath = join(temporaryDirectory, '.claude', 'reviews', 'insights.json');
|
|
70
|
+
expect(existsSync(insightsPath)).toBe(true);
|
|
71
|
+
const content = readFileSync(insightsPath, 'utf-8');
|
|
72
|
+
const parsed = JSON.parse(content);
|
|
73
|
+
expect(parsed.developers).toHaveLength(1);
|
|
74
|
+
expect(parsed.developers[0].developerName).toBe('alice');
|
|
75
|
+
});
|
|
76
|
+
it('should create directory structure if it does not exist', () => {
|
|
77
|
+
const insightsData = {
|
|
78
|
+
developers: [],
|
|
79
|
+
processedReviewIds: [],
|
|
80
|
+
lastUpdated: '2024-01-15T10:00:00Z',
|
|
81
|
+
aiInsights: null,
|
|
82
|
+
reviewCountAtAiGeneration: 0,
|
|
83
|
+
};
|
|
84
|
+
gateway.savePersistedInsights(temporaryDirectory, insightsData);
|
|
85
|
+
const dirPath = join(temporaryDirectory, '.claude', 'reviews');
|
|
86
|
+
expect(existsSync(dirPath)).toBe(true);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
describe('round-trip', () => {
|
|
90
|
+
it('should save and load the same data', () => {
|
|
91
|
+
const insightsData = {
|
|
92
|
+
developers: [{
|
|
93
|
+
developerName: 'bob',
|
|
94
|
+
totalReviews: 5,
|
|
95
|
+
totalScore: 40,
|
|
96
|
+
scoredReviewCount: 5,
|
|
97
|
+
totalBlocking: 2,
|
|
98
|
+
totalWarnings: 8,
|
|
99
|
+
totalSuggestions: 10,
|
|
100
|
+
totalDuration: 300000,
|
|
101
|
+
totalAdditions: 800,
|
|
102
|
+
totalDeletions: 200,
|
|
103
|
+
diffStatsReviewCount: 5,
|
|
104
|
+
recentReviews: [],
|
|
105
|
+
}],
|
|
106
|
+
processedReviewIds: ['rev-1', 'rev-2'],
|
|
107
|
+
lastUpdated: '2024-01-15T10:00:00Z',
|
|
108
|
+
aiInsights: null,
|
|
109
|
+
reviewCountAtAiGeneration: 0,
|
|
110
|
+
};
|
|
111
|
+
gateway.savePersistedInsights(temporaryDirectory, insightsData);
|
|
112
|
+
const loaded = gateway.loadPersistedInsights(temporaryDirectory);
|
|
113
|
+
expect(loaded).toEqual(insightsData);
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
//# sourceMappingURL=insights.gateway.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insights.gateway.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/interface-adapters/gateways/insights.gateway.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,32 +1,100 @@
|
|
|
1
|
-
import { describe, it, expect, vi } from 'vitest';
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
2
2
|
import { SelfUpdateCliGateway } from '../../../../interface-adapters/gateways/selfUpdate.cli.gateway.js';
|
|
3
|
+
import { writePidFile, removePidFile } from '../../../../shared/services/pidFileManager.js';
|
|
4
|
+
import { PID_FILE_PATH } from '../../../../shared/services/daemonPaths.js';
|
|
5
|
+
function createFakeDependencies(overrides) {
|
|
6
|
+
return {
|
|
7
|
+
execFileAsync: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
8
|
+
killProcess: vi.fn(),
|
|
9
|
+
spawnDaemonDelayed: vi.fn(),
|
|
10
|
+
...overrides,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
3
13
|
describe('SelfUpdateCliGateway', () => {
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
removePidFile(PID_FILE_PATH);
|
|
16
|
+
});
|
|
4
17
|
describe('runGlobalUpdate', () => {
|
|
5
18
|
it('should return success when npm update succeeds', async () => {
|
|
6
|
-
const
|
|
7
|
-
const gateway = new SelfUpdateCliGateway(
|
|
19
|
+
const deps = createFakeDependencies();
|
|
20
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
8
21
|
const result = await gateway.runGlobalUpdate();
|
|
9
22
|
expect(result.success).toBe(true);
|
|
10
|
-
expect(
|
|
23
|
+
expect(result.permissionDenied).toBe(false);
|
|
24
|
+
expect(deps.execFileAsync).toHaveBeenCalledWith('npm', ['update', '-g', 'reviewflow']);
|
|
11
25
|
});
|
|
12
|
-
it('should return
|
|
13
|
-
const
|
|
14
|
-
|
|
26
|
+
it('should return permissionDenied true on EACCES error', async () => {
|
|
27
|
+
const deps = createFakeDependencies({
|
|
28
|
+
execFileAsync: vi.fn().mockRejectedValue(new Error('EACCES: permission denied')),
|
|
29
|
+
});
|
|
30
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
15
31
|
const result = await gateway.runGlobalUpdate();
|
|
16
32
|
expect(result.success).toBe(false);
|
|
17
|
-
expect(result.
|
|
33
|
+
expect(result.permissionDenied).toBe(true);
|
|
34
|
+
expect(result.error).toBe('EACCES: permission denied');
|
|
35
|
+
});
|
|
36
|
+
it('should return permissionDenied false on non-EACCES error', async () => {
|
|
37
|
+
const deps = createFakeDependencies({
|
|
38
|
+
execFileAsync: vi.fn().mockRejectedValue(new Error('network error')),
|
|
39
|
+
});
|
|
40
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
41
|
+
const result = await gateway.runGlobalUpdate();
|
|
42
|
+
expect(result.success).toBe(false);
|
|
43
|
+
expect(result.permissionDenied).toBe(false);
|
|
44
|
+
expect(result.error).toBe('network error');
|
|
18
45
|
});
|
|
19
46
|
});
|
|
20
47
|
describe('restartDaemon', () => {
|
|
21
|
-
it('should
|
|
22
|
-
const
|
|
23
|
-
const gateway = new SelfUpdateCliGateway(
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
48
|
+
it('should use server port when no pid file exists', async () => {
|
|
49
|
+
const deps = createFakeDependencies();
|
|
50
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
51
|
+
await gateway.restartDaemon(3847);
|
|
52
|
+
expect(deps.spawnDaemonDelayed).toHaveBeenCalledWith(3847, expect.any(Number));
|
|
53
|
+
});
|
|
54
|
+
it('should use pid file port over server port when pid file exists', async () => {
|
|
55
|
+
writePidFile(PID_FILE_PATH, { pid: 9999, startedAt: new Date().toISOString(), port: 4000 });
|
|
56
|
+
const deps = createFakeDependencies();
|
|
57
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
58
|
+
await gateway.restartDaemon(3847);
|
|
59
|
+
expect(deps.spawnDaemonDelayed).toHaveBeenCalledWith(4000, expect.any(Number));
|
|
60
|
+
});
|
|
61
|
+
it('should kill process from pid file when it exists', async () => {
|
|
62
|
+
writePidFile(PID_FILE_PATH, { pid: 9999, startedAt: new Date().toISOString(), port: 4000 });
|
|
63
|
+
const deps = createFakeDependencies();
|
|
64
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
65
|
+
await gateway.restartDaemon(3847);
|
|
66
|
+
expect(deps.killProcess).toHaveBeenCalledWith(9999, 'SIGTERM');
|
|
67
|
+
});
|
|
68
|
+
it('should kill current process when no pid file exists', async () => {
|
|
69
|
+
const deps = createFakeDependencies();
|
|
70
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
71
|
+
await gateway.restartDaemon(3847);
|
|
72
|
+
expect(deps.killProcess).toHaveBeenCalledWith(process.pid, 'SIGTERM');
|
|
73
|
+
});
|
|
74
|
+
it('should spawn delayed daemon before killing process', async () => {
|
|
75
|
+
const callOrder = [];
|
|
76
|
+
const deps = createFakeDependencies({
|
|
77
|
+
spawnDaemonDelayed: vi.fn(() => { callOrder.push('spawn'); }),
|
|
78
|
+
killProcess: vi.fn(() => { callOrder.push('kill'); }),
|
|
27
79
|
});
|
|
28
|
-
|
|
29
|
-
|
|
80
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
81
|
+
await gateway.restartDaemon(3847);
|
|
82
|
+
expect(callOrder).toEqual(['spawn', 'kill']);
|
|
83
|
+
});
|
|
84
|
+
it('should not throw when kill process fails', async () => {
|
|
85
|
+
const deps = createFakeDependencies({
|
|
86
|
+
killProcess: vi.fn(() => { throw new Error('No such process'); }),
|
|
87
|
+
});
|
|
88
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
89
|
+
await expect(gateway.restartDaemon(3847)).resolves.not.toThrow();
|
|
90
|
+
});
|
|
91
|
+
it('should remove pid file before spawning', async () => {
|
|
92
|
+
writePidFile(PID_FILE_PATH, { pid: 9999, startedAt: new Date().toISOString(), port: 4000 });
|
|
93
|
+
const deps = createFakeDependencies();
|
|
94
|
+
const gateway = new SelfUpdateCliGateway(deps);
|
|
95
|
+
await gateway.restartDaemon(3847);
|
|
96
|
+
const { readPidFile } = await import('../../../../shared/services/pidFileManager.js');
|
|
97
|
+
expect(readPidFile(PID_FILE_PATH)).toBeNull();
|
|
30
98
|
});
|
|
31
99
|
});
|
|
32
100
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"selfUpdate.cli.gateway.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;
|
|
1
|
+
{"version":3,"file":"selfUpdate.cli.gateway.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/interface-adapters/gateways/selfUpdate.cli.gateway.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insights.presenter.test.d.ts","sourceRoot":"","sources":["../../../../../src/tests/units/interface-adapters/presenters/insights.presenter.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { InsightsPresenter } from '../../../../interface-adapters/presenters/insights.presenter.js';
|
|
3
|
+
import { DeveloperInsightFactory } from '../../../../tests/factories/developerInsight.factory.js';
|
|
4
|
+
import { TeamInsightFactory } from '../../../../tests/factories/teamInsight.factory.js';
|
|
5
|
+
describe('InsightsPresenter', () => {
|
|
6
|
+
const presenter = new InsightsPresenter();
|
|
7
|
+
it('should present empty state when no developers', () => {
|
|
8
|
+
const developerInsights = [];
|
|
9
|
+
const teamInsight = TeamInsightFactory.createValid({
|
|
10
|
+
developerCount: 0,
|
|
11
|
+
totalReviewCount: 0,
|
|
12
|
+
strengths: [],
|
|
13
|
+
weaknesses: [],
|
|
14
|
+
tips: [],
|
|
15
|
+
});
|
|
16
|
+
const viewModel = presenter.present({
|
|
17
|
+
developerInsights,
|
|
18
|
+
teamInsight,
|
|
19
|
+
});
|
|
20
|
+
expect(viewModel.isEmpty).toBe(true);
|
|
21
|
+
expect(viewModel.developers).toEqual([]);
|
|
22
|
+
});
|
|
23
|
+
it('should present developer cards sorted by overall level descending', () => {
|
|
24
|
+
const developerInsights = [
|
|
25
|
+
DeveloperInsightFactory.createValid({
|
|
26
|
+
developerName: 'alice',
|
|
27
|
+
overallLevel: 5,
|
|
28
|
+
}),
|
|
29
|
+
DeveloperInsightFactory.createValid({
|
|
30
|
+
developerName: 'bob',
|
|
31
|
+
overallLevel: 8,
|
|
32
|
+
}),
|
|
33
|
+
DeveloperInsightFactory.createValid({
|
|
34
|
+
developerName: 'charlie',
|
|
35
|
+
overallLevel: 6,
|
|
36
|
+
}),
|
|
37
|
+
];
|
|
38
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 3 });
|
|
39
|
+
const viewModel = presenter.present({
|
|
40
|
+
developerInsights,
|
|
41
|
+
teamInsight,
|
|
42
|
+
});
|
|
43
|
+
expect(viewModel.developers[0].developerName).toBe('bob');
|
|
44
|
+
expect(viewModel.developers[1].developerName).toBe('charlie');
|
|
45
|
+
expect(viewModel.developers[2].developerName).toBe('alice');
|
|
46
|
+
});
|
|
47
|
+
it('should include all category levels for each developer', () => {
|
|
48
|
+
const developerInsights = [
|
|
49
|
+
DeveloperInsightFactory.createValid({
|
|
50
|
+
developerName: 'alice',
|
|
51
|
+
categoryLevels: {
|
|
52
|
+
quality: { level: 8, trend: 'improving' },
|
|
53
|
+
responsiveness: { level: 6, trend: 'stable' },
|
|
54
|
+
codeVolume: { level: 7, trend: 'stable' },
|
|
55
|
+
iteration: { level: 5, trend: 'declining' },
|
|
56
|
+
},
|
|
57
|
+
}),
|
|
58
|
+
];
|
|
59
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 1 });
|
|
60
|
+
const viewModel = presenter.present({
|
|
61
|
+
developerInsights,
|
|
62
|
+
teamInsight,
|
|
63
|
+
});
|
|
64
|
+
const alice = viewModel.developers[0];
|
|
65
|
+
expect(alice.categoryLevels.quality.level).toBe(8);
|
|
66
|
+
expect(alice.categoryLevels.quality.trend).toBe('improving');
|
|
67
|
+
expect(alice.categoryLevels.responsiveness.level).toBe(6);
|
|
68
|
+
expect(alice.categoryLevels.iteration.trend).toBe('declining');
|
|
69
|
+
});
|
|
70
|
+
it('should present team insights section', () => {
|
|
71
|
+
const developerInsights = [
|
|
72
|
+
DeveloperInsightFactory.createValid({ developerName: 'alice' }),
|
|
73
|
+
];
|
|
74
|
+
const teamInsight = TeamInsightFactory.createValid({
|
|
75
|
+
developerCount: 1,
|
|
76
|
+
strengths: ['quality'],
|
|
77
|
+
weaknesses: ['responsiveness'],
|
|
78
|
+
tips: ['Improve response times'],
|
|
79
|
+
});
|
|
80
|
+
const viewModel = presenter.present({
|
|
81
|
+
developerInsights,
|
|
82
|
+
teamInsight,
|
|
83
|
+
});
|
|
84
|
+
expect(viewModel.team.strengths).toContain('quality');
|
|
85
|
+
expect(viewModel.team.weaknesses).toContain('responsiveness');
|
|
86
|
+
expect(viewModel.team.tips).toContain('Improve response times');
|
|
87
|
+
});
|
|
88
|
+
it('should include developer title in view model', () => {
|
|
89
|
+
const developerInsights = [
|
|
90
|
+
DeveloperInsightFactory.createValid({
|
|
91
|
+
developerName: 'alice',
|
|
92
|
+
title: 'architect',
|
|
93
|
+
}),
|
|
94
|
+
];
|
|
95
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 1 });
|
|
96
|
+
const viewModel = presenter.present({
|
|
97
|
+
developerInsights,
|
|
98
|
+
teamInsight,
|
|
99
|
+
});
|
|
100
|
+
expect(viewModel.developers[0].title).toBe('architect');
|
|
101
|
+
});
|
|
102
|
+
it('should include review count and strengths/weaknesses', () => {
|
|
103
|
+
const developerInsights = [
|
|
104
|
+
DeveloperInsightFactory.createValid({
|
|
105
|
+
developerName: 'alice',
|
|
106
|
+
reviewCount: 15,
|
|
107
|
+
strengths: ['quality', 'responsiveness'],
|
|
108
|
+
weaknesses: ['iteration'],
|
|
109
|
+
topPriority: 'iteration',
|
|
110
|
+
}),
|
|
111
|
+
];
|
|
112
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 1 });
|
|
113
|
+
const viewModel = presenter.present({
|
|
114
|
+
developerInsights,
|
|
115
|
+
teamInsight,
|
|
116
|
+
});
|
|
117
|
+
const alice = viewModel.developers[0];
|
|
118
|
+
expect(alice.reviewCount).toBe(15);
|
|
119
|
+
expect(alice.strengths).toEqual(['quality', 'responsiveness']);
|
|
120
|
+
expect(alice.weaknesses).toEqual(['iteration']);
|
|
121
|
+
expect(alice.topPriority).toBe('iteration');
|
|
122
|
+
});
|
|
123
|
+
it('should include metrics in developer view model', () => {
|
|
124
|
+
const developerInsights = [
|
|
125
|
+
DeveloperInsightFactory.createValid({
|
|
126
|
+
developerName: 'alice',
|
|
127
|
+
metrics: {
|
|
128
|
+
averageScore: 8.3,
|
|
129
|
+
averageBlocking: 0.1,
|
|
130
|
+
averageWarnings: 1.4,
|
|
131
|
+
averageDuration: 60000,
|
|
132
|
+
totalFollowups: null,
|
|
133
|
+
averageAdditions: 200,
|
|
134
|
+
averageDeletions: 50,
|
|
135
|
+
firstReviewQualityRate: 0.85,
|
|
136
|
+
},
|
|
137
|
+
}),
|
|
138
|
+
];
|
|
139
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 1 });
|
|
140
|
+
const viewModel = presenter.present({
|
|
141
|
+
developerInsights,
|
|
142
|
+
teamInsight,
|
|
143
|
+
});
|
|
144
|
+
const alice = viewModel.developers[0];
|
|
145
|
+
expect(alice.metrics).toBeDefined();
|
|
146
|
+
expect(alice.metrics.averageScore).toBe(8.3);
|
|
147
|
+
expect(alice.metrics.averageBlocking).toBe(0.1);
|
|
148
|
+
expect(alice.metrics.firstReviewQualityRate).toBe(0.85);
|
|
149
|
+
});
|
|
150
|
+
it('should include insight descriptions in developer view model', () => {
|
|
151
|
+
const developerInsights = [
|
|
152
|
+
DeveloperInsightFactory.createValid({
|
|
153
|
+
developerName: 'alice',
|
|
154
|
+
insightDescriptions: [
|
|
155
|
+
{
|
|
156
|
+
category: 'quality',
|
|
157
|
+
type: 'strength',
|
|
158
|
+
descriptionKey: 'insight.quality.highScore',
|
|
159
|
+
params: { score: 8.3, teamAverage: 7.5, percent: 11 },
|
|
160
|
+
},
|
|
161
|
+
],
|
|
162
|
+
}),
|
|
163
|
+
];
|
|
164
|
+
const teamInsight = TeamInsightFactory.createValid({ developerCount: 1 });
|
|
165
|
+
const viewModel = presenter.present({
|
|
166
|
+
developerInsights,
|
|
167
|
+
teamInsight,
|
|
168
|
+
});
|
|
169
|
+
const alice = viewModel.developers[0];
|
|
170
|
+
expect(alice.insightDescriptions).toHaveLength(1);
|
|
171
|
+
expect(alice.insightDescriptions[0].descriptionKey).toBe('insight.quality.highScore');
|
|
172
|
+
});
|
|
173
|
+
it('should include team average levels', () => {
|
|
174
|
+
const developerInsights = [
|
|
175
|
+
DeveloperInsightFactory.createValid({ developerName: 'alice' }),
|
|
176
|
+
];
|
|
177
|
+
const teamInsight = TeamInsightFactory.createValid({
|
|
178
|
+
developerCount: 1,
|
|
179
|
+
averageLevels: {
|
|
180
|
+
quality: 7,
|
|
181
|
+
responsiveness: 5,
|
|
182
|
+
codeVolume: 6,
|
|
183
|
+
iteration: 4,
|
|
184
|
+
},
|
|
185
|
+
});
|
|
186
|
+
const viewModel = presenter.present({
|
|
187
|
+
developerInsights,
|
|
188
|
+
teamInsight,
|
|
189
|
+
});
|
|
190
|
+
expect(viewModel.team.averageLevels.quality).toBe(7);
|
|
191
|
+
expect(viewModel.team.averageLevels.iteration).toBe(4);
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
//# sourceMappingURL=insights.presenter.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insights.presenter.test.js","sourceRoot":"","sources":["../../../../../src/tests/units/interface-adapters/presenters/insights.presenter.test.ts"],"names":[],"mappings":"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"}
|
package/dist/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"developerSheet.test.d.ts","sourceRoot":"","sources":["../../../../../../../src/tests/units/interface-adapters/views/dashboard/modules/developerSheet.test.ts"],"names":[],"mappings":""}
|