@sanity/cli 6.0.0-alpha.3 → 6.0.0-alpha.5

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 (376) hide show
  1. package/dist/actions/auth/login/{index.js → login.js} +1 -1
  2. package/dist/actions/auth/login/{index.js.map → login.js.map} +1 -1
  3. package/dist/actions/dev/startStudioDevServer.js +3 -8
  4. package/dist/actions/dev/startStudioDevServer.js.map +1 -1
  5. package/dist/actions/dev/types.d.ts +1 -3
  6. package/dist/actions/dev/types.js.map +1 -1
  7. package/dist/actions/documents/validate.d.ts +0 -2
  8. package/dist/actions/documents/validate.js +21 -1
  9. package/dist/actions/documents/validate.js.map +1 -1
  10. package/dist/actions/exec/execScript.js +1 -1
  11. package/dist/actions/exec/execScript.js.map +1 -1
  12. package/dist/actions/graphql/__tests__/getGraphQLAPIs.test.js +1 -1
  13. package/dist/actions/graphql/__tests__/getGraphQLAPIs.test.js.map +1 -1
  14. package/dist/actions/graphql/getGraphQLAPIs.js +1 -1
  15. package/dist/actions/graphql/getGraphQLAPIs.js.map +1 -1
  16. package/dist/actions/manifest/extractManifest.js +1 -4
  17. package/dist/actions/manifest/extractManifest.js.map +1 -1
  18. package/dist/actions/organizations/getOrganizationChoices.d.ts +6 -0
  19. package/dist/actions/organizations/getOrganizationChoices.js +23 -0
  20. package/dist/actions/organizations/getOrganizationChoices.js.map +1 -0
  21. package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.d.ts +2 -0
  22. package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js +9 -0
  23. package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js.map +1 -0
  24. package/dist/actions/organizations/hasProjectAttachGrant.d.ts +1 -0
  25. package/dist/actions/organizations/hasProjectAttachGrant.js +24 -0
  26. package/dist/actions/organizations/hasProjectAttachGrant.js.map +1 -0
  27. package/dist/actions/schema/deleteSchemaAction.d.ts +13 -5
  28. package/dist/actions/schema/deleteSchemaAction.js +12 -17
  29. package/dist/actions/schema/deleteSchemaAction.js.map +1 -1
  30. package/dist/actions/schema/deploySchemas.d.ts +15 -0
  31. package/dist/actions/schema/deploySchemas.js +98 -0
  32. package/dist/actions/schema/deploySchemas.js.map +1 -0
  33. package/dist/actions/schema/listSchemas.d.ts +12 -0
  34. package/dist/actions/schema/listSchemas.js +119 -0
  35. package/dist/actions/schema/listSchemas.js.map +1 -0
  36. package/dist/actions/schema/schemaStoreTypes.d.ts +0 -11
  37. package/dist/actions/schema/schemaStoreTypes.js.map +1 -1
  38. package/dist/actions/schema/utils/debug.d.ts +2 -0
  39. package/dist/actions/schema/utils/debug.js +5 -0
  40. package/dist/actions/schema/utils/debug.js.map +1 -0
  41. package/dist/actions/schema/utils/manifestExtractor.d.ts +3 -8
  42. package/dist/actions/schema/utils/manifestExtractor.js +12 -17
  43. package/dist/actions/schema/utils/manifestExtractor.js.map +1 -1
  44. package/dist/actions/schema/utils/manifestReader.d.ts +2 -9
  45. package/dist/actions/schema/utils/manifestReader.js +6 -12
  46. package/dist/actions/schema/utils/manifestReader.js.map +1 -1
  47. package/dist/actions/schema/utils/schemaStoreOutStrings.d.ts +0 -1
  48. package/dist/actions/schema/utils/schemaStoreOutStrings.js +1 -1
  49. package/dist/actions/schema/utils/schemaStoreOutStrings.js.map +1 -1
  50. package/dist/actions/schema/utils/schemaStoreValidation.d.ts +10 -62
  51. package/dist/actions/schema/utils/schemaStoreValidation.js +40 -127
  52. package/dist/actions/schema/utils/schemaStoreValidation.js.map +1 -1
  53. package/dist/actions/schema/utils/uniqByProjectIdDataset.d.ts +14 -0
  54. package/dist/actions/schema/utils/uniqByProjectIdDataset.js +9 -0
  55. package/dist/actions/schema/utils/uniqByProjectIdDataset.js.map +1 -0
  56. package/dist/actions/users/getMembersForProject.d.ts +1 -3
  57. package/dist/actions/users/getMembersForProject.js +6 -17
  58. package/dist/actions/users/getMembersForProject.js.map +1 -1
  59. package/dist/actions/users/types.d.ts +0 -11
  60. package/dist/actions/users/types.js.map +1 -1
  61. package/dist/commands/__tests__/debug.test.js +113 -220
  62. package/dist/commands/__tests__/debug.test.js.map +1 -1
  63. package/dist/commands/__tests__/deploy.test.js +325 -293
  64. package/dist/commands/__tests__/deploy.test.js.map +1 -1
  65. package/dist/commands/__tests__/dev.test.js +62 -19
  66. package/dist/commands/__tests__/dev.test.js.map +1 -1
  67. package/dist/commands/__tests__/init/init.authentication.test.js +73 -0
  68. package/dist/commands/__tests__/init/init.authentication.test.js.map +1 -0
  69. package/dist/commands/__tests__/init/init.create-new-project.test.js +195 -0
  70. package/dist/commands/__tests__/init/init.create-new-project.test.js.map +1 -0
  71. package/dist/commands/__tests__/init/init.plan.test.js +279 -0
  72. package/dist/commands/__tests__/init/init.plan.test.js.map +1 -0
  73. package/dist/commands/__tests__/init/init.setup.test.js +335 -0
  74. package/dist/commands/__tests__/init/init.setup.test.js.map +1 -0
  75. package/dist/commands/__tests__/install.test.js +46 -22
  76. package/dist/commands/__tests__/install.test.js.map +1 -1
  77. package/dist/commands/__tests__/logout.test.js +8 -5
  78. package/dist/commands/__tests__/logout.test.js.map +1 -1
  79. package/dist/commands/__tests__/manage.test.js +29 -24
  80. package/dist/commands/__tests__/manage.test.js.map +1 -1
  81. package/dist/commands/__tests__/migration.test.js +119 -0
  82. package/dist/commands/__tests__/migration.test.js.map +1 -0
  83. package/dist/commands/__tests__/versions.test.js +22 -14
  84. package/dist/commands/__tests__/versions.test.js.map +1 -1
  85. package/dist/commands/backup/__tests__/disable.test.js +72 -75
  86. package/dist/commands/backup/__tests__/disable.test.js.map +1 -1
  87. package/dist/commands/backup/__tests__/download.test.js +169 -80
  88. package/dist/commands/backup/__tests__/download.test.js.map +1 -1
  89. package/dist/commands/backup/__tests__/enable.test.js +109 -140
  90. package/dist/commands/backup/__tests__/enable.test.js.map +1 -1
  91. package/dist/commands/backup/__tests__/list.test.js +84 -75
  92. package/dist/commands/backup/__tests__/list.test.js.map +1 -1
  93. package/dist/commands/backup/disable.js +5 -11
  94. package/dist/commands/backup/disable.js.map +1 -1
  95. package/dist/commands/backup/enable.js +5 -11
  96. package/dist/commands/backup/enable.js.map +1 -1
  97. package/dist/commands/backup/list.js +7 -8
  98. package/dist/commands/backup/list.js.map +1 -1
  99. package/dist/commands/cors/__tests__/add.test.js +68 -38
  100. package/dist/commands/cors/__tests__/add.test.js.map +1 -1
  101. package/dist/commands/cors/__tests__/delete.test.js +52 -37
  102. package/dist/commands/cors/__tests__/delete.test.js.map +1 -1
  103. package/dist/commands/cors/__tests__/list.test.js +80 -57
  104. package/dist/commands/cors/__tests__/list.test.js.map +1 -1
  105. package/dist/commands/cors/add.js +5 -13
  106. package/dist/commands/cors/add.js.map +1 -1
  107. package/dist/commands/cors/delete.js +7 -15
  108. package/dist/commands/cors/delete.js.map +1 -1
  109. package/dist/commands/cors/list.js +2 -10
  110. package/dist/commands/cors/list.js.map +1 -1
  111. package/dist/commands/dataset/__tests__/copy.test.js +197 -89
  112. package/dist/commands/dataset/__tests__/copy.test.js.map +1 -1
  113. package/dist/commands/dataset/__tests__/create.test.js +147 -117
  114. package/dist/commands/dataset/__tests__/create.test.js.map +1 -1
  115. package/dist/commands/dataset/__tests__/delete.test.js +75 -68
  116. package/dist/commands/dataset/__tests__/delete.test.js.map +1 -1
  117. package/dist/commands/dataset/__tests__/export.test.js +123 -83
  118. package/dist/commands/dataset/__tests__/export.test.js.map +1 -1
  119. package/dist/commands/dataset/__tests__/import.test.js +2 -2
  120. package/dist/commands/dataset/__tests__/import.test.js.map +1 -1
  121. package/dist/commands/dataset/__tests__/list.test.js +107 -65
  122. package/dist/commands/dataset/__tests__/list.test.js.map +1 -1
  123. package/dist/commands/dataset/alias/__tests__/create.test.js +114 -74
  124. package/dist/commands/dataset/alias/__tests__/create.test.js.map +1 -1
  125. package/dist/commands/dataset/alias/__tests__/delete.test.js +40 -29
  126. package/dist/commands/dataset/alias/__tests__/delete.test.js.map +1 -1
  127. package/dist/commands/dataset/alias/__tests__/link.test.js +114 -74
  128. package/dist/commands/dataset/alias/__tests__/link.test.js.map +1 -1
  129. package/dist/commands/dataset/alias/__tests__/unlink.test.js +44 -29
  130. package/dist/commands/dataset/alias/__tests__/unlink.test.js.map +1 -1
  131. package/dist/commands/dataset/export.js +4 -4
  132. package/dist/commands/dataset/export.js.map +1 -1
  133. package/dist/commands/dataset/visibility/__tests__/get.test.js +48 -67
  134. package/dist/commands/dataset/visibility/__tests__/get.test.js.map +1 -1
  135. package/dist/commands/dataset/visibility/__tests__/set.test.js +76 -123
  136. package/dist/commands/dataset/visibility/__tests__/set.test.js.map +1 -1
  137. package/dist/commands/dev.js +0 -1
  138. package/dist/commands/dev.js.map +1 -1
  139. package/dist/commands/docs/__tests__/search.test.js +8 -7
  140. package/dist/commands/docs/__tests__/search.test.js.map +1 -1
  141. package/dist/commands/documents/__tests__/create.test.js +328 -265
  142. package/dist/commands/documents/__tests__/create.test.js.map +1 -1
  143. package/dist/commands/documents/__tests__/delete.test.js +119 -87
  144. package/dist/commands/documents/__tests__/delete.test.js.map +1 -1
  145. package/dist/commands/documents/__tests__/get.test.js +68 -95
  146. package/dist/commands/documents/__tests__/get.test.js.map +1 -1
  147. package/dist/commands/documents/__tests__/query.test.js +87 -192
  148. package/dist/commands/documents/__tests__/query.test.js.map +1 -1
  149. package/dist/commands/documents/__tests__/validate.test.js +52 -29
  150. package/dist/commands/documents/__tests__/validate.test.js.map +1 -1
  151. package/dist/commands/documents/create.d.ts +1 -0
  152. package/dist/commands/documents/create.js +10 -9
  153. package/dist/commands/documents/create.js.map +1 -1
  154. package/dist/commands/documents/delete.js +2 -3
  155. package/dist/commands/documents/delete.js.map +1 -1
  156. package/dist/commands/documents/get.js +2 -3
  157. package/dist/commands/documents/get.js.map +1 -1
  158. package/dist/commands/documents/query.js +2 -3
  159. package/dist/commands/documents/query.js.map +1 -1
  160. package/dist/commands/documents/validate.js +0 -20
  161. package/dist/commands/documents/validate.js.map +1 -1
  162. package/dist/commands/graphql/__tests__/list.test.js +57 -45
  163. package/dist/commands/graphql/__tests__/list.test.js.map +1 -1
  164. package/dist/commands/graphql/__tests__/undeploy.test.js +85 -59
  165. package/dist/commands/graphql/__tests__/undeploy.test.js.map +1 -1
  166. package/dist/commands/graphql/list.js +2 -2
  167. package/dist/commands/graphql/list.js.map +1 -1
  168. package/dist/commands/graphql/undeploy.js +4 -9
  169. package/dist/commands/graphql/undeploy.js.map +1 -1
  170. package/dist/commands/hook/__tests__/attempt.test.js +48 -33
  171. package/dist/commands/hook/__tests__/attempt.test.js.map +1 -1
  172. package/dist/commands/hook/__tests__/create.test.js +49 -51
  173. package/dist/commands/hook/__tests__/create.test.js.map +1 -1
  174. package/dist/commands/hook/__tests__/delete.test.js +43 -30
  175. package/dist/commands/hook/__tests__/delete.test.js.map +1 -1
  176. package/dist/commands/hook/__tests__/list.test.js +38 -31
  177. package/dist/commands/hook/__tests__/list.test.js.map +1 -1
  178. package/dist/commands/hook/__tests__/logs.test.js +68 -40
  179. package/dist/commands/hook/__tests__/logs.test.js.map +1 -1
  180. package/dist/commands/hook/create.js +2 -6
  181. package/dist/commands/hook/create.js.map +1 -1
  182. package/dist/commands/hook/delete.js +5 -17
  183. package/dist/commands/hook/delete.js.map +1 -1
  184. package/dist/commands/hook/list.js +2 -8
  185. package/dist/commands/hook/list.js.map +1 -1
  186. package/dist/commands/init.d.ts +4 -0
  187. package/dist/commands/init.js +151 -18
  188. package/dist/commands/init.js.map +1 -1
  189. package/dist/commands/login.js +1 -1
  190. package/dist/commands/login.js.map +1 -1
  191. package/dist/commands/manifest/__tests__/extract.test.js +22 -13
  192. package/dist/commands/manifest/__tests__/extract.test.js.map +1 -1
  193. package/dist/commands/media/__tests__/create-aspect.test.js +41 -28
  194. package/dist/commands/media/__tests__/create-aspect.test.js.map +1 -1
  195. package/dist/commands/media/__tests__/delete-aspect.test.js +44 -35
  196. package/dist/commands/media/__tests__/delete-aspect.test.js.map +1 -1
  197. package/dist/commands/media/__tests__/deploy-aspect.test.js +67 -80
  198. package/dist/commands/media/__tests__/deploy-aspect.test.js.map +1 -1
  199. package/dist/commands/media/__tests__/export.test.js +365 -66
  200. package/dist/commands/media/__tests__/export.test.js.map +1 -1
  201. package/dist/commands/media/__tests__/import.test.js +171 -105
  202. package/dist/commands/media/__tests__/import.test.js.map +1 -1
  203. package/dist/commands/media/export.js +2 -2
  204. package/dist/commands/media/export.js.map +1 -1
  205. package/dist/commands/media/import.js +2 -2
  206. package/dist/commands/media/import.js.map +1 -1
  207. package/dist/commands/projects/__tests__/list.test.js +5 -4
  208. package/dist/commands/projects/__tests__/list.test.js.map +1 -1
  209. package/dist/commands/projects/list.js +2 -6
  210. package/dist/commands/projects/list.js.map +1 -1
  211. package/dist/commands/schema/__tests__/delete.test.js +396 -151
  212. package/dist/commands/schema/__tests__/delete.test.js.map +1 -1
  213. package/dist/commands/schema/__tests__/deploy.test.js +348 -0
  214. package/dist/commands/schema/__tests__/deploy.test.js.map +1 -0
  215. package/dist/commands/schema/__tests__/extract.test.js +19 -11
  216. package/dist/commands/schema/__tests__/extract.test.js.map +1 -1
  217. package/dist/commands/schema/__tests__/list.test.js +399 -0
  218. package/dist/commands/schema/__tests__/list.test.js.map +1 -0
  219. package/dist/commands/schema/__tests__/validate.test.js +27 -10
  220. package/dist/commands/schema/__tests__/validate.test.js.map +1 -1
  221. package/dist/commands/schema/delete.d.ts +1 -1
  222. package/dist/commands/schema/delete.js +20 -23
  223. package/dist/commands/schema/delete.js.map +1 -1
  224. package/dist/commands/schema/deploy.d.ts +16 -0
  225. package/dist/commands/schema/deploy.js +98 -0
  226. package/dist/commands/schema/deploy.js.map +1 -0
  227. package/dist/commands/schema/list.d.ts +15 -0
  228. package/dist/commands/schema/list.js +104 -0
  229. package/dist/commands/schema/list.js.map +1 -0
  230. package/dist/commands/telemetry/__tests__/disable.test.js +7 -5
  231. package/dist/commands/telemetry/__tests__/disable.test.js.map +1 -1
  232. package/dist/commands/telemetry/__tests__/enable.test.js +7 -5
  233. package/dist/commands/telemetry/__tests__/enable.test.js.map +1 -1
  234. package/dist/commands/telemetry/__tests__/status.test.js +7 -5
  235. package/dist/commands/telemetry/__tests__/status.test.js.map +1 -1
  236. package/dist/commands/tokens/__tests__/add.test.js +55 -40
  237. package/dist/commands/tokens/__tests__/add.test.js.map +1 -1
  238. package/dist/commands/tokens/__tests__/delete.test.js +72 -42
  239. package/dist/commands/tokens/__tests__/delete.test.js.map +1 -1
  240. package/dist/commands/tokens/__tests__/list.test.js +87 -60
  241. package/dist/commands/tokens/__tests__/list.test.js.map +1 -1
  242. package/dist/commands/tokens/add.js +3 -5
  243. package/dist/commands/tokens/add.js.map +1 -1
  244. package/dist/commands/users/__tests__/invite.test.js +100 -79
  245. package/dist/commands/users/__tests__/invite.test.js.map +1 -1
  246. package/dist/commands/users/__tests__/list.test.js +186 -180
  247. package/dist/commands/users/__tests__/list.test.js.map +1 -1
  248. package/dist/commands/users/invite.js +6 -17
  249. package/dist/commands/users/invite.js.map +1 -1
  250. package/dist/commands/users/list.js +4 -7
  251. package/dist/commands/users/list.js.map +1 -1
  252. package/dist/config/createCliConfig.d.ts +4 -4
  253. package/dist/services/backup.d.ts +8 -0
  254. package/dist/services/backup.js +19 -0
  255. package/dist/services/backup.js.map +1 -1
  256. package/dist/services/cors.d.ts +23 -0
  257. package/dist/services/cors.js +38 -0
  258. package/dist/services/cors.js.map +1 -0
  259. package/dist/services/graphql.d.ts +7 -0
  260. package/dist/services/graphql.js +11 -0
  261. package/dist/services/graphql.js.map +1 -1
  262. package/dist/services/hooks.d.ts +2 -0
  263. package/dist/services/hooks.js +19 -0
  264. package/dist/services/hooks.js.map +1 -1
  265. package/dist/services/organizations.d.ts +40 -0
  266. package/dist/services/organizations.js +41 -0
  267. package/dist/services/organizations.js.map +1 -0
  268. package/dist/services/projects.d.ts +31 -0
  269. package/dist/services/projects.js +71 -1
  270. package/dist/services/projects.js.map +1 -1
  271. package/dist/services/schemas.d.ts +4 -0
  272. package/dist/services/schemas.js +40 -0
  273. package/dist/services/schemas.js.map +1 -0
  274. package/dist/services/user.d.ts +10 -0
  275. package/dist/services/user.js +24 -0
  276. package/dist/services/user.js.map +1 -0
  277. package/dist/util/__tests__/getCliVersion.test.js +2 -2
  278. package/dist/util/__tests__/getCliVersion.test.js.map +1 -1
  279. package/dist/util/errorMessages.d.ts +1 -0
  280. package/dist/util/errorMessages.js +1 -0
  281. package/dist/util/errorMessages.js.map +1 -1
  282. package/dist/util/getCliVersion.js +1 -1
  283. package/dist/util/getCliVersion.js.map +1 -1
  284. package/dist/util/readPackageJson.d.ts +1 -15
  285. package/dist/util/readPackageJson.js +1 -1
  286. package/dist/util/readPackageJson.js.map +1 -1
  287. package/dist/util/uniqBy.d.ts +1 -0
  288. package/dist/util/uniqBy.js +14 -0
  289. package/dist/util/uniqBy.js.map +1 -0
  290. package/oclif.config.js +6 -1
  291. package/oclif.manifest.json +152 -158
  292. package/package.json +30 -31
  293. package/dist/actions/cors/constants.d.ts +0 -1
  294. package/dist/actions/cors/constants.js +0 -3
  295. package/dist/actions/cors/constants.js.map +0 -1
  296. package/dist/actions/cors/types.d.ts +0 -9
  297. package/dist/actions/cors/types.js +0 -3
  298. package/dist/actions/cors/types.js.map +0 -1
  299. package/dist/actions/migration/getMigrationRootDirectory.d.ts +0 -2
  300. package/dist/actions/migration/getMigrationRootDirectory.js +0 -14
  301. package/dist/actions/migration/getMigrationRootDirectory.js.map +0 -1
  302. package/dist/actions/migration/resolveMigrations.d.ts +0 -19
  303. package/dist/actions/migration/resolveMigrations.js +0 -43
  304. package/dist/actions/migration/resolveMigrations.js.map +0 -1
  305. package/dist/actions/migration/templates/__tests__/minimalAdvanced.test.js +0 -65
  306. package/dist/actions/migration/templates/__tests__/minimalAdvanced.test.js.map +0 -1
  307. package/dist/actions/migration/templates/__tests__/minimalSimple.test.js +0 -145
  308. package/dist/actions/migration/templates/__tests__/minimalSimple.test.js.map +0 -1
  309. package/dist/actions/migration/templates/__tests__/renameField.test.js +0 -63
  310. package/dist/actions/migration/templates/__tests__/renameField.test.js.map +0 -1
  311. package/dist/actions/migration/templates/__tests__/renameType.test.js +0 -61
  312. package/dist/actions/migration/templates/__tests__/renameType.test.js.map +0 -1
  313. package/dist/actions/migration/templates/__tests__/stringToPTE.test.js +0 -87
  314. package/dist/actions/migration/templates/__tests__/stringToPTE.test.js.map +0 -1
  315. package/dist/actions/migration/templates/index.d.ts +0 -5
  316. package/dist/actions/migration/templates/index.js +0 -7
  317. package/dist/actions/migration/templates/index.js.map +0 -1
  318. package/dist/actions/migration/templates/minimalAdvanced.d.ts +0 -4
  319. package/dist/actions/migration/templates/minimalAdvanced.js +0 -21
  320. package/dist/actions/migration/templates/minimalAdvanced.js.map +0 -1
  321. package/dist/actions/migration/templates/minimalSimple.d.ts +0 -4
  322. package/dist/actions/migration/templates/minimalSimple.js +0 -61
  323. package/dist/actions/migration/templates/minimalSimple.js.map +0 -1
  324. package/dist/actions/migration/templates/renameField.d.ts +0 -4
  325. package/dist/actions/migration/templates/renameField.js +0 -20
  326. package/dist/actions/migration/templates/renameField.js.map +0 -1
  327. package/dist/actions/migration/templates/renameType.d.ts +0 -4
  328. package/dist/actions/migration/templates/renameType.js +0 -19
  329. package/dist/actions/migration/templates/renameType.js.map +0 -1
  330. package/dist/actions/migration/templates/stringToPTE.d.ts +0 -4
  331. package/dist/actions/migration/templates/stringToPTE.js +0 -32
  332. package/dist/actions/migration/templates/stringToPTE.js.map +0 -1
  333. package/dist/actions/schema/__tests__/deleteSchemaAction.test.js +0 -294
  334. package/dist/actions/schema/__tests__/deleteSchemaAction.test.js.map +0 -1
  335. package/dist/actions/schema/schemaStoreConstants.d.ts +0 -1
  336. package/dist/actions/schema/schemaStoreConstants.js +0 -4
  337. package/dist/actions/schema/schemaStoreConstants.js.map +0 -1
  338. package/dist/actions/schema/utils/schemaActionHelpers.d.ts +0 -1
  339. package/dist/actions/schema/utils/schemaActionHelpers.js +0 -5
  340. package/dist/actions/schema/utils/schemaActionHelpers.js.map +0 -1
  341. package/dist/actions/schema/utils/schemaApiClient.d.ts +0 -6
  342. package/dist/actions/schema/utils/schemaApiClient.js +0 -17
  343. package/dist/actions/schema/utils/schemaApiClient.js.map +0 -1
  344. package/dist/actions/users/apiVersion.d.ts +0 -6
  345. package/dist/actions/users/apiVersion.js +0 -7
  346. package/dist/actions/users/apiVersion.js.map +0 -1
  347. package/dist/commands/__tests__/init.test.js +0 -411
  348. package/dist/commands/__tests__/init.test.js.map +0 -1
  349. package/dist/commands/migration/__tests__/create.test.js +0 -296
  350. package/dist/commands/migration/__tests__/create.test.js.map +0 -1
  351. package/dist/commands/migration/__tests__/list.test.js +0 -166
  352. package/dist/commands/migration/__tests__/list.test.js.map +0 -1
  353. package/dist/commands/migration/__tests__/run.test.js +0 -481
  354. package/dist/commands/migration/__tests__/run.test.js.map +0 -1
  355. package/dist/commands/migration/create.d.ts +0 -17
  356. package/dist/commands/migration/create.js +0 -143
  357. package/dist/commands/migration/create.js.map +0 -1
  358. package/dist/commands/migration/list.d.ts +0 -9
  359. package/dist/commands/migration/list.js +0 -61
  360. package/dist/commands/migration/list.js.map +0 -1
  361. package/dist/commands/migration/run.d.ts +0 -26
  362. package/dist/commands/migration/run.js +0 -271
  363. package/dist/commands/migration/run.js.map +0 -1
  364. package/dist/util/migration/constants.d.ts +0 -3
  365. package/dist/util/migration/constants.js +0 -10
  366. package/dist/util/migration/constants.js.map +0 -1
  367. package/dist/util/migration/ensureApiVersionFormat.d.ts +0 -9
  368. package/dist/util/migration/ensureApiVersionFormat.js +0 -16
  369. package/dist/util/migration/ensureApiVersionFormat.js.map +0 -1
  370. package/dist/util/migration/prettyMutationFormatter.d.ts +0 -8
  371. package/dist/util/migration/prettyMutationFormatter.js +0 -141
  372. package/dist/util/migration/prettyMutationFormatter.js.map +0 -1
  373. package/dist/utils/migration/resolveMigrationScript.d.ts +0 -44
  374. package/dist/utils/migration/resolveMigrationScript.js +0 -74
  375. package/dist/utils/migration/resolveMigrationScript.js.map +0 -1
  376. /package/dist/actions/auth/login/{index.d.ts → login.d.ts} +0 -0
@@ -0,0 +1,279 @@
1
+ import { createTestClient, mockApi, testCommand } from '@sanity/cli-test';
2
+ import { afterEach, describe, expect, test, vi } from 'vitest';
3
+ import { INIT_API_VERSION } from '../../../actions/init/constants.js';
4
+ import { InitCommand } from '../../init';
5
+ const mockConfirm = vi.hoisted(()=>vi.fn());
6
+ vi.mock('@sanity/cli-core/ux', async ()=>{
7
+ const actual = await vi.importActual('@sanity/cli-core/ux');
8
+ return {
9
+ ...actual,
10
+ confirm: mockConfirm
11
+ };
12
+ });
13
+ vi.mock('@vercel/fs-detectors', ()=>({
14
+ detectFrameworkRecord: vi.fn().mockResolvedValue({
15
+ name: 'Next.js',
16
+ slug: 'nextjs'
17
+ }),
18
+ LocalFileSystemDetector: vi.fn()
19
+ }));
20
+ vi.mock('@sanity/cli-core', async ()=>{
21
+ const actual = await vi.importActual('@sanity/cli-core');
22
+ const testClient = createTestClient({
23
+ apiVersion: INIT_API_VERSION,
24
+ token: 'test-token'
25
+ });
26
+ return {
27
+ ...actual,
28
+ getGlobalCliClient: vi.fn().mockResolvedValue({
29
+ request: testClient.request,
30
+ users: {
31
+ getById: vi.fn().mockResolvedValue({
32
+ email: 'test@example.com',
33
+ id: 'user-123',
34
+ name: 'Test User',
35
+ provider: 'saml-123'
36
+ })
37
+ }
38
+ })
39
+ };
40
+ });
41
+ describe('#init: retrieving plan', ()=>{
42
+ afterEach(()=>{
43
+ vi.clearAllMocks();
44
+ });
45
+ test('validates coupon when --coupon flag is provided', async ()=>{
46
+ mockApi({
47
+ apiVersion: 'v2025-06-01',
48
+ method: 'get',
49
+ uri: '/plans/coupon/TESTCOUPON123'
50
+ }).reply(200, [
51
+ {
52
+ id: 'test-plan-id'
53
+ }
54
+ ]);
55
+ const { error, stdout } = await testCommand(InitCommand, [
56
+ '--coupon=TESTCOUPON123'
57
+ ], {
58
+ mocks: {
59
+ isInteractive: true,
60
+ token: 'test-token'
61
+ }
62
+ });
63
+ expect(error).toBeUndefined();
64
+ expect(stdout).toContain('Coupon "TESTCOUPON123" validated!');
65
+ });
66
+ test('throws error if coupon not found with provided code', async ()=>{
67
+ mockApi({
68
+ apiVersion: 'v2025-06-01',
69
+ method: 'get',
70
+ uri: '/plans/coupon/TESTCOUPON123'
71
+ }).reply(200, []);
72
+ const { error } = await testCommand(InitCommand, [
73
+ '--coupon=TESTCOUPON123',
74
+ '--bare'
75
+ ], {
76
+ mocks: {
77
+ isInteractive: true,
78
+ token: 'test-token'
79
+ }
80
+ });
81
+ expect(error?.message).toContain('Unable to validate coupon, please try again later:');
82
+ expect(error?.message).toContain('No plans found for coupon code "TESTCOUPON123"');
83
+ });
84
+ test('throws error if coupon does not have attached plan id', async ()=>{
85
+ mockApi({
86
+ apiVersion: INIT_API_VERSION,
87
+ method: 'get',
88
+ uri: '/plans/coupon/TESTCOUPON123'
89
+ }).reply(200, [
90
+ {
91
+ id: undefined
92
+ }
93
+ ]);
94
+ const { error } = await testCommand(InitCommand, [
95
+ '--coupon=TESTCOUPON123',
96
+ '--bare'
97
+ ], {
98
+ mocks: {
99
+ isInteractive: true,
100
+ token: 'test-token'
101
+ }
102
+ });
103
+ expect(error?.message).toContain('Unable to validate coupon, please try again later:');
104
+ expect(error?.message).toContain('Unable to find a plan from coupon code');
105
+ });
106
+ test('uses default plan when coupon does not exist and cli in unattended mode', async ()=>{
107
+ mockApi({
108
+ apiVersion: INIT_API_VERSION,
109
+ method: 'get',
110
+ uri: '/plans/coupon/INVALID123'
111
+ }).reply(404, {
112
+ message: 'Coupon not found'
113
+ });
114
+ const { error, stderr, stdout } = await testCommand(InitCommand, [
115
+ '--coupon=INVALID123',
116
+ '--yes',
117
+ '--dataset=test',
118
+ '--project=test'
119
+ ], {
120
+ mocks: {
121
+ token: 'test-token'
122
+ }
123
+ });
124
+ expect(error).toBe(undefined);
125
+ expect(stderr).toContain('Warning: Coupon "INVALID123" is not available - using default plan');
126
+ expect(stdout).toContain('Using default plan.');
127
+ });
128
+ test('uses default plan when coupon invalid and user confirms default plan', async ()=>{
129
+ mockApi({
130
+ apiVersion: INIT_API_VERSION,
131
+ method: 'get',
132
+ uri: '/plans/coupon/INVALID123'
133
+ }).reply(404, {
134
+ message: 'Coupon not found'
135
+ });
136
+ mockConfirm.mockResolvedValue(true);
137
+ const { error, stdout } = await testCommand(InitCommand, [
138
+ '--coupon=INVALID123'
139
+ ], {
140
+ mocks: {
141
+ isInteractive: true,
142
+ token: 'test-token'
143
+ }
144
+ });
145
+ expect(error).toBeUndefined();
146
+ expect(mockConfirm).toHaveBeenCalledWith({
147
+ default: true,
148
+ message: 'Coupon "INVALID123" is not available, use default plan instead?'
149
+ });
150
+ expect(stdout).toContain('Using default plan.');
151
+ });
152
+ test('throws error when coupon invalid and user declines the default plan', async ()=>{
153
+ mockApi({
154
+ apiVersion: INIT_API_VERSION,
155
+ method: 'get',
156
+ uri: '/plans/coupon/INVALID123'
157
+ }).reply(404, {
158
+ message: 'Coupon not found'
159
+ });
160
+ mockConfirm.mockResolvedValue(false);
161
+ const { error } = await testCommand(InitCommand, [
162
+ '--coupon=INVALID123'
163
+ ], {
164
+ mocks: {
165
+ isInteractive: true,
166
+ token: 'test-token'
167
+ }
168
+ });
169
+ expect(error?.message).toContain('Coupon "INVALID123" does not exist');
170
+ });
171
+ test('returns when client request for plan is successful', async ()=>{
172
+ mockApi({
173
+ apiVersion: INIT_API_VERSION,
174
+ method: 'get',
175
+ uri: '/plans/growth'
176
+ }).reply(200, [
177
+ {
178
+ id: 'test-plan-id'
179
+ }
180
+ ]);
181
+ const { error } = await testCommand(InitCommand, [
182
+ '--project-plan=growth'
183
+ ], {
184
+ mocks: {
185
+ isInteractive: true,
186
+ token: 'test-token'
187
+ }
188
+ });
189
+ expect(error).toBeUndefined();
190
+ });
191
+ test('throw error when no plan id is returned by request', async ()=>{
192
+ mockApi({
193
+ apiVersion: INIT_API_VERSION,
194
+ method: 'get',
195
+ uri: '/plans/growth'
196
+ }).reply(200, [
197
+ {
198
+ id: undefined
199
+ }
200
+ ]);
201
+ const { error } = await testCommand(InitCommand, [
202
+ '--project-plan=growth'
203
+ ], {
204
+ mocks: {
205
+ isInteractive: true,
206
+ token: 'test-token'
207
+ }
208
+ });
209
+ expect(error?.message).toContain('Unable to validate plan, please try again later:');
210
+ expect(error?.message).toContain('Unable to find a plan with id growth');
211
+ });
212
+ test('uses default plan when plan id does not exist and cli in unattended mode', async ()=>{
213
+ mockApi({
214
+ apiVersion: INIT_API_VERSION,
215
+ method: 'get',
216
+ uri: '/plans/growth'
217
+ }).reply(404, {
218
+ message: 'Plan not found'
219
+ });
220
+ const { error, stderr, stdout } = await testCommand(InitCommand, [
221
+ '--project-plan=growth',
222
+ '--yes',
223
+ '--dataset=test',
224
+ '--project==test'
225
+ ], {
226
+ mocks: {
227
+ token: 'test-token'
228
+ }
229
+ });
230
+ expect(error).toBe(undefined);
231
+ expect(stderr).toContain('Warning: Project plan "growth" does not exist - using default plan');
232
+ expect(stdout).toContain('Using default plan.');
233
+ });
234
+ test('uses default plan when plan ID not found and user confirms default plan', async ()=>{
235
+ mockApi({
236
+ apiVersion: INIT_API_VERSION,
237
+ method: 'get',
238
+ uri: '/plans/growth'
239
+ }).reply(404, {
240
+ message: 'Plan not found'
241
+ });
242
+ mockConfirm.mockResolvedValue(true);
243
+ const { error, stdout } = await testCommand(InitCommand, [
244
+ '--project-plan=growth'
245
+ ], {
246
+ mocks: {
247
+ isInteractive: true,
248
+ token: 'test-token'
249
+ }
250
+ });
251
+ expect(error).toBeUndefined();
252
+ expect(mockConfirm).toHaveBeenCalledWith({
253
+ default: true,
254
+ message: 'Project plan "growth" does not exist, use default plan instead?'
255
+ });
256
+ expect(stdout).toContain('Using default plan.');
257
+ });
258
+ test('throws error when plan ID not found and user declines default plan', async ()=>{
259
+ mockApi({
260
+ apiVersion: INIT_API_VERSION,
261
+ method: 'get',
262
+ uri: '/plans/growth'
263
+ }).reply(404, {
264
+ message: 'Plan not found'
265
+ });
266
+ mockConfirm.mockResolvedValue(false);
267
+ const { error } = await testCommand(InitCommand, [
268
+ '--project-plan=growth'
269
+ ], {
270
+ mocks: {
271
+ isInteractive: true,
272
+ token: 'test-token'
273
+ }
274
+ });
275
+ expect(error?.message).toContain('Plan id "growth" does not exist');
276
+ });
277
+ });
278
+
279
+ //# sourceMappingURL=init.plan.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/commands/__tests__/init/init.plan.test.ts"],"sourcesContent":["import {createTestClient, mockApi, testCommand} from '@sanity/cli-test'\nimport {afterEach, describe, expect, test, vi} from 'vitest'\n\nimport {INIT_API_VERSION} from '../../../actions/init/constants.js'\nimport {InitCommand} from '../../init'\n\nconst mockConfirm = vi.hoisted(() => vi.fn())\n\nvi.mock('@sanity/cli-core/ux', async () => {\n const actual = await vi.importActual('@sanity/cli-core/ux')\n\n return {\n ...actual,\n confirm: mockConfirm,\n }\n})\n\nvi.mock('@vercel/fs-detectors', () => ({\n detectFrameworkRecord: vi.fn().mockResolvedValue({\n name: 'Next.js',\n slug: 'nextjs',\n }),\n LocalFileSystemDetector: vi.fn(),\n}))\n\nvi.mock('@sanity/cli-core', async () => {\n const actual = await vi.importActual('@sanity/cli-core')\n const testClient = createTestClient({\n apiVersion: INIT_API_VERSION,\n token: 'test-token',\n })\n\n return {\n ...actual,\n getGlobalCliClient: vi.fn().mockResolvedValue({\n request: testClient.request,\n users: {\n getById: vi.fn().mockResolvedValue({\n email: 'test@example.com',\n id: 'user-123',\n name: 'Test User',\n provider: 'saml-123',\n }),\n } as never,\n }),\n }\n})\n\ndescribe('#init: retrieving plan', () => {\n afterEach(() => {\n vi.clearAllMocks()\n })\n\n test('validates coupon when --coupon flag is provided', async () => {\n mockApi({\n apiVersion: 'v2025-06-01',\n method: 'get',\n uri: '/plans/coupon/TESTCOUPON123',\n }).reply(200, [{id: 'test-plan-id'}])\n\n const {error, stdout} = await testCommand(InitCommand, ['--coupon=TESTCOUPON123'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error).toBeUndefined()\n expect(stdout).toContain('Coupon \"TESTCOUPON123\" validated!')\n })\n\n test('throws error if coupon not found with provided code', async () => {\n mockApi({\n apiVersion: 'v2025-06-01',\n method: 'get',\n uri: '/plans/coupon/TESTCOUPON123',\n }).reply(200, [])\n\n const {error} = await testCommand(InitCommand, ['--coupon=TESTCOUPON123', '--bare'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error?.message).toContain('Unable to validate coupon, please try again later:')\n expect(error?.message).toContain('No plans found for coupon code \"TESTCOUPON123\"')\n })\n\n test('throws error if coupon does not have attached plan id', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/coupon/TESTCOUPON123',\n }).reply(200, [{id: undefined}])\n\n const {error} = await testCommand(InitCommand, ['--coupon=TESTCOUPON123', '--bare'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error?.message).toContain('Unable to validate coupon, please try again later:')\n expect(error?.message).toContain('Unable to find a plan from coupon code')\n })\n\n test('uses default plan when coupon does not exist and cli in unattended mode', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/coupon/INVALID123',\n }).reply(404, {message: 'Coupon not found'})\n\n const {error, stderr, stdout} = await testCommand(\n InitCommand,\n ['--coupon=INVALID123', '--yes', '--dataset=test', '--project=test'],\n {\n mocks: {\n token: 'test-token',\n },\n },\n )\n\n expect(error).toBe(undefined)\n expect(stderr).toContain('Warning: Coupon \"INVALID123\" is not available - using default plan')\n expect(stdout).toContain('Using default plan.')\n })\n\n test('uses default plan when coupon invalid and user confirms default plan', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/coupon/INVALID123',\n }).reply(404, {message: 'Coupon not found'})\n\n mockConfirm.mockResolvedValue(true)\n\n const {error, stdout} = await testCommand(InitCommand, ['--coupon=INVALID123'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error).toBeUndefined()\n expect(mockConfirm).toHaveBeenCalledWith({\n default: true,\n message: 'Coupon \"INVALID123\" is not available, use default plan instead?',\n })\n expect(stdout).toContain('Using default plan.')\n })\n\n test('throws error when coupon invalid and user declines the default plan', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/coupon/INVALID123',\n }).reply(404, {message: 'Coupon not found'})\n mockConfirm.mockResolvedValue(false)\n\n const {error} = await testCommand(InitCommand, ['--coupon=INVALID123'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error?.message).toContain('Coupon \"INVALID123\" does not exist')\n })\n\n test('returns when client request for plan is successful', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/growth',\n }).reply(200, [{id: 'test-plan-id'}])\n\n const {error} = await testCommand(InitCommand, ['--project-plan=growth'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error).toBeUndefined()\n })\n\n test('throw error when no plan id is returned by request', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/growth',\n }).reply(200, [{id: undefined}])\n\n const {error} = await testCommand(InitCommand, ['--project-plan=growth'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n expect(error?.message).toContain('Unable to validate plan, please try again later:')\n expect(error?.message).toContain('Unable to find a plan with id growth')\n })\n\n test('uses default plan when plan id does not exist and cli in unattended mode', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/growth',\n }).reply(404, {message: 'Plan not found'})\n\n const {error, stderr, stdout} = await testCommand(\n InitCommand,\n ['--project-plan=growth', '--yes', '--dataset=test', '--project==test'],\n {\n mocks: {\n token: 'test-token',\n },\n },\n )\n\n expect(error).toBe(undefined)\n expect(stderr).toContain('Warning: Project plan \"growth\" does not exist - using default plan')\n expect(stdout).toContain('Using default plan.')\n })\n\n test('uses default plan when plan ID not found and user confirms default plan', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/growth',\n }).reply(404, {message: 'Plan not found'})\n mockConfirm.mockResolvedValue(true)\n\n const {error, stdout} = await testCommand(InitCommand, ['--project-plan=growth'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error).toBeUndefined()\n expect(mockConfirm).toHaveBeenCalledWith({\n default: true,\n message: 'Project plan \"growth\" does not exist, use default plan instead?',\n })\n expect(stdout).toContain('Using default plan.')\n })\n\n test('throws error when plan ID not found and user declines default plan', async () => {\n mockApi({\n apiVersion: INIT_API_VERSION,\n method: 'get',\n uri: '/plans/growth',\n }).reply(404, {message: 'Plan not found'})\n mockConfirm.mockResolvedValue(false)\n\n const {error} = await testCommand(InitCommand, ['--project-plan=growth'], {\n mocks: {\n isInteractive: true,\n token: 'test-token',\n },\n })\n\n expect(error?.message).toContain('Plan id \"growth\" does not exist')\n })\n})\n"],"names":["createTestClient","mockApi","testCommand","afterEach","describe","expect","test","vi","INIT_API_VERSION","InitCommand","mockConfirm","hoisted","fn","mock","actual","importActual","confirm","detectFrameworkRecord","mockResolvedValue","name","slug","LocalFileSystemDetector","testClient","apiVersion","token","getGlobalCliClient","request","users","getById","email","id","provider","clearAllMocks","method","uri","reply","error","stdout","mocks","isInteractive","toBeUndefined","toContain","message","undefined","stderr","toBe","toHaveBeenCalledWith","default"],"mappings":"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"}
@@ -0,0 +1,335 @@
1
+ import { runCommand } from '@oclif/test';
2
+ import { testCommand } from '@sanity/cli-test';
3
+ import { afterEach, describe, expect, test, vi } from 'vitest';
4
+ import { InitCommand } from '../../init';
5
+ const mocks = vi.hoisted(()=>({
6
+ checkIsRemoteTemplate: vi.fn().mockReturnValue(false),
7
+ detectFrameworkRecord: vi.fn(),
8
+ getById: vi.fn(),
9
+ getGitHubRepoInfo: vi.fn()
10
+ }));
11
+ vi.mock('@vercel/fs-detectors', ()=>({
12
+ detectFrameworkRecord: mocks.detectFrameworkRecord,
13
+ LocalFileSystemDetector: vi.fn()
14
+ }));
15
+ vi.mock('../../../actions/init/remoteTemplate.js', ()=>({
16
+ checkIsRemoteTemplate: mocks.checkIsRemoteTemplate,
17
+ getGitHubRepoInfo: mocks.getGitHubRepoInfo
18
+ }));
19
+ vi.mock('@sanity/cli-core', async (importOriginal)=>{
20
+ const actual = await importOriginal();
21
+ return {
22
+ ...actual,
23
+ getGlobalCliClient: vi.fn().mockResolvedValue({
24
+ users: {
25
+ getById: mocks.getById
26
+ }
27
+ })
28
+ };
29
+ });
30
+ // Set default mock behavior for getById
31
+ mocks.getById.mockResolvedValue({
32
+ email: 'test@example.com',
33
+ id: 'user-123',
34
+ name: 'Test User',
35
+ provider: 'saml-123'
36
+ });
37
+ describe('#init: oclif command setup', ()=>{
38
+ afterEach(()=>{
39
+ vi.clearAllMocks();
40
+ });
41
+ test('--help works', async ()=>{
42
+ const { stdout } = await runCommand('init --help');
43
+ expect(stdout).toMatchInlineSnapshot(String.raw`
44
+ "Initialize a new Sanity Studio, project and/or app
45
+
46
+ USAGE
47
+ $ sanity init [--json] [--auto-updates | --bare] [--coupon
48
+ <code> | --project-plan <name>] [--dataset <name> | --dataset-default]
49
+ [--env <filename> | ] [--git <message> | ] [--mcp]
50
+ [--nextjs-add-config-files] [--nextjs-append-env] [--nextjs-embed-studio]
51
+ [--organization <id>] [--output-path <path> | ] [--overwrite-files]
52
+ [--package-manager <manager> | ] [--project <id> | --create-project <name>]
53
+ [--provider <provider>] [--template <template> | ] [--typescript | ]
54
+ [--visibility <mode>] [-y]
55
+
56
+ FLAGS
57
+ -y, --yes Unattended mode, answers "yes" to any
58
+ "yes/no" prompt and otherwise uses defaults
59
+ --[no-]auto-updates Enable auto updates of studio versions
60
+ --bare Skip the Studio initialization and only print
61
+ the selected project ID and dataset name to
62
+ stdout
63
+ --coupon=<code> Optionally select a coupon for a new project
64
+ (cannot be used with --project-plan)
65
+ --create-project=<name> Create a new project with the given name
66
+ --dataset=<name> Dataset name for the studio
67
+ --dataset-default Set up a project with a public dataset named
68
+ "production"
69
+ --env=<filename> Write environment variables to file
70
+ --[no-]git=<message> Specify a commit message for initial commit,
71
+ or disable git init
72
+ --[no-]mcp Enable AI editor integration (MCP) setup
73
+ --organization=<id> Organization ID to use for the project
74
+ --output-path=<path> Path to write studio project to
75
+ --overwrite-files Overwrite existing files
76
+ --package-manager=<manager> Specify which package manager to use
77
+ [allowed: npm, yarn, pnpm]
78
+ --project=<id> Project ID to use for the studio
79
+ --project-plan=<name> Optionally select a plan for a new project
80
+ --provider=<provider> Login provider to use
81
+ --template=<template> [default: clean] Project template to use
82
+ [default: "clean"]
83
+ --[no-]typescript Enable TypeScript support
84
+ --visibility=<mode> Visibility mode for dataset
85
+
86
+ GLOBAL FLAGS
87
+ --json Format output as json.
88
+
89
+ NEXT.JS FLAGS
90
+ --[no-]nextjs-add-config-files Add config files to Next.js project
91
+ --[no-]nextjs-append-env Append project ID and dataset to .env file
92
+ --[no-]nextjs-embed-studio Embed the Studio in Next.js application
93
+
94
+ DESCRIPTION
95
+ Initialize a new Sanity Studio, project and/or app
96
+
97
+ EXAMPLES
98
+ $ sanity init
99
+
100
+ Initialize a new project with a public dataset named "production"
101
+
102
+ $ sanity init --dataset-default
103
+
104
+ Initialize a project with the given project ID and dataset to the given path
105
+
106
+ $ sanity init -y --project abc123 --dataset production --output-path \
107
+ ~/myproj
108
+
109
+ Initialize a project with the given project ID and dataset using the moviedb
110
+ template to the given path
111
+
112
+ $ sanity init -y --project abc123 --dataset staging --template moviedb \
113
+ --output-path .
114
+
115
+ Create a brand new project with name "Movies Unlimited"
116
+
117
+ $ sanity init -y --create-project "Movies Unlimited" --dataset moviedb \
118
+ --visibility private --template moviedb --output-path \
119
+ /Users/espenh/movies-unlimited
120
+
121
+ "
122
+ `);
123
+ });
124
+ test.each([
125
+ {
126
+ flag1: 'auto-updates',
127
+ flag2: 'bare'
128
+ },
129
+ {
130
+ flag1: 'coupon=123',
131
+ flag2: 'project-plan=123'
132
+ },
133
+ {
134
+ flag1: 'dataset="123',
135
+ flag2: 'dataset-default'
136
+ },
137
+ {
138
+ flag1: 'env=.env',
139
+ flag2: 'bare'
140
+ },
141
+ {
142
+ flag1: 'git=test',
143
+ flag2: 'bare'
144
+ },
145
+ {
146
+ flag1: 'no-git',
147
+ flag2: 'git=test'
148
+ },
149
+ {
150
+ flag1: 'output-path=/test-path',
151
+ flag2: 'bare'
152
+ },
153
+ {
154
+ flag1: 'package-manager=pnpm',
155
+ flag2: 'bare'
156
+ },
157
+ {
158
+ flag1: 'template=test',
159
+ flag2: 'bare'
160
+ },
161
+ {
162
+ flag1: 'typescript',
163
+ flag2: 'bare'
164
+ },
165
+ {
166
+ flag1: 'project=test',
167
+ flag2: 'create-project=test'
168
+ }
169
+ ])('throws error when `$flag1` and `$flag2` flags are both passed', async ({ flag1, flag2 })=>{
170
+ const { error } = await testCommand(InitCommand, [
171
+ `--${flag1}`,
172
+ `--${flag2}`
173
+ ], {
174
+ mocks: {
175
+ isInteractive: true,
176
+ token: 'test-token'
177
+ }
178
+ });
179
+ const [name1] = flag1.split('=');
180
+ const [name2, value2 = 'true'] = flag2.split('=');
181
+ expect(error?.message).toContain(`--${name2}=${value2} cannot also be provided when using --${name1}`);
182
+ });
183
+ test.each([
184
+ {
185
+ flag: 'env',
186
+ message: 'Env filename (`--env`) must start with `.env`',
187
+ value: 'invalid.txt'
188
+ },
189
+ {
190
+ flag: 'visibility',
191
+ message: 'Expected --visibility=opaque to be one of: public, private',
192
+ value: 'opaque'
193
+ },
194
+ {
195
+ flag: 'package-manager',
196
+ message: 'Expected --package-manager=pnm to be one of: npm, yarn, pnpm',
197
+ value: 'pnm'
198
+ }
199
+ ])('throws error when `$flag` value is invalid', async ({ flag, message, value })=>{
200
+ const { error } = await testCommand(InitCommand, [
201
+ `--${flag}=${value}`
202
+ ], {
203
+ mocks: {
204
+ isInteractive: true,
205
+ token: 'test-token'
206
+ }
207
+ });
208
+ expect(error?.message).toContain(message);
209
+ });
210
+ test('throws error when type argument is passed', async ()=>{
211
+ const { error } = await testCommand(InitCommand, [
212
+ 'bad-argument'
213
+ ], {
214
+ mocks: {
215
+ isInteractive: true,
216
+ token: 'test-token'
217
+ }
218
+ });
219
+ expect(error?.message).toContain('Unknown init type "bad-argument"');
220
+ });
221
+ test('throws deprecation error when type argument is passed with `plugin`', async ()=>{
222
+ const { error } = await testCommand(InitCommand, [
223
+ 'plugin'
224
+ ], {
225
+ mocks: {
226
+ isInteractive: true,
227
+ token: 'test-token'
228
+ }
229
+ });
230
+ expect(error?.message).toContain('Initializing plugins through the CLI is no longer supported');
231
+ });
232
+ test('throws error when `reconfigure` flag is passed', async ()=>{
233
+ const { error } = await testCommand(InitCommand, [
234
+ '--reconfigure'
235
+ ], {
236
+ mocks: {
237
+ isInteractive: true,
238
+ token: 'test-token'
239
+ }
240
+ });
241
+ expect(error?.message).toContain('--reconfigure is deprecated - manual configuration is now required');
242
+ });
243
+ test('throws error when framework and remote template are used together', async ()=>{
244
+ mocks.detectFrameworkRecord.mockResolvedValueOnce({
245
+ name: 'Next.js',
246
+ slug: 'nextjs'
247
+ });
248
+ mocks.checkIsRemoteTemplate.mockReturnValueOnce(true);
249
+ mocks.getGitHubRepoInfo.mockResolvedValueOnce({
250
+ branch: 'main',
251
+ owner: 'sanity-io',
252
+ repo: 'sanity'
253
+ });
254
+ const { error } = await testCommand(InitCommand, [
255
+ '--template=https://github.com/sanity-io/sanity'
256
+ ], {
257
+ mocks: {
258
+ isInteractive: true,
259
+ token: 'test-token'
260
+ }
261
+ });
262
+ expect(error?.message).toContain('A remote template cannot be used with a detected framework. Detected: Next.js');
263
+ });
264
+ test('throws error when in unattended mode and `dataset` is not set', async ()=>{
265
+ const { error } = await testCommand(InitCommand, [
266
+ '--yes'
267
+ ], {
268
+ mocks: {
269
+ token: 'test-token'
270
+ }
271
+ });
272
+ expect(error?.message).toContain('`--dataset` must be specified in unattended mode');
273
+ });
274
+ test('throws error when `output-path` is not used in unattended mode with non-nextjs project', async ()=>{
275
+ // Mock no framework or a non-Next.js framework
276
+ mocks.detectFrameworkRecord.mockResolvedValueOnce(null);
277
+ const { error } = await testCommand(InitCommand, [
278
+ '--yes',
279
+ '--dataset=production',
280
+ '--project=test-project'
281
+ ], {
282
+ mocks: {
283
+ token: 'test-token'
284
+ }
285
+ });
286
+ // Should throw output-path error for non-Next.js projects
287
+ expect(error?.message).toContain('`--output-path` must be specified in unattended mode');
288
+ });
289
+ test('throws error when in unattended mode and `project` and `create-project` not set', async ()=>{
290
+ mocks.detectFrameworkRecord.mockResolvedValueOnce({
291
+ name: 'Next.js',
292
+ slug: 'nextjs'
293
+ });
294
+ const { error } = await testCommand(InitCommand, [
295
+ '--yes',
296
+ '--dataset=production'
297
+ ], {
298
+ mocks: {
299
+ token: 'test-token'
300
+ }
301
+ });
302
+ expect(error?.message).toContain('`--project <id>` or `--create-project <name>` must be specified in unattended mode');
303
+ });
304
+ test('throws error when in unattended mode and `create-project` not set with `organization`', async ()=>{
305
+ mocks.detectFrameworkRecord.mockResolvedValueOnce({
306
+ name: 'Next.js',
307
+ slug: 'nextjs'
308
+ });
309
+ const { error } = await testCommand(InitCommand, [
310
+ '--yes',
311
+ '--dataset=production',
312
+ '--create-project=test'
313
+ ], {
314
+ mocks: {
315
+ token: 'test-token'
316
+ }
317
+ });
318
+ expect(error?.message).toContain('--create-project is not supported in unattended mode without an organization, please specify an organization with `--organization <id>`');
319
+ });
320
+ test('logs properly if app template flag is not valid', async ()=>{
321
+ mocks.detectFrameworkRecord.mockResolvedValueOnce(null);
322
+ const { stdout } = await testCommand(InitCommand, [
323
+ '--template=invalid-template-name'
324
+ ], {
325
+ mocks: {
326
+ isInteractive: true,
327
+ token: 'test-token'
328
+ }
329
+ });
330
+ // When template is not an app template, it should log "Fetching existing projects"
331
+ expect(stdout).toContain('Fetching existing projects');
332
+ });
333
+ });
334
+
335
+ //# sourceMappingURL=init.setup.test.js.map