@codeyam/codeyam-cli 0.1.0-staging.1669d45 → 0.1.0-staging.2a88920

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 (437) hide show
  1. package/analyzer-template/.build-info.json +8 -8
  2. package/analyzer-template/log.txt +3 -3
  3. package/analyzer-template/package.json +5 -5
  4. package/analyzer-template/packages/ai/index.ts +15 -2
  5. package/analyzer-template/packages/ai/src/lib/analyzeScope.ts +87 -51
  6. package/analyzer-template/packages/ai/src/lib/astScopes/arrayDerivationDetector.ts +199 -0
  7. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +98 -9
  8. package/analyzer-template/packages/ai/src/lib/astScopes/methodSemantics.ts +139 -23
  9. package/analyzer-template/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.ts +6 -126
  10. package/analyzer-template/packages/ai/src/lib/astScopes/processExpression.ts +555 -28
  11. package/analyzer-template/packages/ai/src/lib/astScopes/types.ts +88 -7
  12. package/analyzer-template/packages/ai/src/lib/completionCall.ts +198 -34
  13. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +772 -243
  14. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.ts +205 -0
  15. package/analyzer-template/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.ts +10 -2
  16. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.ts +16 -3
  17. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.ts +6 -4
  18. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.ts +43 -1
  19. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.ts +122 -15
  20. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.ts +160 -0
  21. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.ts +40 -30
  22. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.ts +319 -88
  23. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.ts +129 -0
  24. package/analyzer-template/packages/ai/src/lib/dataStructureChunking.ts +156 -0
  25. package/analyzer-template/packages/ai/src/lib/e2eDataTracking.ts +334 -0
  26. package/analyzer-template/packages/ai/src/lib/extractCriticalDataKeys.ts +120 -0
  27. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +642 -7
  28. package/analyzer-template/packages/ai/src/lib/generateEntityScenarios.ts +35 -6
  29. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +383 -6
  30. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionalEffects.ts +1 -1
  31. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromConditionals.ts +1299 -51
  32. package/analyzer-template/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.ts +239 -0
  33. package/analyzer-template/packages/ai/src/lib/mergeStatements.ts +90 -96
  34. package/analyzer-template/packages/ai/src/lib/promptGenerators/gatherAttributesMap.ts +10 -7
  35. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateChunkPrompt.ts +82 -0
  36. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateCriticalKeysPrompt.ts +103 -0
  37. package/analyzer-template/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.ts +23 -6
  38. package/analyzer-template/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.ts +391 -0
  39. package/analyzer-template/packages/ai/src/lib/resolvePathToControllable.ts +179 -45
  40. package/analyzer-template/packages/ai/src/lib/worker/SerializableDataStructure.ts +26 -4
  41. package/analyzer-template/packages/ai/src/lib/worker/analyzeScopeWorker.ts +114 -2
  42. package/analyzer-template/packages/analyze/src/lib/FileAnalyzer.ts +65 -59
  43. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +113 -26
  44. package/analyzer-template/packages/analyze/src/lib/analysisContext.ts +44 -4
  45. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.ts +19 -0
  46. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.ts +19 -0
  47. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getAllExports.ts +11 -0
  48. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.ts +8 -0
  49. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.ts +49 -1
  50. package/analyzer-template/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.ts +2 -1
  51. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.ts +30 -19
  52. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +14 -4
  53. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +6 -0
  54. package/analyzer-template/packages/analyze/src/lib/files/analyze/gatherEntityMap.ts +4 -2
  55. package/analyzer-template/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.ts +33 -10
  56. package/analyzer-template/packages/analyze/src/lib/files/analyzeRemixRoute.ts +4 -5
  57. package/analyzer-template/packages/analyze/src/lib/files/getImportedExports.ts +14 -12
  58. package/analyzer-template/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.ts +189 -76
  59. package/analyzer-template/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.ts +29 -0
  60. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +77 -9
  61. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +118 -10
  62. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +276 -17
  63. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.ts +56 -11
  64. package/analyzer-template/packages/analyze/src/lib/files/scenarios/propagateArrayItemSchemas.ts +474 -0
  65. package/analyzer-template/packages/analyze/src/lib/files/setImportedExports.ts +2 -1
  66. package/analyzer-template/packages/analyze/src/lib/utils/getFileByPath.ts +19 -0
  67. package/analyzer-template/packages/aws/package.json +2 -2
  68. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -1
  69. package/analyzer-template/packages/database/src/lib/kysely/tables/commitsTable.ts +6 -0
  70. package/analyzer-template/packages/database/src/lib/loadAnalyses.ts +58 -1
  71. package/analyzer-template/packages/database/src/lib/loadAnalysis.ts +13 -0
  72. package/analyzer-template/packages/database/src/lib/loadBranch.ts +16 -1
  73. package/analyzer-template/packages/database/src/lib/loadCommit.ts +11 -0
  74. package/analyzer-template/packages/database/src/lib/loadCommits.ts +28 -0
  75. package/analyzer-template/packages/database/src/lib/loadEntities.ts +26 -3
  76. package/analyzer-template/packages/database/src/lib/loadEntityBranches.ts +12 -0
  77. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +7 -14
  78. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +8 -1
  80. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  81. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/analysesTable.d.ts.map +1 -1
  82. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts +1 -0
  83. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.d.ts.map +1 -1
  84. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js +3 -0
  85. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  86. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts +2 -0
  87. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.d.ts.map +1 -1
  88. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js +45 -2
  89. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalyses.js.map +1 -1
  90. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.d.ts.map +1 -1
  91. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js +8 -0
  92. package/analyzer-template/packages/github/dist/database/src/lib/loadAnalysis.js.map +1 -1
  93. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js +11 -1
  94. package/analyzer-template/packages/github/dist/database/src/lib/loadBranch.js.map +1 -1
  95. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.d.ts.map +1 -1
  96. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js +7 -0
  97. package/analyzer-template/packages/github/dist/database/src/lib/loadCommit.js.map +1 -1
  98. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts +3 -1
  99. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  100. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +22 -1
  101. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  102. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts +3 -1
  103. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  104. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +23 -4
  105. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  106. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.d.ts.map +1 -1
  107. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js +9 -0
  108. package/analyzer-template/packages/github/dist/database/src/lib/loadEntityBranches.js.map +1 -1
  109. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts +2 -2
  110. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  111. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +5 -4
  112. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  113. package/analyzer-template/packages/github/dist/types/index.d.ts +1 -1
  114. package/analyzer-template/packages/github/dist/types/index.d.ts.map +1 -1
  115. package/analyzer-template/packages/github/dist/types/index.js.map +1 -1
  116. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts +25 -1
  117. package/analyzer-template/packages/github/dist/types/src/types/Analysis.d.ts.map +1 -1
  118. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts +2 -0
  119. package/analyzer-template/packages/github/dist/types/src/types/Commit.d.ts.map +1 -1
  120. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  121. package/analyzer-template/packages/github/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  122. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  123. package/analyzer-template/packages/github/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  124. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts +9 -1
  125. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  126. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js +29 -3
  127. package/analyzer-template/packages/github/dist/utils/src/lib/safeFileName.js.map +1 -1
  128. package/analyzer-template/packages/github/package.json +1 -1
  129. package/analyzer-template/packages/types/index.ts +1 -0
  130. package/analyzer-template/packages/types/src/types/Analysis.ts +25 -0
  131. package/analyzer-template/packages/types/src/types/Commit.ts +2 -0
  132. package/analyzer-template/packages/types/src/types/ScenariosDataStructure.ts +70 -6
  133. package/analyzer-template/packages/types/src/types/ScopeAnalysis.ts +6 -1
  134. package/analyzer-template/packages/utils/dist/types/index.d.ts +1 -1
  135. package/analyzer-template/packages/utils/dist/types/index.d.ts.map +1 -1
  136. package/analyzer-template/packages/utils/dist/types/index.js.map +1 -1
  137. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts +25 -1
  138. package/analyzer-template/packages/utils/dist/types/src/types/Analysis.d.ts.map +1 -1
  139. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts +2 -0
  140. package/analyzer-template/packages/utils/dist/types/src/types/Commit.d.ts.map +1 -1
  141. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts +56 -6
  142. package/analyzer-template/packages/utils/dist/types/src/types/ScenariosDataStructure.d.ts.map +1 -1
  143. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts +6 -1
  144. package/analyzer-template/packages/utils/dist/types/src/types/ScopeAnalysis.d.ts.map +1 -1
  145. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts +9 -1
  146. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.d.ts.map +1 -1
  147. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js +29 -3
  148. package/analyzer-template/packages/utils/dist/utils/src/lib/safeFileName.js.map +1 -1
  149. package/analyzer-template/packages/utils/src/lib/safeFileName.ts +48 -3
  150. package/analyzer-template/playwright/capture.ts +20 -8
  151. package/analyzer-template/playwright/captureStatic.ts +1 -1
  152. package/analyzer-template/project/analyzeBaselineCommit.ts +5 -0
  153. package/analyzer-template/project/analyzeRegularCommit.ts +5 -0
  154. package/analyzer-template/project/captureLibraryFunctionDirect.ts +29 -26
  155. package/analyzer-template/project/constructMockCode.ts +367 -37
  156. package/analyzer-template/project/createEntitiesAndSortFiles.ts +83 -0
  157. package/analyzer-template/project/loadReadyToBeCaptured.ts +65 -41
  158. package/analyzer-template/project/orchestrateCapture/AwsCaptureTaskRunner.ts +12 -4
  159. package/analyzer-template/project/orchestrateCapture/SequentialCaptureTaskRunner.ts +18 -7
  160. package/analyzer-template/project/orchestrateCapture/taskRunner.ts +4 -2
  161. package/analyzer-template/project/orchestrateCapture.ts +71 -6
  162. package/analyzer-template/project/reconcileMockDataKeys.ts +152 -9
  163. package/analyzer-template/project/runAnalysis.ts +4 -0
  164. package/analyzer-template/project/start.ts +35 -11
  165. package/analyzer-template/project/writeMockDataTsx.ts +127 -4
  166. package/analyzer-template/project/writeScenarioComponents.ts +101 -8
  167. package/analyzer-template/scripts/comboWorkerLoop.cjs +98 -50
  168. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js +5 -0
  169. package/background/src/lib/virtualized/project/analyzeBaselineCommit.js.map +1 -1
  170. package/background/src/lib/virtualized/project/analyzeRegularCommit.js +5 -0
  171. package/background/src/lib/virtualized/project/analyzeRegularCommit.js.map +1 -1
  172. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js +3 -3
  173. package/background/src/lib/virtualized/project/captureLibraryFunctionDirect.js.map +1 -1
  174. package/background/src/lib/virtualized/project/constructMockCode.js +300 -7
  175. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  176. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js +73 -1
  177. package/background/src/lib/virtualized/project/createEntitiesAndSortFiles.js.map +1 -1
  178. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js +19 -8
  179. package/background/src/lib/virtualized/project/loadReadyToBeCaptured.js.map +1 -1
  180. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js +2 -2
  181. package/background/src/lib/virtualized/project/orchestrateCapture/AwsCaptureTaskRunner.js.map +1 -1
  182. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js +7 -5
  183. package/background/src/lib/virtualized/project/orchestrateCapture/SequentialCaptureTaskRunner.js.map +1 -1
  184. package/background/src/lib/virtualized/project/orchestrateCapture.js +58 -6
  185. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  186. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +126 -9
  187. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  188. package/background/src/lib/virtualized/project/runAnalysis.js +3 -0
  189. package/background/src/lib/virtualized/project/runAnalysis.js.map +1 -1
  190. package/background/src/lib/virtualized/project/start.js +32 -11
  191. package/background/src/lib/virtualized/project/start.js.map +1 -1
  192. package/background/src/lib/virtualized/project/writeMockDataTsx.js +101 -4
  193. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  194. package/background/src/lib/virtualized/project/writeScenarioComponents.js +57 -8
  195. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  196. package/codeyam-cli/src/cli.js +2 -0
  197. package/codeyam-cli/src/cli.js.map +1 -1
  198. package/codeyam-cli/src/commands/debug.js +7 -5
  199. package/codeyam-cli/src/commands/debug.js.map +1 -1
  200. package/codeyam-cli/src/commands/memory.js +273 -0
  201. package/codeyam-cli/src/commands/memory.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +4 -0
  203. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  204. package/codeyam-cli/src/utils/analysisRunner.js +21 -2
  205. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  206. package/codeyam-cli/src/utils/install-skills.js +42 -6
  207. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  208. package/codeyam-cli/src/utils/queue/job.js +1 -0
  209. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  210. package/codeyam-cli/src/utils/queue/manager.js +6 -0
  211. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  212. package/codeyam-cli/src/utils/rules/index.js +5 -0
  213. package/codeyam-cli/src/utils/rules/index.js.map +1 -0
  214. package/codeyam-cli/src/utils/rules/parser.js +106 -0
  215. package/codeyam-cli/src/utils/rules/parser.js.map +1 -0
  216. package/codeyam-cli/src/utils/rules/pathMatcher.js +18 -0
  217. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -0
  218. package/codeyam-cli/src/utils/rules/staleness.js +132 -0
  219. package/codeyam-cli/src/utils/rules/staleness.js.map +1 -0
  220. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +2 -0
  221. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  222. package/codeyam-cli/src/webserver/app/lib/database.js +7 -3
  223. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  224. package/codeyam-cli/src/webserver/bootstrap.js +40 -0
  225. package/codeyam-cli/src/webserver/bootstrap.js.map +1 -1
  226. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-DsN1wKrm.js +11 -0
  227. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeBadge-COi5OvsN.js → EntityTypeBadge-DLqD3qNt.js} +1 -1
  228. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BwdQv49w.js → EntityTypeIcon-Ba2JVPzP.js} +1 -1
  229. package/codeyam-cli/src/webserver/build/client/assets/{InlineSpinner-CEleMv_j.js → InlineSpinner-C8lyxW9k.js} +1 -1
  230. package/codeyam-cli/src/webserver/build/client/assets/{InteractivePreview-D68KarMg.js → InteractivePreview-aht4aafF.js} +2 -2
  231. package/codeyam-cli/src/webserver/build/client/assets/{LibraryFunctionPreview-L75Wvqgw.js → LibraryFunctionPreview-CVtiBnY5.js} +1 -1
  232. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-C53WM8qn.js → LoadingDots-B0GLXMsr.js} +1 -1
  233. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-CrNkmy4i.js → LogViewer-xgeCVgSM.js} +1 -1
  234. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-OApQuNyq.js +16 -0
  235. package/codeyam-cli/src/webserver/build/client/assets/{SafeScreenshot-CQifa1n-.js → SafeScreenshot-DuDvi0jm.js} +1 -1
  236. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-CyaBFX7l.js → ScenarioViewer-DzccYyI8.js} +3 -13
  237. package/codeyam-cli/src/webserver/build/client/assets/{TruncatedFilePath-D36O1rzU.js → TruncatedFilePath-DyFZkK0l.js} +1 -1
  238. package/codeyam-cli/src/webserver/build/client/assets/_index-BwqWJOgH.js +11 -0
  239. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BwavGCpm.js +32 -0
  240. package/codeyam-cli/src/webserver/build/client/assets/api.health-l0sNRNKZ.js +1 -0
  241. package/codeyam-cli/src/webserver/build/client/assets/api.memory-profile-l0sNRNKZ.js +1 -0
  242. package/codeyam-cli/src/webserver/build/client/assets/api.restart-server-l0sNRNKZ.js +1 -0
  243. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-DgTPh8H-.js → chevron-down-Cx24_aWc.js} +1 -1
  244. package/codeyam-cli/src/webserver/build/client/assets/{chunk-EPOLDU6W-DdQKK6on.js → chunk-EPOLDU6W-CXRTFQ3F.js} +1 -1
  245. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-Dmr2bb1R.js → circle-check-BOARzkeR.js} +1 -1
  246. package/codeyam-cli/src/webserver/build/client/assets/copy-Bb-80kDT.js +6 -0
  247. package/codeyam-cli/src/webserver/build/client/assets/{createLucideIcon-Do4ZLUYa.js → createLucideIcon-BdhJEx6B.js} +1 -1
  248. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-BBnGWYga.js +1 -0
  249. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-CbdFyxZh.js → entity._sha._-BJUiQqZF.js} +12 -12
  250. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha.scenarios._scenarioId.fullscreen-B4iCfs5M.js → entity._sha.scenarios._scenarioId.fullscreen-DavjRmOY.js} +1 -1
  251. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.create-scenario-wDWZZO1W.js → entity._sha_.create-scenario-D1T4TGjf.js} +1 -1
  252. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-BMbl7MeQ.js → entity._sha_.edit._scenarioId-CTBG2mmz.js} +1 -1
  253. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-5wRKRIH9.js → entry.client-CS2cb_eZ.js} +1 -1
  254. package/codeyam-cli/src/webserver/build/client/assets/file-code-Dhef1kWN.js +6 -0
  255. package/codeyam-cli/src/webserver/build/client/assets/{fileTableUtils-DD3SDH7t.js → fileTableUtils-DMJ7zii9.js} +1 -1
  256. package/codeyam-cli/src/webserver/build/client/assets/files-CJ6lTdTA.js +1 -0
  257. package/codeyam-cli/src/webserver/build/client/assets/{git-zXjT7J0G.js → git-CPTZZ-JZ.js} +8 -8
  258. package/codeyam-cli/src/webserver/build/client/assets/globals-D3yhhV8x.css +1 -0
  259. package/codeyam-cli/src/webserver/build/client/assets/{index-DLbXwndH.js → index-B1h680n5.js} +1 -1
  260. package/codeyam-cli/src/webserver/build/client/assets/{index-gPZ-lad1.js → index-lzqtyFU8.js} +1 -1
  261. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-BsPXJ81F.js → loader-circle-B7B9V-bu.js} +1 -1
  262. package/codeyam-cli/src/webserver/build/client/assets/manifest-a78b90a2.js +1 -0
  263. package/codeyam-cli/src/webserver/build/client/assets/memory--GCbFsBE.js +92 -0
  264. package/codeyam-cli/src/webserver/build/client/assets/root-eVAaavTS.js +62 -0
  265. package/codeyam-cli/src/webserver/build/client/assets/{search-P2FKIUql.js → search-CxXUmBSd.js} +1 -1
  266. package/codeyam-cli/src/webserver/build/client/assets/{settings-B2eDuBj8.js → settings-CS5f3WzT.js} +1 -1
  267. package/codeyam-cli/src/webserver/build/client/assets/{simulations-L18M6-kN.js → simulations-DwFIBT09.js} +1 -1
  268. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-BDz7kbVA.js → triangle-alert-B6LgvRJg.js} +1 -1
  269. package/codeyam-cli/src/webserver/build/client/assets/{useCustomSizes-29dDmbH8.js → useCustomSizes-C1v1PQzo.js} +1 -1
  270. package/codeyam-cli/src/webserver/build/client/assets/{useLastLogLine-BUm0UVJm.js → useLastLogLine-aSv48UbS.js} +1 -1
  271. package/codeyam-cli/src/webserver/build/client/assets/{useReportContext-CkIOKTrZ.js → useReportContext-DYxHZQuP.js} +1 -1
  272. package/codeyam-cli/src/webserver/build/client/assets/{useToast-KKw5kTn-.js → useToast-mBRpZPiu.js} +1 -1
  273. package/codeyam-cli/src/webserver/build/server/assets/index-BM6TDT1Y.js +1 -0
  274. package/codeyam-cli/src/webserver/build/server/assets/server-build-dYC34MHw.js +257 -0
  275. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  276. package/codeyam-cli/src/webserver/build-info.json +5 -5
  277. package/codeyam-cli/templates/codeyam-memory-hook.sh +200 -0
  278. package/codeyam-cli/templates/codeyam:debug.md +47 -3
  279. package/codeyam-cli/templates/codeyam:diagnose.md +203 -25
  280. package/codeyam-cli/templates/codeyam:memory.md +341 -0
  281. package/codeyam-cli/templates/codeyam:new-rule.md +13 -0
  282. package/codeyam-cli/templates/rule-reflection-hook.py +160 -0
  283. package/codeyam-cli/templates/rules-instructions.md +93 -0
  284. package/package.json +8 -5
  285. package/packages/ai/index.js +7 -3
  286. package/packages/ai/index.js.map +1 -1
  287. package/packages/ai/src/lib/analyzeScope.js +70 -29
  288. package/packages/ai/src/lib/analyzeScope.js.map +1 -1
  289. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js +150 -0
  290. package/packages/ai/src/lib/astScopes/arrayDerivationDetector.js.map +1 -0
  291. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +78 -8
  292. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  293. package/packages/ai/src/lib/astScopes/methodSemantics.js +109 -23
  294. package/packages/ai/src/lib/astScopes/methodSemantics.js.map +1 -1
  295. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js +1 -102
  296. package/packages/ai/src/lib/astScopes/patterns/variableDeclarationHandler.js.map +1 -1
  297. package/packages/ai/src/lib/astScopes/processExpression.js +440 -27
  298. package/packages/ai/src/lib/astScopes/processExpression.js.map +1 -1
  299. package/packages/ai/src/lib/completionCall.js +161 -30
  300. package/packages/ai/src/lib/completionCall.js.map +1 -1
  301. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +589 -166
  302. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  303. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js +179 -0
  304. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/MuiManager.js.map +1 -1
  305. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js +7 -1
  306. package/packages/ai/src/lib/dataStructure/equivalencyManagers/frameworks/ReactFrameworkManager.js.map +1 -1
  307. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js +13 -3
  308. package/packages/ai/src/lib/dataStructure/helpers/BatchSchemaProcessor.js.map +1 -1
  309. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js +6 -4
  310. package/packages/ai/src/lib/dataStructure/helpers/ScopeTreeManager.js.map +1 -1
  311. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js +41 -1
  312. package/packages/ai/src/lib/dataStructure/helpers/cleanKnownObjectFunctions.js.map +1 -1
  313. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js +104 -11
  314. package/packages/ai/src/lib/dataStructure/helpers/cleanNonObjectFunctions.js.map +1 -1
  315. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js +159 -0
  316. package/packages/ai/src/lib/dataStructure/helpers/convertTypeAnnotationsToValues.js.map +1 -0
  317. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js +37 -20
  318. package/packages/ai/src/lib/dataStructure/helpers/deduplicateFunctionSchemas.js.map +1 -1
  319. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js +265 -79
  320. package/packages/ai/src/lib/dataStructure/helpers/fillInSchemaGapsAndUnknowns.js.map +1 -1
  321. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js +107 -0
  322. package/packages/ai/src/lib/dataStructure/helpers/fixNullIdsBySchema.js.map +1 -0
  323. package/packages/ai/src/lib/dataStructureChunking.js +111 -0
  324. package/packages/ai/src/lib/dataStructureChunking.js.map +1 -0
  325. package/packages/ai/src/lib/e2eDataTracking.js +241 -0
  326. package/packages/ai/src/lib/e2eDataTracking.js.map +1 -0
  327. package/packages/ai/src/lib/extractCriticalDataKeys.js +96 -0
  328. package/packages/ai/src/lib/extractCriticalDataKeys.js.map +1 -0
  329. package/packages/ai/src/lib/generateEntityScenarioData.js +525 -8
  330. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  331. package/packages/ai/src/lib/generateEntityScenarios.js +26 -2
  332. package/packages/ai/src/lib/generateEntityScenarios.js.map +1 -1
  333. package/packages/ai/src/lib/generateExecutionFlows.js +281 -4
  334. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  335. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js +946 -42
  336. package/packages/ai/src/lib/generateExecutionFlowsFromConditionals.js.map +1 -1
  337. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js +194 -0
  338. package/packages/ai/src/lib/generateExecutionFlowsFromJsxUsages.js.map +1 -0
  339. package/packages/ai/src/lib/mergeStatements.js +70 -51
  340. package/packages/ai/src/lib/mergeStatements.js.map +1 -1
  341. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js +10 -4
  342. package/packages/ai/src/lib/promptGenerators/gatherAttributesMap.js.map +1 -1
  343. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js +54 -0
  344. package/packages/ai/src/lib/promptGenerators/generateChunkPrompt.js.map +1 -0
  345. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js +15 -7
  346. package/packages/ai/src/lib/promptGenerators/generateEntityScenarioDataGenerator.js.map +1 -1
  347. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js +335 -0
  348. package/packages/ai/src/lib/promptGenerators/simplifyKeysForLLM.js.map +1 -0
  349. package/packages/ai/src/lib/resolvePathToControllable.js +155 -41
  350. package/packages/ai/src/lib/resolvePathToControllable.js.map +1 -1
  351. package/packages/ai/src/lib/worker/SerializableDataStructure.js +7 -0
  352. package/packages/ai/src/lib/worker/SerializableDataStructure.js.map +1 -1
  353. package/packages/ai/src/lib/worker/analyzeScopeWorker.js +94 -1
  354. package/packages/ai/src/lib/worker/analyzeScopeWorker.js.map +1 -1
  355. package/packages/analyze/src/lib/FileAnalyzer.js +60 -36
  356. package/packages/analyze/src/lib/FileAnalyzer.js.map +1 -1
  357. package/packages/analyze/src/lib/ProjectAnalyzer.js +96 -26
  358. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  359. package/packages/analyze/src/lib/analysisContext.js +30 -5
  360. package/packages/analyze/src/lib/analysisContext.js.map +1 -1
  361. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js +14 -0
  362. package/packages/analyze/src/lib/asts/sourceFiles/getAllDeclaredEntityNodes.js.map +1 -1
  363. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js +14 -0
  364. package/packages/analyze/src/lib/asts/sourceFiles/getAllEntityNodes.js.map +1 -1
  365. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js +6 -0
  366. package/packages/analyze/src/lib/asts/sourceFiles/getAllExports.js.map +1 -1
  367. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js +6 -0
  368. package/packages/analyze/src/lib/asts/sourceFiles/getImportsAnalysis.js.map +1 -1
  369. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js +39 -1
  370. package/packages/analyze/src/lib/asts/sourceFiles/getResolvedModule.js.map +1 -1
  371. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js +2 -1
  372. package/packages/analyze/src/lib/asts/sourceFiles/getSourceFilesForAllImports.js.map +1 -1
  373. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js +21 -9
  374. package/packages/analyze/src/lib/files/analyze/analyzeEntities/prepareDataStructures.js.map +1 -1
  375. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +14 -4
  376. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  377. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +5 -0
  378. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  379. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js +2 -1
  380. package/packages/analyze/src/lib/files/analyze/gatherEntityMap.js.map +1 -1
  381. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js +31 -10
  382. package/packages/analyze/src/lib/files/analyze/validateDependencyAnalyses.js.map +1 -1
  383. package/packages/analyze/src/lib/files/analyzeRemixRoute.js +3 -2
  384. package/packages/analyze/src/lib/files/analyzeRemixRoute.js.map +1 -1
  385. package/packages/analyze/src/lib/files/getImportedExports.js +11 -7
  386. package/packages/analyze/src/lib/files/getImportedExports.js.map +1 -1
  387. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js +160 -68
  388. package/packages/analyze/src/lib/files/scenarios/enrichArrayTypesFromChildSignatures.js.map +1 -1
  389. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js +25 -8
  390. package/packages/analyze/src/lib/files/scenarios/gatherDataForMocks.js.map +1 -1
  391. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +71 -9
  392. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  393. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +57 -9
  394. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  395. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +233 -9
  396. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  397. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js +46 -9
  398. package/packages/analyze/src/lib/files/scenarios/mergeValidatedDataStructures.js.map +1 -1
  399. package/packages/analyze/src/lib/files/setImportedExports.js +2 -1
  400. package/packages/analyze/src/lib/files/setImportedExports.js.map +1 -1
  401. package/packages/analyze/src/lib/utils/getFileByPath.js +12 -0
  402. package/packages/analyze/src/lib/utils/getFileByPath.js.map +1 -0
  403. package/packages/database/src/lib/kysely/db.js +8 -1
  404. package/packages/database/src/lib/kysely/db.js.map +1 -1
  405. package/packages/database/src/lib/kysely/tables/commitsTable.js +3 -0
  406. package/packages/database/src/lib/kysely/tables/commitsTable.js.map +1 -1
  407. package/packages/database/src/lib/loadAnalyses.js +45 -2
  408. package/packages/database/src/lib/loadAnalyses.js.map +1 -1
  409. package/packages/database/src/lib/loadAnalysis.js +8 -0
  410. package/packages/database/src/lib/loadAnalysis.js.map +1 -1
  411. package/packages/database/src/lib/loadBranch.js +11 -1
  412. package/packages/database/src/lib/loadBranch.js.map +1 -1
  413. package/packages/database/src/lib/loadCommit.js +7 -0
  414. package/packages/database/src/lib/loadCommit.js.map +1 -1
  415. package/packages/database/src/lib/loadCommits.js +22 -1
  416. package/packages/database/src/lib/loadCommits.js.map +1 -1
  417. package/packages/database/src/lib/loadEntities.js +23 -4
  418. package/packages/database/src/lib/loadEntities.js.map +1 -1
  419. package/packages/database/src/lib/loadEntityBranches.js +9 -0
  420. package/packages/database/src/lib/loadEntityBranches.js.map +1 -1
  421. package/packages/database/src/lib/updateCommitMetadata.js +5 -4
  422. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  423. package/packages/types/index.js.map +1 -1
  424. package/packages/utils/src/lib/safeFileName.js +29 -3
  425. package/packages/utils/src/lib/safeFileName.js.map +1 -1
  426. package/scripts/finalize-analyzer.cjs +3 -3
  427. package/codeyam-cli/src/webserver/build/client/assets/EntityItem-vauWK972.js +0 -1
  428. package/codeyam-cli/src/webserver/build/client/assets/ReportIssueModal-DzJRkCkr.js +0 -11
  429. package/codeyam-cli/src/webserver/build/client/assets/_index-Be83mo_j.js +0 -11
  430. package/codeyam-cli/src/webserver/build/client/assets/activity.(_tab)-BN6wu6Y-.js +0 -37
  431. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-Bn6aCAy_.js +0 -1
  432. package/codeyam-cli/src/webserver/build/client/assets/files-DKyMFI90.js +0 -1
  433. package/codeyam-cli/src/webserver/build/client/assets/globals-DTTQ3gY7.css +0 -1
  434. package/codeyam-cli/src/webserver/build/client/assets/manifest-22590fcf.js +0 -1
  435. package/codeyam-cli/src/webserver/build/client/assets/root-BsAarjAM.js +0 -57
  436. package/codeyam-cli/src/webserver/build/server/assets/index-BND5I5fv.js +0 -1
  437. package/codeyam-cli/src/webserver/build/server/assets/server-build-CFXnd7MG.js +0 -228
@@ -65,6 +65,10 @@ export default async function generateExecutionFlows({
65
65
  }
66
66
 
67
67
  if (!analysis.metadata.executionFlows) {
68
+ console.log(
69
+ `[GenerateExecutionFlows] Starting for ${entity.name} (${entity.filePath})`,
70
+ );
71
+
68
72
  // Build childEntityMetadata from dependentAnalyses for child flow merging
69
73
  // This maps child component names to their metadata (specifically isolatedDataStructure)
70
74
  const childEntityMetadata = buildChildEntityMetadata(
@@ -72,6 +76,16 @@ export default async function generateExecutionFlows({
72
76
  dependentAnalyses,
73
77
  );
74
78
 
79
+ const childCount = Object.keys(childEntityMetadata).length;
80
+ console.log(
81
+ `[GenerateExecutionFlows] Built childEntityMetadata with ${childCount} children`,
82
+ );
83
+ if (childCount > 0) {
84
+ console.log(
85
+ `[GenerateExecutionFlows] Will merge flows from children: [${Object.keys(childEntityMetadata).join(', ')}]`,
86
+ );
87
+ }
88
+
75
89
  const {
76
90
  result: { executionFlows, llmCall: executionFlowsLLMCall },
77
91
  } = await measureAndReportExecutionTime(
@@ -80,15 +94,24 @@ export default async function generateExecutionFlows({
80
94
  entity,
81
95
  mergedDataStructure: analysis.metadata.mergedDataStructure,
82
96
  model,
83
- childEntityMetadata:
84
- Object.keys(childEntityMetadata).length > 0
85
- ? childEntityMetadata
86
- : undefined,
97
+ childEntityMetadata: childCount > 0 ? childEntityMetadata : undefined,
87
98
  }),
88
99
  `Generating execution flows`,
89
100
  updateProgress,
90
101
  );
91
102
 
103
+ console.log(
104
+ `[GenerateExecutionFlows] Generated ${executionFlows.length} execution flows for ${entity.name}`,
105
+ );
106
+ for (const flow of executionFlows) {
107
+ const reqValues = flow.requiredValues
108
+ .map((rv) => `${rv.attributePath}=${rv.value}`)
109
+ .join(', ');
110
+ console.log(
111
+ `[GenerateExecutionFlows] - Flow '${flow.id}': ${flow.name} [${reqValues}]`,
112
+ );
113
+ }
114
+
92
115
  analysis.metadata.executionFlows = executionFlows;
93
116
 
94
117
  if (executionFlowsLLMCall) {
@@ -108,13 +131,20 @@ export default async function generateExecutionFlows({
108
131
  * then looks them up in importedExports to get their file paths,
109
132
  * then retrieves their metadata from dependentAnalyses.
110
133
  */
111
- function buildChildEntityMetadata(
134
+ export function buildChildEntityMetadata(
112
135
  entity: Entity,
113
136
  dependentAnalyses?: ReadonlyAnalysisMap,
114
137
  ): Record<string, Entity['metadata']> {
115
138
  const childEntityMetadata: Record<string, Entity['metadata']> = {};
116
139
 
140
+ console.log(
141
+ `[BuildChildMetadata] Starting for entity: ${entity.name} (${entity.filePath})`,
142
+ );
143
+
117
144
  if (!dependentAnalyses) {
145
+ console.log(
146
+ `[BuildChildMetadata] No dependentAnalyses provided, returning empty`,
147
+ );
118
148
  return childEntityMetadata;
119
149
  }
120
150
 
@@ -122,18 +152,54 @@ function buildChildEntityMetadata(
122
152
  entity.metadata?.isolatedDataStructure?.childBoundaryGatingConditions;
123
153
 
124
154
  if (!childBoundaryGatingConditions) {
155
+ console.log(
156
+ `[BuildChildMetadata] No childBoundaryGatingConditions found in isolatedDataStructure`,
157
+ );
158
+ console.log(
159
+ `[BuildChildMetadata] isolatedDataStructure keys: ${Object.keys(entity.metadata?.isolatedDataStructure ?? {}).join(', ') || 'none'}`,
160
+ );
125
161
  return childEntityMetadata;
126
162
  }
127
163
 
164
+ const childNames = Object.keys(childBoundaryGatingConditions);
165
+ console.log(
166
+ `[BuildChildMetadata] Found ${childNames.length} children in childBoundaryGatingConditions: [${childNames.join(', ')}]`,
167
+ );
168
+
169
+ // Log gating conditions for each child
170
+ for (const [childName, conditions] of Object.entries(
171
+ childBoundaryGatingConditions,
172
+ )) {
173
+ const isUnconditional = conditions.some(
174
+ (c) => c.location === 'unconditional',
175
+ );
176
+ console.log(
177
+ `[BuildChildMetadata] Child '${childName}': ${conditions.length} gating conditions, unconditional=${isUnconditional}`,
178
+ );
179
+ for (const condition of conditions) {
180
+ console.log(
181
+ `[BuildChildMetadata] - path='${condition.path}' location='${condition.location}' isNegated=${condition.isNegated ?? false}`,
182
+ );
183
+ }
184
+ }
185
+
128
186
  const importedExports = entity.metadata?.importedExports ?? [];
187
+ console.log(
188
+ `[BuildChildMetadata] Entity has ${importedExports.length} importedExports`,
189
+ );
190
+
191
+ for (const childName of childNames) {
192
+ console.log(`[BuildChildMetadata] Looking up child '${childName}'...`);
129
193
 
130
- for (const childName of Object.keys(childBoundaryGatingConditions)) {
131
194
  // Find the child in importedExports to get its file path
132
195
  const importedExport = importedExports.find(
133
196
  (ie) => ie.name === childName || ie.resolvedName === childName,
134
197
  );
135
198
 
136
199
  if (!importedExport) {
200
+ console.log(
201
+ `[BuildChildMetadata] Child '${childName}' NOT FOUND in importedExports`,
202
+ );
137
203
  continue;
138
204
  }
139
205
 
@@ -142,15 +208,57 @@ function buildChildEntityMetadata(
142
208
  importedExport.resolvedFilePath ?? importedExport.filePath;
143
209
  const lookupName = importedExport.resolvedName ?? importedExport.name;
144
210
 
211
+ console.log(
212
+ `[BuildChildMetadata] Child '${childName}' found in importedExports: lookupPath='${lookupPath}' lookupName='${lookupName}'`,
213
+ );
214
+
145
215
  // Look up the child's analysis in dependentAnalyses
146
216
  const childAnalysis = dependentAnalyses[lookupPath]?.[lookupName];
147
217
 
148
- if (childAnalysis?.entity?.metadata) {
149
- // Cast to mutable type - the metadata is only read, not modified
150
- childEntityMetadata[childName] = childAnalysis.entity
151
- .metadata as Entity['metadata'];
218
+ if (!childAnalysis) {
219
+ console.log(
220
+ `[BuildChildMetadata] Child '${childName}' analysis NOT FOUND in dependentAnalyses[${lookupPath}][${lookupName}]`,
221
+ );
222
+ console.log(
223
+ `[BuildChildMetadata] Available paths in dependentAnalyses: [${Object.keys(dependentAnalyses).slice(0, 10).join(', ')}...]`,
224
+ );
225
+ continue;
226
+ }
227
+
228
+ if (!childAnalysis.entity?.metadata) {
229
+ console.log(
230
+ `[BuildChildMetadata] Child '${childName}' analysis found but entity.metadata is missing`,
231
+ );
232
+ continue;
233
+ }
234
+
235
+ // Log what we found in the child's metadata
236
+ const childIsolated = childAnalysis.entity.metadata.isolatedDataStructure;
237
+ const childConditionalUsages = childIsolated?.conditionalUsages ?? {};
238
+ const childConditionalCount = Object.keys(childConditionalUsages).length;
239
+
240
+ console.log(
241
+ `[BuildChildMetadata] Child '${childName}' FOUND with metadata:`,
242
+ );
243
+ console.log(
244
+ `[BuildChildMetadata] - conditionalUsages: ${childConditionalCount} paths`,
245
+ );
246
+ if (childConditionalCount > 0) {
247
+ for (const [path, usages] of Object.entries(childConditionalUsages)) {
248
+ console.log(
249
+ `[BuildChildMetadata] - '${path}': ${(usages as any[]).length} usages`,
250
+ );
251
+ }
152
252
  }
253
+
254
+ // Cast to mutable type - the metadata is only read, not modified
255
+ childEntityMetadata[childName] = childAnalysis.entity
256
+ .metadata as Entity['metadata'];
153
257
  }
154
258
 
259
+ console.log(
260
+ `[BuildChildMetadata] RESULT: Found metadata for ${Object.keys(childEntityMetadata).length} children: [${Object.keys(childEntityMetadata).join(', ')}]`,
261
+ );
262
+
155
263
  return childEntityMetadata;
156
264
  }
@@ -40,6 +40,52 @@ function getTypeParameter(functionName: string): string | null {
40
40
  return null;
41
41
  }
42
42
 
43
+ // Primitive types that should not have child paths
44
+ const PRIMITIVE_TYPES = new Set([
45
+ 'number',
46
+ 'string',
47
+ 'boolean',
48
+ 'null',
49
+ 'undefined',
50
+ ]);
51
+
52
+ // Check if a type string represents a primitive type
53
+ // Handles union types like "string | undefined" or "number | null"
54
+ function isPrimitiveType(typeStr: string): boolean {
55
+ if (PRIMITIVE_TYPES.has(typeStr)) {
56
+ return true;
57
+ }
58
+ // Check union types - if ALL parts of the union are primitives, it's primitive
59
+ // e.g., "string | undefined" -> ["string", "undefined"] -> both are primitive -> true
60
+ // e.g., "object | null" -> ["object", "null"] -> object is not primitive -> false
61
+ if (typeStr.includes('|')) {
62
+ const parts = typeStr.split('|').map((p) => p.trim());
63
+ return parts.every((part) => PRIMITIVE_TYPES.has(part));
64
+ }
65
+ return false;
66
+ }
67
+
68
+ // Check if a new schema path would go through a primitive type
69
+ // e.g., if schema has 'entities[].scenarioCount': 'number', then
70
+ // 'entities[].scenarioCount.sha' would go through a primitive and should be rejected
71
+ function wouldGoThroughPrimitive(
72
+ newPath: string,
73
+ schema: { [key: string]: string },
74
+ ): boolean {
75
+ const pathParts = splitOutsideParenthesesAndArrays(newPath);
76
+
77
+ // Check each prefix of the path (excluding the full path itself)
78
+ for (let i = 1; i < pathParts.length; i++) {
79
+ const prefixPath = joinParenthesesAndArrays(pathParts.slice(0, i));
80
+ const prefixType = schema[prefixPath];
81
+ if (prefixType && isPrimitiveType(prefixType)) {
82
+ return true;
83
+ }
84
+ }
85
+
86
+ return false;
87
+ }
88
+
43
89
  // Check if schemaPathPart matches or is a function call variant of pathPart
44
90
  // e.g., 'isEntityBeingAnalyzed(entity.sha)' matches 'isEntityBeingAnalyzed'
45
91
  function pathPartMatches(pathPart: string, schemaPathPart: string): boolean {
@@ -57,10 +103,14 @@ function bestValueFromOptions(options: Array<string | undefined>) {
57
103
  options = options.filter(Boolean) as string[];
58
104
 
59
105
  const known = options.find((o) => !o.includes('unknown'));
60
- if (known) return known;
106
+ if (known) {
107
+ return known;
108
+ }
61
109
 
62
110
  const notUnknown = options.find((o) => o !== 'unknown');
63
- if (notUnknown) return notUnknown;
111
+ if (notUnknown) {
112
+ return notUnknown;
113
+ }
64
114
 
65
115
  return options[0] ?? 'unknown';
66
116
  }
@@ -152,10 +202,21 @@ export default function mergeInDependentDataStructure({
152
202
  equivalentPostfixes: Record<string, string>;
153
203
  }[] = [];
154
204
 
205
+ // Pre-build a lookup map from cleaned function name to dependency for O(1) lookups.
206
+ // This avoids O(n) linear search in findRelevantDependency which was causing O(n²) performance.
207
+ const dependencyByCleanedName = new Map<
208
+ string,
209
+ (typeof importedExports)[0]
210
+ >();
211
+ for (const dep of importedExports) {
212
+ const cleanedName = cleanFunctionName(dep.name);
213
+ if (!dependencyByCleanedName.has(cleanedName)) {
214
+ dependencyByCleanedName.set(cleanedName, dep);
215
+ }
216
+ }
217
+
155
218
  const findRelevantDependency = (functionName: any) => {
156
- return importedExports.find(
157
- (d) => cleanFunctionName(d.name) === cleanFunctionName(functionName),
158
- );
219
+ return dependencyByCleanedName.get(cleanFunctionName(functionName));
159
220
  };
160
221
 
161
222
  const findRelevantDependentDataStructure = (functionName: any) => {
@@ -291,16 +352,16 @@ export default function mergeInDependentDataStructure({
291
352
  } else {
292
353
  equivalentSchemaPathsEntry.equivalentRoots.push(...equivalentRoots);
293
354
  }
355
+
356
+ // Deduplicate roots using a Set for O(n) instead of O(n²)
357
+ const seenRoots = new Set<string>();
294
358
  equivalentSchemaPathsEntry.equivalentRoots =
295
- equivalentSchemaPathsEntry.equivalentRoots.filter(
296
- (er, index, self) =>
297
- index ===
298
- self.findIndex(
299
- (e) =>
300
- e.schemaRootPath === er.schemaRootPath &&
301
- e.function?.name === er.function?.name,
302
- ),
303
- );
359
+ equivalentSchemaPathsEntry.equivalentRoots.filter((er) => {
360
+ const key = er.schemaRootPath + '::' + (er.function?.name ?? '');
361
+ if (seenRoots.has(key)) return false;
362
+ seenRoots.add(key);
363
+ return true;
364
+ });
304
365
 
305
366
  return equivalentSchemaPathsEntry;
306
367
  };
@@ -880,7 +941,44 @@ export default function mergeInDependentDataStructure({
880
941
  equivalentSchemaPaths = mergeAllEquivalentSchemaPaths();
881
942
 
882
943
  for (const esp of equivalentSchemaPaths) {
883
- for (const equivalentRoot of esp.equivalentRoots) {
944
+ // Pre-compute which postfixes have children to avoid O(n²) lookups in the inner loop.
945
+ // A postfix "has children" if there are other postfixes that extend it.
946
+ const postfixesWithChildren = new Set<string>();
947
+ const postfixKeys = Object.keys(esp.equivalentPostfixes);
948
+
949
+ // Check for empty postfix having children (any other postfixes exist)
950
+ if (postfixKeys.length > 1 && '' in esp.equivalentPostfixes) {
951
+ postfixesWithChildren.add('');
952
+ }
953
+
954
+ // Check for array element postfixes having children using a prefix set.
955
+ // This avoids O(n²) scans across large postfix lists.
956
+ // e.g., 'currentEntities[]' has children if a path like 'currentEntities[].sha' exists.
957
+ const postfixPrefixSet = new Set<string>();
958
+ for (const postfixPath of postfixKeys) {
959
+ if (!postfixPath) continue;
960
+ const parts = splitOutsideParenthesesAndArrays(postfixPath);
961
+ for (let i = 1; i < parts.length; i++) {
962
+ postfixPrefixSet.add(joinParenthesesAndArrays(parts.slice(0, i)));
963
+ }
964
+ }
965
+ for (const postfixPath of postfixKeys) {
966
+ if (postfixPath.endsWith('[]') && postfixPrefixSet.has(postfixPath)) {
967
+ postfixesWithChildren.add(postfixPath);
968
+ }
969
+ }
970
+
971
+ // Deduplicate equivalentRoots that would write to the same schema paths.
972
+ // Roots with the same (function, schemaRootPath, postfix) are redundant.
973
+ const seenRootKeys = new Set<string>();
974
+ const uniqueRoots = esp.equivalentRoots.filter((root) => {
975
+ const key = `${root.function?.filePath ?? ''}::${root.function?.name ?? ''}::${root.schemaRootPath}::${root.postfix ?? ''}`;
976
+ if (seenRootKeys.has(key)) return false;
977
+ seenRootKeys.add(key);
978
+ return true;
979
+ });
980
+
981
+ for (const equivalentRoot of uniqueRoots) {
884
982
  let merged:
885
983
  | {
886
984
  signatureSchema: { [key: string]: string };
@@ -905,9 +1003,21 @@ export default function mergeInDependentDataStructure({
905
1003
  )) {
906
1004
  let relevantPostfix = postfixPath;
907
1005
  if (equivalentRoot.postfix) {
1006
+ // Check if postfixPath starts with equivalentRoot.postfix at a path boundary.
1007
+ // Must ensure exact path part match - "entityCode" should NOT match "entity" prefix.
1008
+ // Valid: "entity.foo" starts with "entity" (boundary at '.')
1009
+ // Valid: "entity[0]" starts with "entity" (boundary at '[')
1010
+ // Invalid: "entityCode" starts with "entity" (no boundary, different property)
908
1011
  if (!postfixPath.startsWith(equivalentRoot.postfix)) {
909
1012
  continue;
910
1013
  }
1014
+ // Additional check: ensure the match is at a path boundary
1015
+ const nextChar = postfixPath[equivalentRoot.postfix.length];
1016
+ if (nextChar !== undefined && nextChar !== '.' && nextChar !== '[') {
1017
+ // The postfixPath continues with more characters that aren't a path separator.
1018
+ // This means "entity" matched "entityCode" which is wrong - they're different properties.
1019
+ continue;
1020
+ }
911
1021
 
912
1022
  const postFixPathParts =
913
1023
  splitOutsideParenthesesAndArrays(postfixPath);
@@ -924,6 +1034,44 @@ export default function mergeInDependentDataStructure({
924
1034
  relevantPostfix,
925
1035
  ]);
926
1036
 
1037
+ // Skip paths that would go through a primitive type
1038
+ // e.g., if schema has 'entities[].scenarioCount': 'number', skip 'entities[].scenarioCount.sha'
1039
+ if (wouldGoThroughPrimitive(newSchemaPath, schema)) {
1040
+ continue;
1041
+ }
1042
+
1043
+ // Skip setting primitive type when there are child postfixes that indicate structure.
1044
+ // This prevents downgrading an object/array element to a primitive type.
1045
+ // Uses pre-computed postfixesWithChildren Set for O(1) lookup instead of O(n) iteration.
1046
+ const hasChildPostfixes =
1047
+ (relevantPostfix === '' || relevantPostfix.endsWith('[]')) &&
1048
+ postfixesWithChildren.has(postfixPath);
1049
+ if (PRIMITIVE_TYPES.has(postfixValue) && hasChildPostfixes) {
1050
+ continue;
1051
+ }
1052
+
1053
+ // Don't overwrite a more specific type with a less specific one
1054
+ // This can happen when nested roots share entries with their parent roots
1055
+ const existingType = schema[newSchemaPath];
1056
+ if (existingType) {
1057
+ // Don't overwrite a primitive type with 'object' or 'array'
1058
+ // e.g., if schema has 'entities[].scenarioCount': 'number', don't overwrite with 'object'
1059
+ if (
1060
+ PRIMITIVE_TYPES.has(existingType) &&
1061
+ (postfixValue === 'object' || postfixValue === 'array')
1062
+ ) {
1063
+ continue;
1064
+ }
1065
+ // Don't overwrite a complex/union type with a primitive
1066
+ // e.g., if schema has 'scenarios[]': 'Scenario | null', don't overwrite with 'string'
1067
+ if (
1068
+ !PRIMITIVE_TYPES.has(existingType) &&
1069
+ PRIMITIVE_TYPES.has(postfixValue)
1070
+ ) {
1071
+ continue;
1072
+ }
1073
+ }
1074
+
927
1075
  schema[newSchemaPath] = postfixValue;
928
1076
  }
929
1077
 
@@ -1134,6 +1282,83 @@ export default function mergeInDependentDataStructure({
1134
1282
  }
1135
1283
 
1136
1284
  cleanSchema(depSchema.returnValueSchema);
1285
+
1286
+ // Pull signature requirements from downstream functions into the mocked return value.
1287
+ // When a mocked function's return flows into another function's signature (via usageEquivalencies),
1288
+ // we need to include that function's signature requirements in the mock.
1289
+ //
1290
+ // Example: fromE5() returns a currency object that flows to calculateTotalPrice(price, quantity).
1291
+ // calculateTotalPrice's signatureSchema shows signature[0].multiply() is required.
1292
+ // We need to add multiply() to fromE5's mock return value.
1293
+ const usageEquivalencies = srcSchema.usageEquivalencies ?? {};
1294
+ for (const [returnPath, equivalencies] of Object.entries(
1295
+ usageEquivalencies,
1296
+ )) {
1297
+ // Only process return value paths (functionCallReturnValue)
1298
+ if (!returnPath.includes('.functionCallReturnValue')) continue;
1299
+
1300
+ for (const equiv of equivalencies) {
1301
+ // Check if this equivalency points to a signature path
1302
+ const signatureMatch = equiv.schemaPath.match(/\.signature\[(\d+)\]$/);
1303
+ if (!signatureMatch) continue;
1304
+
1305
+ const targetFunctionName = cleanFunctionName(equiv.scopeNodeName);
1306
+ const signatureIndex = signatureMatch[1];
1307
+
1308
+ // Look up the target function's analysis to get its signature requirements
1309
+ // First try dependentAnalyses, then dependencySchemas
1310
+ let targetSignatureSchema: Record<string, string> | undefined;
1311
+
1312
+ // Check dependentAnalyses first (has the full merged analysis)
1313
+ for (const depFilePath in dependentAnalyses) {
1314
+ const analysis = dependentAnalyses[depFilePath]?.[targetFunctionName];
1315
+ if (analysis?.metadata?.mergedDataStructure?.signatureSchema) {
1316
+ targetSignatureSchema =
1317
+ analysis.metadata.mergedDataStructure.signatureSchema;
1318
+ break;
1319
+ }
1320
+ }
1321
+
1322
+ // Fallback to dependencySchemas if not found
1323
+ if (!targetSignatureSchema) {
1324
+ for (const depFilePath in dependencySchemas) {
1325
+ const schema = dependencySchemas[depFilePath]?.[targetFunctionName];
1326
+ if (schema?.signatureSchema) {
1327
+ targetSignatureSchema = schema.signatureSchema;
1328
+ break;
1329
+ }
1330
+ }
1331
+ }
1332
+
1333
+ if (!targetSignatureSchema) continue;
1334
+
1335
+ // Find all paths in the target's signatureSchema that extend from signature[N]
1336
+ // e.g., signature[0].multiply(quantity) -> .multiply(quantity)
1337
+ const signaturePrefix = `signature[${signatureIndex}]`;
1338
+ for (const [sigPath, sigType] of Object.entries(
1339
+ targetSignatureSchema,
1340
+ )) {
1341
+ if (!sigPath.startsWith(signaturePrefix)) continue;
1342
+
1343
+ // Skip the base signature[N] path itself - we only want the method/property extensions
1344
+ if (sigPath === signaturePrefix) continue;
1345
+
1346
+ // Extract the suffix after signature[N] (e.g., ".multiply(quantity)")
1347
+ const suffix = sigPath.slice(signaturePrefix.length);
1348
+
1349
+ // Build the path for the mocked return value
1350
+ // e.g., fromE5(priceE5).functionCallReturnValue.multiply(quantity)
1351
+ const returnValuePath = returnPath + suffix;
1352
+
1353
+ // Add to the mocked dependency's return value schema if not already present
1354
+ if (!(returnValuePath in depSchema.returnValueSchema)) {
1355
+ depSchema.returnValueSchema[returnValuePath] = sigType;
1356
+ }
1357
+ }
1358
+ }
1359
+ }
1360
+
1361
+ cleanSchema(depSchema.returnValueSchema);
1137
1362
  }
1138
1363
 
1139
1364
  // Process the input dependencySchemas FIRST (before child dependentAnalyses).
@@ -1177,6 +1402,40 @@ export default function mergeInDependentDataStructure({
1177
1402
  cleanSchema(depSchema.returnValueSchema);
1178
1403
  }
1179
1404
 
1405
+ // TYPE REFINEMENT: Check if dependentAnalyses has a more specific type for this dependency.
1406
+ // When a parent passes `entity.filePath` (string | undefined) to a child component
1407
+ // that requires `filePath: string`, we should use the child's more specific type.
1408
+ // This prevents mock data from having undefined values for required props.
1409
+ //
1410
+ // This runs REGARDLESS of whether equivalencies already processed the schema,
1411
+ // because equivalencies copy the parent's type (string | undefined), not the child's
1412
+ // required type (string).
1413
+ const depSchema = findOrCreateDependentSchemas({ filePath, name });
1414
+ const childAnalysis = dependentAnalyses[filePath]?.[name];
1415
+ const childSignatureSchema =
1416
+ childAnalysis?.metadata?.mergedDataStructure?.signatureSchema;
1417
+
1418
+ if (childSignatureSchema) {
1419
+ for (const path in depSchema.signatureSchema) {
1420
+ const parentType = depSchema.signatureSchema[path];
1421
+ const childType = childSignatureSchema[path];
1422
+
1423
+ if (parentType && childType) {
1424
+ // Check if parent has optional type and child has required type
1425
+ const parentIsOptional =
1426
+ parentType.includes('| undefined') ||
1427
+ parentType.includes('| null');
1428
+ const childIsOptional =
1429
+ childType.includes('| undefined') || childType.includes('| null');
1430
+
1431
+ // If child requires a more specific type (not optional), use it
1432
+ if (parentIsOptional && !childIsOptional) {
1433
+ depSchema.signatureSchema[path] = childType;
1434
+ }
1435
+ }
1436
+ }
1437
+ }
1438
+
1180
1439
  // For functions with multiple different type parameters, also create separate entries
1181
1440
  // for each type-parameterized variant. This allows gatherDataForMocks to look up
1182
1441
  // the specific schema for each call signature.
@@ -1275,8 +1534,8 @@ export default function mergeInDependentDataStructure({
1275
1534
  // Merge in the nested dependency schemas
1276
1535
  for (const path in nestedDepSchema.returnValueSchema) {
1277
1536
  if (!(path in targetDepSchema.returnValueSchema)) {
1278
- targetDepSchema.returnValueSchema[path] =
1279
- nestedDepSchema.returnValueSchema[path];
1537
+ const value = nestedDepSchema.returnValueSchema[path];
1538
+ targetDepSchema.returnValueSchema[path] = value;
1280
1539
  }
1281
1540
  }
1282
1541
 
@@ -2,6 +2,49 @@ import { splitOutsideParenthesesAndArrays } from '~codeyam/ai';
2
2
  import { JsonTypeDefinition, ReadonlyAnalysisMap } from '~codeyam/types';
3
3
  import { awsLog } from '~codeyam/utils';
4
4
 
5
+ /**
6
+ * Deep merge for JsonTypeDefinition schemas.
7
+ * Only recursively merges when BOTH sides are plain objects (not arrays, not primitives).
8
+ * This is different from the general deepMerge which is designed for data values -
9
+ * here we're merging type schemas where leaf values are strings like "boolean" or "function".
10
+ *
11
+ * When types are incompatible (e.g., array vs object), prefer keeping the base value
12
+ * since it was set first from the root entity's validatedVariables.
13
+ */
14
+ function deepMergeSchemas(
15
+ base: JsonTypeDefinition,
16
+ override: JsonTypeDefinition,
17
+ ): JsonTypeDefinition {
18
+ // If override is null/undefined, return base
19
+ if (override === null || override === undefined) return base;
20
+ // If base is null/undefined, return override
21
+ if (base === null || base === undefined) return override;
22
+
23
+ // Only recursively merge if BOTH are plain objects (not arrays, not primitives)
24
+ const baseIsPlainObject =
25
+ typeof base === 'object' && !Array.isArray(base) && base !== null;
26
+ const overrideIsPlainObject =
27
+ typeof override === 'object' &&
28
+ !Array.isArray(override) &&
29
+ override !== null;
30
+
31
+ if (baseIsPlainObject && overrideIsPlainObject) {
32
+ const result: JsonTypeDefinition = { ...base };
33
+ for (const key in override) {
34
+ result[key] = deepMergeSchemas(
35
+ base[key] as JsonTypeDefinition,
36
+ override[key] as JsonTypeDefinition,
37
+ );
38
+ }
39
+ return result;
40
+ }
41
+
42
+ // For incompatible types (array vs object, string vs object, etc.), keep base
43
+ // This ensures the root entity's structure is preserved when a dependency
44
+ // has a different view of the same mock
45
+ return base;
46
+ }
47
+
5
48
  export function mergeInStructure(
6
49
  name: string | number,
7
50
  key: string | number,
@@ -155,10 +198,10 @@ export default function mergeValidatedDataStructures({
155
198
  }
156
199
  activeValidatedParts = validatedVariables[usedName] as JsonTypeDefinition;
157
200
  }
158
- dataForMocks = {
159
- ...dataForMocks,
160
- ...validatedData,
161
- };
201
+ // Use deep merge instead of shallow spread to preserve previously merged
202
+ // dependency data. This fixes Issue #15 where multiple dependencies with
203
+ // the same top-level key (e.g., trpc) would overwrite each other.
204
+ dataForMocks = deepMergeSchemas(dataForMocks, validatedData);
162
205
  };
163
206
 
164
207
  for (const dependency of relevantDependencies) {
@@ -181,13 +224,15 @@ export default function mergeValidatedDataStructures({
181
224
  for (const mockName in dependencyDataForMocks) {
182
225
  addMockDataForEntity(mockName);
183
226
 
184
- // If addMockDataForEntity didn't find matching entries in validatedVariables,
185
- // copy the dependency's value directly. This handles cases like usePathname()
186
- // which returns a simple "string" type but isn't in the root's validatedVariables.
187
- if (dataForMocks[mockName] === undefined) {
188
- dataForMocks[mockName] = dependencyDataForMocks[
189
- mockName
190
- ] as JsonTypeDefinition;
227
+ // Always deep merge the dependency's value to preserve nested structures.
228
+ // This handles cases like usePathname() which returns a simple "string" type,
229
+ // AND cases like trpc where both root and dependency have nested data that
230
+ // needs to be combined (e.g., trpc.quote from root + trpc.fastener.getAttributeValues
231
+ // from dependency).
232
+ if (dependencyDataForMocks[mockName] !== undefined) {
233
+ dataForMocks = deepMergeSchemas(dataForMocks, {
234
+ [mockName]: dependencyDataForMocks[mockName],
235
+ } as JsonTypeDefinition);
191
236
  }
192
237
  }
193
238
  }