convex 1.34.0 → 1.35.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (607) hide show
  1. package/CHANGELOG.md +98 -43
  2. package/dist/browser.bundle.js +13 -10
  3. package/dist/browser.bundle.js.map +3 -3
  4. package/dist/cjs/browser/index-node.js +3 -1
  5. package/dist/cjs/browser/index.js +3 -1
  6. package/dist/cjs/browser/index.js.map +2 -2
  7. package/dist/cjs/browser/query_options.js.map +2 -2
  8. package/dist/cjs/browser/sync/authentication_manager.js +4 -1
  9. package/dist/cjs/browser/sync/authentication_manager.js.map +2 -2
  10. package/dist/cjs/browser/sync/web_socket_manager.js +1 -7
  11. package/dist/cjs/browser/sync/web_socket_manager.js.map +2 -2
  12. package/dist/cjs/cli/aiFiles.js +39 -20
  13. package/dist/cjs/cli/aiFiles.js.map +3 -3
  14. package/dist/cjs/cli/codegen_templates/readme.js +14 -1
  15. package/dist/cjs/cli/codegen_templates/readme.js.map +2 -2
  16. package/dist/cjs/cli/configure.js +34 -32
  17. package/dist/cjs/cli/configure.js.map +2 -2
  18. package/dist/cjs/cli/deploy.js +7 -8
  19. package/dist/cjs/cli/deploy.js.map +2 -2
  20. package/dist/cjs/cli/deploymentCreate.js +225 -40
  21. package/dist/cjs/cli/deploymentCreate.js.map +3 -3
  22. package/dist/cjs/cli/deploymentSelect.js +14 -13
  23. package/dist/cjs/cli/deploymentSelect.js.map +2 -2
  24. package/dist/cjs/cli/dev.js +30 -11
  25. package/dist/cjs/cli/dev.js.map +2 -2
  26. package/dist/cjs/cli/docs.js +1 -1
  27. package/dist/cjs/cli/docs.js.map +2 -2
  28. package/dist/cjs/cli/init.js +1 -1
  29. package/dist/cjs/cli/init.js.map +2 -2
  30. package/dist/cjs/cli/lib/aiFiles/agentsmd.js +73 -0
  31. package/dist/cjs/cli/lib/aiFiles/agentsmd.js.map +7 -0
  32. package/dist/cjs/cli/lib/aiFiles/claudemd.js +73 -0
  33. package/dist/cjs/cli/lib/aiFiles/claudemd.js.map +7 -0
  34. package/dist/cjs/cli/lib/aiFiles/cursorrules.js +48 -0
  35. package/dist/cjs/cli/lib/aiFiles/cursorrules.js.map +7 -0
  36. package/dist/cjs/cli/lib/aiFiles/guidelinesmd.js +58 -0
  37. package/dist/cjs/cli/lib/aiFiles/guidelinesmd.js.map +7 -0
  38. package/dist/cjs/cli/lib/aiFiles/index.js +215 -0
  39. package/dist/cjs/cli/lib/aiFiles/index.js.map +7 -0
  40. package/dist/cjs/cli/lib/aiFiles/paths.js.map +7 -0
  41. package/dist/cjs/cli/lib/aiFiles/skills.js +196 -0
  42. package/dist/cjs/cli/lib/aiFiles/skills.js.map +7 -0
  43. package/dist/cjs/cli/lib/aiFiles/state.js +96 -0
  44. package/dist/cjs/cli/lib/aiFiles/state.js.map +7 -0
  45. package/dist/cjs/cli/lib/aiFiles/status.js +198 -0
  46. package/dist/cjs/cli/lib/aiFiles/status.js.map +7 -0
  47. package/dist/cjs/cli/lib/aiFiles/utils.js +128 -0
  48. package/dist/cjs/cli/lib/aiFiles/utils.js.map +7 -0
  49. package/dist/cjs/cli/lib/api.js +70 -7
  50. package/dist/cjs/cli/lib/api.js.map +2 -2
  51. package/dist/cjs/cli/lib/command.js +10 -6
  52. package/dist/cjs/cli/lib/command.js.map +2 -2
  53. package/dist/cjs/cli/lib/config.js +43 -7
  54. package/dist/cjs/cli/lib/config.js.map +3 -3
  55. package/dist/cjs/cli/lib/deploy2.js +9 -26
  56. package/dist/cjs/cli/lib/deploy2.js.map +2 -2
  57. package/dist/cjs/cli/lib/deployApi/componentDefinition.js +4 -1
  58. package/dist/cjs/cli/lib/deployApi/componentDefinition.js.map +2 -2
  59. package/dist/cjs/cli/lib/deploymentSelection.js +45 -2
  60. package/dist/cjs/cli/lib/deploymentSelection.js.map +2 -2
  61. package/dist/cjs/cli/lib/deploymentSelector.js +1 -0
  62. package/dist/cjs/cli/lib/deploymentSelector.js.map +2 -2
  63. package/dist/cjs/cli/lib/dev.js +162 -117
  64. package/dist/cjs/cli/lib/dev.js.map +2 -2
  65. package/dist/cjs/cli/lib/env.js +1 -13
  66. package/dist/cjs/cli/lib/env.js.map +2 -2
  67. package/dist/cjs/cli/lib/expiration.js +104 -0
  68. package/dist/cjs/cli/lib/expiration.js.map +7 -0
  69. package/dist/cjs/cli/lib/generatedFunctionLogsApi.js.map +1 -1
  70. package/dist/cjs/cli/lib/init.js +4 -3
  71. package/dist/cjs/cli/lib/init.js.map +2 -2
  72. package/dist/cjs/cli/lib/insights.js +1 -1
  73. package/dist/cjs/cli/lib/insights.js.map +2 -2
  74. package/dist/cjs/cli/lib/localDeployment/anonymous.js +15 -8
  75. package/dist/cjs/cli/lib/localDeployment/anonymous.js.map +2 -2
  76. package/dist/cjs/cli/lib/localDeployment/localDeployment.js +8 -10
  77. package/dist/cjs/cli/lib/localDeployment/localDeployment.js.map +2 -2
  78. package/dist/cjs/cli/lib/localDeployment/run.js +1 -0
  79. package/dist/cjs/cli/lib/localDeployment/run.js.map +2 -2
  80. package/dist/cjs/cli/lib/localDeployment/upgrade.js +2 -2
  81. package/dist/cjs/cli/lib/localDeployment/upgrade.js.map +2 -2
  82. package/dist/cjs/cli/lib/localDeployment/utils.js +9 -0
  83. package/dist/cjs/cli/lib/localDeployment/utils.js.map +2 -2
  84. package/dist/cjs/cli/lib/mcp/tools/status.js +1 -1
  85. package/dist/cjs/cli/lib/mcp/tools/status.js.map +2 -2
  86. package/dist/cjs/cli/lib/updates.js +12 -13
  87. package/dist/cjs/cli/lib/updates.js.map +2 -2
  88. package/dist/cjs/cli/lib/usage.js +2 -1
  89. package/dist/cjs/cli/lib/usage.js.map +2 -2
  90. package/dist/cjs/cli/lib/utils/prompts.js +2 -1
  91. package/dist/cjs/cli/lib/utils/prompts.js.map +2 -2
  92. package/dist/cjs/cli/lib/utils/utils.js +46 -20
  93. package/dist/cjs/cli/lib/utils/utils.js.map +3 -3
  94. package/dist/cjs/cli/lib/versionApi.js +7 -4
  95. package/dist/cjs/cli/lib/versionApi.js.map +2 -2
  96. package/dist/cjs/cli/lib/workos/workos.js +4 -6
  97. package/dist/cjs/cli/lib/workos/workos.js.map +2 -2
  98. package/dist/cjs/index.js +1 -1
  99. package/dist/cjs/index.js.map +1 -1
  100. package/dist/cjs/react/client.js +43 -6
  101. package/dist/cjs/react/client.js.map +2 -2
  102. package/dist/cjs/react/index.js +2 -0
  103. package/dist/cjs/react/index.js.map +2 -2
  104. package/dist/cjs/react-clerk/ConvexProviderWithClerk.js.map +1 -1
  105. package/dist/cjs/server/api.js.map +2 -2
  106. package/dist/cjs/server/components/definition.js.map +1 -1
  107. package/dist/cjs/server/components/index.js +40 -4
  108. package/dist/cjs/server/components/index.js.map +2 -2
  109. package/dist/cjs/server/data_model.js.map +1 -1
  110. package/dist/cjs/server/impl/meta_impl.js +78 -0
  111. package/dist/cjs/server/impl/meta_impl.js.map +7 -0
  112. package/dist/cjs/server/impl/registration_impl.js +16 -11
  113. package/dist/cjs/server/impl/registration_impl.js.map +2 -2
  114. package/dist/cjs/server/index.js.map +2 -2
  115. package/dist/cjs/server/meta.js +17 -0
  116. package/dist/cjs/server/meta.js.map +7 -0
  117. package/dist/cjs/server/registration.js.map +1 -1
  118. package/dist/cjs-types/browser/index.d.ts +1 -0
  119. package/dist/cjs-types/browser/index.d.ts.map +1 -1
  120. package/dist/cjs-types/browser/query_options.d.ts +12 -9
  121. package/dist/cjs-types/browser/query_options.d.ts.map +1 -1
  122. package/dist/cjs-types/browser/sync/authentication_manager.d.ts.map +1 -1
  123. package/dist/cjs-types/browser/sync/web_socket_manager.d.ts.map +1 -1
  124. package/dist/cjs-types/cli/aiFiles.d.ts.map +1 -1
  125. package/dist/cjs-types/cli/codegen_templates/readme.d.ts.map +1 -1
  126. package/dist/cjs-types/cli/configure.d.ts.map +1 -1
  127. package/dist/cjs-types/cli/configure.test.d.ts +2 -0
  128. package/dist/cjs-types/cli/configure.test.d.ts.map +1 -0
  129. package/dist/cjs-types/cli/deploy.d.ts.map +1 -1
  130. package/dist/cjs-types/cli/deploymentCreate.d.ts +1 -0
  131. package/dist/cjs-types/cli/deploymentCreate.d.ts.map +1 -1
  132. package/dist/cjs-types/cli/deploymentSelect.d.ts +2 -1
  133. package/dist/cjs-types/cli/deploymentSelect.d.ts.map +1 -1
  134. package/dist/cjs-types/cli/dev.d.ts +3 -1
  135. package/dist/cjs-types/cli/dev.d.ts.map +1 -1
  136. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.d.ts +19 -0
  137. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.d.ts.map +1 -0
  138. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.test.d.ts +2 -0
  139. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.test.d.ts.map +1 -0
  140. package/dist/cjs-types/cli/lib/aiFiles/claudemd.d.ts +19 -0
  141. package/dist/cjs-types/cli/lib/aiFiles/claudemd.d.ts.map +1 -0
  142. package/dist/cjs-types/cli/lib/aiFiles/claudemd.test.d.ts +2 -0
  143. package/dist/cjs-types/cli/lib/aiFiles/claudemd.test.d.ts.map +1 -0
  144. package/dist/cjs-types/cli/lib/aiFiles/cursorrules.d.ts +10 -0
  145. package/dist/cjs-types/cli/lib/aiFiles/cursorrules.d.ts.map +1 -0
  146. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.d.ts +12 -0
  147. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.d.ts.map +1 -0
  148. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.test.d.ts +2 -0
  149. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.test.d.ts.map +1 -0
  150. package/dist/cjs-types/cli/lib/aiFiles/index.d.ts +42 -0
  151. package/dist/cjs-types/cli/lib/aiFiles/index.d.ts.map +1 -0
  152. package/dist/cjs-types/cli/lib/aiFiles/index.test.d.ts.map +1 -0
  153. package/dist/cjs-types/cli/lib/aiFiles/integration.test.d.ts.map +1 -0
  154. package/dist/cjs-types/cli/lib/{ai → aiFiles}/paths.d.ts +4 -0
  155. package/dist/cjs-types/cli/lib/aiFiles/paths.d.ts.map +1 -0
  156. package/dist/cjs-types/cli/lib/aiFiles/prompt.test.d.ts.map +1 -0
  157. package/dist/cjs-types/cli/lib/aiFiles/skills.d.ts +20 -0
  158. package/dist/cjs-types/cli/lib/aiFiles/skills.d.ts.map +1 -0
  159. package/dist/cjs-types/cli/lib/aiFiles/state.d.ts +38 -0
  160. package/dist/cjs-types/cli/lib/aiFiles/state.d.ts.map +1 -0
  161. package/dist/cjs-types/cli/lib/aiFiles/state.test.d.ts +2 -0
  162. package/dist/cjs-types/cli/lib/aiFiles/state.test.d.ts.map +1 -0
  163. package/dist/cjs-types/cli/lib/aiFiles/status.d.ts +6 -0
  164. package/dist/cjs-types/cli/lib/aiFiles/status.d.ts.map +1 -0
  165. package/dist/cjs-types/cli/lib/aiFiles/utils.d.ts +56 -0
  166. package/dist/cjs-types/cli/lib/aiFiles/utils.d.ts.map +1 -0
  167. package/dist/cjs-types/cli/lib/aiFiles/utils.test.d.ts +2 -0
  168. package/dist/cjs-types/cli/lib/aiFiles/utils.test.d.ts.map +1 -0
  169. package/dist/cjs-types/cli/lib/api.d.ts +3 -3
  170. package/dist/cjs-types/cli/lib/api.d.ts.map +1 -1
  171. package/dist/cjs-types/cli/lib/command.d.ts +2 -1
  172. package/dist/cjs-types/cli/lib/command.d.ts.map +1 -1
  173. package/dist/cjs-types/cli/lib/config.d.ts +18 -6
  174. package/dist/cjs-types/cli/lib/config.d.ts.map +1 -1
  175. package/dist/cjs-types/cli/lib/deploy2.d.ts +5 -2
  176. package/dist/cjs-types/cli/lib/deploy2.d.ts.map +1 -1
  177. package/dist/cjs-types/cli/lib/deployApi/componentDefinition.d.ts +27 -12
  178. package/dist/cjs-types/cli/lib/deployApi/componentDefinition.d.ts.map +1 -1
  179. package/dist/cjs-types/cli/lib/deployApi/definitionConfig.d.ts +24 -24
  180. package/dist/cjs-types/cli/lib/deployApi/modules.d.ts +14 -14
  181. package/dist/cjs-types/cli/lib/deployApi/startPush.d.ts +61 -52
  182. package/dist/cjs-types/cli/lib/deployApi/startPush.d.ts.map +1 -1
  183. package/dist/cjs-types/cli/lib/deploymentSelection.d.ts.map +1 -1
  184. package/dist/cjs-types/cli/lib/deploymentSelector.d.ts +2 -0
  185. package/dist/cjs-types/cli/lib/deploymentSelector.d.ts.map +1 -1
  186. package/dist/cjs-types/cli/lib/dev.d.ts.map +1 -1
  187. package/dist/cjs-types/cli/lib/env.d.ts +0 -4
  188. package/dist/cjs-types/cli/lib/env.d.ts.map +1 -1
  189. package/dist/cjs-types/cli/lib/expiration.d.ts +35 -0
  190. package/dist/cjs-types/cli/lib/expiration.d.ts.map +1 -0
  191. package/dist/cjs-types/cli/lib/expiration.test.d.ts +2 -0
  192. package/dist/cjs-types/cli/lib/expiration.test.d.ts.map +1 -0
  193. package/dist/cjs-types/cli/lib/generatedFunctionLogsApi.d.ts +16 -1
  194. package/dist/cjs-types/cli/lib/generatedFunctionLogsApi.d.ts.map +1 -1
  195. package/dist/cjs-types/cli/lib/init.d.ts.map +1 -1
  196. package/dist/cjs-types/cli/lib/localDeployment/anonymous.d.ts.map +1 -1
  197. package/dist/cjs-types/cli/lib/localDeployment/localDeployment.d.ts.map +1 -1
  198. package/dist/cjs-types/cli/lib/localDeployment/run.d.ts +15 -0
  199. package/dist/cjs-types/cli/lib/localDeployment/run.d.ts.map +1 -1
  200. package/dist/cjs-types/cli/lib/localDeployment/upgrade.d.ts.map +1 -1
  201. package/dist/cjs-types/cli/lib/localDeployment/utils.d.ts +7 -0
  202. package/dist/cjs-types/cli/lib/localDeployment/utils.d.ts.map +1 -1
  203. package/dist/cjs-types/cli/lib/mcp/requestContext.d.ts +3 -3
  204. package/dist/cjs-types/cli/lib/mcp/tools/insights.d.ts +2 -2
  205. package/dist/cjs-types/cli/lib/updates.d.ts +4 -3
  206. package/dist/cjs-types/cli/lib/updates.d.ts.map +1 -1
  207. package/dist/cjs-types/cli/lib/usage.d.ts.map +1 -1
  208. package/dist/cjs-types/cli/lib/utils/prompts.d.ts +1 -0
  209. package/dist/cjs-types/cli/lib/utils/prompts.d.ts.map +1 -1
  210. package/dist/cjs-types/cli/lib/utils/utils.d.ts +16 -2
  211. package/dist/cjs-types/cli/lib/utils/utils.d.ts.map +1 -1
  212. package/dist/cjs-types/cli/lib/versionApi.d.ts +7 -1
  213. package/dist/cjs-types/cli/lib/versionApi.d.ts.map +1 -1
  214. package/dist/cjs-types/cli/lib/workos/workos.d.ts.map +1 -1
  215. package/dist/cjs-types/index.d.ts +1 -1
  216. package/dist/cjs-types/react/client.d.ts +54 -2
  217. package/dist/cjs-types/react/client.d.ts.map +1 -1
  218. package/dist/cjs-types/react/index.d.ts +7 -2
  219. package/dist/cjs-types/react/index.d.ts.map +1 -1
  220. package/dist/cjs-types/react/use_query_object_options.test.d.ts +5 -0
  221. package/dist/cjs-types/react/use_query_object_options.test.d.ts.map +1 -0
  222. package/dist/cjs-types/react/use_query_result.test.d.ts +5 -0
  223. package/dist/cjs-types/react/use_query_result.test.d.ts.map +1 -0
  224. package/dist/cjs-types/react-clerk/ConvexProviderWithClerk.d.ts +1 -1
  225. package/dist/cjs-types/server/api.d.ts +5 -1
  226. package/dist/cjs-types/server/api.d.ts.map +1 -1
  227. package/dist/cjs-types/server/components/definition.d.ts +1 -0
  228. package/dist/cjs-types/server/components/definition.d.ts.map +1 -1
  229. package/dist/cjs-types/server/components/index.d.ts +5 -1
  230. package/dist/cjs-types/server/components/index.d.ts.map +1 -1
  231. package/dist/cjs-types/server/data_model.d.ts +2 -1
  232. package/dist/cjs-types/server/data_model.d.ts.map +1 -1
  233. package/dist/cjs-types/server/impl/meta_impl.d.ts +5 -0
  234. package/dist/cjs-types/server/impl/meta_impl.d.ts.map +1 -0
  235. package/dist/cjs-types/server/impl/registration_impl.d.ts.map +1 -1
  236. package/dist/cjs-types/server/index.d.ts +1 -0
  237. package/dist/cjs-types/server/index.d.ts.map +1 -1
  238. package/dist/cjs-types/server/meta.d.ts +72 -0
  239. package/dist/cjs-types/server/meta.d.ts.map +1 -0
  240. package/dist/cjs-types/server/registration.d.ts.map +1 -1
  241. package/dist/cli.bundle.cjs +2446 -1933
  242. package/dist/cli.bundle.cjs.map +4 -4
  243. package/dist/esm/browser/index-node.js +1 -0
  244. package/dist/esm/browser/index.js +1 -0
  245. package/dist/esm/browser/index.js.map +2 -2
  246. package/dist/esm/browser/query_options.js.map +2 -2
  247. package/dist/esm/browser/sync/authentication_manager.js +4 -1
  248. package/dist/esm/browser/sync/authentication_manager.js.map +2 -2
  249. package/dist/esm/browser/sync/web_socket_manager.js +1 -7
  250. package/dist/esm/browser/sync/web_socket_manager.js.map +2 -2
  251. package/dist/esm/cli/aiFiles.js +41 -23
  252. package/dist/esm/cli/aiFiles.js.map +2 -2
  253. package/dist/esm/cli/codegen_templates/readme.js +14 -1
  254. package/dist/esm/cli/codegen_templates/readme.js.map +2 -2
  255. package/dist/esm/cli/configure.js +35 -33
  256. package/dist/esm/cli/configure.js.map +2 -2
  257. package/dist/esm/cli/deploy.js +11 -10
  258. package/dist/esm/cli/deploy.js.map +2 -2
  259. package/dist/esm/cli/deploymentCreate.js +238 -42
  260. package/dist/esm/cli/deploymentCreate.js.map +2 -2
  261. package/dist/esm/cli/deploymentSelect.js +13 -12
  262. package/dist/esm/cli/deploymentSelect.js.map +2 -2
  263. package/dist/esm/cli/dev.js +34 -13
  264. package/dist/esm/cli/dev.js.map +2 -2
  265. package/dist/esm/cli/docs.js +1 -1
  266. package/dist/esm/cli/docs.js.map +2 -2
  267. package/dist/esm/cli/init.js +2 -2
  268. package/dist/esm/cli/init.js.map +2 -2
  269. package/dist/esm/cli/lib/aiFiles/agentsmd.js +56 -0
  270. package/dist/esm/cli/lib/aiFiles/agentsmd.js.map +7 -0
  271. package/dist/esm/cli/lib/aiFiles/claudemd.js +56 -0
  272. package/dist/esm/cli/lib/aiFiles/claudemd.js.map +7 -0
  273. package/dist/esm/cli/lib/aiFiles/cursorrules.js +16 -0
  274. package/dist/esm/cli/lib/aiFiles/cursorrules.js.map +7 -0
  275. package/dist/esm/cli/lib/aiFiles/guidelinesmd.js +35 -0
  276. package/dist/esm/cli/lib/aiFiles/guidelinesmd.js.map +7 -0
  277. package/dist/esm/cli/lib/aiFiles/index.js +193 -0
  278. package/dist/esm/cli/lib/aiFiles/index.js.map +7 -0
  279. package/dist/esm/cli/lib/aiFiles/paths.js.map +7 -0
  280. package/dist/esm/cli/lib/aiFiles/skills.js +163 -0
  281. package/dist/esm/cli/lib/aiFiles/skills.js.map +7 -0
  282. package/dist/esm/cli/lib/aiFiles/state.js +60 -0
  283. package/dist/esm/cli/lib/aiFiles/state.js.map +7 -0
  284. package/dist/esm/cli/lib/aiFiles/status.js +178 -0
  285. package/dist/esm/cli/lib/aiFiles/status.js.map +7 -0
  286. package/dist/esm/cli/lib/aiFiles/utils.js +97 -0
  287. package/dist/esm/cli/lib/aiFiles/utils.js.map +7 -0
  288. package/dist/esm/cli/lib/api.js +70 -7
  289. package/dist/esm/cli/lib/api.js.map +2 -2
  290. package/dist/esm/cli/lib/command.js +10 -6
  291. package/dist/esm/cli/lib/command.js.map +2 -2
  292. package/dist/esm/cli/lib/config.js +41 -6
  293. package/dist/esm/cli/lib/config.js.map +2 -2
  294. package/dist/esm/cli/lib/deploy2.js +13 -26
  295. package/dist/esm/cli/lib/deploy2.js.map +2 -2
  296. package/dist/esm/cli/lib/deployApi/componentDefinition.js +4 -1
  297. package/dist/esm/cli/lib/deployApi/componentDefinition.js.map +2 -2
  298. package/dist/esm/cli/lib/deploymentSelection.js +46 -2
  299. package/dist/esm/cli/lib/deploymentSelection.js.map +2 -2
  300. package/dist/esm/cli/lib/deploymentSelector.js +1 -0
  301. package/dist/esm/cli/lib/deploymentSelector.js.map +2 -2
  302. package/dist/esm/cli/lib/dev.js +162 -118
  303. package/dist/esm/cli/lib/dev.js.map +2 -2
  304. package/dist/esm/cli/lib/env.js +0 -11
  305. package/dist/esm/cli/lib/env.js.map +2 -2
  306. package/dist/esm/cli/lib/expiration.js +80 -0
  307. package/dist/esm/cli/lib/expiration.js.map +7 -0
  308. package/dist/esm/cli/lib/init.js +4 -3
  309. package/dist/esm/cli/lib/init.js.map +2 -2
  310. package/dist/esm/cli/lib/insights.js +1 -1
  311. package/dist/esm/cli/lib/insights.js.map +2 -2
  312. package/dist/esm/cli/lib/localDeployment/anonymous.js +16 -9
  313. package/dist/esm/cli/lib/localDeployment/anonymous.js.map +2 -2
  314. package/dist/esm/cli/lib/localDeployment/localDeployment.js +9 -11
  315. package/dist/esm/cli/lib/localDeployment/localDeployment.js.map +2 -2
  316. package/dist/esm/cli/lib/localDeployment/run.js +1 -1
  317. package/dist/esm/cli/lib/localDeployment/run.js.map +2 -2
  318. package/dist/esm/cli/lib/localDeployment/upgrade.js +2 -2
  319. package/dist/esm/cli/lib/localDeployment/upgrade.js.map +2 -2
  320. package/dist/esm/cli/lib/localDeployment/utils.js +8 -0
  321. package/dist/esm/cli/lib/localDeployment/utils.js.map +2 -2
  322. package/dist/esm/cli/lib/mcp/tools/status.js +1 -1
  323. package/dist/esm/cli/lib/mcp/tools/status.js.map +2 -2
  324. package/dist/esm/cli/lib/updates.js +14 -12
  325. package/dist/esm/cli/lib/updates.js.map +2 -2
  326. package/dist/esm/cli/lib/usage.js +2 -1
  327. package/dist/esm/cli/lib/usage.js.map +2 -2
  328. package/dist/esm/cli/lib/utils/prompts.js +2 -1
  329. package/dist/esm/cli/lib/utils/prompts.js.map +2 -2
  330. package/dist/esm/cli/lib/utils/utils.js +45 -20
  331. package/dist/esm/cli/lib/utils/utils.js.map +3 -3
  332. package/dist/esm/cli/lib/versionApi.js +7 -4
  333. package/dist/esm/cli/lib/versionApi.js.map +2 -2
  334. package/dist/esm/cli/lib/workos/workos.js +4 -6
  335. package/dist/esm/cli/lib/workos/workos.js.map +2 -2
  336. package/dist/esm/index.js +1 -1
  337. package/dist/esm/index.js.map +1 -1
  338. package/dist/esm/react/client.js +43 -6
  339. package/dist/esm/react/client.js.map +2 -2
  340. package/dist/esm/react/index.js +1 -0
  341. package/dist/esm/react/index.js.map +2 -2
  342. package/dist/esm/react-clerk/ConvexProviderWithClerk.js.map +1 -1
  343. package/dist/esm/server/api.js.map +2 -2
  344. package/dist/esm/server/components/index.js +40 -4
  345. package/dist/esm/server/components/index.js.map +2 -2
  346. package/dist/esm/server/impl/meta_impl.js +54 -0
  347. package/dist/esm/server/impl/meta_impl.js.map +7 -0
  348. package/dist/esm/server/impl/registration_impl.js +20 -11
  349. package/dist/esm/server/impl/registration_impl.js.map +2 -2
  350. package/dist/esm/server/index.js.map +2 -2
  351. package/dist/esm/server/meta.js +2 -0
  352. package/dist/esm/server/meta.js.map +7 -0
  353. package/dist/esm-types/browser/index.d.ts +1 -0
  354. package/dist/esm-types/browser/index.d.ts.map +1 -1
  355. package/dist/esm-types/browser/query_options.d.ts +12 -9
  356. package/dist/esm-types/browser/query_options.d.ts.map +1 -1
  357. package/dist/esm-types/browser/sync/authentication_manager.d.ts.map +1 -1
  358. package/dist/esm-types/browser/sync/web_socket_manager.d.ts.map +1 -1
  359. package/dist/esm-types/cli/aiFiles.d.ts.map +1 -1
  360. package/dist/esm-types/cli/codegen_templates/readme.d.ts.map +1 -1
  361. package/dist/esm-types/cli/configure.d.ts.map +1 -1
  362. package/dist/esm-types/cli/configure.test.d.ts +2 -0
  363. package/dist/esm-types/cli/configure.test.d.ts.map +1 -0
  364. package/dist/esm-types/cli/deploy.d.ts.map +1 -1
  365. package/dist/esm-types/cli/deploymentCreate.d.ts +1 -0
  366. package/dist/esm-types/cli/deploymentCreate.d.ts.map +1 -1
  367. package/dist/esm-types/cli/deploymentSelect.d.ts +2 -1
  368. package/dist/esm-types/cli/deploymentSelect.d.ts.map +1 -1
  369. package/dist/esm-types/cli/dev.d.ts +3 -1
  370. package/dist/esm-types/cli/dev.d.ts.map +1 -1
  371. package/dist/esm-types/cli/lib/aiFiles/agentsmd.d.ts +19 -0
  372. package/dist/esm-types/cli/lib/aiFiles/agentsmd.d.ts.map +1 -0
  373. package/dist/esm-types/cli/lib/aiFiles/agentsmd.test.d.ts +2 -0
  374. package/dist/esm-types/cli/lib/aiFiles/agentsmd.test.d.ts.map +1 -0
  375. package/dist/esm-types/cli/lib/aiFiles/claudemd.d.ts +19 -0
  376. package/dist/esm-types/cli/lib/aiFiles/claudemd.d.ts.map +1 -0
  377. package/dist/esm-types/cli/lib/aiFiles/claudemd.test.d.ts +2 -0
  378. package/dist/esm-types/cli/lib/aiFiles/claudemd.test.d.ts.map +1 -0
  379. package/dist/esm-types/cli/lib/aiFiles/cursorrules.d.ts +10 -0
  380. package/dist/esm-types/cli/lib/aiFiles/cursorrules.d.ts.map +1 -0
  381. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.d.ts +12 -0
  382. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.d.ts.map +1 -0
  383. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.test.d.ts +2 -0
  384. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.test.d.ts.map +1 -0
  385. package/dist/esm-types/cli/lib/aiFiles/index.d.ts +42 -0
  386. package/dist/esm-types/cli/lib/aiFiles/index.d.ts.map +1 -0
  387. package/dist/esm-types/cli/lib/aiFiles/index.test.d.ts.map +1 -0
  388. package/dist/esm-types/cli/lib/aiFiles/integration.test.d.ts.map +1 -0
  389. package/dist/esm-types/cli/lib/{ai → aiFiles}/paths.d.ts +4 -0
  390. package/dist/esm-types/cli/lib/aiFiles/paths.d.ts.map +1 -0
  391. package/dist/esm-types/cli/lib/aiFiles/prompt.test.d.ts.map +1 -0
  392. package/dist/esm-types/cli/lib/aiFiles/skills.d.ts +20 -0
  393. package/dist/esm-types/cli/lib/aiFiles/skills.d.ts.map +1 -0
  394. package/dist/esm-types/cli/lib/aiFiles/state.d.ts +38 -0
  395. package/dist/esm-types/cli/lib/aiFiles/state.d.ts.map +1 -0
  396. package/dist/esm-types/cli/lib/aiFiles/state.test.d.ts +2 -0
  397. package/dist/esm-types/cli/lib/aiFiles/state.test.d.ts.map +1 -0
  398. package/dist/esm-types/cli/lib/aiFiles/status.d.ts +6 -0
  399. package/dist/esm-types/cli/lib/aiFiles/status.d.ts.map +1 -0
  400. package/dist/esm-types/cli/lib/aiFiles/utils.d.ts +56 -0
  401. package/dist/esm-types/cli/lib/aiFiles/utils.d.ts.map +1 -0
  402. package/dist/esm-types/cli/lib/aiFiles/utils.test.d.ts +2 -0
  403. package/dist/esm-types/cli/lib/aiFiles/utils.test.d.ts.map +1 -0
  404. package/dist/esm-types/cli/lib/api.d.ts +3 -3
  405. package/dist/esm-types/cli/lib/api.d.ts.map +1 -1
  406. package/dist/esm-types/cli/lib/command.d.ts +2 -1
  407. package/dist/esm-types/cli/lib/command.d.ts.map +1 -1
  408. package/dist/esm-types/cli/lib/config.d.ts +18 -6
  409. package/dist/esm-types/cli/lib/config.d.ts.map +1 -1
  410. package/dist/esm-types/cli/lib/deploy2.d.ts +5 -2
  411. package/dist/esm-types/cli/lib/deploy2.d.ts.map +1 -1
  412. package/dist/esm-types/cli/lib/deployApi/componentDefinition.d.ts +27 -12
  413. package/dist/esm-types/cli/lib/deployApi/componentDefinition.d.ts.map +1 -1
  414. package/dist/esm-types/cli/lib/deployApi/definitionConfig.d.ts +24 -24
  415. package/dist/esm-types/cli/lib/deployApi/modules.d.ts +14 -14
  416. package/dist/esm-types/cli/lib/deployApi/startPush.d.ts +61 -52
  417. package/dist/esm-types/cli/lib/deployApi/startPush.d.ts.map +1 -1
  418. package/dist/esm-types/cli/lib/deploymentSelection.d.ts.map +1 -1
  419. package/dist/esm-types/cli/lib/deploymentSelector.d.ts +2 -0
  420. package/dist/esm-types/cli/lib/deploymentSelector.d.ts.map +1 -1
  421. package/dist/esm-types/cli/lib/dev.d.ts.map +1 -1
  422. package/dist/esm-types/cli/lib/env.d.ts +0 -4
  423. package/dist/esm-types/cli/lib/env.d.ts.map +1 -1
  424. package/dist/esm-types/cli/lib/expiration.d.ts +35 -0
  425. package/dist/esm-types/cli/lib/expiration.d.ts.map +1 -0
  426. package/dist/esm-types/cli/lib/expiration.test.d.ts +2 -0
  427. package/dist/esm-types/cli/lib/expiration.test.d.ts.map +1 -0
  428. package/dist/esm-types/cli/lib/generatedFunctionLogsApi.d.ts +16 -1
  429. package/dist/esm-types/cli/lib/generatedFunctionLogsApi.d.ts.map +1 -1
  430. package/dist/esm-types/cli/lib/init.d.ts.map +1 -1
  431. package/dist/esm-types/cli/lib/localDeployment/anonymous.d.ts.map +1 -1
  432. package/dist/esm-types/cli/lib/localDeployment/localDeployment.d.ts.map +1 -1
  433. package/dist/esm-types/cli/lib/localDeployment/run.d.ts +15 -0
  434. package/dist/esm-types/cli/lib/localDeployment/run.d.ts.map +1 -1
  435. package/dist/esm-types/cli/lib/localDeployment/upgrade.d.ts.map +1 -1
  436. package/dist/esm-types/cli/lib/localDeployment/utils.d.ts +7 -0
  437. package/dist/esm-types/cli/lib/localDeployment/utils.d.ts.map +1 -1
  438. package/dist/esm-types/cli/lib/mcp/requestContext.d.ts +3 -3
  439. package/dist/esm-types/cli/lib/mcp/tools/insights.d.ts +2 -2
  440. package/dist/esm-types/cli/lib/updates.d.ts +4 -3
  441. package/dist/esm-types/cli/lib/updates.d.ts.map +1 -1
  442. package/dist/esm-types/cli/lib/usage.d.ts.map +1 -1
  443. package/dist/esm-types/cli/lib/utils/prompts.d.ts +1 -0
  444. package/dist/esm-types/cli/lib/utils/prompts.d.ts.map +1 -1
  445. package/dist/esm-types/cli/lib/utils/utils.d.ts +16 -2
  446. package/dist/esm-types/cli/lib/utils/utils.d.ts.map +1 -1
  447. package/dist/esm-types/cli/lib/versionApi.d.ts +7 -1
  448. package/dist/esm-types/cli/lib/versionApi.d.ts.map +1 -1
  449. package/dist/esm-types/cli/lib/workos/workos.d.ts.map +1 -1
  450. package/dist/esm-types/index.d.ts +1 -1
  451. package/dist/esm-types/react/client.d.ts +54 -2
  452. package/dist/esm-types/react/client.d.ts.map +1 -1
  453. package/dist/esm-types/react/index.d.ts +7 -2
  454. package/dist/esm-types/react/index.d.ts.map +1 -1
  455. package/dist/esm-types/react/use_query_object_options.test.d.ts +5 -0
  456. package/dist/esm-types/react/use_query_object_options.test.d.ts.map +1 -0
  457. package/dist/esm-types/react/use_query_result.test.d.ts +5 -0
  458. package/dist/esm-types/react/use_query_result.test.d.ts.map +1 -0
  459. package/dist/esm-types/react-clerk/ConvexProviderWithClerk.d.ts +1 -1
  460. package/dist/esm-types/server/api.d.ts +5 -1
  461. package/dist/esm-types/server/api.d.ts.map +1 -1
  462. package/dist/esm-types/server/components/definition.d.ts +1 -0
  463. package/dist/esm-types/server/components/definition.d.ts.map +1 -1
  464. package/dist/esm-types/server/components/index.d.ts +5 -1
  465. package/dist/esm-types/server/components/index.d.ts.map +1 -1
  466. package/dist/esm-types/server/data_model.d.ts +2 -1
  467. package/dist/esm-types/server/data_model.d.ts.map +1 -1
  468. package/dist/esm-types/server/impl/meta_impl.d.ts +5 -0
  469. package/dist/esm-types/server/impl/meta_impl.d.ts.map +1 -0
  470. package/dist/esm-types/server/impl/registration_impl.d.ts.map +1 -1
  471. package/dist/esm-types/server/index.d.ts +1 -0
  472. package/dist/esm-types/server/index.d.ts.map +1 -1
  473. package/dist/esm-types/server/meta.d.ts +72 -0
  474. package/dist/esm-types/server/meta.d.ts.map +1 -0
  475. package/dist/esm-types/server/registration.d.ts.map +1 -1
  476. package/dist/react.bundle.js +55 -15
  477. package/dist/react.bundle.js.map +3 -3
  478. package/package.json +11 -7
  479. package/schemas/convex.schema.json +22 -3
  480. package/src/browser/index.ts +3 -0
  481. package/src/browser/query_options.test.ts +0 -9
  482. package/src/browser/query_options.ts +36 -15
  483. package/src/browser/sync/authentication_manager.ts +9 -4
  484. package/src/browser/sync/client_node.test.ts +125 -0
  485. package/src/browser/sync/web_socket_manager.ts +1 -7
  486. package/src/cli/aiFiles.ts +56 -33
  487. package/src/cli/codegen_templates/readme.ts +14 -1
  488. package/src/cli/configure.test.ts +138 -0
  489. package/src/cli/configure.ts +62 -55
  490. package/src/cli/deploy.ts +12 -9
  491. package/src/cli/deploymentCreate.test.ts +349 -14
  492. package/src/cli/deploymentCreate.ts +268 -41
  493. package/src/cli/deploymentSelect.test.ts +136 -27
  494. package/src/cli/deploymentSelect.ts +50 -41
  495. package/src/cli/deploymentSelection.test.ts +399 -37
  496. package/src/cli/dev.ts +49 -14
  497. package/src/cli/docs.ts +1 -1
  498. package/src/cli/init.ts +2 -2
  499. package/src/cli/lib/{ai → aiFiles}/MANUAL_TESTING.md +6 -2
  500. package/src/cli/lib/aiFiles/agentsmd.test.ts +133 -0
  501. package/src/cli/lib/aiFiles/agentsmd.ts +81 -0
  502. package/src/cli/lib/aiFiles/claudemd.test.ts +92 -0
  503. package/src/cli/lib/aiFiles/claudemd.ts +81 -0
  504. package/src/cli/lib/aiFiles/cursorrules.ts +25 -0
  505. package/src/cli/lib/aiFiles/guidelinesmd.test.ts +50 -0
  506. package/src/cli/lib/aiFiles/guidelinesmd.ts +49 -0
  507. package/src/cli/lib/{ai → aiFiles}/index.test.ts +343 -516
  508. package/src/cli/lib/aiFiles/index.ts +297 -0
  509. package/src/cli/lib/{ai → aiFiles}/integration.test.ts +195 -158
  510. package/src/cli/lib/{ai → aiFiles}/paths.ts +5 -0
  511. package/src/cli/lib/{ai → aiFiles}/prompt.test.ts +79 -31
  512. package/src/cli/lib/aiFiles/skills.ts +243 -0
  513. package/src/cli/lib/aiFiles/state.test.ts +280 -0
  514. package/src/cli/lib/aiFiles/state.ts +82 -0
  515. package/src/cli/lib/aiFiles/status.ts +246 -0
  516. package/src/cli/lib/aiFiles/utils.test.ts +50 -0
  517. package/src/cli/lib/aiFiles/utils.ts +191 -0
  518. package/src/cli/lib/api.ts +88 -7
  519. package/src/cli/lib/command.ts +18 -8
  520. package/src/cli/lib/config.test.ts +185 -8
  521. package/src/cli/lib/config.ts +73 -12
  522. package/src/cli/lib/deploy2.ts +14 -27
  523. package/src/cli/lib/deployApi/componentDefinition.ts +4 -1
  524. package/src/cli/lib/deploymentSelection.ts +59 -6
  525. package/src/cli/lib/deploymentSelector.test.ts +6 -0
  526. package/src/cli/lib/deploymentSelector.ts +2 -0
  527. package/src/cli/lib/dev.ts +202 -153
  528. package/src/cli/lib/env.ts +0 -15
  529. package/src/cli/lib/expiration.test.ts +159 -0
  530. package/src/cli/lib/expiration.ts +124 -0
  531. package/src/cli/lib/generatedFunctionLogsApi.ts +16 -1
  532. package/src/cli/lib/init.ts +6 -2
  533. package/src/cli/lib/insights.ts +1 -1
  534. package/src/cli/lib/localDeployment/anonymous.ts +19 -9
  535. package/src/cli/lib/localDeployment/localDeployment.ts +9 -11
  536. package/src/cli/lib/localDeployment/run.ts +1 -1
  537. package/src/cli/lib/localDeployment/upgrade.ts +12 -10
  538. package/src/cli/lib/localDeployment/utils.ts +12 -0
  539. package/src/cli/lib/mcp/tools/status.ts +1 -1
  540. package/src/cli/lib/updates.test.ts +97 -60
  541. package/src/cli/lib/updates.ts +17 -15
  542. package/src/cli/lib/usage.ts +3 -1
  543. package/src/cli/lib/utils/prompts.ts +2 -0
  544. package/src/cli/lib/utils/utils.test.ts +6 -6
  545. package/src/cli/lib/utils/utils.ts +66 -27
  546. package/src/cli/lib/versionApi.test.ts +13 -10
  547. package/src/cli/lib/versionApi.ts +13 -5
  548. package/src/cli/lib/workos/workos.ts +4 -5
  549. package/src/index.ts +1 -1
  550. package/src/react/client.test.tsx +65 -0
  551. package/src/react/client.ts +129 -13
  552. package/src/react/index.ts +9 -1
  553. package/src/react/use_query_object_options.test.ts +50 -0
  554. package/src/react/use_query_result.test.ts +41 -0
  555. package/src/react-clerk/ConvexProviderWithClerk.test.tsx +1 -1
  556. package/src/react-clerk/ConvexProviderWithClerk.tsx +1 -1
  557. package/src/server/api.ts +5 -1
  558. package/src/server/components/definition.ts +3 -0
  559. package/src/server/components/index.ts +62 -5
  560. package/src/server/data_model.ts +2 -1
  561. package/src/server/impl/meta_impl.ts +74 -0
  562. package/src/server/impl/registration_impl.ts +21 -9
  563. package/src/server/index.ts +8 -0
  564. package/src/server/meta.ts +76 -0
  565. package/src/server/registration.ts +10 -0
  566. package/src/server/schema.test.ts +78 -1
  567. package/dist/cjs/cli/lib/ai/config.js +0 -144
  568. package/dist/cjs/cli/lib/ai/config.js.map +0 -7
  569. package/dist/cjs/cli/lib/ai/index.js +0 -704
  570. package/dist/cjs/cli/lib/ai/index.js.map +0 -7
  571. package/dist/cjs/cli/lib/ai/paths.js.map +0 -7
  572. package/dist/cjs-types/cli/lib/ai/config.d.ts +0 -50
  573. package/dist/cjs-types/cli/lib/ai/config.d.ts.map +0 -1
  574. package/dist/cjs-types/cli/lib/ai/config.test.d.ts +0 -2
  575. package/dist/cjs-types/cli/lib/ai/config.test.d.ts.map +0 -1
  576. package/dist/cjs-types/cli/lib/ai/index.d.ts +0 -56
  577. package/dist/cjs-types/cli/lib/ai/index.d.ts.map +0 -1
  578. package/dist/cjs-types/cli/lib/ai/index.test.d.ts.map +0 -1
  579. package/dist/cjs-types/cli/lib/ai/integration.test.d.ts.map +0 -1
  580. package/dist/cjs-types/cli/lib/ai/paths.d.ts.map +0 -1
  581. package/dist/cjs-types/cli/lib/ai/prompt.test.d.ts.map +0 -1
  582. package/dist/esm/cli/lib/ai/config.js +0 -109
  583. package/dist/esm/cli/lib/ai/config.js.map +0 -7
  584. package/dist/esm/cli/lib/ai/index.js +0 -684
  585. package/dist/esm/cli/lib/ai/index.js.map +0 -7
  586. package/dist/esm/cli/lib/ai/paths.js.map +0 -7
  587. package/dist/esm-types/cli/lib/ai/config.d.ts +0 -50
  588. package/dist/esm-types/cli/lib/ai/config.d.ts.map +0 -1
  589. package/dist/esm-types/cli/lib/ai/config.test.d.ts +0 -2
  590. package/dist/esm-types/cli/lib/ai/config.test.d.ts.map +0 -1
  591. package/dist/esm-types/cli/lib/ai/index.d.ts +0 -56
  592. package/dist/esm-types/cli/lib/ai/index.d.ts.map +0 -1
  593. package/dist/esm-types/cli/lib/ai/index.test.d.ts.map +0 -1
  594. package/dist/esm-types/cli/lib/ai/integration.test.d.ts.map +0 -1
  595. package/dist/esm-types/cli/lib/ai/paths.d.ts.map +0 -1
  596. package/dist/esm-types/cli/lib/ai/prompt.test.d.ts.map +0 -1
  597. package/src/cli/lib/ai/config.test.ts +0 -338
  598. package/src/cli/lib/ai/config.ts +0 -159
  599. package/src/cli/lib/ai/index.ts +0 -1006
  600. /package/dist/cjs/cli/lib/{ai → aiFiles}/paths.js +0 -0
  601. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/index.test.d.ts +0 -0
  602. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/integration.test.d.ts +0 -0
  603. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/prompt.test.d.ts +0 -0
  604. /package/dist/esm/cli/lib/{ai → aiFiles}/paths.js +0 -0
  605. /package/dist/esm-types/cli/lib/{ai → aiFiles}/index.test.d.ts +0 -0
  606. /package/dist/esm-types/cli/lib/{ai → aiFiles}/integration.test.d.ts +0 -0
  607. /package/dist/esm-types/cli/lib/{ai → aiFiles}/prompt.test.d.ts +0 -0
@@ -18,6 +18,8 @@ import {
18
18
  handleLocalDeployment,
19
19
  loadLocalDeploymentCredentials,
20
20
  } from "./lib/localDeployment/localDeployment.js";
21
+ import { handleAnonymousDeployment } from "./lib/localDeployment/anonymous.js";
22
+ import { loadProjectLocalConfig } from "./lib/localDeployment/filePaths.js";
21
23
  import {
22
24
  validateOrSelectTeam,
23
25
  validateOrSelectProject,
@@ -67,7 +69,7 @@ vi.mock("./lib/localDeployment/run.js", async (importOriginal) => {
67
69
  await action();
68
70
  },
69
71
  ),
70
- assertLocalBackendRunning: vi.fn(),
72
+ fetchLocalBackendStatus: vi.fn().mockResolvedValue({ kind: "running" }),
71
73
  };
72
74
  });
73
75
 
@@ -135,7 +137,7 @@ vi.mock("./lib/updates.js", async (importOriginal) => {
135
137
  const actual = await importOriginal<typeof import("./lib/updates.js")>();
136
138
  return {
137
139
  ...actual,
138
- checkVersion: vi.fn(),
140
+ checkVersionAndAiFilesStaleness: vi.fn(),
139
141
  };
140
142
  });
141
143
 
@@ -156,14 +158,33 @@ vi.mock("./lib/localDeployment/localDeployment.js", async (importOriginal) => {
156
158
  };
157
159
  });
158
160
 
161
+ vi.mock("./lib/localDeployment/filePaths.js", async (importOriginal) => {
162
+ const actual =
163
+ await importOriginal<typeof import("./lib/localDeployment/filePaths.js")>();
164
+ return {
165
+ ...actual,
166
+ loadProjectLocalConfig: vi.fn().mockReturnValue(null),
167
+ };
168
+ });
169
+
170
+ vi.mock("./lib/localDeployment/anonymous.js", async (importOriginal) => {
171
+ const actual =
172
+ await importOriginal<typeof import("./lib/localDeployment/anonymous.js")>();
173
+ return {
174
+ ...actual,
175
+ handleAnonymousDeployment: vi.fn(),
176
+ };
177
+ });
178
+
159
179
  vi.mock("./lib/login.js", async (importOriginal) => {
160
180
  const actual = await importOriginal<typeof import("./lib/login.js")>();
161
181
  return { ...actual, ensureLoggedIn: vi.fn() };
162
182
  });
163
183
 
164
- vi.mock("./lib/ai/index.js", async (importOriginal) => {
165
- const actual = await importOriginal<typeof import("./lib/ai/index.js")>();
166
- return { ...actual, maybeSetupAiFiles: vi.fn() };
184
+ vi.mock("./lib/aiFiles/index.js", async (importOriginal) => {
185
+ const actual =
186
+ await importOriginal<typeof import("./lib/aiFiles/index.js")>();
187
+ return { ...actual, attemptSetupAiFiles: vi.fn() };
167
188
  });
168
189
 
169
190
  vi.mock("./configure.js", async (importOriginal) => {
@@ -226,10 +247,14 @@ function setupBigBrainRoutes(routes: Record<string, (data?: any) => any>) {
226
247
 
227
248
  describe("deployment selection flows", () => {
228
249
  let savedEnv: NodeJS.ProcessEnv;
250
+ let savedIsTTY: boolean | undefined;
229
251
 
230
252
  beforeEach(() => {
231
253
  savedEnv = { ...process.env };
254
+ savedIsTTY = process.stdin.isTTY;
232
255
  process.env = {};
256
+ // Default to interactive TTY for existing tests
257
+ process.stdin.isTTY = true as any;
233
258
 
234
259
  vi.resetAllMocks();
235
260
  vi.mocked(readGlobalConfig).mockReturnValue(null);
@@ -260,10 +285,17 @@ describe("deployment selection flows", () => {
260
285
  new Error("validateOrSelectProject should be mocked"),
261
286
  );
262
287
  vi.mocked(ensureLoggedIn).mockResolvedValue(undefined);
288
+ vi.mocked(handleAnonymousDeployment).mockResolvedValue({
289
+ deploymentName: "anon-test",
290
+ deploymentUrl: "http://127.0.0.1:3210",
291
+ adminKey: "anon|admin|key",
292
+ onActivity: async () => {},
293
+ });
263
294
  });
264
295
 
265
296
  afterEach(() => {
266
297
  process.env = savedEnv;
298
+ process.stdin.isTTY = savedIsTTY as any;
267
299
  });
268
300
 
269
301
  // Suppress process.exit and stderr
@@ -474,7 +506,7 @@ describe("deployment selection flows", () => {
474
506
  expect(bigBrainAPIMaybeThrows).not.toHaveBeenCalled();
475
507
  });
476
508
 
477
- it("resolves CONVEX_DEPLOYMENT to dev deployment by default", async () => {
509
+ it("resolves CONVEX_DEPLOYMENT to CONVEX_DEPLOYMENT by default", async () => {
478
510
  process.env.CONVEX_DEPLOYMENT = "dev:joyful-capybara-123";
479
511
  vi.mocked(readGlobalConfig).mockReturnValue({
480
512
  accessToken: "test-token",
@@ -487,10 +519,11 @@ describe("deployment selection flows", () => {
487
519
  teamId: 1,
488
520
  projectId: 1,
489
521
  }),
490
- "deployment/provision_and_authorize": () => ({
522
+ "deployment/authorize_within_current_project": () => ({
491
523
  adminKey: "dev-key",
492
- url: "https://swift-squirrel-234.convex.cloud",
493
- deploymentName: "swift-squirrel-234",
524
+ url: "https://joyful-capybara-123.convex.cloud",
525
+ deploymentName: "joyful-capybara-123",
526
+ deploymentType: "dev",
494
527
  }),
495
528
  });
496
529
 
@@ -502,7 +535,7 @@ describe("deployment selection flows", () => {
502
535
  expect(deploymentFetch).toHaveBeenCalledWith(
503
536
  expect.anything(),
504
537
  expect.objectContaining({
505
- deploymentUrl: "https://swift-squirrel-234.convex.cloud",
538
+ deploymentUrl: "https://joyful-capybara-123.convex.cloud",
506
539
  adminKey: "dev-key",
507
540
  }),
508
541
  );
@@ -515,11 +548,16 @@ describe("deployment selection flows", () => {
515
548
  }),
516
549
  );
517
550
 
518
- // checkAccessToSelectedProject calls getTeamAndProjectSlugForDeployment
519
- expect(bigBrainAPIMaybeThrows).toHaveBeenCalledWith(
551
+ expect(bigBrainAPI).toHaveBeenCalledWith(
520
552
  expect.objectContaining({
521
- path: "deployment/joyful-capybara-123/team_and_project",
522
- method: "GET",
553
+ path: "deployment/authorize_within_current_project",
554
+ data: expect.objectContaining({
555
+ selectedDeploymentName: "joyful-capybara-123",
556
+ projectSelection: expect.objectContaining({
557
+ kind: "deploymentName",
558
+ deploymentName: "joyful-capybara-123",
559
+ }),
560
+ }),
523
561
  }),
524
562
  );
525
563
  });
@@ -890,12 +928,18 @@ describe("deployment selection flows", () => {
890
928
  teamId: 1,
891
929
  projectId: 1,
892
930
  }),
893
- "deployment/provision_and_authorize": () => ({
931
+ "teams/my-team/projects/my-project/deployments": () => true,
932
+ "deployment/authorize_within_current_project": () => ({
894
933
  adminKey: "dev-key",
895
934
  url: "https://joyful-capybara-123.convex.cloud",
896
935
  deploymentName: "joyful-capybara-123",
936
+ deploymentType: "dev",
897
937
  }),
898
938
  });
939
+ mockPlatformGet.mockResolvedValue({
940
+ data: { name: "joyful-capybara-123" },
941
+ error: undefined,
942
+ });
899
943
 
900
944
  const mockFetch = vi.fn().mockResolvedValue({ ok: true });
901
945
  vi.mocked(deploymentFetch).mockReturnValue(mockFetch as any);
@@ -904,10 +948,24 @@ describe("deployment selection flows", () => {
904
948
  from: "user",
905
949
  });
906
950
 
907
- expect(bigBrainAPIMaybeThrows).toHaveBeenCalledWith(
951
+ expect(mockPlatformGet).toHaveBeenCalledWith(
952
+ "/teams/{team_id_or_slug}/projects/{project_slug}/deployment",
908
953
  expect.objectContaining({
909
- path: "deployment/provision_and_authorize",
910
- data: expect.objectContaining({ deploymentType: "dev" }),
954
+ params: expect.objectContaining({
955
+ path: {
956
+ team_id_or_slug: "my-team",
957
+ project_slug: "my-project",
958
+ },
959
+ query: { defaultDev: true },
960
+ }),
961
+ }),
962
+ );
963
+ expect(bigBrainAPI).toHaveBeenCalledWith(
964
+ expect.objectContaining({
965
+ path: "deployment/authorize_within_current_project",
966
+ data: expect.objectContaining({
967
+ selectedDeploymentName: "joyful-capybara-123",
968
+ }),
911
969
  }),
912
970
  );
913
971
  });
@@ -1149,12 +1207,18 @@ describe("deployment selection flows", () => {
1149
1207
  teamId: 1,
1150
1208
  projectId: 1,
1151
1209
  }),
1152
- "deployment/provision_and_authorize": () => ({
1210
+ "teams/my-team/projects/other-project/deployments": () => true,
1211
+ "deployment/authorize_within_current_project": () => ({
1153
1212
  adminKey: "other-project-dev-key",
1154
1213
  url: "https://other-project-dev.convex.cloud",
1155
1214
  deploymentName: "other-project-dev",
1215
+ deploymentType: "dev",
1156
1216
  }),
1157
1217
  });
1218
+ mockPlatformGet.mockResolvedValue({
1219
+ data: { name: "other-project-dev" },
1220
+ error: undefined,
1221
+ });
1158
1222
 
1159
1223
  const mockFetch = vi.fn().mockResolvedValue({ ok: true });
1160
1224
  vi.mocked(deploymentFetch).mockReturnValue(mockFetch as any);
@@ -1164,13 +1228,23 @@ describe("deployment selection flows", () => {
1164
1228
  { from: "user" },
1165
1229
  );
1166
1230
 
1167
- expect(bigBrainAPIMaybeThrows).toHaveBeenCalledWith(
1231
+ expect(mockPlatformGet).toHaveBeenCalledWith(
1232
+ "/teams/{team_id_or_slug}/projects/{project_slug}/deployment",
1168
1233
  expect.objectContaining({
1169
- path: "deployment/provision_and_authorize",
1234
+ params: expect.objectContaining({
1235
+ path: {
1236
+ team_id_or_slug: "my-team",
1237
+ project_slug: "other-project",
1238
+ },
1239
+ query: { defaultDev: true },
1240
+ }),
1241
+ }),
1242
+ );
1243
+ expect(bigBrainAPI).toHaveBeenCalledWith(
1244
+ expect.objectContaining({
1245
+ path: "deployment/authorize_within_current_project",
1170
1246
  data: expect.objectContaining({
1171
- teamSlug: "my-team",
1172
- projectSlug: "other-project",
1173
- deploymentType: "dev",
1247
+ selectedDeploymentName: "other-project-dev",
1174
1248
  }),
1175
1249
  }),
1176
1250
  );
@@ -1265,12 +1339,17 @@ describe("deployment selection flows", () => {
1265
1339
  it("resolves --deployment team:project:dev to dev deployment in fully qualified team/project", async () => {
1266
1340
  setupBigBrainRoutes({
1267
1341
  "teams/myteam/projects/myproject/deployments": () => true,
1268
- "deployment/provision_and_authorize": () => ({
1342
+ "deployment/authorize_within_current_project": () => ({
1269
1343
  adminKey: "fq-dev-key",
1270
1344
  url: "https://fq-dev-deploy.convex.cloud",
1271
1345
  deploymentName: "fq-dev-deploy",
1346
+ deploymentType: "dev",
1272
1347
  }),
1273
1348
  });
1349
+ mockPlatformGet.mockResolvedValue({
1350
+ data: { name: "fq-dev-deploy" },
1351
+ error: undefined,
1352
+ });
1274
1353
 
1275
1354
  const mockFetch = vi.fn().mockResolvedValue({ ok: true });
1276
1355
  vi.mocked(deploymentFetch).mockReturnValue(mockFetch as any);
@@ -1280,13 +1359,23 @@ describe("deployment selection flows", () => {
1280
1359
  { from: "user" },
1281
1360
  );
1282
1361
 
1283
- expect(bigBrainAPIMaybeThrows).toHaveBeenCalledWith(
1362
+ expect(mockPlatformGet).toHaveBeenCalledWith(
1363
+ "/teams/{team_id_or_slug}/projects/{project_slug}/deployment",
1284
1364
  expect.objectContaining({
1285
- path: "deployment/provision_and_authorize",
1365
+ params: expect.objectContaining({
1366
+ path: {
1367
+ team_id_or_slug: "myteam",
1368
+ project_slug: "myproject",
1369
+ },
1370
+ query: { defaultDev: true },
1371
+ }),
1372
+ }),
1373
+ );
1374
+ expect(bigBrainAPI).toHaveBeenCalledWith(
1375
+ expect.objectContaining({
1376
+ path: "deployment/authorize_within_current_project",
1286
1377
  data: expect.objectContaining({
1287
- teamSlug: "myteam",
1288
- projectSlug: "myproject",
1289
- deploymentType: "dev",
1378
+ selectedDeploymentName: "fq-dev-deploy",
1290
1379
  }),
1291
1380
  }),
1292
1381
  );
@@ -1331,6 +1420,109 @@ describe("deployment selection flows", () => {
1331
1420
  ),
1332
1421
  ).rejects.toThrow();
1333
1422
  });
1423
+
1424
+ it("resolves --deployment local to local deployment credentials", async () => {
1425
+ vi.mocked(loadProjectLocalConfig).mockReturnValue({
1426
+ deploymentName: "local-my_team-my_project-abc",
1427
+ config: {
1428
+ ports: { cloud: 3210, site: 3211 },
1429
+ adminKey: "local-key",
1430
+ backendVersion: "1.0.0",
1431
+ },
1432
+ });
1433
+ vi.mocked(loadLocalDeploymentCredentials).mockResolvedValue({
1434
+ deploymentName: "local-my_team-my_project-abc",
1435
+ deploymentUrl: "http://127.0.0.1:3210",
1436
+ adminKey: "local-key",
1437
+ });
1438
+ // The local deployment name is resolved via Big Brain for project
1439
+ // access checks (checkAccessToSelectedProject)
1440
+ setupBigBrainRoutes({
1441
+ "deployment/local-my_team-my_project-abc/team_and_project": () => ({
1442
+ team: "my-team",
1443
+ project: "my-project",
1444
+ teamId: 1,
1445
+ projectId: 1,
1446
+ }),
1447
+ });
1448
+
1449
+ const mockFetch = vi.fn().mockResolvedValue({ ok: true });
1450
+ vi.mocked(deploymentFetch).mockReturnValue(mockFetch as any);
1451
+
1452
+ await env.parseAsync(["set", "ABC", "DEF", "--deployment", "local"], {
1453
+ from: "user",
1454
+ });
1455
+
1456
+ expect(loadLocalDeploymentCredentials).toHaveBeenCalledWith(
1457
+ expect.anything(),
1458
+ "local-my_team-my_project-abc",
1459
+ );
1460
+ expect(deploymentFetch).toHaveBeenCalledWith(
1461
+ expect.anything(),
1462
+ expect.objectContaining({
1463
+ deploymentUrl: "http://127.0.0.1:3210",
1464
+ adminKey: "local-key",
1465
+ }),
1466
+ );
1467
+ });
1468
+
1469
+ it("resolves --deployment local without CONVEX_DEPLOYMENT set", async () => {
1470
+ delete process.env.CONVEX_DEPLOYMENT;
1471
+
1472
+ vi.mocked(loadProjectLocalConfig).mockReturnValue({
1473
+ deploymentName: "local-my_team-my_project-abc",
1474
+ config: {
1475
+ ports: { cloud: 3210, site: 3211 },
1476
+ adminKey: "local-key",
1477
+ backendVersion: "1.0.0",
1478
+ },
1479
+ });
1480
+ vi.mocked(loadLocalDeploymentCredentials).mockResolvedValue({
1481
+ deploymentName: "local-my_team-my_project-abc",
1482
+ deploymentUrl: "http://127.0.0.1:3210",
1483
+ adminKey: "local-key",
1484
+ });
1485
+ setupBigBrainRoutes({
1486
+ "deployment/local-my_team-my_project-abc/team_and_project": () => ({
1487
+ team: "my-team",
1488
+ project: "my-project",
1489
+ teamId: 1,
1490
+ projectId: 1,
1491
+ }),
1492
+ });
1493
+
1494
+ const mockFetch = vi.fn().mockResolvedValue({ ok: true });
1495
+ vi.mocked(deploymentFetch).mockReturnValue(mockFetch as any);
1496
+
1497
+ await env.parseAsync(["set", "ABC", "DEF", "--deployment", "local"], {
1498
+ from: "user",
1499
+ });
1500
+
1501
+ expect(deploymentFetch).toHaveBeenCalledWith(
1502
+ expect.anything(),
1503
+ expect.objectContaining({
1504
+ deploymentUrl: "http://127.0.0.1:3210",
1505
+ adminKey: "local-key",
1506
+ }),
1507
+ );
1508
+ });
1509
+
1510
+ it("errors when --deployment local but no local deployment exists", async () => {
1511
+ vi.mocked(loadProjectLocalConfig).mockReturnValue(null);
1512
+
1513
+ await expect(
1514
+ env.parseAsync(["set", "ABC", "DEF", "--deployment", "local"], {
1515
+ from: "user",
1516
+ }),
1517
+ ).rejects.toThrow();
1518
+
1519
+ expect(process.stderr.write).toHaveBeenCalledWith(
1520
+ expect.stringContaining("No local deployment found"),
1521
+ );
1522
+ expect(process.stderr.write).toHaveBeenCalledWith(
1523
+ expect.stringContaining("npx convex deployment create local"),
1524
+ );
1525
+ });
1334
1526
  });
1335
1527
  });
1336
1528
 
@@ -1555,6 +1747,59 @@ describe("deployment selection flows", () => {
1555
1747
  expect(bigBrainAPIMaybeThrows).not.toHaveBeenCalled();
1556
1748
  });
1557
1749
 
1750
+ it("dev with CONVEX_DEPLOYMENT=local:... uses fresh credentials from handleLocalDeployment", async () => {
1751
+ process.env.CONVEX_DEPLOYMENT = "local:my-local-deployment";
1752
+ vi.mocked(readGlobalConfig).mockReturnValue({
1753
+ accessToken: "test-token",
1754
+ });
1755
+
1756
+ // loadLocalDeploymentCredentials returns stale saved config (e.g. from a
1757
+ // previous run on a different port).
1758
+ vi.mocked(loadLocalDeploymentCredentials).mockResolvedValue({
1759
+ deploymentName: "my-local-deployment",
1760
+ deploymentUrl: "http://127.0.0.1:3212",
1761
+ adminKey: "stale|admin|key",
1762
+ });
1763
+
1764
+ // handleLocalDeployment starts a new backend, potentially on different
1765
+ // ports, and returns the actual credentials.
1766
+ vi.mocked(handleLocalDeployment).mockResolvedValue({
1767
+ deploymentName: "my-local-deployment",
1768
+ deploymentUrl: "http://127.0.0.1:3210",
1769
+ adminKey: "fresh|admin|key",
1770
+ onActivity: async () => {},
1771
+ } as any);
1772
+
1773
+ setupBigBrainRoutes({
1774
+ "deployment/my-local-deployment/team_and_project": () => ({
1775
+ team: "my-team",
1776
+ project: "my-project",
1777
+ teamId: 1,
1778
+ projectId: 1,
1779
+ }),
1780
+ });
1781
+
1782
+ await dev.parseAsync([], { from: "user" });
1783
+
1784
+ expect(handleLocalDeployment).toHaveBeenCalledWith(
1785
+ expect.anything(),
1786
+ expect.objectContaining({
1787
+ teamSlug: "my-team",
1788
+ projectSlug: "my-project",
1789
+ }),
1790
+ );
1791
+ // Must use the fresh credentials from handleLocalDeployment, not the
1792
+ // stale ones from loadLocalDeploymentCredentials.
1793
+ expect(devAgainstDeployment).toHaveBeenCalledWith(
1794
+ expect.anything(),
1795
+ expect.objectContaining({
1796
+ url: "http://127.0.0.1:3210",
1797
+ adminKey: "fresh|admin|key",
1798
+ }),
1799
+ expect.anything(),
1800
+ );
1801
+ });
1802
+
1558
1803
  it("dev --local crashes when local deployments are globally disabled", async () => {
1559
1804
  vi.mocked(readGlobalConfig).mockReturnValue({
1560
1805
  accessToken: "test-token",
@@ -1573,7 +1818,7 @@ describe("deployment selection flows", () => {
1573
1818
  expect(devAgainstDeployment).not.toHaveBeenCalled();
1574
1819
  });
1575
1820
 
1576
- it("defaults to dev deployment with CONVEX_DEPLOYMENT", async () => {
1821
+ it("resolves CONVEX_DEPLOYMENT to the configured deployment", async () => {
1577
1822
  process.env.CONVEX_DEPLOYMENT = "dev:joyful-capybara-123";
1578
1823
  vi.mocked(readGlobalConfig).mockReturnValue({
1579
1824
  accessToken: "test-token",
@@ -1586,7 +1831,7 @@ describe("deployment selection flows", () => {
1586
1831
  teamId: 1,
1587
1832
  projectId: 1,
1588
1833
  }),
1589
- "deployment/provision_and_authorize": () => ({
1834
+ "deployment/authorize_within_current_project": () => ({
1590
1835
  adminKey: "dev-key",
1591
1836
  url: "https://joyful-capybara-123.convex.cloud",
1592
1837
  deploymentName: "joyful-capybara-123",
@@ -1596,10 +1841,12 @@ describe("deployment selection flows", () => {
1596
1841
 
1597
1842
  await dev.parseAsync([], { from: "user" });
1598
1843
 
1599
- expect(bigBrainAPIMaybeThrows).toHaveBeenCalledWith(
1844
+ expect(bigBrainAPI).toHaveBeenCalledWith(
1600
1845
  expect.objectContaining({
1601
- path: "deployment/provision_and_authorize",
1602
- data: expect.objectContaining({ deploymentType: "dev" }),
1846
+ path: "deployment/authorize_within_current_project",
1847
+ data: expect.objectContaining({
1848
+ selectedDeploymentName: "joyful-capybara-123",
1849
+ }),
1603
1850
  }),
1604
1851
  );
1605
1852
  expect(devAgainstDeployment).toHaveBeenCalledWith(
@@ -1660,7 +1907,7 @@ describe("deployment selection flows", () => {
1660
1907
  expect(bigBrainAPIMaybeThrows).not.toHaveBeenCalled();
1661
1908
  });
1662
1909
 
1663
- it("uses --cloud flag with CONVEX_DEPLOYMENT to force cloud dev deployment", async () => {
1910
+ it("resolves CONVEX_DEPLOYMENT with --cloud to the configured deployment", async () => {
1664
1911
  process.env.CONVEX_DEPLOYMENT = "dev:joyful-capybara-123";
1665
1912
  vi.mocked(readGlobalConfig).mockReturnValue({
1666
1913
  accessToken: "test-token",
@@ -1673,7 +1920,7 @@ describe("deployment selection flows", () => {
1673
1920
  teamId: 1,
1674
1921
  projectId: 1,
1675
1922
  }),
1676
- "deployment/provision_and_authorize": () => ({
1923
+ "deployment/authorize_within_current_project": () => ({
1677
1924
  adminKey: "cloud-dev-key",
1678
1925
  url: "https://joyful-capybara-123.convex.cloud",
1679
1926
  deploymentName: "joyful-capybara-123",
@@ -1692,5 +1939,120 @@ describe("deployment selection flows", () => {
1692
1939
  expect.anything(),
1693
1940
  );
1694
1941
  });
1942
+
1943
+ describe("non-interactive terminal", () => {
1944
+ beforeEach(() => {
1945
+ process.stdin.isTTY = false as any;
1946
+ });
1947
+
1948
+ it("non-interactive, not logged in, no config → uses anonymous deployment", async () => {
1949
+ await dev.parseAsync(["--once"], { from: "user" });
1950
+
1951
+ expect(handleAnonymousDeployment).toHaveBeenCalled();
1952
+ expect(bigBrainAPI).not.toHaveBeenCalled();
1953
+ expect(bigBrainAPIMaybeThrows).not.toHaveBeenCalled();
1954
+ expect(validateOrSelectTeam).not.toHaveBeenCalled();
1955
+ expect(validateOrSelectProject).not.toHaveBeenCalled();
1956
+ });
1957
+
1958
+ it("non-interactive, logged in, no CONVEX_DEPLOYMENT → uses anonymous deployment", async () => {
1959
+ vi.mocked(readGlobalConfig).mockReturnValue({
1960
+ accessToken: "test-token",
1961
+ });
1962
+
1963
+ await dev.parseAsync(["--once"], { from: "user" });
1964
+
1965
+ expect(handleAnonymousDeployment).toHaveBeenCalled();
1966
+ expect(validateOrSelectTeam).not.toHaveBeenCalled();
1967
+ expect(validateOrSelectProject).not.toHaveBeenCalled();
1968
+ });
1969
+
1970
+ it("non-interactive with CONVEX_DEPLOYMENT → resolves to the configured deployment", async () => {
1971
+ process.env.CONVEX_DEPLOYMENT = "dev:joyful-capybara-123";
1972
+ vi.mocked(readGlobalConfig).mockReturnValue({
1973
+ accessToken: "test-token",
1974
+ });
1975
+
1976
+ setupBigBrainRoutes({
1977
+ "deployment/joyful-capybara-123/team_and_project": () => ({
1978
+ team: "my-team",
1979
+ project: "my-project",
1980
+ teamId: 1,
1981
+ projectId: 1,
1982
+ }),
1983
+ "deployment/authorize_within_current_project": () => ({
1984
+ adminKey: "dev-key",
1985
+ url: "https://joyful-capybara-123.convex.cloud",
1986
+ deploymentName: "joyful-capybara-123",
1987
+ deploymentType: "dev",
1988
+ }),
1989
+ });
1990
+
1991
+ await dev.parseAsync([], { from: "user" });
1992
+
1993
+ expect(devAgainstDeployment).toHaveBeenCalledWith(
1994
+ expect.anything(),
1995
+ expect.objectContaining({
1996
+ url: "https://joyful-capybara-123.convex.cloud",
1997
+ adminKey: "dev-key",
1998
+ }),
1999
+ expect.anything(),
2000
+ );
2001
+ expect(handleAnonymousDeployment).not.toHaveBeenCalled();
2002
+ });
2003
+
2004
+ it("non-interactive with CONVEX_DEPLOY_KEY → uses deploy key", async () => {
2005
+ process.env.CONVEX_DEPLOY_KEY = "project:identifier|secretkey";
2006
+
2007
+ setupBigBrainRoutes({
2008
+ "deployment/provision_and_authorize": () => ({
2009
+ adminKey: "dev-key",
2010
+ url: "https://swift-squirrel-234.convex.cloud",
2011
+ deploymentName: "swift-squirrel-234",
2012
+ deploymentType: "dev",
2013
+ }),
2014
+ });
2015
+
2016
+ await dev.parseAsync([], { from: "user" });
2017
+
2018
+ expect(devAgainstDeployment).toHaveBeenCalledWith(
2019
+ expect.anything(),
2020
+ expect.objectContaining({
2021
+ url: "https://swift-squirrel-234.convex.cloud",
2022
+ adminKey: "dev-key",
2023
+ }),
2024
+ expect.anything(),
2025
+ );
2026
+ expect(handleAnonymousDeployment).not.toHaveBeenCalled();
2027
+ });
2028
+
2029
+ it("non-interactive with CONVEX_SELF_HOSTED_URL → uses self-hosted", async () => {
2030
+ process.env.CONVEX_SELF_HOSTED_URL = "http://localhost:3210";
2031
+ process.env.CONVEX_SELF_HOSTED_ADMIN_KEY = "self-hosted-key";
2032
+
2033
+ await dev.parseAsync([], { from: "user" });
2034
+
2035
+ expect(devAgainstDeployment).toHaveBeenCalledWith(
2036
+ expect.anything(),
2037
+ expect.objectContaining({
2038
+ url: "http://localhost:3210",
2039
+ adminKey: "self-hosted-key",
2040
+ }),
2041
+ expect.anything(),
2042
+ );
2043
+ expect(handleAnonymousDeployment).not.toHaveBeenCalled();
2044
+ });
2045
+ });
2046
+ });
2047
+
2048
+ it("dev --deployment crashes with helpful message pointing to deployment select", async () => {
2049
+ await expect(
2050
+ dev.parseAsync(["--deployment", "happy-animal-123"], { from: "user" }),
2051
+ ).rejects.toThrow();
2052
+
2053
+ expect(process.stderr.write).toHaveBeenCalledWith(
2054
+ expect.stringContaining("npx convex deployment select happy-animal-123"),
2055
+ );
2056
+ expect(devAgainstDeployment).not.toHaveBeenCalled();
1695
2057
  });
1696
2058
  });