@codeyam/codeyam-cli 0.1.0-staging.d3e886e → 0.1.0-staging.d4f25c3

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 (730) 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 +23 -23
  4. package/analyzer-template/packages/ai/package.json +3 -3
  5. package/analyzer-template/packages/ai/src/lib/astScopes/astScopeAnalyzer.ts +34 -3
  6. package/analyzer-template/packages/ai/src/lib/completionCall.ts +114 -113
  7. package/analyzer-template/packages/ai/src/lib/dataStructure/ScopeDataStructure.ts +259 -5
  8. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.ts +62 -0
  9. package/analyzer-template/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.ts +35 -0
  10. package/analyzer-template/packages/ai/src/lib/generateEntityScenarioData.ts +78 -2
  11. package/analyzer-template/packages/ai/src/lib/generateExecutionFlows.ts +0 -33
  12. package/analyzer-template/packages/analyze/src/lib/ProjectAnalyzer.ts +19 -7
  13. package/analyzer-template/packages/analyze/src/lib/asts/index.ts +7 -2
  14. package/analyzer-template/packages/analyze/src/lib/asts/nodes/getNodeType.ts +1 -0
  15. package/analyzer-template/packages/analyze/src/lib/files/analyze/analyzeEntities.ts +9 -1
  16. package/analyzer-template/packages/analyze/src/lib/files/analyze/dependencyResolver.ts +0 -6
  17. package/analyzer-template/packages/analyze/src/lib/files/analyze/findOrCreateEntity.ts +12 -0
  18. package/analyzer-template/packages/analyze/src/lib/files/scenarios/TransformationTracer.ts +65 -28
  19. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateDataStructure.ts +83 -0
  20. package/analyzer-template/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.ts +0 -98
  21. package/analyzer-template/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.ts +23 -4
  22. package/analyzer-template/packages/aws/package.json +10 -10
  23. package/analyzer-template/packages/database/index.ts +1 -0
  24. package/analyzer-template/packages/database/package.json +3 -3
  25. package/analyzer-template/packages/database/src/lib/kysely/db.ts +8 -0
  26. package/analyzer-template/packages/database/src/lib/kysely/tables/editorScenariosTable.ts +164 -0
  27. package/analyzer-template/packages/database/src/lib/loadCommits.ts +31 -20
  28. package/analyzer-template/packages/database/src/lib/loadEntities.ts +0 -6
  29. package/analyzer-template/packages/database/src/lib/loadReadyToBeCapturedAnalyses.ts +0 -5
  30. package/analyzer-template/packages/database/src/lib/updateCommitMetadata.ts +94 -143
  31. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatus.ts +58 -42
  32. package/analyzer-template/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.ts +81 -65
  33. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.ts +29 -1
  34. package/analyzer-template/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.ts +33 -5
  35. package/analyzer-template/packages/github/dist/database/index.d.ts +1 -0
  36. package/analyzer-template/packages/github/dist/database/index.d.ts.map +1 -1
  37. package/analyzer-template/packages/github/dist/database/index.js +1 -0
  38. package/analyzer-template/packages/github/dist/database/index.js.map +1 -1
  39. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts +2 -0
  40. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.d.ts.map +1 -1
  41. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js +5 -0
  42. package/analyzer-template/packages/github/dist/database/src/lib/kysely/db.js.map +1 -1
  43. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts +29 -0
  44. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.d.ts.map +1 -0
  45. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  46. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  47. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts +5 -0
  48. package/analyzer-template/packages/github/dist/database/src/lib/kysely/tables/scenariosTable.d.ts.map +1 -1
  49. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.d.ts.map +1 -1
  50. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js +23 -13
  51. package/analyzer-template/packages/github/dist/database/src/lib/loadCommits.js.map +1 -1
  52. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.d.ts.map +1 -1
  53. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js +0 -6
  54. package/analyzer-template/packages/github/dist/database/src/lib/loadEntities.js.map +1 -1
  55. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.d.ts.map +1 -1
  56. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  57. package/analyzer-template/packages/github/dist/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  58. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.d.ts.map +1 -1
  59. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js +76 -90
  60. package/analyzer-template/packages/github/dist/database/src/lib/updateCommitMetadata.js.map +1 -1
  61. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.d.ts.map +1 -1
  62. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  63. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  64. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.d.ts.map +1 -1
  65. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  66. package/analyzer-template/packages/github/dist/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  67. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.d.ts.map +1 -1
  68. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  69. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  70. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.d.ts.map +1 -1
  71. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  72. package/analyzer-template/packages/github/dist/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  73. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  74. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  75. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js +2 -0
  76. package/analyzer-template/packages/github/dist/types/src/enums/ProjectFramework.js.map +1 -1
  77. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  78. package/analyzer-template/packages/github/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  79. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts +10 -0
  80. package/analyzer-template/packages/github/dist/types/src/types/Scenario.d.ts.map +1 -1
  81. package/analyzer-template/packages/github/package.json +1 -1
  82. package/analyzer-template/packages/types/src/enums/ProjectFramework.ts +2 -0
  83. package/analyzer-template/packages/types/src/types/ProjectMetadata.ts +1 -0
  84. package/analyzer-template/packages/types/src/types/Scenario.ts +10 -0
  85. package/analyzer-template/packages/ui-components/package.json +1 -1
  86. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts +2 -0
  87. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.d.ts.map +1 -1
  88. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js +2 -0
  89. package/analyzer-template/packages/utils/dist/types/src/enums/ProjectFramework.js.map +1 -1
  90. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts +1 -0
  91. package/analyzer-template/packages/utils/dist/types/src/types/ProjectMetadata.d.ts.map +1 -1
  92. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts +10 -0
  93. package/analyzer-template/packages/utils/dist/types/src/types/Scenario.d.ts.map +1 -1
  94. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.d.ts.map +1 -1
  95. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js +6 -2
  96. package/analyzer-template/packages/utils/dist/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  97. package/analyzer-template/packages/utils/src/lib/fs/rsyncCopy.ts +14 -2
  98. package/analyzer-template/playwright/captureFromUrl.ts +89 -82
  99. package/analyzer-template/project/constructMockCode.ts +168 -48
  100. package/analyzer-template/project/orchestrateCapture.ts +4 -1
  101. package/analyzer-template/project/reconcileMockDataKeys.ts +19 -14
  102. package/analyzer-template/project/start.ts +3 -0
  103. package/analyzer-template/project/startScenarioCapture.ts +9 -0
  104. package/analyzer-template/project/writeClientLogRoute.ts +125 -0
  105. package/analyzer-template/project/writeMockDataTsx.ts +17 -0
  106. package/analyzer-template/project/writeScenarioComponents.ts +96 -17
  107. package/analyzer-template/tsconfig.json +13 -1
  108. package/background/src/lib/virtualized/project/constructMockCode.js +143 -39
  109. package/background/src/lib/virtualized/project/constructMockCode.js.map +1 -1
  110. package/background/src/lib/virtualized/project/orchestrateCapture.js +4 -1
  111. package/background/src/lib/virtualized/project/orchestrateCapture.js.map +1 -1
  112. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js +17 -11
  113. package/background/src/lib/virtualized/project/reconcileMockDataKeys.js.map +1 -1
  114. package/background/src/lib/virtualized/project/start.js +2 -0
  115. package/background/src/lib/virtualized/project/start.js.map +1 -1
  116. package/background/src/lib/virtualized/project/startScenarioCapture.js +5 -0
  117. package/background/src/lib/virtualized/project/startScenarioCapture.js.map +1 -1
  118. package/background/src/lib/virtualized/project/writeClientLogRoute.js +110 -0
  119. package/background/src/lib/virtualized/project/writeClientLogRoute.js.map +1 -0
  120. package/background/src/lib/virtualized/project/writeMockDataTsx.js +12 -0
  121. package/background/src/lib/virtualized/project/writeMockDataTsx.js.map +1 -1
  122. package/background/src/lib/virtualized/project/writeScenarioComponents.js +73 -12
  123. package/background/src/lib/virtualized/project/writeScenarioComponents.js.map +1 -1
  124. package/codeyam-cli/scripts/apply-setup.js +208 -11
  125. package/codeyam-cli/scripts/apply-setup.js.map +1 -1
  126. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js +196 -0
  127. package/codeyam-cli/src/__tests__/memory-scripts/filter-session.test.js.map +1 -0
  128. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js +114 -0
  129. package/codeyam-cli/src/__tests__/memory-scripts/read-json-field.test.js.map +1 -0
  130. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js +149 -0
  131. package/codeyam-cli/src/__tests__/memory-scripts/ripgrep-fallback.test.js.map +1 -0
  132. package/codeyam-cli/src/cli.js +41 -25
  133. package/codeyam-cli/src/cli.js.map +1 -1
  134. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js +51 -0
  135. package/codeyam-cli/src/commands/__tests__/editor.isolateArgs.test.js.map +1 -0
  136. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js +56 -0
  137. package/codeyam-cli/src/commands/__tests__/editor.stepDispatch.test.js.map +1 -0
  138. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js +101 -47
  139. package/codeyam-cli/src/commands/__tests__/init.gitignore.test.js.map +1 -1
  140. package/codeyam-cli/src/commands/analyze.js +17 -7
  141. package/codeyam-cli/src/commands/analyze.js.map +1 -1
  142. package/codeyam-cli/src/commands/default.js +14 -2
  143. package/codeyam-cli/src/commands/default.js.map +1 -1
  144. package/codeyam-cli/src/commands/editor.js +4630 -0
  145. package/codeyam-cli/src/commands/editor.js.map +1 -0
  146. package/codeyam-cli/src/commands/editorIsolateArgs.js +25 -0
  147. package/codeyam-cli/src/commands/editorIsolateArgs.js.map +1 -0
  148. package/codeyam-cli/src/commands/init.js +109 -45
  149. package/codeyam-cli/src/commands/init.js.map +1 -1
  150. package/codeyam-cli/src/commands/memory.js +89 -75
  151. package/codeyam-cli/src/commands/memory.js.map +1 -1
  152. package/codeyam-cli/src/commands/telemetry.js +37 -0
  153. package/codeyam-cli/src/commands/telemetry.js.map +1 -0
  154. package/codeyam-cli/src/data/techStacks.js +77 -0
  155. package/codeyam-cli/src/data/techStacks.js.map +1 -0
  156. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js +173 -0
  157. package/codeyam-cli/src/utils/__tests__/analyzerFinalization.test.js.map +1 -0
  158. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js +46 -0
  159. package/codeyam-cli/src/utils/__tests__/backgroundServer.test.js.map +1 -0
  160. package/codeyam-cli/src/utils/__tests__/devServerState.test.js +134 -0
  161. package/codeyam-cli/src/utils/__tests__/devServerState.test.js.map +1 -0
  162. package/codeyam-cli/src/utils/__tests__/editorApi.test.js +137 -0
  163. package/codeyam-cli/src/utils/__tests__/editorApi.test.js.map +1 -0
  164. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js +2379 -0
  165. package/codeyam-cli/src/utils/__tests__/editorAudit.test.js.map +1 -0
  166. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js +76 -0
  167. package/codeyam-cli/src/utils/__tests__/editorBroadcastViewport.test.js.map +1 -0
  168. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js +93 -0
  169. package/codeyam-cli/src/utils/__tests__/editorCapture.test.js.map +1 -0
  170. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js +100 -0
  171. package/codeyam-cli/src/utils/__tests__/editorDeleteScenario.test.js.map +1 -0
  172. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js +304 -0
  173. package/codeyam-cli/src/utils/__tests__/editorDevServer.test.js.map +1 -0
  174. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js +194 -0
  175. package/codeyam-cli/src/utils/__tests__/editorEntityChangeStatus.test.js.map +1 -0
  176. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js +315 -0
  177. package/codeyam-cli/src/utils/__tests__/editorEntityHelpers.test.js.map +1 -0
  178. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js +294 -0
  179. package/codeyam-cli/src/utils/__tests__/editorImageVerifier.test.js.map +1 -0
  180. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js +542 -0
  181. package/codeyam-cli/src/utils/__tests__/editorJournal.test.js.map +1 -0
  182. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js +594 -0
  183. package/codeyam-cli/src/utils/__tests__/editorLoaderHelpers.test.js.map +1 -0
  184. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js +435 -0
  185. package/codeyam-cli/src/utils/__tests__/editorMigration.test.js.map +1 -0
  186. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js +270 -0
  187. package/codeyam-cli/src/utils/__tests__/editorMockState.test.js.map +1 -0
  188. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js +217 -0
  189. package/codeyam-cli/src/utils/__tests__/editorPreloadHelpers.test.js.map +1 -0
  190. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js +353 -0
  191. package/codeyam-cli/src/utils/__tests__/editorPreview.test.js.map +1 -0
  192. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js +153 -0
  193. package/codeyam-cli/src/utils/__tests__/editorProxySession.test.js.map +1 -0
  194. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js +139 -0
  195. package/codeyam-cli/src/utils/__tests__/editorScenarioLookup.test.js.map +1 -0
  196. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js +221 -0
  197. package/codeyam-cli/src/utils/__tests__/editorScenarioSwitch.test.js.map +1 -0
  198. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js +1559 -0
  199. package/codeyam-cli/src/utils/__tests__/editorScenarios.test.js.map +1 -0
  200. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js +280 -0
  201. package/codeyam-cli/src/utils/__tests__/editorSeedAdapter.test.js.map +1 -0
  202. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js +143 -0
  203. package/codeyam-cli/src/utils/__tests__/editorSeedAdapterPrismaValidation.test.js.map +1 -0
  204. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js +66 -0
  205. package/codeyam-cli/src/utils/__tests__/editorSessionFilter.test.js.map +1 -0
  206. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js +53 -0
  207. package/codeyam-cli/src/utils/__tests__/editorShouldRevalidate.test.js.map +1 -0
  208. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js +1857 -0
  209. package/codeyam-cli/src/utils/__tests__/entityChangeStatus.test.js.map +1 -0
  210. package/codeyam-cli/src/utils/__tests__/git.editor.test.js +134 -0
  211. package/codeyam-cli/src/utils/__tests__/git.editor.test.js.map +1 -0
  212. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js +107 -0
  213. package/codeyam-cli/src/utils/__tests__/journalCaptureStabilization.test.js.map +1 -0
  214. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js +26 -20
  215. package/codeyam-cli/src/utils/__tests__/npmVersionCheck.test.js.map +1 -1
  216. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js +129 -0
  217. package/codeyam-cli/src/utils/__tests__/parseRegisterArg.test.js.map +1 -0
  218. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js +9 -0
  219. package/codeyam-cli/src/utils/__tests__/pathIgnoring.test.js.map +1 -1
  220. package/codeyam-cli/src/utils/__tests__/project.test.js +65 -0
  221. package/codeyam-cli/src/utils/__tests__/project.test.js.map +1 -0
  222. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js +118 -0
  223. package/codeyam-cli/src/utils/__tests__/routePatternMatching.test.js.map +1 -0
  224. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js +284 -0
  225. package/codeyam-cli/src/utils/__tests__/scenarioCoverage.test.js.map +1 -0
  226. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js +121 -0
  227. package/codeyam-cli/src/utils/__tests__/scenarioMarkers.test.js.map +1 -0
  228. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js +672 -0
  229. package/codeyam-cli/src/utils/__tests__/scenariosManifest.test.js.map +1 -0
  230. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js +51 -4
  231. package/codeyam-cli/src/utils/__tests__/setupClaudeCodeSettings.test.js.map +1 -1
  232. package/codeyam-cli/src/utils/__tests__/telemetry.test.js +159 -0
  233. package/codeyam-cli/src/utils/__tests__/telemetry.test.js.map +1 -0
  234. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js +51 -0
  235. package/codeyam-cli/src/utils/__tests__/templateConsistency.test.js.map +1 -0
  236. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js +142 -0
  237. package/codeyam-cli/src/utils/__tests__/webappDetection.test.js.map +1 -0
  238. package/codeyam-cli/src/utils/analysisRunner.js +3 -1
  239. package/codeyam-cli/src/utils/analysisRunner.js.map +1 -1
  240. package/codeyam-cli/src/utils/analyzer.js +9 -0
  241. package/codeyam-cli/src/utils/analyzer.js.map +1 -1
  242. package/codeyam-cli/src/utils/analyzerFinalization.js +100 -0
  243. package/codeyam-cli/src/utils/analyzerFinalization.js.map +1 -0
  244. package/codeyam-cli/src/utils/backgroundServer.js +105 -13
  245. package/codeyam-cli/src/utils/backgroundServer.js.map +1 -1
  246. package/codeyam-cli/src/utils/buildFlags.js +4 -0
  247. package/codeyam-cli/src/utils/buildFlags.js.map +1 -0
  248. package/codeyam-cli/src/utils/database.js +37 -2
  249. package/codeyam-cli/src/utils/database.js.map +1 -1
  250. package/codeyam-cli/src/utils/devModeEvents.js +40 -0
  251. package/codeyam-cli/src/utils/devModeEvents.js.map +1 -0
  252. package/codeyam-cli/src/utils/devServerState.js +71 -0
  253. package/codeyam-cli/src/utils/devServerState.js.map +1 -0
  254. package/codeyam-cli/src/utils/editorApi.js +79 -0
  255. package/codeyam-cli/src/utils/editorApi.js.map +1 -0
  256. package/codeyam-cli/src/utils/editorAudit.js +480 -0
  257. package/codeyam-cli/src/utils/editorAudit.js.map +1 -0
  258. package/codeyam-cli/src/utils/editorBroadcastViewport.js +26 -0
  259. package/codeyam-cli/src/utils/editorBroadcastViewport.js.map +1 -0
  260. package/codeyam-cli/src/utils/editorCapture.js +102 -0
  261. package/codeyam-cli/src/utils/editorCapture.js.map +1 -0
  262. package/codeyam-cli/src/utils/editorDeleteScenario.js +67 -0
  263. package/codeyam-cli/src/utils/editorDeleteScenario.js.map +1 -0
  264. package/codeyam-cli/src/utils/editorDevServer.js +197 -0
  265. package/codeyam-cli/src/utils/editorDevServer.js.map +1 -0
  266. package/codeyam-cli/src/utils/editorEntityChangeStatus.js +50 -0
  267. package/codeyam-cli/src/utils/editorEntityChangeStatus.js.map +1 -0
  268. package/codeyam-cli/src/utils/editorEntityHelpers.js +144 -0
  269. package/codeyam-cli/src/utils/editorEntityHelpers.js.map +1 -0
  270. package/codeyam-cli/src/utils/editorImageVerifier.js +155 -0
  271. package/codeyam-cli/src/utils/editorImageVerifier.js.map +1 -0
  272. package/codeyam-cli/src/utils/editorJournal.js +225 -0
  273. package/codeyam-cli/src/utils/editorJournal.js.map +1 -0
  274. package/codeyam-cli/src/utils/editorLoaderHelpers.js +152 -0
  275. package/codeyam-cli/src/utils/editorLoaderHelpers.js.map +1 -0
  276. package/codeyam-cli/src/utils/editorMigration.js +224 -0
  277. package/codeyam-cli/src/utils/editorMigration.js.map +1 -0
  278. package/codeyam-cli/src/utils/editorMockState.js +248 -0
  279. package/codeyam-cli/src/utils/editorMockState.js.map +1 -0
  280. package/codeyam-cli/src/utils/editorPreloadHelpers.js +135 -0
  281. package/codeyam-cli/src/utils/editorPreloadHelpers.js.map +1 -0
  282. package/codeyam-cli/src/utils/editorPreview.js +137 -0
  283. package/codeyam-cli/src/utils/editorPreview.js.map +1 -0
  284. package/codeyam-cli/src/utils/editorScenarioSwitch.js +112 -0
  285. package/codeyam-cli/src/utils/editorScenarioSwitch.js.map +1 -0
  286. package/codeyam-cli/src/utils/editorScenarios.js +557 -0
  287. package/codeyam-cli/src/utils/editorScenarios.js.map +1 -0
  288. package/codeyam-cli/src/utils/editorSeedAdapter.js +422 -0
  289. package/codeyam-cli/src/utils/editorSeedAdapter.js.map +1 -0
  290. package/codeyam-cli/src/utils/editorShouldRevalidate.js +21 -0
  291. package/codeyam-cli/src/utils/editorShouldRevalidate.js.map +1 -0
  292. package/codeyam-cli/src/utils/entityChangeStatus.js +366 -0
  293. package/codeyam-cli/src/utils/entityChangeStatus.js.map +1 -0
  294. package/codeyam-cli/src/utils/entityChangeStatus.server.js +196 -0
  295. package/codeyam-cli/src/utils/entityChangeStatus.server.js.map +1 -0
  296. package/codeyam-cli/src/utils/fileMetadata.js +5 -0
  297. package/codeyam-cli/src/utils/fileMetadata.js.map +1 -1
  298. package/codeyam-cli/src/utils/fileWatcher.js +63 -9
  299. package/codeyam-cli/src/utils/fileWatcher.js.map +1 -1
  300. package/codeyam-cli/src/utils/git.js +103 -0
  301. package/codeyam-cli/src/utils/git.js.map +1 -1
  302. package/codeyam-cli/src/utils/install-skills.js +71 -15
  303. package/codeyam-cli/src/utils/install-skills.js.map +1 -1
  304. package/codeyam-cli/src/utils/interactiveSyncWatcher.js +126 -0
  305. package/codeyam-cli/src/utils/interactiveSyncWatcher.js.map +1 -0
  306. package/codeyam-cli/src/utils/npmVersionCheck.js +2 -2
  307. package/codeyam-cli/src/utils/npmVersionCheck.js.map +1 -1
  308. package/codeyam-cli/src/utils/parseRegisterArg.js +31 -0
  309. package/codeyam-cli/src/utils/parseRegisterArg.js.map +1 -0
  310. package/codeyam-cli/src/utils/pathIgnoring.js +19 -7
  311. package/codeyam-cli/src/utils/pathIgnoring.js.map +1 -1
  312. package/codeyam-cli/src/utils/progress.js +2 -2
  313. package/codeyam-cli/src/utils/progress.js.map +1 -1
  314. package/codeyam-cli/src/utils/project.js +15 -5
  315. package/codeyam-cli/src/utils/project.js.map +1 -1
  316. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js +11 -11
  317. package/codeyam-cli/src/utils/queue/__tests__/heartbeat.test.js.map +1 -1
  318. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js +22 -0
  319. package/codeyam-cli/src/utils/queue/__tests__/manager.test.js.map +1 -1
  320. package/codeyam-cli/src/utils/queue/heartbeat.js +13 -5
  321. package/codeyam-cli/src/utils/queue/heartbeat.js.map +1 -1
  322. package/codeyam-cli/src/utils/queue/job.js +70 -1
  323. package/codeyam-cli/src/utils/queue/job.js.map +1 -1
  324. package/codeyam-cli/src/utils/queue/manager.js +7 -6
  325. package/codeyam-cli/src/utils/queue/manager.js.map +1 -1
  326. package/codeyam-cli/src/utils/requireSimulations.js +1 -1
  327. package/codeyam-cli/src/utils/requireSimulations.js.map +1 -1
  328. package/codeyam-cli/src/utils/routePatternMatching.js +129 -0
  329. package/codeyam-cli/src/utils/routePatternMatching.js.map +1 -0
  330. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js +5 -6
  331. package/codeyam-cli/src/utils/ruleReflection/__tests__/contextBuilder.test.js.map +1 -1
  332. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js +1 -1
  333. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/assertRules.js.map +1 -1
  334. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js +0 -1
  335. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/helpers/setupTempProject.js.map +1 -1
  336. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js +2 -4
  337. package/codeyam-cli/src/utils/ruleReflection/__tests__/integration/ruleReflectionE2E.test.js.map +1 -1
  338. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js +4 -6
  339. package/codeyam-cli/src/utils/ruleReflection/__tests__/promptBuilder.test.js.map +1 -1
  340. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js +1 -1
  341. package/codeyam-cli/src/utils/ruleReflection/contextBuilder.js.map +1 -1
  342. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js +83 -0
  343. package/codeyam-cli/src/utils/rules/__tests__/parser.test.js.map +1 -0
  344. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js +118 -0
  345. package/codeyam-cli/src/utils/rules/__tests__/pathMatcher.test.js.map +1 -0
  346. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js +72 -0
  347. package/codeyam-cli/src/utils/rules/__tests__/rulePlacement.test.js.map +1 -0
  348. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js +76 -0
  349. package/codeyam-cli/src/utils/rules/__tests__/sourceFiles.test.js.map +1 -0
  350. package/codeyam-cli/src/utils/rules/index.js +1 -0
  351. package/codeyam-cli/src/utils/rules/index.js.map +1 -1
  352. package/codeyam-cli/src/utils/rules/parser.js +14 -4
  353. package/codeyam-cli/src/utils/rules/parser.js.map +1 -1
  354. package/codeyam-cli/src/utils/rules/pathMatcher.js +34 -3
  355. package/codeyam-cli/src/utils/rules/pathMatcher.js.map +1 -1
  356. package/codeyam-cli/src/utils/rules/rulePlacement.js +65 -0
  357. package/codeyam-cli/src/utils/rules/rulePlacement.js.map +1 -0
  358. package/codeyam-cli/src/utils/rules/sourceFiles.js +43 -0
  359. package/codeyam-cli/src/utils/rules/sourceFiles.js.map +1 -0
  360. package/codeyam-cli/src/utils/scenarioCoverage.js +77 -0
  361. package/codeyam-cli/src/utils/scenarioCoverage.js.map +1 -0
  362. package/codeyam-cli/src/utils/scenarioMarkers.js +134 -0
  363. package/codeyam-cli/src/utils/scenarioMarkers.js.map +1 -0
  364. package/codeyam-cli/src/utils/scenariosManifest.js +285 -0
  365. package/codeyam-cli/src/utils/scenariosManifest.js.map +1 -0
  366. package/codeyam-cli/src/utils/serverState.js +57 -2
  367. package/codeyam-cli/src/utils/serverState.js.map +1 -1
  368. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js +83 -11
  369. package/codeyam-cli/src/utils/setupClaudeCodeSettings.js.map +1 -1
  370. package/codeyam-cli/src/utils/simulationGateMiddleware.js +166 -0
  371. package/codeyam-cli/src/utils/simulationGateMiddleware.js.map +1 -0
  372. package/codeyam-cli/src/utils/slugUtils.js +25 -0
  373. package/codeyam-cli/src/utils/slugUtils.js.map +1 -0
  374. package/codeyam-cli/src/utils/syncMocksMiddleware.js +7 -26
  375. package/codeyam-cli/src/utils/syncMocksMiddleware.js.map +1 -1
  376. package/codeyam-cli/src/utils/telemetry.js +106 -0
  377. package/codeyam-cli/src/utils/telemetry.js.map +1 -0
  378. package/codeyam-cli/src/utils/telemetryMiddleware.js +22 -0
  379. package/codeyam-cli/src/utils/telemetryMiddleware.js.map +1 -0
  380. package/codeyam-cli/src/utils/testRunner.js +158 -0
  381. package/codeyam-cli/src/utils/testRunner.js.map +1 -0
  382. package/codeyam-cli/src/utils/transcriptPruning.js +67 -0
  383. package/codeyam-cli/src/utils/transcriptPruning.js.map +1 -0
  384. package/codeyam-cli/src/utils/versionInfo.js +46 -0
  385. package/codeyam-cli/src/utils/versionInfo.js.map +1 -1
  386. package/codeyam-cli/src/utils/webappDetection.js +35 -2
  387. package/codeyam-cli/src/utils/webappDetection.js.map +1 -1
  388. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js +35 -0
  389. package/codeyam-cli/src/webserver/__tests__/buildPtyEnv.test.js.map +1 -0
  390. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js +80 -0
  391. package/codeyam-cli/src/webserver/__tests__/clientErrors.test.js.map +1 -0
  392. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js +628 -0
  393. package/codeyam-cli/src/webserver/__tests__/editorProxy.test.js.map +1 -0
  394. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js +217 -0
  395. package/codeyam-cli/src/webserver/__tests__/idleDetector.test.js.map +1 -0
  396. package/codeyam-cli/src/webserver/app/lib/clientErrors.js +71 -0
  397. package/codeyam-cli/src/webserver/app/lib/clientErrors.js.map +1 -0
  398. package/codeyam-cli/src/webserver/app/lib/database.js +41 -27
  399. package/codeyam-cli/src/webserver/app/lib/database.js.map +1 -1
  400. package/codeyam-cli/src/webserver/app/lib/dbNotifier.js.map +1 -1
  401. package/codeyam-cli/src/webserver/app/lib/git.js +397 -0
  402. package/codeyam-cli/src/webserver/app/lib/git.js.map +1 -0
  403. package/codeyam-cli/src/webserver/app/types/editor.js +8 -0
  404. package/codeyam-cli/src/webserver/app/types/editor.js.map +1 -0
  405. package/codeyam-cli/src/webserver/backgroundServer.js +141 -42
  406. package/codeyam-cli/src/webserver/backgroundServer.js.map +1 -1
  407. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-CLe80MMu.js +1 -0
  408. package/codeyam-cli/src/webserver/build/client/assets/{EntityItem-bwuHPyTa.js → EntityItem-Crt_KN_U.js} +5 -5
  409. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CQgyEGV-.js +1 -0
  410. package/codeyam-cli/src/webserver/build/client/assets/{EntityTypeIcon-BH0XDim7.js → EntityTypeIcon-CD7lGABo.js} +9 -9
  411. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-CgTNOhnu.js +1 -0
  412. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-CKeQT5Ty.js +25 -0
  413. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-D3s1MFkb.js +3 -0
  414. package/codeyam-cli/src/webserver/build/client/assets/{LoadingDots-BvMu2i-g.js → LoadingDots-By5zI316.js} +1 -1
  415. package/codeyam-cli/src/webserver/build/client/assets/{LogViewer-kgBTLoJD.js → LogViewer-CM5zg40N.js} +3 -3
  416. package/codeyam-cli/src/webserver/build/client/assets/{ReportIssueModal-BzPgx-xO.js → ReportIssueModal-C2PLkej3.js} +4 -4
  417. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-DanvyBPb.js +1 -0
  418. package/codeyam-cli/src/webserver/build/client/assets/{ScenarioViewer-BX2Ny2Qj.js → ScenarioViewer-DUMfcNVK.js} +3 -3
  419. package/codeyam-cli/src/webserver/build/client/assets/Spinner-D0LgAaSa.js +34 -0
  420. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CK7-NaPZ.js +1 -0
  421. package/codeyam-cli/src/webserver/build/client/assets/ViewportInspectBar-BA_Ry-rs.js +1 -0
  422. package/codeyam-cli/src/webserver/build/client/assets/{_index-BRx8ZGZo.js → _index-BAWd-Xjf.js} +4 -4
  423. package/codeyam-cli/src/webserver/build/client/assets/{activity.(_tab)-4S4yPfFw.js → activity.(_tab)-BOARiB-g.js} +8 -8
  424. package/codeyam-cli/src/webserver/build/client/assets/addon-canvas-DpzMmAy5.js +1 -0
  425. package/codeyam-cli/src/webserver/build/client/assets/addon-fit-YJmn1quW.js +12 -0
  426. package/codeyam-cli/src/webserver/build/client/assets/addon-web-links-CHx25PAe.js +1 -0
  427. package/codeyam-cli/src/webserver/build/client/assets/addon-webgl-DI8QOUvO.js +58 -0
  428. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-Bg3e7q4S.js +22 -0
  429. package/codeyam-cli/src/webserver/build/client/assets/api.dev-mode-events-l0sNRNKZ.js +1 -0
  430. package/codeyam-cli/src/webserver/build/client/assets/api.editor-audit-l0sNRNKZ.js +1 -0
  431. package/codeyam-cli/src/webserver/build/client/assets/api.editor-capture-scenario-l0sNRNKZ.js +1 -0
  432. package/codeyam-cli/src/webserver/build/client/assets/api.editor-client-errors-l0sNRNKZ.js +1 -0
  433. package/codeyam-cli/src/webserver/build/client/assets/api.editor-commit-l0sNRNKZ.js +1 -0
  434. package/codeyam-cli/src/webserver/build/client/assets/api.editor-dev-server-l0sNRNKZ.js +1 -0
  435. package/codeyam-cli/src/webserver/build/client/assets/api.editor-entity-status-l0sNRNKZ.js +1 -0
  436. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-diff-l0sNRNKZ.js +1 -0
  437. package/codeyam-cli/src/webserver/build/client/assets/api.editor-file-l0sNRNKZ.js +1 -0
  438. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-entry-l0sNRNKZ.js +1 -0
  439. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-image._-l0sNRNKZ.js +1 -0
  440. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-l0sNRNKZ.js +1 -0
  441. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-screenshot-l0sNRNKZ.js +1 -0
  442. package/codeyam-cli/src/webserver/build/client/assets/api.editor-journal-update-l0sNRNKZ.js +1 -0
  443. package/codeyam-cli/src/webserver/build/client/assets/api.editor-load-commit-l0sNRNKZ.js +1 -0
  444. package/codeyam-cli/src/webserver/build/client/assets/api.editor-project-info-l0sNRNKZ.js +1 -0
  445. package/codeyam-cli/src/webserver/build/client/assets/api.editor-refresh-l0sNRNKZ.js +1 -0
  446. package/codeyam-cli/src/webserver/build/client/assets/api.editor-register-scenario-l0sNRNKZ.js +1 -0
  447. package/codeyam-cli/src/webserver/build/client/assets/api.editor-rename-scenario-l0sNRNKZ.js +1 -0
  448. package/codeyam-cli/src/webserver/build/client/assets/api.editor-save-seed-state-l0sNRNKZ.js +1 -0
  449. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-coverage-l0sNRNKZ.js +1 -0
  450. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-data-l0sNRNKZ.js +1 -0
  451. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-image._-l0sNRNKZ.js +1 -0
  452. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenario-prompt-l0sNRNKZ.js +1 -0
  453. package/codeyam-cli/src/webserver/build/client/assets/api.editor-scenarios-l0sNRNKZ.js +1 -0
  454. package/codeyam-cli/src/webserver/build/client/assets/api.editor-session-l0sNRNKZ.js +1 -0
  455. package/codeyam-cli/src/webserver/build/client/assets/api.editor-switch-scenario-l0sNRNKZ.js +1 -0
  456. package/codeyam-cli/src/webserver/build/client/assets/api.editor-test-results-l0sNRNKZ.js +1 -0
  457. package/codeyam-cli/src/webserver/build/client/assets/api.rule-path-l0sNRNKZ.js +1 -0
  458. package/codeyam-cli/src/webserver/build/client/assets/{book-open-D4IPYH_y.js → book-open-CL-lMgHh.js} +2 -2
  459. package/codeyam-cli/src/webserver/build/client/assets/{chevron-down-CG65viiV.js → chevron-down-GmAjGS9-.js} +2 -2
  460. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-BAdwhyCx.js +43 -0
  461. package/codeyam-cli/src/webserver/build/client/assets/{circle-check-igfMr5DY.js → circle-check-DFcQkN5j.js} +2 -2
  462. package/codeyam-cli/src/webserver/build/client/assets/{copy-Coc4o_8c.js → copy-C6iF61Xs.js} +3 -3
  463. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-4ImjHTVC.js +41 -0
  464. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-C8y4mmyv.js +1 -0
  465. package/codeyam-cli/src/webserver/build/client/assets/editor._tab-Gbk_i5Js.js +1 -0
  466. package/codeyam-cli/src/webserver/build/client/assets/editor.entity.(_sha)-DN5ouXAl.js +58 -0
  467. package/codeyam-cli/src/webserver/build/client/assets/editorPreview-oepecPae.js +41 -0
  468. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha._-B0h9AqE6.js → entity._sha._-Blfy9UlN.js} +11 -11
  469. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.dev-KTQuL0aj.js +6 -0
  470. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-C6eeL24i.js +6 -0
  471. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-DQM8E7L4.js +6 -0
  472. package/codeyam-cli/src/webserver/build/client/assets/{entity._sha_.edit._scenarioId-PePWg17F.js → entity._sha_.edit._scenarioId-CAoXLsQr.js} +2 -2
  473. package/codeyam-cli/src/webserver/build/client/assets/{entry.client-I-Wo99C_.js → entry.client-SuW9syRS.js} +6 -6
  474. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-Daa96Fr1.js +1 -0
  475. package/codeyam-cli/src/webserver/build/client/assets/files-D-xGrg29.js +1 -0
  476. package/codeyam-cli/src/webserver/build/client/assets/git-Bq_fbXP5.js +1 -0
  477. package/codeyam-cli/src/webserver/build/client/assets/globals-fAqOD9ex.css +1 -0
  478. package/codeyam-cli/src/webserver/build/client/assets/{index-_417gcQW.js → index-Bp1l4hSv.js} +1 -1
  479. package/codeyam-cli/src/webserver/build/client/assets/{index-CUM5iXwc.js → index-CWV9XZiG.js} +1 -1
  480. package/codeyam-cli/src/webserver/build/client/assets/index-DE3jI_dv.js +15 -0
  481. package/codeyam-cli/src/webserver/build/client/assets/jsx-runtime-D_zvdyIk.js +9 -0
  482. package/codeyam-cli/src/webserver/build/client/assets/labs-B_IX45ih.js +1 -0
  483. package/codeyam-cli/src/webserver/build/client/assets/{loader-circle-TzRHMVog.js → loader-circle-De-7qQ2u.js} +2 -2
  484. package/codeyam-cli/src/webserver/build/client/assets/manifest-389033be.js +1 -0
  485. package/codeyam-cli/src/webserver/build/client/assets/memory-Cx2xEx7s.js +101 -0
  486. package/codeyam-cli/src/webserver/build/client/assets/{pause-hjzB7t2z.js → pause-CFxEKL1u.js} +3 -3
  487. package/codeyam-cli/src/webserver/build/client/assets/root-DB3O9_9j.js +67 -0
  488. package/codeyam-cli/src/webserver/build/client/assets/{search-DcAwD_Ln.js → search-BdBb5aqc.js} +2 -2
  489. package/codeyam-cli/src/webserver/build/client/assets/settings-DdE-Untf.js +1 -0
  490. package/codeyam-cli/src/webserver/build/client/assets/simulations-DSCdE99u.js +1 -0
  491. package/codeyam-cli/src/webserver/build/client/assets/{terminal-DbEAHMbA.js → terminal-CrplD4b1.js} +3 -3
  492. package/codeyam-cli/src/webserver/build/client/assets/{triangle-alert-CAD5b1o_.js → triangle-alert-DqJ0j69l.js} +2 -2
  493. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-DhXHbEjP.js +1 -0
  494. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-BNd5hYuW.js +2 -0
  495. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-Cy5Qg_UR.js +1 -0
  496. package/codeyam-cli/src/webserver/build/client/assets/useToast-5HR2j9ZE.js +1 -0
  497. package/codeyam-cli/src/webserver/build/client/assets/xterm-BqvuqXEL.js +27 -0
  498. package/codeyam-cli/src/webserver/build/client/sound-test.html +98 -0
  499. package/codeyam-cli/src/webserver/build/server/assets/analysisRunner-D_1MSYeW.js +13 -0
  500. package/codeyam-cli/src/webserver/build/server/assets/index-ckWaCf_v.js +1 -0
  501. package/codeyam-cli/src/webserver/build/server/assets/init-ld124R4Z.js +10 -0
  502. package/codeyam-cli/src/webserver/build/server/assets/progress-CHTtrxFG.js +1 -0
  503. package/codeyam-cli/src/webserver/build/server/assets/server-build-DzzNZGv_.js +551 -0
  504. package/codeyam-cli/src/webserver/build/server/index.js +1 -1
  505. package/codeyam-cli/src/webserver/build-info.json +5 -5
  506. package/codeyam-cli/src/webserver/devServer.js +39 -5
  507. package/codeyam-cli/src/webserver/devServer.js.map +1 -1
  508. package/codeyam-cli/src/webserver/editorProxy.js +976 -0
  509. package/codeyam-cli/src/webserver/editorProxy.js.map +1 -0
  510. package/codeyam-cli/src/webserver/idleDetector.js +106 -0
  511. package/codeyam-cli/src/webserver/idleDetector.js.map +1 -0
  512. package/codeyam-cli/src/webserver/mockStateEvents.js +28 -0
  513. package/codeyam-cli/src/webserver/mockStateEvents.js.map +1 -0
  514. package/codeyam-cli/src/webserver/public/sound-test.html +98 -0
  515. package/codeyam-cli/src/webserver/scripts/codeyam-preload.mjs +414 -0
  516. package/codeyam-cli/src/webserver/scripts/journalCapture.ts +266 -0
  517. package/codeyam-cli/src/webserver/server.js +341 -1
  518. package/codeyam-cli/src/webserver/server.js.map +1 -1
  519. package/codeyam-cli/src/webserver/terminalServer.js +831 -0
  520. package/codeyam-cli/src/webserver/terminalServer.js.map +1 -0
  521. package/codeyam-cli/templates/chrome-extension-react/EXTENSION_SETUP.md +75 -0
  522. package/codeyam-cli/templates/chrome-extension-react/README.md +46 -0
  523. package/codeyam-cli/templates/chrome-extension-react/gitignore +15 -0
  524. package/codeyam-cli/templates/chrome-extension-react/index.html +12 -0
  525. package/codeyam-cli/templates/chrome-extension-react/package.json +27 -0
  526. package/codeyam-cli/templates/chrome-extension-react/popup.html +12 -0
  527. package/codeyam-cli/templates/chrome-extension-react/public/manifest.json +15 -0
  528. package/codeyam-cli/templates/chrome-extension-react/src/background/service-worker.ts +7 -0
  529. package/codeyam-cli/templates/chrome-extension-react/src/globals.css +6 -0
  530. package/codeyam-cli/templates/chrome-extension-react/src/lib/storage.ts +37 -0
  531. package/codeyam-cli/templates/chrome-extension-react/src/popup/App.tsx +12 -0
  532. package/codeyam-cli/templates/chrome-extension-react/src/popup/main.tsx +10 -0
  533. package/codeyam-cli/templates/chrome-extension-react/tsconfig.json +24 -0
  534. package/codeyam-cli/templates/chrome-extension-react/vite.config.ts +41 -0
  535. package/codeyam-cli/templates/codeyam-editor-claude.md +147 -0
  536. package/codeyam-cli/templates/codeyam-editor-reference.md +214 -0
  537. package/codeyam-cli/templates/editor-step-hook.py +321 -0
  538. package/codeyam-cli/templates/expo-react-native/MOBILE_SETUP.md +89 -0
  539. package/codeyam-cli/templates/expo-react-native/README.md +41 -0
  540. package/codeyam-cli/templates/expo-react-native/app/(tabs)/_layout.tsx +33 -0
  541. package/codeyam-cli/templates/expo-react-native/app/(tabs)/index.tsx +12 -0
  542. package/codeyam-cli/templates/expo-react-native/app/(tabs)/settings.tsx +12 -0
  543. package/codeyam-cli/templates/expo-react-native/app/_layout.tsx +12 -0
  544. package/codeyam-cli/templates/expo-react-native/app.json +18 -0
  545. package/codeyam-cli/templates/expo-react-native/babel.config.js +9 -0
  546. package/codeyam-cli/templates/expo-react-native/gitignore +12 -0
  547. package/codeyam-cli/templates/expo-react-native/global.css +3 -0
  548. package/codeyam-cli/templates/expo-react-native/lib/storage.ts +32 -0
  549. package/codeyam-cli/templates/expo-react-native/metro.config.js +6 -0
  550. package/codeyam-cli/templates/expo-react-native/nativewind-env.d.ts +1 -0
  551. package/codeyam-cli/templates/expo-react-native/package.json +38 -0
  552. package/codeyam-cli/templates/expo-react-native/tailwind.config.js +10 -0
  553. package/codeyam-cli/templates/expo-react-native/tsconfig.json +10 -0
  554. package/codeyam-cli/templates/hooks/staleness-check.sh +43 -0
  555. package/codeyam-cli/templates/isolation-route/next-app.tsx.template +80 -0
  556. package/codeyam-cli/templates/isolation-route/next-pages.tsx.template +79 -0
  557. package/codeyam-cli/templates/isolation-route/vite-react.tsx.template +78 -0
  558. package/codeyam-cli/templates/msw/browser-setup.ts.template +47 -0
  559. package/codeyam-cli/templates/msw/handler-router.ts.template +47 -0
  560. package/codeyam-cli/templates/msw/server-setup.ts.template +52 -0
  561. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_PATTERNS.md +308 -0
  562. package/codeyam-cli/templates/nextjs-prisma-sqlite/AUTH_UPGRADE.md +304 -0
  563. package/codeyam-cli/templates/nextjs-prisma-sqlite/DATABASE.md +126 -0
  564. package/codeyam-cli/templates/nextjs-prisma-sqlite/FEATURE_PATTERNS.md +37 -0
  565. package/codeyam-cli/templates/nextjs-prisma-sqlite/README.md +53 -0
  566. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/api/todos/route.ts +17 -0
  567. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/codeyam-isolate/layout.tsx +12 -0
  568. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/globals.css +26 -0
  569. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/layout.tsx +34 -0
  570. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/lib/prisma.ts +24 -0
  571. package/codeyam-cli/templates/nextjs-prisma-sqlite/app/page.tsx +10 -0
  572. package/codeyam-cli/templates/nextjs-prisma-sqlite/env +4 -0
  573. package/codeyam-cli/templates/nextjs-prisma-sqlite/eslint.config.mjs +11 -0
  574. package/codeyam-cli/templates/nextjs-prisma-sqlite/gitignore +64 -0
  575. package/codeyam-cli/templates/nextjs-prisma-sqlite/next.config.ts +14 -0
  576. package/codeyam-cli/templates/nextjs-prisma-sqlite/package.json +39 -0
  577. package/codeyam-cli/templates/nextjs-prisma-sqlite/postcss.config.mjs +7 -0
  578. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/schema.prisma +27 -0
  579. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma/seed.ts +40 -0
  580. package/codeyam-cli/templates/nextjs-prisma-sqlite/prisma.config.ts +12 -0
  581. package/codeyam-cli/templates/nextjs-prisma-sqlite/seed-adapter.ts +127 -0
  582. package/codeyam-cli/templates/nextjs-prisma-sqlite/tsconfig.json +34 -0
  583. package/codeyam-cli/templates/nextjs-prisma-sqlite/vitest.config.ts +13 -0
  584. package/codeyam-cli/templates/nextjs-prisma-supabase/README.md +52 -0
  585. package/codeyam-cli/templates/nextjs-prisma-supabase/SUPABASE_SETUP.md +104 -0
  586. package/codeyam-cli/templates/nextjs-prisma-supabase/app/api/todos/route.ts +17 -0
  587. package/codeyam-cli/templates/nextjs-prisma-supabase/app/globals.css +26 -0
  588. package/codeyam-cli/templates/nextjs-prisma-supabase/app/layout.tsx +34 -0
  589. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/prisma.ts +20 -0
  590. package/codeyam-cli/templates/nextjs-prisma-supabase/app/lib/supabase.ts +12 -0
  591. package/codeyam-cli/templates/nextjs-prisma-supabase/app/page.tsx +10 -0
  592. package/codeyam-cli/templates/nextjs-prisma-supabase/env +9 -0
  593. package/codeyam-cli/templates/nextjs-prisma-supabase/eslint.config.mjs +11 -0
  594. package/codeyam-cli/templates/nextjs-prisma-supabase/gitignore +40 -0
  595. package/codeyam-cli/templates/nextjs-prisma-supabase/next.config.ts +11 -0
  596. package/codeyam-cli/templates/nextjs-prisma-supabase/package.json +37 -0
  597. package/codeyam-cli/templates/nextjs-prisma-supabase/postcss.config.mjs +7 -0
  598. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/schema.prisma +27 -0
  599. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma/seed.ts +39 -0
  600. package/codeyam-cli/templates/nextjs-prisma-supabase/prisma.config.ts +12 -0
  601. package/codeyam-cli/templates/nextjs-prisma-supabase/tsconfig.json +34 -0
  602. package/codeyam-cli/templates/prompts/conversation-guidance.txt +44 -0
  603. package/codeyam-cli/templates/prompts/conversation-prompt.txt +28 -0
  604. package/codeyam-cli/templates/prompts/interruption-prompt.txt +31 -0
  605. package/codeyam-cli/templates/prompts/stale-rules-prompt.txt +24 -0
  606. package/codeyam-cli/templates/rule-notification-hook.py +44 -17
  607. package/codeyam-cli/templates/rule-reflection-hook.py +25 -5
  608. package/codeyam-cli/templates/rules-instructions.md +34 -88
  609. package/codeyam-cli/templates/seed-adapters/supabase.ts +282 -0
  610. package/codeyam-cli/templates/skills/codeyam-dev-mode/SKILL.md +237 -0
  611. package/codeyam-cli/templates/skills/codeyam-editor/SKILL.md +211 -0
  612. package/codeyam-cli/templates/{codeyam-memory.md → skills/codeyam-memory/SKILL.md} +215 -0
  613. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/deprecated-prompt.md +100 -0
  614. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/detect-deprecated-patterns.mjs +139 -0
  615. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/find-exports.mjs +52 -0
  616. package/codeyam-cli/templates/skills/codeyam-memory/scripts/holistic-analysis/misleading-api-prompt.md +117 -0
  617. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/read-json-field.mjs +61 -0
  618. package/codeyam-cli/templates/skills/codeyam-memory/scripts/lib/ripgrep-fallback.mjs +155 -0
  619. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/analyze-prompt.md +46 -0
  620. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/cleanup.mjs +13 -0
  621. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/filter-session.mjs +95 -0
  622. package/codeyam-cli/templates/skills/codeyam-memory/scripts/session-mining/preprocess.mjs +160 -0
  623. package/codeyam-cli/templates/{codeyam-new-rule.md → skills/codeyam-new-rule/SKILL.md} +0 -2
  624. package/package.json +22 -14
  625. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js +22 -4
  626. package/packages/ai/src/lib/astScopes/astScopeAnalyzer.js.map +1 -1
  627. package/packages/ai/src/lib/completionCall.js +10 -7
  628. package/packages/ai/src/lib/completionCall.js.map +1 -1
  629. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js +234 -3
  630. package/packages/ai/src/lib/dataStructure/ScopeDataStructure.js.map +1 -1
  631. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js +54 -0
  632. package/packages/ai/src/lib/dataStructure/helpers/coercePrimitivesToArraysBySchema.js.map +1 -0
  633. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js +34 -0
  634. package/packages/ai/src/lib/dataStructure/helpers/stripNullableMarkers.js.map +1 -0
  635. package/packages/ai/src/lib/generateEntityScenarioData.js +57 -2
  636. package/packages/ai/src/lib/generateEntityScenarioData.js.map +1 -1
  637. package/packages/ai/src/lib/generateExecutionFlows.js +0 -11
  638. package/packages/ai/src/lib/generateExecutionFlows.js.map +1 -1
  639. package/packages/analyze/src/lib/ProjectAnalyzer.js +13 -4
  640. package/packages/analyze/src/lib/ProjectAnalyzer.js.map +1 -1
  641. package/packages/analyze/src/lib/asts/index.js +4 -2
  642. package/packages/analyze/src/lib/asts/index.js.map +1 -1
  643. package/packages/analyze/src/lib/asts/nodes/getNodeType.js +1 -0
  644. package/packages/analyze/src/lib/asts/nodes/getNodeType.js.map +1 -1
  645. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js +8 -1
  646. package/packages/analyze/src/lib/files/analyze/analyzeEntities.js.map +1 -1
  647. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js +0 -5
  648. package/packages/analyze/src/lib/files/analyze/dependencyResolver.js.map +1 -1
  649. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js +9 -0
  650. package/packages/analyze/src/lib/files/analyze/findOrCreateEntity.js.map +1 -1
  651. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js +54 -27
  652. package/packages/analyze/src/lib/files/scenarios/TransformationTracer.js.map +1 -1
  653. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js +65 -0
  654. package/packages/analyze/src/lib/files/scenarios/generateDataStructure.js.map +1 -1
  655. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js +0 -40
  656. package/packages/analyze/src/lib/files/scenarios/generateExecutionFlows.js.map +1 -1
  657. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js +18 -4
  658. package/packages/analyze/src/lib/files/scenarios/mergeInDependentDataStructure.js.map +1 -1
  659. package/packages/database/index.js +1 -0
  660. package/packages/database/index.js.map +1 -1
  661. package/packages/database/src/lib/kysely/db.js +5 -0
  662. package/packages/database/src/lib/kysely/db.js.map +1 -1
  663. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js +149 -0
  664. package/packages/database/src/lib/kysely/tables/editorScenariosTable.js.map +1 -0
  665. package/packages/database/src/lib/loadCommits.js +23 -13
  666. package/packages/database/src/lib/loadCommits.js.map +1 -1
  667. package/packages/database/src/lib/loadEntities.js +0 -6
  668. package/packages/database/src/lib/loadEntities.js.map +1 -1
  669. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js +1 -4
  670. package/packages/database/src/lib/loadReadyToBeCapturedAnalyses.js.map +1 -1
  671. package/packages/database/src/lib/updateCommitMetadata.js +76 -90
  672. package/packages/database/src/lib/updateCommitMetadata.js.map +1 -1
  673. package/packages/database/src/lib/updateFreshAnalysisStatus.js +41 -30
  674. package/packages/database/src/lib/updateFreshAnalysisStatus.js.map +1 -1
  675. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js +68 -57
  676. package/packages/database/src/lib/updateFreshAnalysisStatusWithScenarios.js.map +1 -1
  677. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js +29 -1
  678. package/packages/generate/src/lib/componentScenarioPage/generateScenarioClientWrapper.js.map +1 -1
  679. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js +33 -5
  680. package/packages/generate/src/lib/componentScenarioPage/getIFrameMessageListenerCode.js.map +1 -1
  681. package/packages/types/src/enums/ProjectFramework.js +2 -0
  682. package/packages/types/src/enums/ProjectFramework.js.map +1 -1
  683. package/packages/utils/src/lib/fs/rsyncCopy.js +6 -2
  684. package/packages/utils/src/lib/fs/rsyncCopy.js.map +1 -1
  685. package/scripts/npm-post-install.cjs +34 -0
  686. package/codeyam-cli/src/commands/detect-universal-mocks.js +0 -120
  687. package/codeyam-cli/src/commands/detect-universal-mocks.js.map +0 -1
  688. package/codeyam-cli/src/commands/list.js +0 -31
  689. package/codeyam-cli/src/commands/list.js.map +0 -1
  690. package/codeyam-cli/src/commands/webapp-info.js +0 -146
  691. package/codeyam-cli/src/commands/webapp-info.js.map +0 -1
  692. package/codeyam-cli/src/utils/universal-mocks.js +0 -152
  693. package/codeyam-cli/src/utils/universal-mocks.js.map +0 -1
  694. package/codeyam-cli/src/webserver/build/client/assets/CopyButton-jNYXRRNI.js +0 -1
  695. package/codeyam-cli/src/webserver/build/client/assets/EntityTypeBadge-CvzqMxcu.js +0 -1
  696. package/codeyam-cli/src/webserver/build/client/assets/InlineSpinner-EhOseatT.js +0 -34
  697. package/codeyam-cli/src/webserver/build/client/assets/InteractivePreview-yjIHlOGa.js +0 -25
  698. package/codeyam-cli/src/webserver/build/client/assets/LibraryFunctionPreview-Cq5o8jL4.js +0 -3
  699. package/codeyam-cli/src/webserver/build/client/assets/SafeScreenshot-CwZrv-Ok.js +0 -1
  700. package/codeyam-cli/src/webserver/build/client/assets/TruncatedFilePath-CDpEprKa.js +0 -1
  701. package/codeyam-cli/src/webserver/build/client/assets/agent-transcripts-DHKuQSmR.js +0 -17
  702. package/codeyam-cli/src/webserver/build/client/assets/chunk-JZWAC4HX-DB3aFuEO.js +0 -51
  703. package/codeyam-cli/src/webserver/build/client/assets/createLucideIcon-D1zB-pYc.js +0 -21
  704. package/codeyam-cli/src/webserver/build/client/assets/dev.empty-JTAjQ54M.js +0 -1
  705. package/codeyam-cli/src/webserver/build/client/assets/entity._sha.scenarios._scenarioId.fullscreen-DjLxr2JB.js +0 -6
  706. package/codeyam-cli/src/webserver/build/client/assets/entity._sha_.create-scenario-CtYowLOt.js +0 -6
  707. package/codeyam-cli/src/webserver/build/client/assets/fileTableUtils-9sMMAiWJ.js +0 -1
  708. package/codeyam-cli/src/webserver/build/client/assets/files-Co65J0s3.js +0 -1
  709. package/codeyam-cli/src/webserver/build/client/assets/git-BdHOxVfg.js +0 -15
  710. package/codeyam-cli/src/webserver/build/client/assets/globals-CCgBKWy4.css +0 -1
  711. package/codeyam-cli/src/webserver/build/client/assets/labs-BK0C1H1T.js +0 -1
  712. package/codeyam-cli/src/webserver/build/client/assets/manifest-390cb8fa.js +0 -1
  713. package/codeyam-cli/src/webserver/build/client/assets/memory-CzZySbBE.js +0 -78
  714. package/codeyam-cli/src/webserver/build/client/assets/root-DnbDhvTU.js +0 -62
  715. package/codeyam-cli/src/webserver/build/client/assets/settings-CclxrcPK.js +0 -1
  716. package/codeyam-cli/src/webserver/build/client/assets/simulations-DVNJVQgD.js +0 -1
  717. package/codeyam-cli/src/webserver/build/client/assets/useCustomSizes-BqgrAzs3.js +0 -1
  718. package/codeyam-cli/src/webserver/build/client/assets/useLastLogLine-DAFqfEDH.js +0 -2
  719. package/codeyam-cli/src/webserver/build/client/assets/useReportContext-DZlYx2c4.js +0 -1
  720. package/codeyam-cli/src/webserver/build/client/assets/useToast-ihdMtlf6.js +0 -1
  721. package/codeyam-cli/src/webserver/build/server/assets/index-CxaRxKVt.js +0 -1
  722. package/codeyam-cli/src/webserver/build/server/assets/server-build-D4DT0nM_.js +0 -259
  723. package/codeyam-cli/templates/codeyam-stop-hook.sh +0 -284
  724. package/scripts/finalize-analyzer.cjs +0 -13
  725. /package/codeyam-cli/templates/{codeyam-diagnose.md → commands/codeyam-diagnose.md} +0 -0
  726. /package/codeyam-cli/templates/{codeyam-debug.md → skills/codeyam-debug/SKILL.md} +0 -0
  727. /package/codeyam-cli/templates/{codeyam-setup.md → skills/codeyam-setup/SKILL.md} +0 -0
  728. /package/codeyam-cli/templates/{codeyam-sim.md → skills/codeyam-sim/SKILL.md} +0 -0
  729. /package/codeyam-cli/templates/{codeyam-test.md → skills/codeyam-test/SKILL.md} +0 -0
  730. /package/codeyam-cli/templates/{codeyam-verify.md → skills/codeyam-verify/SKILL.md} +0 -0
@@ -0,0 +1,628 @@
1
+ import http from 'http';
2
+ import zlib from 'zlib';
3
+ import { injectHealthScript, PREVIEW_HEALTH_SCRIPT, getPreviewHealthReport, resetPreviewHealth, } from "../editorProxy.js";
4
+ describe('editorProxy', () => {
5
+ describe('normalizeTargetUrl', () => {
6
+ it('should leave localhost as-is (no longer normalizes to 127.0.0.1)', () => {
7
+ const { normalizeTargetUrl } = require('../editorProxy');
8
+ expect(normalizeTargetUrl('http://localhost:3112')).toBe('http://localhost:3112');
9
+ });
10
+ it('should leave 127.0.0.1 unchanged', () => {
11
+ const { normalizeTargetUrl } = require('../editorProxy');
12
+ expect(normalizeTargetUrl('http://127.0.0.1:3112')).toBe('http://127.0.0.1:3112');
13
+ });
14
+ it('should leave other hostnames unchanged', () => {
15
+ const { normalizeTargetUrl } = require('../editorProxy');
16
+ expect(normalizeTargetUrl('http://myhost:3112')).toBe('http://myhost:3112');
17
+ });
18
+ it('should strip trailing slash', () => {
19
+ const { normalizeTargetUrl } = require('../editorProxy');
20
+ expect(normalizeTargetUrl('http://localhost:3112/')).toBe('http://localhost:3112');
21
+ });
22
+ });
23
+ describe('resolveLoopbackAddress', () => {
24
+ let server;
25
+ afterEach((done) => {
26
+ if (server?.listening) {
27
+ server.close(done);
28
+ }
29
+ else {
30
+ done();
31
+ }
32
+ });
33
+ it('should resolve to 127.0.0.1 when server binds to IPv4', async () => {
34
+ const { resolveLoopbackAddress } = require('../editorProxy');
35
+ server = http.createServer((_req, res) => res.end('ok'));
36
+ await new Promise((resolve) => server.listen(0, '127.0.0.1', () => resolve()));
37
+ const port = server.address().port;
38
+ const host = await resolveLoopbackAddress(port);
39
+ expect(host).toBe('127.0.0.1');
40
+ });
41
+ it('should resolve to ::1 when server binds to IPv6 only', async () => {
42
+ const { resolveLoopbackAddress } = require('../editorProxy');
43
+ server = http.createServer((_req, res) => res.end('ok'));
44
+ await new Promise((resolve) => server.listen(0, '::1', () => resolve()));
45
+ const port = server.address().port;
46
+ const host = await resolveLoopbackAddress(port);
47
+ expect(host).toBe('::1');
48
+ });
49
+ it('should return null when no server is listening', async () => {
50
+ const { resolveLoopbackAddress } = require('../editorProxy');
51
+ const host = await resolveLoopbackAddress(19876);
52
+ expect(host).toBeNull();
53
+ });
54
+ });
55
+ describe('proxy forwarding uses 127.0.0.1', () => {
56
+ let targetServer;
57
+ let targetPort;
58
+ afterEach((done) => {
59
+ if (targetServer?.listening) {
60
+ targetServer.close(done);
61
+ }
62
+ else {
63
+ done();
64
+ }
65
+ });
66
+ it('should forward requests to target and return correct response', async () => {
67
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
68
+ // Start a target server that returns 200
69
+ targetServer = http.createServer((_req, res) => {
70
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
71
+ res.end('OK from target');
72
+ });
73
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
74
+ targetPort = targetServer.address().port;
75
+ // Start proxy pointing to the target using localhost URL
76
+ const result = await startEditorProxy({
77
+ port: 0, // let OS pick
78
+ targetUrl: `http://localhost:${targetPort}`,
79
+ });
80
+ expect(result).not.toBeNull();
81
+ // Make a request through the proxy
82
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
83
+ expect(response.status).toBe(200);
84
+ const body = await response.text();
85
+ expect(body).toBe('OK from target');
86
+ await stopEditorProxy();
87
+ });
88
+ it('should log when target returns non-2xx status', async () => {
89
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
90
+ // Start a target that returns 404
91
+ targetServer = http.createServer((_req, res) => {
92
+ res.writeHead(404, { 'Content-Type': 'text/plain' });
93
+ res.end('Not Found');
94
+ });
95
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
96
+ targetPort = targetServer.address().port;
97
+ const warnSpy = jest.spyOn(console, 'warn').mockImplementation();
98
+ const result = await startEditorProxy({
99
+ port: 0,
100
+ targetUrl: `http://localhost:${targetPort}`,
101
+ });
102
+ const response = await fetch(`http://127.0.0.1:${result.port}/test-path`);
103
+ expect(response.status).toBe(404);
104
+ // Verify a warning was logged about the non-2xx response
105
+ expect(warnSpy.mock.calls.some((call) => String(call[0]).includes('[editorProxy]') &&
106
+ String(call[0]).includes('404') &&
107
+ String(call[0]).includes('/test-path'))).toBe(true);
108
+ warnSpy.mockRestore();
109
+ await stopEditorProxy();
110
+ });
111
+ it('should verify forwarding works after start via self-test', async () => {
112
+ const { startEditorProxy, stopEditorProxy, verifyProxyForwarding, } = require('../editorProxy');
113
+ // Start a target that returns 200
114
+ targetServer = http.createServer((_req, res) => {
115
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
116
+ res.end('healthy');
117
+ });
118
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
119
+ targetPort = targetServer.address().port;
120
+ const result = await startEditorProxy({
121
+ port: 0,
122
+ targetUrl: `http://localhost:${targetPort}`,
123
+ });
124
+ const verified = await verifyProxyForwarding();
125
+ expect(verified).toBe(true);
126
+ await stopEditorProxy();
127
+ });
128
+ it('should report verification failure when target is down', async () => {
129
+ const { startEditorProxy, stopEditorProxy, verifyProxyForwarding, } = require('../editorProxy');
130
+ const result = await startEditorProxy({
131
+ port: 0,
132
+ targetUrl: 'http://127.0.0.1:19876',
133
+ });
134
+ const verified = await verifyProxyForwarding();
135
+ expect(verified).toBe(false);
136
+ await stopEditorProxy();
137
+ });
138
+ it('should return false for verification when proxy is not running', async () => {
139
+ const { verifyProxyForwarding, stopEditorProxy, } = require('../editorProxy');
140
+ await stopEditorProxy();
141
+ const verified = await verifyProxyForwarding();
142
+ expect(verified).toBe(false);
143
+ });
144
+ it('should return 502 when target is unreachable', async () => {
145
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
146
+ // Start proxy pointing to a port with nothing listening
147
+ const result = await startEditorProxy({
148
+ port: 0,
149
+ targetUrl: 'http://localhost:19876',
150
+ });
151
+ expect(result).not.toBeNull();
152
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
153
+ expect(response.status).toBe(502);
154
+ await stopEditorProxy();
155
+ });
156
+ it('should forward requests to an IPv6-only target server', async () => {
157
+ const { startEditorProxy, stopEditorProxy } = require('../editorProxy');
158
+ // Start a target server bound to IPv6 only (::1) — this is what Vite 6 does on macOS
159
+ targetServer = http.createServer((_req, res) => {
160
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
161
+ res.end('OK from IPv6 target');
162
+ });
163
+ await new Promise((resolve) => targetServer.listen(0, '::1', () => resolve()));
164
+ targetPort = targetServer.address().port;
165
+ // Start proxy with a localhost URL (simulating Vite's "Local: http://localhost:PORT")
166
+ const result = await startEditorProxy({
167
+ port: 0,
168
+ targetUrl: `http://localhost:${targetPort}`,
169
+ });
170
+ expect(result).not.toBeNull();
171
+ // The proxy should successfully forward to the IPv6-only target
172
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
173
+ expect(response.status).toBe(200);
174
+ const body = await response.text();
175
+ expect(body).toBe('OK from IPv6 target');
176
+ await stopEditorProxy();
177
+ });
178
+ });
179
+ describe('injectHealthScript', () => {
180
+ it('should inject before </head> when present', () => {
181
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
182
+ const result = injectHealthScript(html);
183
+ expect(result).toContain(PREVIEW_HEALTH_SCRIPT + '</head>');
184
+ expect(result).toContain('<title>Test</title>');
185
+ });
186
+ it('should inject before </body> when no </head>', () => {
187
+ const html = '<html><body>Hello</body></html>';
188
+ const result = injectHealthScript(html);
189
+ expect(result).toContain(PREVIEW_HEALTH_SCRIPT + '</body>');
190
+ });
191
+ it('should append when no </head> or </body>', () => {
192
+ const html = '<div>Hello</div>';
193
+ const result = injectHealthScript(html);
194
+ expect(result).toBe('<div>Hello</div>' + PREVIEW_HEALTH_SCRIPT);
195
+ });
196
+ it('should include the data-codeyam-health attribute', () => {
197
+ const html = '<html><head></head><body></body></html>';
198
+ const result = injectHealthScript(html);
199
+ expect(result).toContain('data-codeyam-health');
200
+ });
201
+ });
202
+ describe('preview health endpoint', () => {
203
+ let targetServer;
204
+ let targetPort;
205
+ afterEach(async () => {
206
+ const { stopEditorProxy } = require('../editorProxy');
207
+ await stopEditorProxy();
208
+ if (targetServer?.listening) {
209
+ await new Promise((resolve) => targetServer.close(() => resolve()));
210
+ }
211
+ resetPreviewHealth();
212
+ });
213
+ it('should intercept POST /__codeyam__/preview-health and store errors', async () => {
214
+ const { startEditorProxy } = require('../editorProxy');
215
+ // Start a target that returns 200
216
+ targetServer = http.createServer((_req, res) => {
217
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
218
+ res.end('ok');
219
+ });
220
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
221
+ targetPort = targetServer.address().port;
222
+ const result = await startEditorProxy({
223
+ port: 0,
224
+ targetUrl: `http://localhost:${targetPort}`,
225
+ });
226
+ expect(result).not.toBeNull();
227
+ // Post error data to the health endpoint
228
+ const response = await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
229
+ method: 'POST',
230
+ headers: { 'Content-Type': 'application/json' },
231
+ body: JSON.stringify({
232
+ errors: [
233
+ {
234
+ type: 'error',
235
+ message: 'Cannot read properties of undefined',
236
+ timestamp: 1710000000,
237
+ },
238
+ ],
239
+ url: 'http://localhost:3112/',
240
+ }),
241
+ });
242
+ expect(response.status).toBe(204);
243
+ // Check the stored health data
244
+ const health = getPreviewHealthReport();
245
+ expect(health).not.toBeNull();
246
+ expect(health.errors).toHaveLength(1);
247
+ expect(health.errors[0].message).toBe('Cannot read properties of undefined');
248
+ expect(health.url).toBe('http://localhost:3112/');
249
+ });
250
+ it('should store loaded/hasContent from load report', async () => {
251
+ const { startEditorProxy } = require('../editorProxy');
252
+ targetServer = http.createServer((_req, res) => {
253
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
254
+ res.end('ok');
255
+ });
256
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
257
+ targetPort = targetServer.address().port;
258
+ const result = await startEditorProxy({
259
+ port: 0,
260
+ targetUrl: `http://localhost:${targetPort}`,
261
+ });
262
+ // Post load report
263
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
264
+ method: 'POST',
265
+ headers: { 'Content-Type': 'application/json' },
266
+ body: JSON.stringify({
267
+ loaded: true,
268
+ hasContent: true,
269
+ url: 'http://localhost:3112/',
270
+ errorCount: 0,
271
+ }),
272
+ });
273
+ const health = getPreviewHealthReport();
274
+ expect(health).not.toBeNull();
275
+ expect(health.loaded).toBe(true);
276
+ expect(health.hasContent).toBe(true);
277
+ });
278
+ it('should inject health script into HTML responses', async () => {
279
+ const { startEditorProxy } = require('../editorProxy');
280
+ // Target that returns HTML
281
+ targetServer = http.createServer((_req, res) => {
282
+ res.writeHead(200, { 'Content-Type': 'text/html' });
283
+ res.end('<html><head><title>App</title></head><body><div>Hello</div></body></html>');
284
+ });
285
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
286
+ targetPort = targetServer.address().port;
287
+ const result = await startEditorProxy({
288
+ port: 0,
289
+ targetUrl: `http://localhost:${targetPort}`,
290
+ });
291
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
292
+ const body = await response.text();
293
+ expect(body).toContain('data-codeyam-health');
294
+ expect(body).toContain('/__codeyam__/preview-health');
295
+ expect(body).toContain('<title>App</title>');
296
+ expect(body).toContain('<div>Hello</div>');
297
+ });
298
+ it('should NOT inject health script into non-HTML responses', async () => {
299
+ const { startEditorProxy } = require('../editorProxy');
300
+ targetServer = http.createServer((_req, res) => {
301
+ res.writeHead(200, { 'Content-Type': 'application/json' });
302
+ res.end('{"data": "test"}');
303
+ });
304
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
305
+ targetPort = targetServer.address().port;
306
+ const result = await startEditorProxy({
307
+ port: 0,
308
+ targetUrl: `http://localhost:${targetPort}`,
309
+ });
310
+ const response = await fetch(`http://127.0.0.1:${result.port}/api/data`);
311
+ const body = await response.text();
312
+ expect(body).toBe('{"data": "test"}');
313
+ expect(body).not.toContain('data-codeyam-health');
314
+ });
315
+ it('should accumulate errors across multiple health reports', async () => {
316
+ const { startEditorProxy } = require('../editorProxy');
317
+ targetServer = http.createServer((_req, res) => {
318
+ res.writeHead(200, { 'Content-Type': 'text/plain' });
319
+ res.end('ok');
320
+ });
321
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
322
+ targetPort = targetServer.address().port;
323
+ const result = await startEditorProxy({
324
+ port: 0,
325
+ targetUrl: `http://localhost:${targetPort}`,
326
+ });
327
+ // First error report
328
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
329
+ method: 'POST',
330
+ headers: { 'Content-Type': 'application/json' },
331
+ body: JSON.stringify({
332
+ errors: [{ type: 'error', message: 'Error 1', timestamp: 1 }],
333
+ url: 'http://localhost:3112/',
334
+ }),
335
+ });
336
+ // Second error report
337
+ await fetch(`http://127.0.0.1:${result.port}/__codeyam__/preview-health`, {
338
+ method: 'POST',
339
+ headers: { 'Content-Type': 'application/json' },
340
+ body: JSON.stringify({
341
+ errors: [
342
+ { type: 'console.error', message: 'Error 2', timestamp: 2 },
343
+ ],
344
+ url: 'http://localhost:3112/',
345
+ }),
346
+ });
347
+ const health = getPreviewHealthReport();
348
+ expect(health).not.toBeNull();
349
+ expect(health.errors).toHaveLength(2);
350
+ expect(health.errors[0].message).toBe('Error 1');
351
+ expect(health.errors[1].message).toBe('Error 2');
352
+ });
353
+ });
354
+ describe('buildLocalStorageScript', () => {
355
+ it('should return empty string when no localStorage config', () => {
356
+ const { buildLocalStorageScript } = require('../editorProxy');
357
+ expect(buildLocalStorageScript(null, 'scenario-123')).toBe('');
358
+ expect(buildLocalStorageScript(undefined, 'scenario-123')).toBe('');
359
+ });
360
+ it('should emit cleanup script when localStorage config is empty object', () => {
361
+ // BUG FIX: When switching from a scenario with localStorage data to one
362
+ // with empty localStorage (e.g. "First Launch - Welcome"), we must still
363
+ // clean up the previous scenario's keys. Otherwise the app reads stale data.
364
+ const { buildLocalStorageScript } = require('../editorProxy');
365
+ const script = buildLocalStorageScript({}, 'scenario-123');
366
+ expect(script).not.toBe('');
367
+ // Should clean up previous keys
368
+ expect(script).toContain('localStorage.removeItem');
369
+ expect(script).toContain('__codeyam_ls_keys__');
370
+ expect(script).toContain('__codeyam_ls_sid__');
371
+ // Should NOT set any new keys (empty config)
372
+ expect(script).not.toContain('localStorage.setItem(\"margo');
373
+ });
374
+ it('should generate a script that sets localStorage entries', () => {
375
+ const { buildLocalStorageScript } = require('../editorProxy');
376
+ const config = {
377
+ margo_articles: [{ id: 'a1', title: 'Test Article' }],
378
+ margo_collections: [{ id: 'c1', name: 'Test Collection' }],
379
+ };
380
+ const script = buildLocalStorageScript(config, 'scenario-abc');
381
+ // Should be wrapped in a script tag
382
+ expect(script).toMatch(/^<script data-codeyam-ls>/);
383
+ expect(script).toMatch(/<\/script>$/);
384
+ // Should gate on scenario ID to avoid re-seeding on reload
385
+ expect(script).toContain('scenario-abc');
386
+ expect(script).toContain('__codeyam_ls_sid__');
387
+ // Should set the localStorage entries
388
+ expect(script).toContain('margo_articles');
389
+ expect(script).toContain('margo_collections');
390
+ expect(script).toContain('localStorage.setItem');
391
+ // Should track which keys were set for cleanup
392
+ expect(script).toContain('__codeyam_ls_keys__');
393
+ });
394
+ it('should emit gated localStorage.clear() when prototypeId is provided and config is null', () => {
395
+ const { buildLocalStorageScript } = require('../editorProxy');
396
+ const script = buildLocalStorageScript(null, 'scenario-123', 'proto-abc');
397
+ // Should not be empty — prototypeId triggers a clear script
398
+ expect(script).not.toBe('');
399
+ expect(script).toContain('localStorage.clear()');
400
+ // Should be gated by the __codeyam_proto__ marker
401
+ expect(script).toContain('__codeyam_proto__');
402
+ expect(script).toContain('proto-abc');
403
+ });
404
+ it('should not emit clear script when prototypeId is absent and config is null', () => {
405
+ const { buildLocalStorageScript } = require('../editorProxy');
406
+ // No prototypeId — same as before
407
+ expect(buildLocalStorageScript(null, 'scenario-123')).toBe('');
408
+ expect(buildLocalStorageScript(null, 'scenario-123', null)).toBe('');
409
+ expect(buildLocalStorageScript(undefined, 'scenario-123', null)).toBe('');
410
+ });
411
+ it('should clean up keys from previous scenario before setting new ones', () => {
412
+ const { buildLocalStorageScript } = require('../editorProxy');
413
+ const config = { my_key: 'my_value' };
414
+ const script = buildLocalStorageScript(config, 'scenario-xyz');
415
+ // Should read previous keys and remove them
416
+ expect(script).toContain('__codeyam_ls_keys__');
417
+ expect(script).toContain('localStorage.removeItem');
418
+ });
419
+ it('should JSON.stringify non-string values', () => {
420
+ const { buildLocalStorageScript } = require('../editorProxy');
421
+ const config = {
422
+ string_key: 'plain string',
423
+ object_key: { nested: true },
424
+ array_key: [1, 2, 3],
425
+ };
426
+ const script = buildLocalStorageScript(config, 'scenario-1');
427
+ // Object/array values should be JSON-stringified and embedded as JS string literals.
428
+ // JSON.stringify is applied twice: once to serialize the value, once to make it a safe JS string.
429
+ // So {"nested":true} becomes "{\"nested\":true}" in the script source.
430
+ expect(script).toContain('object_key');
431
+ expect(script).toContain('nested');
432
+ expect(script).toContain('array_key');
433
+ expect(script).toContain('[1,2,3]');
434
+ });
435
+ it('should include localStorage mutation watcher that sends postMessage on changes', () => {
436
+ const { buildLocalStorageScript } = require('../editorProxy');
437
+ const config = { my_key: 'my_value' };
438
+ const script = buildLocalStorageScript(config, 'scenario-1');
439
+ // Should hook setItem, removeItem, and clear
440
+ expect(script).toContain('__codeyam_orig_setItem__');
441
+ expect(script).toContain('__codeyam_orig_removeItem__');
442
+ expect(script).toContain('__codeyam_orig_clear__');
443
+ // Should send postMessage to parent
444
+ expect(script).toContain('codeyam-localstorage-changed');
445
+ expect(script).toContain('postMessage');
446
+ // Should filter out internal codeyam keys
447
+ expect(script).toContain('__codeyam_');
448
+ });
449
+ it('should include localStorage mutation watcher even for empty localStorage config', () => {
450
+ const { buildLocalStorageScript } = require('../editorProxy');
451
+ const script = buildLocalStorageScript({}, 'scenario-1');
452
+ // Empty config still needs the watcher since the app may write to localStorage
453
+ expect(script).toContain('codeyam-localstorage-changed');
454
+ });
455
+ it('should include a listener for codeyam-get-localstorage requests', () => {
456
+ const { buildLocalStorageScript } = require('../editorProxy');
457
+ const config = { my_key: 'my_value' };
458
+ const script = buildLocalStorageScript(config, 'scenario-1');
459
+ // Should listen for get-localstorage requests from parent
460
+ expect(script).toContain('codeyam-get-localstorage');
461
+ expect(script).toContain('codeyam-localstorage-state');
462
+ });
463
+ it('should not include mutation watcher when no localStorage config and no prototypeId', () => {
464
+ const { buildLocalStorageScript } = require('../editorProxy');
465
+ // No config at all — returns empty string, no watcher needed
466
+ expect(buildLocalStorageScript(null, 'scenario-1')).toBe('');
467
+ });
468
+ it('should re-seed localStorage when scenario data changes even if ID is the same', () => {
469
+ // BUG: When a scenario is re-registered with updated data (e.g., adding
470
+ // collections to articles), the scenario ID stays the same. The guard
471
+ // checked only the ID, so the browser skipped re-seeding and showed stale
472
+ // data. The screenshot (captured by Playwright with a fresh browser)
473
+ // showed the new data, but the live preview didn't.
474
+ const { buildLocalStorageScript } = require('../editorProxy');
475
+ const originalData = {
476
+ articles: '[{"id":"a1","title":"Test"}]',
477
+ };
478
+ const updatedData = {
479
+ articles: '[{"id":"a1","title":"Test","collectionIds":["c1"]}]',
480
+ collections: '[{"id":"c1","name":"Dev"}]',
481
+ };
482
+ const script1 = buildLocalStorageScript(originalData, 'scenario-abc');
483
+ const script2 = buildLocalStorageScript(updatedData, 'scenario-abc');
484
+ // Both scripts use the same scenario ID
485
+ expect(script1).toContain('scenario-abc');
486
+ expect(script2).toContain('scenario-abc');
487
+ // The guard values must be DIFFERENT so the browser re-seeds
488
+ // Extract the guard comparison value from each script
489
+ const guardPattern = /__codeyam_ls_sid__.*?===\s*([^\)]+)\)/;
490
+ const guard1 = script1.match(guardPattern)?.[1];
491
+ const guard2 = script2.match(guardPattern)?.[1];
492
+ expect(guard1).toBeDefined();
493
+ expect(guard2).toBeDefined();
494
+ expect(guard1).not.toEqual(guard2);
495
+ });
496
+ });
497
+ describe('localStorage injection in HTML responses', () => {
498
+ it('should inject localStorage script before health script in HTML', () => {
499
+ const { buildLocalStorageScript, injectHealthScript, } = require('../editorProxy');
500
+ const lsScript = buildLocalStorageScript({ items: [1, 2] }, 'scenario-1');
501
+ // localStorage script should be injected before the health script
502
+ // (needs to run before app loads)
503
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
504
+ const result = injectHealthScript(html, lsScript);
505
+ expect(result).toContain('data-codeyam-ls');
506
+ expect(result).toContain('data-codeyam-health');
507
+ // localStorage script should appear BEFORE health script in the output
508
+ const lsIdx = result.indexOf('data-codeyam-ls');
509
+ const healthIdx = result.indexOf('data-codeyam-health');
510
+ expect(lsIdx).toBeLessThan(healthIdx);
511
+ });
512
+ it('should not inject localStorage script when none provided', () => {
513
+ const html = '<html><head><title>Test</title></head><body>Hello</body></html>';
514
+ const result = injectHealthScript(html);
515
+ expect(result).toContain('data-codeyam-health');
516
+ expect(result).not.toContain('data-codeyam-ls');
517
+ });
518
+ });
519
+ describe('compressed response handling', () => {
520
+ let targetServer;
521
+ let targetPort;
522
+ afterEach(async () => {
523
+ const { stopEditorProxy } = require('../editorProxy');
524
+ await stopEditorProxy();
525
+ if (targetServer?.listening) {
526
+ await new Promise((resolve) => targetServer.close(() => resolve()));
527
+ }
528
+ resetPreviewHealth();
529
+ });
530
+ it('should strip accept-encoding so target returns uncompressed HTML for injection', async () => {
531
+ const { startEditorProxy } = require('../editorProxy');
532
+ const originalHtml = '<html><head><title>Compressed</title></head><body><div>Gzipped</div></body></html>';
533
+ // Target server that compresses only when client sends Accept-Encoding
534
+ // (simulates real dev servers like Next.js/Vite)
535
+ targetServer = http.createServer((req, res) => {
536
+ const acceptEncoding = req.headers['accept-encoding'] || '';
537
+ if (acceptEncoding.includes('gzip')) {
538
+ const compressed = zlib.gzipSync(Buffer.from(originalHtml));
539
+ res.writeHead(200, {
540
+ 'Content-Type': 'text/html',
541
+ 'Content-Encoding': 'gzip',
542
+ 'Content-Length': compressed.length,
543
+ });
544
+ res.end(compressed);
545
+ }
546
+ else {
547
+ res.writeHead(200, { 'Content-Type': 'text/html' });
548
+ res.end(originalHtml);
549
+ }
550
+ });
551
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
552
+ targetPort = targetServer.address().port;
553
+ const result = await startEditorProxy({
554
+ port: 0,
555
+ targetUrl: `http://localhost:${targetPort}`,
556
+ });
557
+ expect(result).not.toBeNull();
558
+ // Request through proxy WITH Accept-Encoding (simulating a real browser)
559
+ const response = await fetch(`http://127.0.0.1:${result.port}/`, {
560
+ headers: { 'Accept-Encoding': 'gzip, deflate, br' },
561
+ });
562
+ // The proxy should return a valid, readable response
563
+ expect(response.status).toBe(200);
564
+ const body = await response.text();
565
+ // Should contain the original HTML content (not corrupted binary)
566
+ expect(body).toContain('<title>Compressed</title>');
567
+ expect(body).toContain('<div>Gzipped</div>');
568
+ // Should have injected the health script
569
+ expect(body).toContain('data-codeyam-health');
570
+ // Should NOT have Content-Encoding since the proxy serves uncompressed
571
+ expect(response.headers.get('content-encoding')).toBeNull();
572
+ });
573
+ });
574
+ describe('Cache-Control on HTML responses', () => {
575
+ let targetServer;
576
+ let targetPort;
577
+ afterEach(async () => {
578
+ const { stopEditorProxy } = require('../editorProxy');
579
+ await stopEditorProxy();
580
+ if (targetServer?.listening) {
581
+ await new Promise((resolve) => targetServer.close(() => resolve()));
582
+ }
583
+ resetPreviewHealth();
584
+ });
585
+ it('should add Cache-Control: no-store to proxied HTML responses', async () => {
586
+ const { startEditorProxy } = require('../editorProxy');
587
+ // Target server that serves plain HTML without cache headers
588
+ targetServer = http.createServer((_req, res) => {
589
+ res.writeHead(200, { 'Content-Type': 'text/html' });
590
+ res.end('<html><head><title>Test</title></head><body>Hello</body></html>');
591
+ });
592
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
593
+ targetPort = targetServer.address().port;
594
+ const result = await startEditorProxy({
595
+ port: 0,
596
+ targetUrl: `http://localhost:${targetPort}`,
597
+ });
598
+ expect(result).not.toBeNull();
599
+ const response = await fetch(`http://127.0.0.1:${result.port}/`);
600
+ expect(response.status).toBe(200);
601
+ // Proxy must set no-store so the browser doesn't cache pages between
602
+ // scenario switches (application scenarios share the same proxy URL
603
+ // but differ in seed data).
604
+ expect(response.headers.get('cache-control')).toBe('no-store, must-revalidate');
605
+ });
606
+ it('should NOT add Cache-Control: no-store to non-HTML responses', async () => {
607
+ const { startEditorProxy } = require('../editorProxy');
608
+ // Target server that serves JSON without cache headers
609
+ targetServer = http.createServer((_req, res) => {
610
+ res.writeHead(200, { 'Content-Type': 'application/json' });
611
+ res.end(JSON.stringify({ ok: true }));
612
+ });
613
+ await new Promise((resolve) => targetServer.listen(0, '127.0.0.1', () => resolve()));
614
+ targetPort = targetServer.address().port;
615
+ const result = await startEditorProxy({
616
+ port: 0,
617
+ targetUrl: `http://localhost:${targetPort}`,
618
+ });
619
+ expect(result).not.toBeNull();
620
+ const response = await fetch(`http://127.0.0.1:${result.port}/api/data`);
621
+ expect(response.status).toBe(200);
622
+ // Non-HTML responses pass through the target's original headers;
623
+ // the proxy only forces no-store on HTML.
624
+ expect(response.headers.get('cache-control')).toBeNull();
625
+ });
626
+ });
627
+ });
628
+ //# sourceMappingURL=editorProxy.test.js.map