@codeyam/codeyam-cli 0.1.0-staging.e38f7bd → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1038) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/common/execAsync.ts +1 -1
  3. package/analyzer-template/log.txt +3 -3
  4. package/analyzer-template/package.json +21 -17
  5. package/analyzer-template/packages/ai/index.ts +21 -5
  6. package/analyzer-template/packages/ai/package.json +4 -4
  7. package/analyzer-template/packages/ai/src/lib/__mocks__/completionCall.ts +122 -0
  8. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +228 -24
  9. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  10. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +205 -10
  11. package/analyzer-template/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.ts +644 -0
  12. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +181 -23
  13. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.ts +10 -17
  14. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.ts +18 -0
  15. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.ts +38 -1
  16. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +181 -1
  17. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +1619 -125
  18. package/analyzer-template/packages/ai/src/lib/astScopes/sharedPatterns.ts +28 -0
  19. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +324 -5
  20. package/analyzer-template/packages/ai/src/lib/checkAllAttributes.ts +29 -10
  21. package/analyzer-template/packages/ai/src/lib/completionCall.ts +216 -36
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +2543 -399
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.ts +21 -4
  24. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +976 -0
  25. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +243 -77
  26. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  27. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  28. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +71 -2
  29. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +161 -19
  30. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.ts +70 -0
  31. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.ts +163 -14
  32. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.ts +98 -0
  33. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +179 -0
  34. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  35. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +441 -82
  36. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  37. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +174 -0
  38. package/analyzer-template/packages/ai/src/lib/deepEqual.ts +30 -0
  39. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  40. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  41. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarioData.ts +74 -7
  42. package/analyzer-template/packages/ai/src/lib/generateChangesEntityScenarios.ts +89 -112
  43. package/analyzer-template/packages/ai/src/lib/generateEntityDataStructure.ts +63 -2
  44. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +1419 -101
  45. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +216 -109
  46. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +614 -0
  47. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +528 -0
  48. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +2484 -0
  49. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  50. package/analyzer-template/packages/ai/src/lib/getConditionalUsagesFromCode.ts +143 -31
  51. package/analyzer-template/packages/ai/src/lib/guessScenarioDataFromDescription.ts +8 -2
  52. package/analyzer-template/packages/ai/src/lib/isolateScopes.ts +328 -7
  53. package/analyzer-template/packages/ai/src/lib/mergeJsonTypeDefinitions.ts +5 -0
  54. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +111 -87
  55. package/analyzer-template/packages/ai/src/lib/promptGenerators/collapseNullableObjects.ts +118 -0
  56. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +17 -7
  57. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.ts +1 -1
  58. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.ts +32 -102
  59. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  60. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  61. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +110 -6
  62. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.ts +14 -53
  63. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.ts +58 -0
  64. package/analyzer-template/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.ts +28 -2
  65. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  66. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +824 -0
  67. package/analyzer-template/packages/ai/src/lib/splitOutsideParentheses.ts +5 -1
  68. package/analyzer-template/packages/ai/src/lib/validateExecutionFlowPaths.ts +531 -0
  69. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +127 -3
  70. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +121 -2
  71. package/analyzer-template/packages/analyze/index.ts +2 -0
  72. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +79 -59
  73. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  74. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  75. package/analyzer-template/packages/analyze/src/lib/asts/nodes/index.ts +1 -0
  76. package/analyzer-template/packages/analyze/src/lib/asts/nodes/isAsyncFunction.ts +67 -0
  77. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  78. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  79. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  80. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  81. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  82. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  83. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +570 -180
  84. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +54 -1
  85. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
  86. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +3 -0
  87. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  88. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  89. package/analyzer-template/packages/analyze/src/lib/files/analyzeChange.ts +31 -15
  90. package/analyzer-template/packages/analyze/src/lib/files/analyzeEntity.ts +11 -7
  91. package/analyzer-template/packages/analyze/src/lib/files/analyzeInitial.ts +11 -12
  92. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  93. package/analyzer-template/packages/analyze/src/lib/files/enums/steps.ts +1 -1
  94. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +22 -13
  95. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +1315 -0
  96. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +313 -0
  97. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.ts +102 -0
  98. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +711 -78
  99. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.ts +1 -1
  100. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.ts +28 -62
  101. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +550 -137
  102. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +264 -0
  103. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarioData.ts +78 -83
  104. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateScenarios.ts +4 -8
  105. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +1067 -167
  106. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  107. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  108. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  109. package/analyzer-template/packages/analyze/src/lib/index.ts +1 -0
  110. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  111. package/analyzer-template/packages/aws/codebuild/index.ts +1 -0
  112. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts +11 -1
  113. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.d.ts.map +1 -1
  114. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js +29 -18
  115. package/analyzer-template/packages/aws/dist/src/lib/codebuild/waitForBuild.js.map +1 -1
  116. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts +2 -2
  117. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.d.ts.map +1 -1
  118. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js +2 -2
  119. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  120. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts +8 -18
  121. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.d.ts.map +1 -1
  122. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js +17 -61
  123. package/analyzer-template/packages/aws/dist/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  124. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts +15 -0
  125. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.d.ts.map +1 -0
  126. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js +31 -0
  127. package/analyzer-template/packages/aws/dist/src/lib/s3/checkS3ObjectExists.js.map +1 -0
  128. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.d.ts.map +1 -1
  129. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js +8 -1
  130. package/analyzer-template/packages/aws/dist/src/lib/s3/uploadFileToS3.js.map +1 -1
  131. package/analyzer-template/packages/aws/package.json +3 -3
  132. package/analyzer-template/packages/aws/s3/index.ts +1 -0
  133. package/analyzer-template/packages/aws/src/lib/codebuild/waitForBuild.ts +43 -19
  134. package/analyzer-template/packages/aws/src/lib/ecs/ecsDefineContainer.ts +3 -3
  135. package/analyzer-template/packages/aws/src/lib/ecs/ecsTaskFactory.ts +17 -69
  136. package/analyzer-template/packages/aws/src/lib/s3/checkS3ObjectExists.ts +47 -0
  137. package/analyzer-template/packages/aws/src/lib/s3/uploadFileToS3.ts +8 -1
  138. package/analyzer-template/packages/database/package.json +1 -1
  139. package/analyzer-template/packages/database/src/lib/analysisBranchToDb.ts +1 -1
  140. package/analyzer-template/packages/database/src/lib/analysisToDb.ts +1 -1
  141. package/analyzer-template/packages/database/src/lib/branchToDb.ts +1 -1
  142. package/analyzer-template/packages/database/src/lib/commitBranchToDb.ts +1 -1
  143. package/analyzer-template/packages/database/src/lib/commitToDb.ts +1 -1
  144. package/analyzer-template/packages/database/src/lib/fileToDb.ts +1 -1
  145. package/analyzer-template/packages/database/src/lib/kysely/db.ts +18 -5
  146. package/analyzer-template/packages/database/src/lib/kysely/tableRelations.ts +2 -2
  147. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  148. package/analyzer-template/packages/database/src/lib/kysely/tables/debugReportsTable.ts +36 -9
  149. package/analyzer-template/packages/database/src/lib/kysely/tables/labsRequestsTable.ts +52 -0
  150. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  151. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  152. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  153. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  154. package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
  155. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  156. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  157. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +30 -5
  158. package/analyzer-template/packages/database/src/lib/projectToDb.ts +1 -1
  159. package/analyzer-template/packages/database/src/lib/saveFiles.ts +1 -1
  160. package/analyzer-template/packages/database/src/lib/scenarioToDb.ts +1 -1
  161. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
  162. package/analyzer-template/packages/database/src/lib/userScenarioToDb.ts +1 -1
  163. package/analyzer-template/packages/generate/index.ts +3 -0
  164. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.ts +17 -1
  165. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +193 -0
  166. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.ts +73 -0
  167. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +9 -4
  168. package/analyzer-template/packages/generate/src/lib/deepMerge.ts +26 -1
  169. package/analyzer-template/packages/generate/src/lib/directExecutionScript.ts +17 -2
  170. package/analyzer-template/packages/generate/src/lib/getComponentScenarioPath.ts +8 -3
  171. package/analyzer-template/packages/generate/src/lib/scenarioComponentForServer.ts +114 -0
  172. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js +1 -1
  173. package/analyzer-template/packages/github/dist/database/src/lib/analysisBranchToDb.js.map +1 -1
  174. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js +1 -1
  175. package/analyzer-template/packages/github/dist/database/src/lib/analysisToDb.js.map +1 -1
  176. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js +1 -1
  177. package/analyzer-template/packages/github/dist/database/src/lib/branchToDb.js.map +1 -1
  178. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js +1 -1
  179. package/analyzer-template/packages/github/dist/database/src/lib/commitBranchToDb.js.map +1 -1
  180. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js +1 -1
  181. package/analyzer-template/packages/github/dist/database/src/lib/commitToDb.js.map +1 -1
  182. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js +1 -1
  183. package/analyzer-template/packages/github/dist/database/src/lib/fileToDb.js.map +1 -1
  184. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +4 -2
  185. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  186. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +13 -3
  187. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  188. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tableRelations.d.ts +2 -2
  189. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts +1 -11
  190. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  191. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  192. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  193. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  194. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  195. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts +30 -7
  196. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.d.ts.map +1 -1
  197. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
  198. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  199. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts +1 -0
  200. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/entitiesTable.d.ts.map +1 -1
  201. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts +23 -0
  202. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.d.ts.map +1 -0
  203. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  204. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  205. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +2 -6
  206. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  207. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  208. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  209. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  210. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  211. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  212. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  213. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  214. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  215. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  216. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  217. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  218. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  219. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  220. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  221. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
  222. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  223. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  224. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  225. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  226. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  227. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  228. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  229. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  230. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  231. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +23 -5
  232. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  233. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js +1 -1
  234. package/analyzer-template/packages/github/dist/database/src/lib/projectToDb.js.map +1 -1
  235. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js +1 -1
  236. package/analyzer-template/packages/github/dist/database/src/lib/saveFiles.js.map +1 -1
  237. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js +1 -1
  238. package/analyzer-template/packages/github/dist/database/src/lib/scenarioToDb.js.map +1 -1
  239. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  240. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  241. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
  242. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  243. package/analyzer-template/packages/github/dist/generate/index.d.ts +3 -0
  244. package/analyzer-template/packages/github/dist/generate/index.d.ts.map +1 -1
  245. package/analyzer-template/packages/github/dist/generate/index.js +3 -0
  246. package/analyzer-template/packages/github/dist/generate/index.js.map +1 -1
  247. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.d.ts.map +1 -1
  248. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  249. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  250. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts +9 -0
  251. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -0
  252. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  253. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  254. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts +20 -0
  255. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.d.ts.map +1 -0
  256. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  257. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  258. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  259. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +8 -4
  260. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  261. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.d.ts.map +1 -1
  262. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js +27 -1
  263. package/analyzer-template/packages/github/dist/generate/src/lib/deepMerge.js.map +1 -1
  264. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.d.ts.map +1 -1
  265. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js +10 -1
  266. package/analyzer-template/packages/github/dist/generate/src/lib/directExecutionScript.js.map +1 -1
  267. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.d.ts.map +1 -1
  268. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js +7 -3
  269. package/analyzer-template/packages/github/dist/generate/src/lib/getComponentScenarioPath.js.map +1 -1
  270. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts +8 -0
  271. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.d.ts.map +1 -0
  272. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js +89 -0
  273. package/analyzer-template/packages/github/dist/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  274. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.d.ts.map +1 -1
  275. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js +10 -0
  276. package/analyzer-template/packages/github/dist/github/src/lib/loadOrCreateCommit.js.map +1 -1
  277. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.d.ts.map +1 -1
  278. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js +3 -0
  279. package/analyzer-template/packages/github/dist/github/src/lib/syncPrimaryBranch.js.map +1 -1
  280. package/analyzer-template/packages/github/dist/types/index.d.ts +2 -2
  281. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  282. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  283. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +87 -13
  284. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  285. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  286. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  287. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts +2 -0
  288. package/analyzer-template/packages/github/dist/types/src/types/Entity.d.ts.map +1 -1
  289. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  290. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  291. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +11 -6
  292. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  293. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  294. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  295. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  296. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  297. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts +2 -0
  298. package/analyzer-template/packages/github/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  299. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -1
  300. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js +26 -2
  301. package/analyzer-template/packages/github/dist/utils/src/lib/applyUniversalMocks.js.map +1 -1
  302. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -1
  303. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js +25 -0
  304. package/analyzer-template/packages/github/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  305. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  306. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  307. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  308. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  309. package/analyzer-template/packages/github/package.json +1 -1
  310. package/analyzer-template/packages/github/src/lib/loadOrCreateCommit.ts +14 -0
  311. package/analyzer-template/packages/github/src/lib/syncPrimaryBranch.ts +2 -0
  312. package/analyzer-template/packages/process/index.ts +2 -0
  313. package/analyzer-template/packages/process/package.json +12 -0
  314. package/analyzer-template/packages/process/tsconfig.json +8 -0
  315. package/analyzer-template/packages/types/index.ts +5 -0
  316. package/analyzer-template/packages/types/src/types/Analysis.ts +104 -13
  317. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  318. package/analyzer-template/packages/types/src/types/Entity.ts +2 -0
  319. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +7 -0
  320. package/analyzer-template/packages/types/src/types/Scenario.ts +11 -10
  321. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +228 -3
  322. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  323. package/analyzer-template/packages/types/src/types/StatementInfo.ts +2 -0
  324. package/analyzer-template/packages/ui-components/package.json +4 -4
  325. package/analyzer-template/packages/ui-components/src/components/ScenarioDetailInteractiveView.tsx +23 -7
  326. package/analyzer-template/packages/utils/dist/types/index.d.ts +2 -2
  327. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  328. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  329. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +87 -13
  330. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  331. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  332. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  333. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts +2 -0
  334. package/analyzer-template/packages/utils/dist/types/src/types/Entity.d.ts.map +1 -1
  335. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +7 -0
  336. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  337. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +11 -6
  338. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  339. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +199 -3
  340. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  341. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  342. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  343. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts +2 -0
  344. package/analyzer-template/packages/utils/dist/types/src/types/StatementInfo.d.ts.map +1 -1
  345. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.d.ts.map +1 -1
  346. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js +26 -2
  347. package/analyzer-template/packages/utils/dist/utils/src/lib/applyUniversalMocks.js.map +1 -1
  348. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  349. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +93 -2
  350. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  351. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.d.ts.map +1 -1
  352. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js +25 -0
  353. package/analyzer-template/packages/utils/dist/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  354. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  355. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  356. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  357. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  358. package/analyzer-template/packages/utils/src/lib/applyUniversalMocks.ts +28 -2
  359. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +108 -2
  360. package/analyzer-template/packages/utils/src/lib/lightweightEntityExtractor.ts +27 -0
  361. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  362. package/analyzer-template/playwright/capture.ts +57 -26
  363. package/analyzer-template/playwright/captureStatic.ts +1 -1
  364. package/analyzer-template/playwright/getCodeYamInfo.ts +12 -7
  365. package/analyzer-template/playwright/takeElementScreenshot.ts +26 -11
  366. package/analyzer-template/playwright/takeScreenshot.ts +15 -9
  367. package/analyzer-template/playwright/waitForServer.ts +21 -6
  368. package/analyzer-template/project/TESTING.md +83 -0
  369. package/analyzer-template/project/analyzeBaselineCommit.ts +9 -0
  370. package/analyzer-template/project/analyzeBranchCommit.ts +4 -0
  371. package/analyzer-template/project/analyzeFileEntities.ts +4 -0
  372. package/analyzer-template/project/analyzeRegularCommit.ts +9 -0
  373. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  374. package/analyzer-template/project/constructMockCode.ts +1319 -158
  375. package/analyzer-template/project/controller/startController.ts +16 -1
  376. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  377. package/analyzer-template/project/executeLibraryFunctionDirect.ts +7 -3
  378. package/analyzer-template/project/loadReadyToBeCaptured.ts +82 -42
  379. package/analyzer-template/project/mocks/analyzeFileMock.ts +8 -7
  380. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  381. package/analyzer-template/project/orchestrateCapture/KyselyAnalysisLoader.ts +13 -9
  382. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +93 -42
  383. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  384. package/analyzer-template/project/orchestrateCapture.ts +88 -12
  385. package/analyzer-template/project/reconcileMockDataKeys.ts +245 -2
  386. package/analyzer-template/project/runAnalysis.ts +11 -0
  387. package/analyzer-template/project/runMultiScenarioServer.ts +11 -10
  388. package/analyzer-template/project/serverOnlyModules.ts +413 -0
  389. package/analyzer-template/project/start.ts +72 -19
  390. package/analyzer-template/project/startScenarioCapture.ts +79 -41
  391. package/analyzer-template/project/writeMockDataTsx.ts +466 -73
  392. package/analyzer-template/project/writeScenarioClientWrapper.ts +21 -0
  393. package/analyzer-template/project/writeScenarioComponents.ts +1433 -214
  394. package/analyzer-template/project/writeScenarioFiles.ts +26 -0
  395. package/analyzer-template/project/writeSimpleRoot.ts +56 -22
  396. package/analyzer-template/project/writeUniversalMocks.ts +32 -11
  397. package/analyzer-template/scripts/comboWorkerLoop.cjs +99 -50
  398. package/analyzer-template/scripts/defaultCmd.sh +9 -0
  399. package/analyzer-template/tsconfig.json +2 -1
  400. package/background/src/lib/local/createLocalAnalyzer.js +2 -30
  401. package/background/src/lib/local/createLocalAnalyzer.js.map +1 -1
  402. package/background/src/lib/local/execAsync.js +1 -1
  403. package/background/src/lib/local/execAsync.js.map +1 -1
  404. package/background/src/lib/virtualized/common/execAsync.js +1 -1
  405. package/background/src/lib/virtualized/common/execAsync.js.map +1 -1
  406. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +7 -1
  407. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  408. package/background/src/lib/virtualized/project/analyzeBranchCommit.js +2 -1
  409. package/background/src/lib/virtualized/project/analyzeBranchCommit.js.map +1 -1
  410. package/background/src/lib/virtualized/project/analyzeFileEntities.js +2 -1
  411. package/background/src/lib/virtualized/project/analyzeFileEntities.js.map +1 -1
  412. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +7 -1
  413. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  414. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  415. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  416. package/background/src/lib/virtualized/project/constructMockCode.js +1171 -120
  417. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  418. package/background/src/lib/virtualized/project/controller/startController.js +11 -1
  419. package/background/src/lib/virtualized/project/controller/startController.js.map +1 -1
  420. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  421. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  422. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js +6 -3
  423. package/background/src/lib/virtualized/project/executeLibraryFunctionDirect.js.map +1 -1
  424. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +34 -9
  425. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  426. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js +7 -7
  427. package/background/src/lib/virtualized/project/mocks/analyzeFileMock.js.map +1 -1
  428. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  429. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  430. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js +12 -6
  431. package/background/src/lib/virtualized/project/orchestrateCapture/KyselyAnalysisLoader.js.map +1 -1
  432. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +73 -36
  433. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  434. package/background/src/lib/virtualized/project/orchestrateCapture.js +72 -13
  435. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  436. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +204 -2
  437. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  438. package/background/src/lib/virtualized/project/runAnalysis.js +9 -0
  439. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  440. package/background/src/lib/virtualized/project/runMultiScenarioServer.js +11 -9
  441. package/background/src/lib/virtualized/project/runMultiScenarioServer.js.map +1 -1
  442. package/background/src/lib/virtualized/project/serverOnlyModules.js +338 -0
  443. package/background/src/lib/virtualized/project/serverOnlyModules.js.map +1 -0
  444. package/background/src/lib/virtualized/project/start.js +62 -19
  445. package/background/src/lib/virtualized/project/start.js.map +1 -1
  446. package/background/src/lib/virtualized/project/startScenarioCapture.js +61 -31
  447. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  448. package/background/src/lib/virtualized/project/writeMockDataTsx.js +404 -62
  449. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  450. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js +15 -0
  451. package/background/src/lib/virtualized/project/writeScenarioClientWrapper.js.map +1 -0
  452. package/background/src/lib/virtualized/project/writeScenarioComponents.js +1056 -146
  453. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  454. package/background/src/lib/virtualized/project/writeScenarioFiles.js +19 -0
  455. package/background/src/lib/virtualized/project/writeScenarioFiles.js.map +1 -1
  456. package/background/src/lib/virtualized/project/writeSimpleRoot.js +57 -20
  457. package/background/src/lib/virtualized/project/writeSimpleRoot.js.map +1 -1
  458. package/background/src/lib/virtualized/project/writeUniversalMocks.js +27 -12
  459. package/background/src/lib/virtualized/project/writeUniversalMocks.js.map +1 -1
  460. package/codeyam-cli/scripts/apply-setup.js +180 -0
  461. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  462. package/codeyam-cli/src/cli.js +11 -1
  463. package/codeyam-cli/src/cli.js.map +1 -1
  464. package/codeyam-cli/src/codeyam-cli.js +18 -2
  465. package/codeyam-cli/src/codeyam-cli.js.map +1 -1
  466. package/codeyam-cli/src/commands/analyze.js +5 -3
  467. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  468. package/codeyam-cli/src/commands/baseline.js +176 -0
  469. package/codeyam-cli/src/commands/baseline.js.map +1 -0
  470. package/codeyam-cli/src/commands/debug.js +44 -18
  471. package/codeyam-cli/src/commands/debug.js.map +1 -1
  472. package/codeyam-cli/src/commands/default.js +30 -34
  473. package/codeyam-cli/src/commands/default.js.map +1 -1
  474. package/codeyam-cli/src/commands/detect-universal-mocks.js +2 -0
  475. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +1 -1
  476. package/codeyam-cli/src/commands/init.js +49 -257
  477. package/codeyam-cli/src/commands/init.js.map +1 -1
  478. package/codeyam-cli/src/commands/memory.js +264 -0
  479. package/codeyam-cli/src/commands/memory.js.map +1 -0
  480. package/codeyam-cli/src/commands/recapture.js +228 -0
  481. package/codeyam-cli/src/commands/recapture.js.map +1 -0
  482. package/codeyam-cli/src/commands/report.js +72 -24
  483. package/codeyam-cli/src/commands/report.js.map +1 -1
  484. package/codeyam-cli/src/commands/setup-sandbox.js +2 -0
  485. package/codeyam-cli/src/commands/setup-sandbox.js.map +1 -1
  486. package/codeyam-cli/src/commands/setup-simulations.js +284 -0
  487. package/codeyam-cli/src/commands/setup-simulations.js.map +1 -0
  488. package/codeyam-cli/src/commands/start.js +8 -12
  489. package/codeyam-cli/src/commands/start.js.map +1 -1
  490. package/codeyam-cli/src/commands/status.js +23 -1
  491. package/codeyam-cli/src/commands/status.js.map +1 -1
  492. package/codeyam-cli/src/commands/test-startup.js +3 -1
  493. package/codeyam-cli/src/commands/test-startup.js.map +1 -1
  494. package/codeyam-cli/src/commands/verify.js +14 -2
  495. package/codeyam-cli/src/commands/verify.js.map +1 -1
  496. package/codeyam-cli/src/commands/wipe.js +108 -0
  497. package/codeyam-cli/src/commands/wipe.js.map +1 -0
  498. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +179 -0
  499. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -0
  500. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js +81 -0
  501. package/codeyam-cli/src/utils/__tests__/serverVersionStaleness.test.js.map +1 -0
  502. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +128 -82
  503. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  504. package/codeyam-cli/src/utils/analysisRunner.js +29 -15
  505. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  506. package/codeyam-cli/src/utils/analyzer.js +7 -0
  507. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  508. package/codeyam-cli/src/utils/backgroundServer.js +104 -23
  509. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  510. package/codeyam-cli/src/utils/database.js +91 -5
  511. package/codeyam-cli/src/utils/database.js.map +1 -1
  512. package/codeyam-cli/src/utils/generateReport.js +253 -106
  513. package/codeyam-cli/src/utils/generateReport.js.map +1 -1
  514. package/codeyam-cli/src/utils/git.js +79 -0
  515. package/codeyam-cli/src/utils/git.js.map +1 -0
  516. package/codeyam-cli/src/utils/install-skills.js +76 -42
  517. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  518. package/codeyam-cli/src/utils/labsAutoCheck.js +19 -0
  519. package/codeyam-cli/src/utils/labsAutoCheck.js.map +1 -0
  520. package/codeyam-cli/src/utils/npmVersionCheck.js +76 -0
  521. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -0
  522. package/codeyam-cli/src/utils/progress.js +7 -0
  523. package/codeyam-cli/src/utils/progress.js.map +1 -1
  524. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +38 -0
  525. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  526. package/codeyam-cli/src/utils/queue/job.js +249 -16
  527. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  528. package/codeyam-cli/src/utils/queue/manager.js +103 -7
  529. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  530. package/codeyam-cli/src/utils/queue/persistence.js.map +1 -1
  531. package/codeyam-cli/src/utils/requireSimulations.js +10 -0
  532. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -0
  533. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js +82 -0
  534. package/codeyam-cli/src/utils/ruleReflection/__tests__/confusionDetector.test.js.map +1 -0
  535. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +230 -0
  536. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -0
  537. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +67 -0
  538. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -0
  539. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js +105 -0
  540. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/captureFixture.js.map +1 -0
  541. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js +34 -0
  542. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/loadCapturedFixture.js.map +1 -0
  543. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js +162 -0
  544. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/runClaude.js.map +1 -0
  545. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +75 -0
  546. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -0
  547. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +378 -0
  548. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -0
  549. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +115 -0
  550. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -0
  551. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js +127 -0
  552. package/codeyam-cli/src/utils/ruleReflection/__tests__/transcriptParser.test.js.map +1 -0
  553. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js +50 -0
  554. package/codeyam-cli/src/utils/ruleReflection/confusionDetector.js.map +1 -0
  555. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +116 -0
  556. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -0
  557. package/codeyam-cli/src/utils/ruleReflection/index.js +5 -0
  558. package/codeyam-cli/src/utils/ruleReflection/index.js.map +1 -0
  559. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js +44 -0
  560. package/codeyam-cli/src/utils/ruleReflection/promptBuilder.js.map +1 -0
  561. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js +85 -0
  562. package/codeyam-cli/src/utils/ruleReflection/transcriptParser.js.map +1 -0
  563. package/codeyam-cli/src/utils/ruleReflection/types.js +5 -0
  564. package/codeyam-cli/src/utils/ruleReflection/types.js.map +1 -0
  565. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js +293 -0
  566. package/codeyam-cli/src/utils/rules/__tests__/ruleState.test.js.map +1 -0
  567. package/codeyam-cli/src/utils/rules/index.js +6 -0
  568. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  569. package/codeyam-cli/src/utils/rules/parser.js +83 -0
  570. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  571. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  572. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  573. package/codeyam-cli/src/utils/rules/ruleState.js +150 -0
  574. package/codeyam-cli/src/utils/rules/ruleState.js.map +1 -0
  575. package/codeyam-cli/src/utils/rules/staleness.js +137 -0
  576. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  577. package/codeyam-cli/src/utils/serverState.js +37 -10
  578. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  579. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +21 -42
  580. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  581. package/codeyam-cli/src/utils/versionInfo.js +25 -19
  582. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  583. package/codeyam-cli/src/utils/wipe.js +128 -0
  584. package/codeyam-cli/src/utils/wipe.js.map +1 -0
  585. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js +66 -0
  586. package/codeyam-cli/src/webserver/__tests__/dependency-smoke.test.js.map +1 -0
  587. package/codeyam-cli/src/webserver/app/lib/database.js +118 -6
  588. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  589. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  590. package/codeyam-cli/src/webserver/backgroundServer.js +55 -10
  591. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  592. package/codeyam-cli/src/webserver/bootstrap.js +60 -0
  593. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -0
  594. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +1 -0
  595. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-bwuHPyTa.js +11 -0
  596. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-kykTbcnD.js → EntityTypeBadge-CvzqMxcu.js} +1 -1
  597. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-BH0XDim7.js +41 -0
  598. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +34 -0
  599. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-yjIHlOGa.js +25 -0
  600. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-Cq5o8jL4.js +3 -0
  601. package/codeyam-cli/src/webserver/build/client/assets/LoadingDots-BvMu2i-g.js +6 -0
  602. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-kgBTLoJD.js +3 -0
  603. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-BzPgx-xO.js +11 -0
  604. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CwZrv-Ok.js +1 -0
  605. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-BX2Ny2Qj.js +10 -0
  606. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-C06nsHKY.js → TruncatedFilePath-CDpEprKa.js} +1 -1
  607. package/codeyam-cli/src/webserver/build/client/assets/_index-BRx8ZGZo.js +11 -0
  608. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-4S4yPfFw.js +27 -0
  609. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +17 -0
  610. package/codeyam-cli/src/webserver/build/client/assets/api.agent-transcripts-l0sNRNKZ.js +1 -0
  611. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  612. package/codeyam-cli/src/webserver/build/client/assets/api.labs-unlock-l0sNRNKZ.js +1 -0
  613. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  614. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  615. package/codeyam-cli/src/webserver/build/client/assets/api.save-fixture-l0sNRNKZ.js +1 -0
  616. package/codeyam-cli/src/webserver/build/client/assets/book-open-D4IPYH_y.js +6 -0
  617. package/codeyam-cli/src/webserver/build/client/assets/chevron-down-CG65viiV.js +6 -0
  618. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-DB3aFuEO.js +51 -0
  619. package/codeyam-cli/src/webserver/build/client/assets/circle-check-igfMr5DY.js +6 -0
  620. package/codeyam-cli/src/webserver/build/client/assets/copy-Coc4o_8c.js +11 -0
  621. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D1zB-pYc.js +21 -0
  622. package/codeyam-cli/src/webserver/build/client/assets/{cy-logo-cli-C1gnJVOL.svg → cy-logo-cli-CCKUIm0S.svg} +2 -2
  623. package/codeyam-cli/src/webserver/build/client/assets/cy-logo-cli-DcX-ZS3p.js +1 -0
  624. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +1 -0
  625. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CYqBrC9s.js → entity._sha._-B0h9AqE6.js} +22 -15
  626. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +6 -0
  627. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +6 -0
  628. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-PePWg17F.js +5 -0
  629. package/codeyam-cli/src/webserver/build/client/assets/entry.client-I-Wo99C_.js +29 -0
  630. package/codeyam-cli/src/webserver/build/client/assets/executionFlowCoverage-BWhdfn70.js +1 -0
  631. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-9sMMAiWJ.js +1 -0
  632. package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +1 -0
  633. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +15 -0
  634. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +1 -0
  635. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-fmIEn3Bc.js +9 -0
  636. package/codeyam-cli/src/webserver/build/client/assets/index-CUM5iXwc.js +9 -0
  637. package/codeyam-cli/src/webserver/build/client/assets/index-_417gcQW.js +3 -0
  638. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +1 -0
  639. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-TzRHMVog.js +6 -0
  640. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +1 -0
  641. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +78 -0
  642. package/codeyam-cli/src/webserver/build/client/assets/pause-hjzB7t2z.js +11 -0
  643. package/codeyam-cli/src/webserver/build/client/assets/preload-helper-ckwbz45p.js +1 -0
  644. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +62 -0
  645. package/codeyam-cli/src/webserver/build/client/assets/scenarioStatus-B_8jpV3e.js +1 -0
  646. package/codeyam-cli/src/webserver/build/client/assets/search-DcAwD_Ln.js +6 -0
  647. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +1 -0
  648. package/codeyam-cli/src/webserver/build/client/assets/simulations-DVNJVQgD.js +1 -0
  649. package/codeyam-cli/src/webserver/build/client/assets/terminal-DbEAHMbA.js +11 -0
  650. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-CAD5b1o_.js +6 -0
  651. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +1 -0
  652. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-Blr5oZDE.js → useLastLogLine-DAFqfEDH.js} +1 -1
  653. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DZlYx2c4.js +1 -0
  654. package/codeyam-cli/src/webserver/build/client/assets/{useToast-Bbf4Hokd.js → useToast-ihdMtlf6.js} +1 -1
  655. package/codeyam-cli/src/webserver/build/server/assets/index-CxaRxKVt.js +1 -0
  656. package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +259 -0
  657. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  658. package/codeyam-cli/src/webserver/build-info.json +5 -5
  659. package/codeyam-cli/src/webserver/devServer.js +1 -3
  660. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  661. package/codeyam-cli/src/webserver/server.js +35 -25
  662. package/codeyam-cli/src/webserver/server.js.map +1 -1
  663. package/codeyam-cli/templates/{codeyam-debug-skill.md → codeyam-debug.md} +48 -4
  664. package/codeyam-cli/templates/codeyam-diagnose.md +481 -0
  665. package/codeyam-cli/templates/codeyam-memory-hook.sh +199 -0
  666. package/codeyam-cli/templates/codeyam-memory.md +396 -0
  667. package/codeyam-cli/templates/codeyam-new-rule.md +13 -0
  668. package/codeyam-cli/templates/{codeyam-setup-skill.md → codeyam-setup.md} +151 -4
  669. package/codeyam-cli/templates/{codeyam-sim-skill.md → codeyam-sim.md} +1 -1
  670. package/codeyam-cli/templates/{codeyam-test-skill.md → codeyam-test.md} +1 -1
  671. package/codeyam-cli/templates/{codeyam-verify-skill.md → codeyam-verify.md} +1 -1
  672. package/codeyam-cli/templates/rule-notification-hook.py +56 -0
  673. package/codeyam-cli/templates/rule-reflection-hook.py +627 -0
  674. package/codeyam-cli/templates/rules-instructions.md +132 -0
  675. package/package.json +25 -22
  676. package/packages/ai/index.js +8 -6
  677. package/packages/ai/index.js.map +1 -1
  678. package/packages/ai/src/lib/analyzeScope.js +181 -13
  679. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  680. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  681. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  682. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +154 -9
  683. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  684. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js +435 -0
  685. package/packages/ai/src/lib/astScopes/conditionalEffectsExtractor.js.map +1 -0
  686. package/packages/ai/src/lib/astScopes/methodSemantics.js +138 -23
  687. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  688. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js +10 -14
  689. package/packages/ai/src/lib/astScopes/patterns/forInStatementHandler.js.map +1 -1
  690. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js +8 -0
  691. package/packages/ai/src/lib/astScopes/patterns/ifStatementHandler.js.map +1 -1
  692. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js +23 -0
  693. package/packages/ai/src/lib/astScopes/patterns/switchStatementHandler.js.map +1 -1
  694. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +138 -1
  695. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  696. package/packages/ai/src/lib/astScopes/processExpression.js +1235 -104
  697. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  698. package/packages/ai/src/lib/astScopes/sharedPatterns.js +25 -0
  699. package/packages/ai/src/lib/astScopes/sharedPatterns.js.map +1 -1
  700. package/packages/ai/src/lib/checkAllAttributes.js +24 -9
  701. package/packages/ai/src/lib/checkAllAttributes.js.map +1 -1
  702. package/packages/ai/src/lib/completionCall.js +178 -31
  703. package/packages/ai/src/lib/completionCall.js.map +1 -1
  704. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +1961 -224
  705. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  706. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js +19 -4
  707. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/JavascriptFrameworkManager.js.map +1 -1
  708. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +661 -0
  709. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -0
  710. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +180 -56
  711. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  712. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  713. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  714. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  715. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  716. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +66 -2
  717. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  718. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +139 -13
  719. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  720. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js +63 -0
  721. package/packages/ai/src/lib/dataStructure/helpers/coerceObjectsToPrimitivesBySchema.js.map +1 -0
  722. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js +142 -12
  723. package/packages/ai/src/lib/dataStructure/helpers/convertDotNotation.js.map +1 -1
  724. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js +86 -0
  725. package/packages/ai/src/lib/dataStructure/helpers/convertNullToUndefinedBySchema.js.map +1 -0
  726. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +173 -0
  727. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  728. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  729. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  730. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +371 -73
  731. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  732. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  733. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  734. package/packages/ai/src/lib/dataStructureChunking.js +126 -0
  735. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  736. package/packages/ai/src/lib/deepEqual.js +32 -0
  737. package/packages/ai/src/lib/deepEqual.js.map +1 -0
  738. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  739. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  740. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  741. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  742. package/packages/ai/src/lib/generateChangesEntityScenarioData.js +62 -5
  743. package/packages/ai/src/lib/generateChangesEntityScenarioData.js.map +1 -1
  744. package/packages/ai/src/lib/generateChangesEntityScenarios.js +81 -90
  745. package/packages/ai/src/lib/generateChangesEntityScenarios.js.map +1 -1
  746. package/packages/ai/src/lib/generateEntityDataStructure.js +50 -1
  747. package/packages/ai/src/lib/generateEntityDataStructure.js.map +1 -1
  748. package/packages/ai/src/lib/generateEntityScenarioData.js +1127 -91
  749. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  750. package/packages/ai/src/lib/generateEntityScenarios.js +193 -83
  751. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  752. package/packages/ai/src/lib/generateExecutionFlows.js +414 -0
  753. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -0
  754. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js +380 -0
  755. package/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.js.map +1 -0
  756. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +1807 -0
  757. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -0
  758. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  759. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  760. package/packages/ai/src/lib/getConditionalUsagesFromCode.js +84 -14
  761. package/packages/ai/src/lib/getConditionalUsagesFromCode.js.map +1 -1
  762. package/packages/ai/src/lib/guessScenarioDataFromDescription.js +2 -1
  763. package/packages/ai/src/lib/guessScenarioDataFromDescription.js.map +1 -1
  764. package/packages/ai/src/lib/isolateScopes.js +270 -7
  765. package/packages/ai/src/lib/isolateScopes.js.map +1 -1
  766. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js +5 -0
  767. package/packages/ai/src/lib/mergeJsonTypeDefinitions.js.map +1 -1
  768. package/packages/ai/src/lib/mergeStatements.js +88 -46
  769. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  770. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js +97 -0
  771. package/packages/ai/src/lib/promptGenerators/collapseNullableObjects.js.map +1 -0
  772. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +16 -4
  773. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  774. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js +1 -1
  775. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenarioDataGenerator.js.map +1 -1
  776. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js +21 -64
  777. package/packages/ai/src/lib/promptGenerators/generateChangesEntityScenariosGenerator.js.map +1 -1
  778. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  779. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  780. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +83 -6
  781. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  782. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js +10 -34
  783. package/packages/ai/src/lib/promptGenerators/generateEntityScenariosGenerator.js.map +1 -1
  784. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js +45 -0
  785. package/packages/ai/src/lib/promptGenerators/generateMissingKeysPrompt.js.map +1 -0
  786. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js +16 -3
  787. package/packages/ai/src/lib/promptGenerators/guessNewScenarioDataFromDescriptionGenerator.js.map +1 -1
  788. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  789. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  790. package/packages/ai/src/lib/resolvePathToControllable.js +677 -0
  791. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -0
  792. package/packages/ai/src/lib/splitOutsideParentheses.js +3 -1
  793. package/packages/ai/src/lib/splitOutsideParentheses.js.map +1 -1
  794. package/packages/ai/src/lib/worker/SerializableDataStructure.js +29 -0
  795. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  796. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +98 -1
  797. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  798. package/packages/analyze/index.js +1 -0
  799. package/packages/analyze/index.js.map +1 -1
  800. package/packages/analyze/src/lib/FileAnalyzer.js +75 -36
  801. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  802. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  803. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  804. package/packages/analyze/src/lib/analysisContext.js +30 -5
  805. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  806. package/packages/analyze/src/lib/asts/nodes/index.js +1 -0
  807. package/packages/analyze/src/lib/asts/nodes/index.js.map +1 -1
  808. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js +52 -0
  809. package/packages/analyze/src/lib/asts/nodes/isAsyncFunction.js.map +1 -0
  810. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  811. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  812. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  813. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  814. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  815. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  816. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  817. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  818. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  819. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  820. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  821. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  822. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +428 -123
  823. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  824. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +42 -1
  825. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  826. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
  827. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  828. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +2 -0
  829. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  830. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  831. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  832. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  833. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  834. package/packages/analyze/src/lib/files/analyzeChange.js +21 -11
  835. package/packages/analyze/src/lib/files/analyzeChange.js.map +1 -1
  836. package/packages/analyze/src/lib/files/analyzeEntity.js +9 -8
  837. package/packages/analyze/src/lib/files/analyzeEntity.js.map +1 -1
  838. package/packages/analyze/src/lib/files/analyzeInitial.js +9 -10
  839. package/packages/analyze/src/lib/files/analyzeInitial.js.map +1 -1
  840. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  841. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  842. package/packages/analyze/src/lib/files/enums/steps.js +1 -1
  843. package/packages/analyze/src/lib/files/enums/steps.js.map +1 -1
  844. package/packages/analyze/src/lib/files/getImportedExports.js +17 -8
  845. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  846. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +880 -0
  847. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -0
  848. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +255 -0
  849. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -0
  850. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js +85 -0
  851. package/packages/analyze/src/lib/files/scenarios/enrichUnknownTypesFromSourceEquivalencies.js.map +1 -0
  852. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +550 -62
  853. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  854. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js +1 -1
  855. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarioData.js.map +1 -1
  856. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js +29 -34
  857. package/packages/analyze/src/lib/files/scenarios/generateChangesScenarios.js.map +1 -1
  858. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +404 -85
  859. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  860. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +144 -0
  861. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -0
  862. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js +56 -69
  863. package/packages/analyze/src/lib/files/scenarios/generateScenarioData.js.map +1 -1
  864. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js +4 -8
  865. package/packages/analyze/src/lib/files/scenarios/generateScenarios.js.map +1 -1
  866. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +875 -141
  867. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  868. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  869. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  870. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  871. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  872. package/packages/analyze/src/lib/index.js +1 -0
  873. package/packages/analyze/src/lib/index.js.map +1 -1
  874. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  875. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  876. package/packages/aws/src/lib/ecs/ecsDefineContainer.js +2 -2
  877. package/packages/aws/src/lib/ecs/ecsDefineContainer.js.map +1 -1
  878. package/packages/aws/src/lib/ecs/ecsTaskFactory.js +17 -61
  879. package/packages/aws/src/lib/ecs/ecsTaskFactory.js.map +1 -1
  880. package/packages/database/src/lib/analysisBranchToDb.js +1 -1
  881. package/packages/database/src/lib/analysisBranchToDb.js.map +1 -1
  882. package/packages/database/src/lib/analysisToDb.js +1 -1
  883. package/packages/database/src/lib/analysisToDb.js.map +1 -1
  884. package/packages/database/src/lib/branchToDb.js +1 -1
  885. package/packages/database/src/lib/branchToDb.js.map +1 -1
  886. package/packages/database/src/lib/commitBranchToDb.js +1 -1
  887. package/packages/database/src/lib/commitBranchToDb.js.map +1 -1
  888. package/packages/database/src/lib/commitToDb.js +1 -1
  889. package/packages/database/src/lib/commitToDb.js.map +1 -1
  890. package/packages/database/src/lib/fileToDb.js +1 -1
  891. package/packages/database/src/lib/fileToDb.js.map +1 -1
  892. package/packages/database/src/lib/kysely/db.js +13 -3
  893. package/packages/database/src/lib/kysely/db.js.map +1 -1
  894. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  895. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  896. package/packages/database/src/lib/kysely/tables/debugReportsTable.js +9 -3
  897. package/packages/database/src/lib/kysely/tables/debugReportsTable.js.map +1 -1
  898. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js +35 -0
  899. package/packages/database/src/lib/kysely/tables/labsRequestsTable.js.map +1 -0
  900. package/packages/database/src/lib/loadAnalyses.js +45 -2
  901. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  902. package/packages/database/src/lib/loadAnalysis.js +8 -0
  903. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  904. package/packages/database/src/lib/loadBranch.js +11 -1
  905. package/packages/database/src/lib/loadBranch.js.map +1 -1
  906. package/packages/database/src/lib/loadCommit.js +7 -0
  907. package/packages/database/src/lib/loadCommit.js.map +1 -1
  908. package/packages/database/src/lib/loadCommits.js +22 -1
  909. package/packages/database/src/lib/loadCommits.js.map +1 -1
  910. package/packages/database/src/lib/loadEntities.js +23 -4
  911. package/packages/database/src/lib/loadEntities.js.map +1 -1
  912. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  913. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  914. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +23 -5
  915. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  916. package/packages/database/src/lib/projectToDb.js +1 -1
  917. package/packages/database/src/lib/projectToDb.js.map +1 -1
  918. package/packages/database/src/lib/saveFiles.js +1 -1
  919. package/packages/database/src/lib/saveFiles.js.map +1 -1
  920. package/packages/database/src/lib/scenarioToDb.js +1 -1
  921. package/packages/database/src/lib/scenarioToDb.js.map +1 -1
  922. package/packages/database/src/lib/updateCommitMetadata.js +5 -4
  923. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  924. package/packages/generate/index.js +3 -0
  925. package/packages/generate/index.js.map +1 -1
  926. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js +16 -1
  927. package/packages/generate/src/lib/componentScenarioPage/componentScenarioPageNext.js.map +1 -1
  928. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +189 -0
  929. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -0
  930. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js +53 -0
  931. package/packages/generate/src/lib/componentScenarioPage/generateScenarioServerComponent.js.map +1 -0
  932. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +8 -4
  933. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  934. package/packages/generate/src/lib/deepMerge.js +27 -1
  935. package/packages/generate/src/lib/deepMerge.js.map +1 -1
  936. package/packages/generate/src/lib/directExecutionScript.js +10 -1
  937. package/packages/generate/src/lib/directExecutionScript.js.map +1 -1
  938. package/packages/generate/src/lib/getComponentScenarioPath.js +7 -3
  939. package/packages/generate/src/lib/getComponentScenarioPath.js.map +1 -1
  940. package/packages/generate/src/lib/scenarioComponentForServer.js +89 -0
  941. package/packages/generate/src/lib/scenarioComponentForServer.js.map +1 -0
  942. package/packages/github/src/lib/loadOrCreateCommit.js +10 -0
  943. package/packages/github/src/lib/loadOrCreateCommit.js.map +1 -1
  944. package/packages/github/src/lib/syncPrimaryBranch.js +3 -0
  945. package/packages/github/src/lib/syncPrimaryBranch.js.map +1 -1
  946. package/packages/process/index.js +3 -0
  947. package/packages/process/index.js.map +1 -0
  948. package/packages/process/src/GlobalProcessManager.js.map +1 -0
  949. package/{background/src/lib/process → packages/process/src}/ProcessManager.js +1 -1
  950. package/packages/process/src/ProcessManager.js.map +1 -0
  951. package/packages/process/src/index.js.map +1 -0
  952. package/packages/process/src/managedExecAsync.js.map +1 -0
  953. package/packages/types/index.js.map +1 -1
  954. package/packages/utils/src/lib/applyUniversalMocks.js +26 -2
  955. package/packages/utils/src/lib/applyUniversalMocks.js.map +1 -1
  956. package/packages/utils/src/lib/fs/rsyncCopy.js +93 -2
  957. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  958. package/packages/utils/src/lib/lightweightEntityExtractor.js +25 -0
  959. package/packages/utils/src/lib/lightweightEntityExtractor.js.map +1 -1
  960. package/packages/utils/src/lib/safeFileName.js +29 -3
  961. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  962. package/scripts/finalize-analyzer.cjs +8 -74
  963. package/analyzer-template/packages/ai/src/lib/findMatchingAttribute.ts +0 -102
  964. package/analyzer-template/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.ts +0 -197
  965. package/analyzer-template/packages/ai/src/lib/generateChangesEntityKeyAttributes.ts +0 -271
  966. package/analyzer-template/packages/ai/src/lib/generateEntityKeyAttributes.ts +0 -294
  967. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.ts +0 -67
  968. package/analyzer-template/packages/ai/src/lib/transformMockDataToMatchSchema.ts +0 -156
  969. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.ts +0 -115
  970. package/analyzer-template/process/INTEGRATION_COMPLETE.md +0 -333
  971. package/analyzer-template/process/INTEGRATION_EXAMPLE.md +0 -525
  972. package/analyzer-template/process/README.md +0 -507
  973. package/background/src/lib/process/GlobalProcessManager.js.map +0 -1
  974. package/background/src/lib/process/ProcessManager.js.map +0 -1
  975. package/background/src/lib/process/index.js.map +0 -1
  976. package/background/src/lib/process/managedExecAsync.js.map +0 -1
  977. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js +0 -238
  978. package/codeyam-cli/scripts/fixtures/cal.com/universal-mocks/packages/prisma/index.js.map +0 -1
  979. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-D4htqD-x.js +0 -1
  980. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeIcon-Catz6XEN.js +0 -1
  981. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-TlHocYno.js +0 -26
  982. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-CVMmGuIc.js +0 -3
  983. package/codeyam-cli/src/webserver/build/client/assets/LogViewer-JkfQ-VaI.js +0 -3
  984. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-CVZ0H4BL.js +0 -1
  985. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-BrMAP1nP.js +0 -1
  986. package/codeyam-cli/src/webserver/build/client/assets/ScenarioViewer-CJhE4cCv.js +0 -5
  987. package/codeyam-cli/src/webserver/build/client/assets/_index-faVIcr_i.js +0 -1
  988. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-CLMa2sgx.js +0 -7
  989. package/codeyam-cli/src/webserver/build/client/assets/chevron-down-DwYjrK_h.js +0 -1
  990. package/codeyam-cli/src/webserver/build/client/assets/chunk-WWGJGFF6-CgXbbZRx.js +0 -26
  991. package/codeyam-cli/src/webserver/build/client/assets/circle-check-B2oHQ-zo.js +0 -1
  992. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-BBYuR56H.js +0 -1
  993. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-CT0Q5lVu.js +0 -1
  994. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-Bj5GHkhb.js +0 -1
  995. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.edit._scenarioId-eW5z9AyZ.js +0 -5
  996. package/codeyam-cli/src/webserver/build/client/assets/entry.client-B9tSboXM.js +0 -5
  997. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-CmO-EZAB.js +0 -1
  998. package/codeyam-cli/src/webserver/build/client/assets/files-DLinnTOx.js +0 -1
  999. package/codeyam-cli/src/webserver/build/client/assets/git-CIxwBQvb.js +0 -12
  1000. package/codeyam-cli/src/webserver/build/client/assets/globals-xPz593l2.css +0 -1
  1001. package/codeyam-cli/src/webserver/build/client/assets/html2canvas-pro.esm-XQCGvadH.js +0 -5
  1002. package/codeyam-cli/src/webserver/build/client/assets/index-_LjBsTxX.js +0 -8
  1003. package/codeyam-cli/src/webserver/build/client/assets/loader-circle-D_EGChhq.js +0 -1
  1004. package/codeyam-cli/src/webserver/build/client/assets/manifest-ca438c41.js +0 -1
  1005. package/codeyam-cli/src/webserver/build/client/assets/root-CHHYHuzL.js +0 -16
  1006. package/codeyam-cli/src/webserver/build/client/assets/search-DY8yoDpH.js +0 -1
  1007. package/codeyam-cli/src/webserver/build/client/assets/server-build-CMKNK2uU.css +0 -1
  1008. package/codeyam-cli/src/webserver/build/client/assets/settings-BT6wVHd5.js +0 -1
  1009. package/codeyam-cli/src/webserver/build/client/assets/simulations-gv3H7JV7.js +0 -1
  1010. package/codeyam-cli/src/webserver/build/client/assets/triangle-alert-BthANBVv.js +0 -1
  1011. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-CANr3QJ5.js +0 -1
  1012. package/codeyam-cli/src/webserver/build/server/assets/index-BtBPtyHx.js +0 -1
  1013. package/codeyam-cli/src/webserver/build/server/assets/server-build-N2cTnejq.js +0 -166
  1014. package/codeyam-cli/templates/debug-command.md +0 -141
  1015. package/packages/ai/src/lib/findMatchingAttribute.js +0 -77
  1016. package/packages/ai/src/lib/findMatchingAttribute.js.map +0 -1
  1017. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js +0 -136
  1018. package/packages/ai/src/lib/gatherRelevantDependentKeyAttributes.js.map +0 -1
  1019. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js +0 -220
  1020. package/packages/ai/src/lib/generateChangesEntityKeyAttributes.js.map +0 -1
  1021. package/packages/ai/src/lib/generateEntityKeyAttributes.js +0 -241
  1022. package/packages/ai/src/lib/generateEntityKeyAttributes.js.map +0 -1
  1023. package/packages/ai/src/lib/isFrontend.js +0 -5
  1024. package/packages/ai/src/lib/isFrontend.js.map +0 -1
  1025. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js +0 -40
  1026. package/packages/ai/src/lib/promptGenerators/generateEntityKeyAttributesGenerator.js.map +0 -1
  1027. package/packages/ai/src/lib/transformMockDataToMatchSchema.js +0 -124
  1028. package/packages/ai/src/lib/transformMockDataToMatchSchema.js.map +0 -1
  1029. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js +0 -72
  1030. package/packages/analyze/src/lib/files/scenarios/generateKeyAttributes.js.map +0 -1
  1031. /package/analyzer-template/{process → packages/process/src}/GlobalProcessManager.ts +0 -0
  1032. /package/analyzer-template/{process → packages/process/src}/ProcessManager.ts +0 -0
  1033. /package/analyzer-template/{process → packages/process/src}/index.ts +0 -0
  1034. /package/analyzer-template/{process → packages/process/src}/managedExecAsync.ts +0 -0
  1035. /package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-CMKNK2uU.css → styles-CMKNK2uU.css} +0 -0
  1036. /package/{background/src/lib/process → packages/process/src}/GlobalProcessManager.js +0 -0
  1037. /package/{background/src/lib/process → packages/process/src}/index.js +0 -0
  1038. /package/{background/src/lib/process → packages/process/src}/managedExecAsync.js +0 -0
@@ -0,0 +1,120 @@
1
+ import type { ExecutionFlow, ScenariosDataStructure } from '~codeyam/types';
2
+
3
+ /**
4
+ * Extract the data structure keys that are critical for satisfying execution flow requirements.
5
+ *
6
+ * When generating scenario mock data, only a subset of the full dataForMocks structure
7
+ * is actually needed to satisfy the scenario's covered flows' requiredValues.
8
+ * This function identifies those critical keys so they can be processed with more focus
9
+ * (e.g., in a separate LLM call or prioritized in the prompt).
10
+ *
11
+ * @param dataForMocks - The full data structure schema
12
+ * @param executionFlows - All execution flows for the entity
13
+ * @param coveredFlowIds - The flow IDs covered by the current scenario
14
+ * @returns Array of top-level keys from dataForMocks that are referenced by the covered flows
15
+ */
16
+ export function extractCriticalDataKeys(
17
+ dataForMocks: ScenariosDataStructure['dataForMocks'],
18
+ executionFlows: ExecutionFlow[],
19
+ coveredFlowIds: string[],
20
+ ): string[] {
21
+ if (!dataForMocks || typeof dataForMocks !== 'object') {
22
+ return [];
23
+ }
24
+
25
+ const dataKeys = Object.keys(dataForMocks);
26
+ const criticalKeys = new Set<string>();
27
+
28
+ // Get the covered flows
29
+ const coveredFlows = executionFlows.filter((flow) =>
30
+ coveredFlowIds.includes(flow.id),
31
+ );
32
+
33
+ // For each covered flow, check if any requiredValue references a dataForMocks key
34
+ for (const flow of coveredFlows) {
35
+ if (!flow.requiredValues) continue;
36
+
37
+ for (const rv of flow.requiredValues) {
38
+ const path = rv.attributePath;
39
+ if (!path) continue;
40
+
41
+ // Try to match the attributePath to a dataForMocks key
42
+ // The path format is: "functionCall().functionCallReturnValue.property"
43
+ // or: "functionCall<Type>().functionCallReturnValue.property"
44
+ // We need to extract the function call part and match it to a key
45
+
46
+ for (const key of dataKeys) {
47
+ if (pathMatchesKey(path, key)) {
48
+ criticalKeys.add(key);
49
+ break; // One match per requiredValue is enough
50
+ }
51
+ }
52
+ }
53
+ }
54
+
55
+ return Array.from(criticalKeys);
56
+ }
57
+
58
+ /**
59
+ * Check if an attributePath references a given dataForMocks key.
60
+ *
61
+ * Handles various path formats:
62
+ * - "useParams().functionCallReturnValue.*" matches "useParams()"
63
+ * - "useLoaderData<LoaderData>().functionCallReturnValue.data" matches "useLoaderData<LoaderData>()"
64
+ * - "useFetcher().data.success" matches "useFetcher()"
65
+ */
66
+ function pathMatchesKey(attributePath: string, dataKey: string): boolean {
67
+ // Normalize both for comparison
68
+ // Remove .functionCallReturnValue from the path
69
+ const normalizedPath = attributePath.replace('.functionCallReturnValue', '');
70
+
71
+ // Check if the path starts with the key (exact match for function call keys)
72
+ if (normalizedPath.startsWith(dataKey)) {
73
+ // Ensure it's not a partial match (e.g., "use" shouldn't match "useState")
74
+ const afterKey = normalizedPath.slice(dataKey.length);
75
+ // Valid continuations: end of string, '.', or '['
76
+ if (
77
+ afterKey === '' ||
78
+ afterKey.startsWith('.') ||
79
+ afterKey.startsWith('[')
80
+ ) {
81
+ return true;
82
+ }
83
+ }
84
+
85
+ // Try matching without type parameters if needed
86
+ // e.g., "useLoaderData<LoaderData>()" should match attributePaths with same base
87
+ const keyWithoutTypes = removeTypeParameters(dataKey);
88
+ const pathWithoutTypes = removeTypeParameters(normalizedPath);
89
+
90
+ if (pathWithoutTypes.startsWith(keyWithoutTypes)) {
91
+ const afterKey = pathWithoutTypes.slice(keyWithoutTypes.length);
92
+ if (
93
+ afterKey === '' ||
94
+ afterKey.startsWith('.') ||
95
+ afterKey.startsWith('[')
96
+ ) {
97
+ return true;
98
+ }
99
+ }
100
+
101
+ return false;
102
+ }
103
+
104
+ /**
105
+ * Remove type parameters from a function call string.
106
+ * e.g., "useLoaderData<LoaderData>()" -> "useLoaderData()"
107
+ */
108
+ function removeTypeParameters(str: string): string {
109
+ // Match and remove <...> including nested angle brackets
110
+ let result = str;
111
+ let prevLength = 0;
112
+
113
+ // Keep removing until no more changes (handles nested generics)
114
+ while (result.length !== prevLength) {
115
+ prevLength = result.length;
116
+ result = result.replace(/<[^<>]*>/g, '');
117
+ }
118
+
119
+ return result;
120
+ }
@@ -16,6 +16,8 @@ import type {
16
16
  import { LlmCall } from '~codeyam/types';
17
17
  import validateJson from './validateJson';
18
18
  import checkAllAttributes from './checkAllAttributes';
19
+ import convertNullToUndefinedBySchema from './dataStructure/helpers/convertNullToUndefinedBySchema';
20
+ import deepEqual from './deepEqual';
19
21
  import { awsLog } from '~codeyam/utils';
20
22
  import { AI, parseJsonSafe } from '~codeyam/ai';
21
23
 
@@ -59,12 +61,14 @@ async function generateChangesDataForScenario({
59
61
  llmCalls: LlmCall[];
60
62
  }> {
61
63
  if (
62
- structure === existingStructure &&
63
- scenario.metadata.keyAttributeInstructions ===
64
- existingScenario.metadata.keyAttributeInstructions
64
+ deepEqual(structure, existingStructure) &&
65
+ deepEqual(
66
+ scenario.metadata?.coveredFlows,
67
+ existingScenario?.metadata?.coveredFlows,
68
+ )
65
69
  ) {
66
70
  console.log(
67
- "CodeYam: No changes in scenario's structure or keyAttributeInstructions - returning existing scenario data",
71
+ "CodeYam: No changes in scenario's structure or coveredFlows - returning existing scenario data",
68
72
  {
69
73
  analysisId: scenario.analysisId,
70
74
  scenarioId: scenario.id,
@@ -95,6 +99,7 @@ async function generateChangesDataForScenario({
95
99
  prompt = generateEntityScenarioDataGenerator(
96
100
  structure,
97
101
  scenario,
102
+ undefined, // executionFlows - not available in changes context
98
103
  defaultScenarioData,
99
104
  incompleteResponse,
100
105
  );
@@ -219,8 +224,8 @@ async function generateChangesDataForScenario({
219
224
  if (!Array.isArray(argumentsData)) {
220
225
  argumentsData = [];
221
226
  }
222
- fullScenarioData.data.argumentsData = argumentsData.map((arg) =>
223
- checkAllAttributes(arg),
227
+ fullScenarioData.data.argumentsData = argumentsData.map(
228
+ (arg) => checkAllAttributes(arg) as { [key: string]: unknown },
224
229
  );
225
230
 
226
231
  if (structure.dataForMocks && !fullScenarioData.data.mockData) {
@@ -232,7 +237,28 @@ async function generateChangesDataForScenario({
232
237
  }
233
238
  fullScenarioData.data.mockData = checkAllAttributes(
234
239
  fullScenarioData.data.mockData,
235
- );
240
+ ) as { [key: string]: unknown };
241
+
242
+ // Convert null values to undefined based on schema type constraints.
243
+ // LLM uses null for "no value" (JSON doesn't support undefined), but TypeScript
244
+ // types like "string | undefined" don't accept null. This converts null→undefined
245
+ // for fields typed as "T | undefined" (but preserves null for "T | null").
246
+ if (structure.dataForMocks && fullScenarioData.data.mockData) {
247
+ convertNullToUndefinedBySchema(
248
+ fullScenarioData.data.mockData,
249
+ structure.dataForMocks,
250
+ );
251
+ }
252
+ if (structure.arguments && fullScenarioData.data.argumentsData) {
253
+ for (let i = 0; i < fullScenarioData.data.argumentsData.length; i++) {
254
+ if (structure.arguments[i]) {
255
+ convertNullToUndefinedBySchema(
256
+ fullScenarioData.data.argumentsData[i],
257
+ structure.arguments[i],
258
+ );
259
+ }
260
+ }
261
+ }
236
262
 
237
263
  return {
238
264
  llmCalls: [{ name: scenario.name, id: llmCall.id }],
@@ -346,6 +372,47 @@ NEVER include "error" fields in responses. Skip them entirely.
346
372
  - If structure has \`{ data: {...}, error: {...} }\`, only fill \`data\`
347
373
  - Leave out any attribute named "error"—do not set to null, omit entirely
348
374
 
375
+ ## CRITICAL: Preserve Exact Structure
376
+ Your response MUST mirror the EXACT nested structure provided in mockData Structure.
377
+ - Do NOT reorganize, split, or create duplicate keys
378
+ - The hierarchy of nested objects must match exactly what was provided
379
+ - Only change the leaf VALUES (replacing type descriptions like "string" with actual data like "hello")
380
+ - Arrays should have 3-5 items to provide realistic test data variety
381
+
382
+ **Example** - if given this structure:
383
+ \`\`\`json
384
+ {
385
+ "createClient()": {
386
+ "from(\\"users\\")": {
387
+ "select(\\"*\\")": { "data": [{ "id": "string", "name": "string" }] },
388
+ "delete()": { "eq(\\"id\\", id)": {} }
389
+ }
390
+ }
391
+ }
392
+ \`\`\`
393
+
394
+ Return ONE \`from("users")\` key containing BOTH \`select("*")\` and \`delete()\`:
395
+ \`\`\`json
396
+ {
397
+ "createClient()": {
398
+ "from(\\"users\\")": {
399
+ "select(\\"*\\")": { "data": [{ "id": "user-1", "name": "Alice" }, { "id": "user-2", "name": "Bob" }] },
400
+ "delete()": { "eq(\\"id\\", \\"user-1\\")": {} }
401
+ }
402
+ }
403
+ }
404
+ \`\`\`
405
+
406
+ **WRONG** - do NOT create duplicate keys like this:
407
+ \`\`\`json
408
+ {
409
+ "createClient()": {
410
+ "from(\\"users\\")": { "select(\\"*\\")": { ... } },
411
+ "from(\\"users\\")": { "delete()": { ... } }
412
+ }
413
+ }
414
+ \`\`\`
415
+
349
416
  ## Special Markers
350
417
 
351
418
  ### Dynamic Dates (\`~~codeyam-code~~\`)
@@ -5,21 +5,19 @@ import generateChangesEntityScenariosGenerator from './promptGenerators/generate
5
5
  import {
6
6
  Analysis,
7
7
  Entity,
8
+ ExecutionFlow,
8
9
  ReadonlyAnalysisMap,
9
10
  Scenario,
10
11
  } from '~codeyam/types';
11
12
  import { ScenarioResult } from './generateEntityScenarios';
12
- import findMatchingAttribute from './findMatchingAttribute';
13
13
  import { awsLog } from '~codeyam/utils';
14
14
  import { sanitizePlaywrightInstructions } from './validatePlaywrightInstructions';
15
- import gatherRelevantDependentKeyAttributes from './gatherRelevantDependentKeyAttributes';
16
15
  import { AI, DEFAULT_LARGER_MODEL, parseJsonSafe } from '~codeyam/ai';
17
16
 
18
17
  interface GenerateChangesEntityScenariosArgs {
19
18
  entity: Entity;
20
- keyAttributes: Analysis['metadata']['keyAttributes'];
21
- addedKeyAttributes: Analysis['metadata']['keyAttributes'];
22
- removedKeyAttributes: Analysis['metadata']['keyAttributes'];
19
+ executionFlows?: ExecutionFlow[];
20
+ previousExecutionFlows?: ExecutionFlow[];
23
21
  dependentAnalyses?: ReadonlyAnalysisMap;
24
22
  existingScenarios: Scenario[];
25
23
  commitDiff: string;
@@ -33,10 +31,8 @@ const DEFAULT_SCENARIO_NAME = 'Default Scenario';
33
31
 
34
32
  export default async function generateChangesEntityScenarios({
35
33
  entity,
36
- keyAttributes,
37
- addedKeyAttributes,
38
- removedKeyAttributes,
39
- dependentAnalyses,
34
+ executionFlows,
35
+ previousExecutionFlows,
40
36
  existingScenarios,
41
37
  commitDiff,
42
38
  analysis,
@@ -44,16 +40,22 @@ export default async function generateChangesEntityScenarios({
44
40
  model,
45
41
  changedDataStructureFields = [],
46
42
  }: GenerateChangesEntityScenariosArgs) {
47
- const relevantDependentKeyAttributes = gatherRelevantDependentKeyAttributes(
48
- entity,
49
- analysis.metadata.mergedDataStructure,
50
- dependentAnalyses,
43
+ // Determine added/removed flows
44
+ const currentFlowIds = new Set((executionFlows ?? []).map((f) => f.id));
45
+ const previousFlowIds = new Set(
46
+ (previousExecutionFlows ?? []).map((f) => f.id),
51
47
  );
48
+
49
+ const addedFlows =
50
+ executionFlows?.filter((f) => !previousFlowIds.has(f.id)) ?? [];
51
+ const removedFlows =
52
+ previousExecutionFlows?.filter((f) => !currentFlowIds.has(f.id)) ?? [];
53
+
54
+ // If no changes, return existing scenarios
52
55
  if (
53
- (!addedKeyAttributes || addedKeyAttributes.length === 0) &&
54
- (!removedKeyAttributes || removedKeyAttributes.length === 0) &&
55
- !existingScenarios.some((s) => s.metadata?.playwrightInstructions) &&
56
- Object.keys(relevantDependentKeyAttributes).length === 0
56
+ addedFlows.length === 0 &&
57
+ removedFlows.length === 0 &&
58
+ !existingScenarios.some((s) => s.metadata?.playwrightInstructions)
57
59
  ) {
58
60
  return { scenarios: existingScenarios };
59
61
  }
@@ -62,21 +64,20 @@ export default async function generateChangesEntityScenarios({
62
64
  `CodeYam: Generating ${error ? 'error ' : ''}changes entity scenarios`,
63
65
  {
64
66
  filePath: entity.filePath,
65
- entityNam: entity.name,
66
- analysis: analysis.id,
67
- keyAttributes: keyAttributes.map((a) => a.externalPath),
68
- addedKeyAttributes: addedKeyAttributes?.map((a) => a.externalPath),
69
- removedKeyAttributes: removedKeyAttributes?.map((a) => a.externalPath),
67
+ entityName: entity.name,
68
+ analysisId: analysis.id,
69
+ currentFlowCount: executionFlows?.length ?? 0,
70
+ addedFlows: addedFlows.map((f) => f.id),
71
+ removedFlows: removedFlows.map((f) => f.id),
70
72
  },
71
73
  );
72
74
 
73
75
  const prompt = generateChangesEntityScenariosGenerator({
74
76
  entity,
75
77
  mergedDataStructure: analysis.metadata.mergedDataStructure,
76
- keyAttributes,
77
- addedKeyAttributes,
78
- removedKeyAttributes,
79
- dependentAnalyses,
78
+ executionFlows,
79
+ addedFlows,
80
+ removedFlows,
80
81
  existingScenarios,
81
82
  commitDiff,
82
83
  error,
@@ -93,7 +94,7 @@ export default async function generateChangesEntityScenarios({
93
94
  type: `generate${error ? 'Error' : ''}ChangesEntityScenarios`,
94
95
  systemMessage: error
95
96
  ? ERROR_SYSTEM_MESSAGE
96
- : generateChangesSystemMessage(context, scenarioCount, false),
97
+ : generateChangesSystemMessage(context, scenarioCount),
97
98
  prompt,
98
99
  model: model ?? DEFAULT_LARGER_MODEL,
99
100
  });
@@ -111,32 +112,17 @@ export default async function generateChangesEntityScenarios({
111
112
  path: entity.file.path,
112
113
  },
113
114
  },
114
- keyAttributes,
115
- addedKeyAttributes,
116
- removedKeyAttributes,
117
- dependentAnalyses: Object.fromEntries(
118
- Object.entries(dependentAnalyses ?? {}).map(([path, analyses]) => [
119
- path,
120
- Object.fromEntries(
121
- Object.entries(analyses).map(([name, analysis]) => [
122
- name,
123
- {
124
- metadata: {
125
- keyAttributes: analysis.metadata?.keyAttributes,
126
- },
127
- },
128
- ]),
129
- ),
130
- ]),
131
- ),
115
+ executionFlows,
116
+ addedFlows,
117
+ removedFlows,
132
118
  existingScenarios: existingScenarios.map((s) => ({
133
119
  id: s.id,
134
120
  name: s.name,
135
121
  description: s.description,
136
122
  metadata: {
137
- error: s.metadata.error,
138
- keyAttributeInstructions: s.metadata.keyAttributeInstructions,
139
- playwrightInstructions: s.metadata.playwrightInstructions,
123
+ error: s.metadata?.error,
124
+ coveredFlows: s.metadata?.coveredFlows,
125
+ playwrightInstructions: s.metadata?.playwrightInstructions,
140
126
  },
141
127
  })),
142
128
  commitDiff,
@@ -146,7 +132,7 @@ export default async function generateChangesEntityScenarios({
146
132
  isolatedDataStructure: {
147
133
  equivalentSignatureVariables:
148
134
  entity.metadata.isolatedDataStructure
149
- .equivalentSignatureVariables,
135
+ ?.equivalentSignatureVariables,
150
136
  },
151
137
  },
152
138
  },
@@ -191,7 +177,7 @@ export default async function generateChangesEntityScenarios({
191
177
  );
192
178
 
193
179
  const revisedFromPreviousVersion = previousVersion
194
- ? !!scenarioInfo.keyAttributeInstructions
180
+ ? !!scenarioInfo.coveredFlows
195
181
  : undefined;
196
182
  const useScenarioData = !previousVersion || revisedFromPreviousVersion;
197
183
 
@@ -204,58 +190,42 @@ export default async function generateChangesEntityScenarios({
204
190
  : previousVersion.description,
205
191
  metadata: {
206
192
  testName:
207
- useScenarioData || !previousVersion.metadata.testName
193
+ useScenarioData || !previousVersion?.metadata?.testName
208
194
  ? scenarioInfo.testName
209
195
  : previousVersion.metadata.testName,
210
196
  error,
211
197
  revisedFromPreviousVersion,
212
198
  codeSnippet: useScenarioData
213
199
  ? scenarioInfo.codeSnippet
214
- : previousVersion.metadata.codeSnippet,
215
- fix: useScenarioData ? scenarioInfo.fix : previousVersion.metadata.fix,
200
+ : previousVersion?.metadata?.codeSnippet,
201
+ fix: useScenarioData
202
+ ? scenarioInfo.fix
203
+ : previousVersion?.metadata?.fix,
216
204
  fixSnippet: useScenarioData
217
205
  ? scenarioInfo.fixSnippet
218
- : previousVersion.metadata.fixSnippet,
206
+ : previousVersion?.metadata?.fixSnippet,
219
207
  likelihood: useScenarioData
220
208
  ? scenarioInfo.likelihood
221
- : previousVersion.metadata.likelihood,
209
+ : previousVersion?.metadata?.likelihood,
222
210
  likelihoodDescription: useScenarioData
223
211
  ? scenarioInfo.likelihoodDescription
224
- : previousVersion.metadata.likelihoodDescription,
212
+ : previousVersion?.metadata?.likelihoodDescription,
225
213
  severity: useScenarioData
226
214
  ? scenarioInfo.severity
227
- : previousVersion.metadata.severity,
215
+ : previousVersion?.metadata?.severity,
228
216
  severityDescription: useScenarioData
229
217
  ? scenarioInfo.severityDescription
230
- : previousVersion.metadata.severityDescription,
231
- dataMapping: useScenarioData
232
- ? scenarioInfo.dataMapping
233
- : previousVersion.metadata.dataMapping,
234
- keyAttributeInstructions: useScenarioData
235
- ? Object.keys(scenarioInfo.keyAttributeInstructions).reduce(
236
- (acc: any, key) => {
237
- const attributesList = keyAttributes.map(
238
- (attr) => attr.internalPath,
239
- );
240
- const matchingKey = findMatchingAttribute(
241
- key,
242
- attributesList,
243
- entity.metadata.isolatedDataStructure
244
- .equivalentSignatureVariables,
245
- );
246
- acc[matchingKey] = scenarioInfo.keyAttributeInstructions[key];
247
- return acc;
248
- },
249
- {},
250
- )
251
- : previousVersion.metadata.keyAttributeInstructions,
218
+ : previousVersion?.metadata?.severityDescription,
219
+ coveredFlows: useScenarioData
220
+ ? scenarioInfo.coveredFlows || []
221
+ : previousVersion?.metadata?.coveredFlows || [],
252
222
  playwrightInstructions: useScenarioData
253
223
  ? sanitizePlaywrightInstructions(
254
224
  scenarioInfo.playwrightInstructions || [],
255
225
  entity.name,
256
226
  scenarioInfo.name,
257
227
  )
258
- : previousVersion.metadata.playwrightInstructions,
228
+ : previousVersion?.metadata?.playwrightInstructions,
259
229
  },
260
230
  previousVersionId: previousVersion?.id,
261
231
  });
@@ -271,7 +241,6 @@ export default async function generateChangesEntityScenarios({
271
241
  function generateChangesSystemMessage(
272
242
  context?: string,
273
243
  scenarioCount?: number,
274
- _isError?: boolean,
275
244
  ): string {
276
245
  const contextSection = context
277
246
  ? `## Business Context
@@ -288,27 +257,35 @@ Focus scenario updates on demonstrating this change.${scenarioCount ? ` Generate
288
257
 
289
258
  return `You are updating data scenarios after a code change. Determine which existing scenarios need updating, which should be removed, and if new ones are needed.
290
259
 
291
- ${contextSection}## Update Rules
260
+ ${contextSection}## Your Goal: Maintain Full Execution Flow Coverage
261
+
262
+ You are given:
263
+ - \`executionFlows\`: All current distinct outcomes/behaviors this component can produce
264
+ - \`addedFlows\`: New flows that didn't exist before
265
+ - \`removedFlows\`: Flows that no longer exist
266
+ - \`existingScenarios\`: Current scenarios with their coveredFlows
267
+
268
+ **Your job**: Update scenarios to maintain coverage of ALL current execution flows.
292
269
 
293
- ### Removed Key Attributes
294
- - Update scenarios using removed attributes—replace with new attributes or remove if no longer relevant
295
- - CRITICAL: "${DEFAULT_SCENARIO_NAME}" must NEVER contain removed attributes—update or replace them
296
- - Try to maintain 3+ scenarios; create replacements if removing too many
270
+ ## Update Rules
297
271
 
298
- ### Added Key Attributes
299
- - Create or update scenarios to demonstrate new behavior
272
+ ### Removed Flows
273
+ - If an existing scenario only covers removed flows, remove the scenario
274
+ - If a scenario covers both removed and current flows, update its coveredFlows to remove the deleted ones
300
275
 
301
- ### Playwright Instructions
302
- - Validate existing instructions still work after code changes
303
- - Update any that reference changed UI elements
276
+ ### Added Flows
277
+ - Create new scenarios or update existing ones to cover new flows
278
+ - Follow the same rules as initial scenario generation:
279
+ - Blocking flows (blocksOtherFlows: true) get their own dedicated scenarios
280
+ - Non-blocking flows can be combined with compatible existing scenarios
304
281
 
305
282
  ### Unchanged Scenarios
306
- - Return name only (no other fields needed)
283
+ - Return name only (no other fields needed) if the scenario's covered flows are all still valid
307
284
 
308
285
  ### Default Scenario
309
286
  - First scenario must be "${DEFAULT_SCENARIO_NAME}" (exact name)
310
287
  - NEVER include playwrightInstructions—captures initial state only
311
- - Must include all current key attributes with valid values
288
+ - Should cover as many non-blocking, non-error flows as possible
312
289
 
313
290
  ## Response Format
314
291
 
@@ -326,27 +303,31 @@ Otherwise:
326
303
  "overview": "Added empty state scenario for new display behavior.",
327
304
  "dataScenarios": [
328
305
  { "name": "${DEFAULT_SCENARIO_NAME}" },
329
- { "name": "Many notifications" },
306
+ { "name": "Settings Modal" },
330
307
  {
331
- "name": "No notifications",
332
- "testName": "it(\\"shows empty message when no notifications\\")",
333
- "description": "User has no notifications.",
334
- "keyAttributeInstructions": {
335
- "notifications[]": { "localVariable": "notifications[]", "instruction": "Empty array" }
336
- }
308
+ "name": "Empty State",
309
+ "testName": "it(\\"shows empty message when no items\\")",
310
+ "description": "User has no items to display.",
311
+ "coveredFlows": ["empty-list"]
337
312
  }
338
313
  ]
339
314
  }
340
315
  \`\`\`
341
316
 
317
+ ## Field Descriptions
318
+
319
+ - **name**: Human-readable scenario name (letters, numbers, spaces only)
320
+ - **testName**: Jest-style test description (only for new/updated scenarios)
321
+ - **description**: What the user sees (only for new/updated scenarios)
322
+ - **coveredFlows**: Array of execution flow IDs this scenario covers (only for new/updated scenarios)
323
+ - **playwrightInstructions**: User interactions needed (only for new/updated scenarios that require interaction)
324
+
342
325
  ## Rules
343
326
  - Scenario names: letters, numbers, spaces only
344
327
  - testName: Jest style with specific expectations
345
- - Use values from \`validValueOptions\` in key attributes list
346
- - Include dependency key attributes if dependencies involved
347
- - React elements: simple only (\`<div>\`, \`<span>\`)
348
- - No external library references—plain JS/TS values
349
- - Relative dates OK: "today", "tomorrow", "last month"
328
+ - All values must be valid JSON
329
+ - EVERY execution flow must be covered by at least one scenario
330
+ - Blocking flows get dedicated scenarios
350
331
  `;
351
332
  }
352
333
 
@@ -381,27 +362,23 @@ Be conservative with high scores.
381
362
  - No external library references—mock with plain JS
382
363
  - Each scenario causes a DISTINCT error type
383
364
 
384
- Note: In JS/TS, any non-zero value satisfies a boolean check—this won't error.
385
-
386
365
  ## Response Format
387
366
  \`\`\`json
388
367
  {
389
368
  "errorDataScenarios": [
390
369
  { "name": "Existing valid error" },
391
370
  {
392
- "dataMapping": { "notifications array": "props.notifications" },
393
371
  "name": "Non-utf8 encoding error",
394
- "codeSnippet": "const encoded = encodeURIComponent(message);",
372
+ "testName": "it(\\"throws on non-utf8 characters\\")",
395
373
  "description": "encodeURIComponent throws on non-utf8 characters",
374
+ "codeSnippet": "const encoded = encodeURIComponent(message);",
396
375
  "fix": "Wrap in try/catch",
397
376
  "fixSnippet": "try { encoded = encodeURIComponent(message); } catch (e) { ... }",
398
377
  "likelihood": 7,
399
378
  "likelihoodDescription": "International users may input non-utf8 characters",
400
379
  "severity": 2,
401
380
  "severityDescription": "Function throws uncaught error",
402
- "keyAttributeInstructions": {
403
- "notifications[]": "Array with message containing non-utf8 characters"
404
- }
381
+ "coveredFlows": []
405
382
  }
406
383
  ]
407
384
  }