@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.
- package/dist/actions/auth/login/{index.js → login.js} +1 -1
- package/dist/actions/auth/login/{index.js.map → login.js.map} +1 -1
- package/dist/actions/dev/startStudioDevServer.js +3 -8
- package/dist/actions/dev/startStudioDevServer.js.map +1 -1
- package/dist/actions/dev/types.d.ts +1 -3
- package/dist/actions/dev/types.js.map +1 -1
- package/dist/actions/documents/validate.d.ts +0 -2
- package/dist/actions/documents/validate.js +21 -1
- package/dist/actions/documents/validate.js.map +1 -1
- package/dist/actions/exec/execScript.js +1 -1
- package/dist/actions/exec/execScript.js.map +1 -1
- package/dist/actions/graphql/__tests__/getGraphQLAPIs.test.js +1 -1
- package/dist/actions/graphql/__tests__/getGraphQLAPIs.test.js.map +1 -1
- package/dist/actions/graphql/getGraphQLAPIs.js +1 -1
- package/dist/actions/graphql/getGraphQLAPIs.js.map +1 -1
- package/dist/actions/manifest/extractManifest.js +1 -4
- package/dist/actions/manifest/extractManifest.js.map +1 -1
- package/dist/actions/organizations/getOrganizationChoices.d.ts +6 -0
- package/dist/actions/organizations/getOrganizationChoices.js +23 -0
- package/dist/actions/organizations/getOrganizationChoices.js.map +1 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.d.ts +2 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js +9 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js.map +1 -0
- package/dist/actions/organizations/hasProjectAttachGrant.d.ts +1 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js +24 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js.map +1 -0
- package/dist/actions/schema/deleteSchemaAction.d.ts +13 -5
- package/dist/actions/schema/deleteSchemaAction.js +12 -17
- package/dist/actions/schema/deleteSchemaAction.js.map +1 -1
- package/dist/actions/schema/deploySchemas.d.ts +15 -0
- package/dist/actions/schema/deploySchemas.js +98 -0
- package/dist/actions/schema/deploySchemas.js.map +1 -0
- package/dist/actions/schema/listSchemas.d.ts +12 -0
- package/dist/actions/schema/listSchemas.js +119 -0
- package/dist/actions/schema/listSchemas.js.map +1 -0
- package/dist/actions/schema/schemaStoreTypes.d.ts +0 -11
- package/dist/actions/schema/schemaStoreTypes.js.map +1 -1
- package/dist/actions/schema/utils/debug.d.ts +2 -0
- package/dist/actions/schema/utils/debug.js +5 -0
- package/dist/actions/schema/utils/debug.js.map +1 -0
- package/dist/actions/schema/utils/manifestExtractor.d.ts +3 -8
- package/dist/actions/schema/utils/manifestExtractor.js +12 -17
- package/dist/actions/schema/utils/manifestExtractor.js.map +1 -1
- package/dist/actions/schema/utils/manifestReader.d.ts +2 -9
- package/dist/actions/schema/utils/manifestReader.js +6 -12
- package/dist/actions/schema/utils/manifestReader.js.map +1 -1
- package/dist/actions/schema/utils/schemaStoreOutStrings.d.ts +0 -1
- package/dist/actions/schema/utils/schemaStoreOutStrings.js +1 -1
- package/dist/actions/schema/utils/schemaStoreOutStrings.js.map +1 -1
- package/dist/actions/schema/utils/schemaStoreValidation.d.ts +10 -62
- package/dist/actions/schema/utils/schemaStoreValidation.js +40 -127
- package/dist/actions/schema/utils/schemaStoreValidation.js.map +1 -1
- package/dist/actions/schema/utils/uniqByProjectIdDataset.d.ts +14 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js +9 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js.map +1 -0
- package/dist/actions/users/getMembersForProject.d.ts +1 -3
- package/dist/actions/users/getMembersForProject.js +6 -17
- package/dist/actions/users/getMembersForProject.js.map +1 -1
- package/dist/actions/users/types.d.ts +0 -11
- package/dist/actions/users/types.js.map +1 -1
- package/dist/commands/__tests__/debug.test.js +113 -220
- package/dist/commands/__tests__/debug.test.js.map +1 -1
- package/dist/commands/__tests__/deploy.test.js +325 -293
- package/dist/commands/__tests__/deploy.test.js.map +1 -1
- package/dist/commands/__tests__/dev.test.js +62 -19
- package/dist/commands/__tests__/dev.test.js.map +1 -1
- package/dist/commands/__tests__/init/init.authentication.test.js +73 -0
- package/dist/commands/__tests__/init/init.authentication.test.js.map +1 -0
- package/dist/commands/__tests__/init/init.create-new-project.test.js +195 -0
- package/dist/commands/__tests__/init/init.create-new-project.test.js.map +1 -0
- package/dist/commands/__tests__/init/init.plan.test.js +279 -0
- package/dist/commands/__tests__/init/init.plan.test.js.map +1 -0
- package/dist/commands/__tests__/init/init.setup.test.js +335 -0
- package/dist/commands/__tests__/init/init.setup.test.js.map +1 -0
- package/dist/commands/__tests__/install.test.js +46 -22
- package/dist/commands/__tests__/install.test.js.map +1 -1
- package/dist/commands/__tests__/logout.test.js +8 -5
- package/dist/commands/__tests__/logout.test.js.map +1 -1
- package/dist/commands/__tests__/manage.test.js +29 -24
- package/dist/commands/__tests__/manage.test.js.map +1 -1
- package/dist/commands/__tests__/migration.test.js +119 -0
- package/dist/commands/__tests__/migration.test.js.map +1 -0
- package/dist/commands/__tests__/versions.test.js +22 -14
- package/dist/commands/__tests__/versions.test.js.map +1 -1
- package/dist/commands/backup/__tests__/disable.test.js +72 -75
- package/dist/commands/backup/__tests__/disable.test.js.map +1 -1
- package/dist/commands/backup/__tests__/download.test.js +169 -80
- package/dist/commands/backup/__tests__/download.test.js.map +1 -1
- package/dist/commands/backup/__tests__/enable.test.js +109 -140
- package/dist/commands/backup/__tests__/enable.test.js.map +1 -1
- package/dist/commands/backup/__tests__/list.test.js +84 -75
- package/dist/commands/backup/__tests__/list.test.js.map +1 -1
- package/dist/commands/backup/disable.js +5 -11
- package/dist/commands/backup/disable.js.map +1 -1
- package/dist/commands/backup/enable.js +5 -11
- package/dist/commands/backup/enable.js.map +1 -1
- package/dist/commands/backup/list.js +7 -8
- package/dist/commands/backup/list.js.map +1 -1
- package/dist/commands/cors/__tests__/add.test.js +68 -38
- package/dist/commands/cors/__tests__/add.test.js.map +1 -1
- package/dist/commands/cors/__tests__/delete.test.js +52 -37
- package/dist/commands/cors/__tests__/delete.test.js.map +1 -1
- package/dist/commands/cors/__tests__/list.test.js +80 -57
- package/dist/commands/cors/__tests__/list.test.js.map +1 -1
- package/dist/commands/cors/add.js +5 -13
- package/dist/commands/cors/add.js.map +1 -1
- package/dist/commands/cors/delete.js +7 -15
- package/dist/commands/cors/delete.js.map +1 -1
- package/dist/commands/cors/list.js +2 -10
- package/dist/commands/cors/list.js.map +1 -1
- package/dist/commands/dataset/__tests__/copy.test.js +197 -89
- package/dist/commands/dataset/__tests__/copy.test.js.map +1 -1
- package/dist/commands/dataset/__tests__/create.test.js +147 -117
- package/dist/commands/dataset/__tests__/create.test.js.map +1 -1
- package/dist/commands/dataset/__tests__/delete.test.js +75 -68
- package/dist/commands/dataset/__tests__/delete.test.js.map +1 -1
- package/dist/commands/dataset/__tests__/export.test.js +123 -83
- package/dist/commands/dataset/__tests__/export.test.js.map +1 -1
- package/dist/commands/dataset/__tests__/import.test.js +2 -2
- package/dist/commands/dataset/__tests__/import.test.js.map +1 -1
- package/dist/commands/dataset/__tests__/list.test.js +107 -65
- package/dist/commands/dataset/__tests__/list.test.js.map +1 -1
- package/dist/commands/dataset/alias/__tests__/create.test.js +114 -74
- package/dist/commands/dataset/alias/__tests__/create.test.js.map +1 -1
- package/dist/commands/dataset/alias/__tests__/delete.test.js +40 -29
- package/dist/commands/dataset/alias/__tests__/delete.test.js.map +1 -1
- package/dist/commands/dataset/alias/__tests__/link.test.js +114 -74
- package/dist/commands/dataset/alias/__tests__/link.test.js.map +1 -1
- package/dist/commands/dataset/alias/__tests__/unlink.test.js +44 -29
- package/dist/commands/dataset/alias/__tests__/unlink.test.js.map +1 -1
- package/dist/commands/dataset/export.js +4 -4
- package/dist/commands/dataset/export.js.map +1 -1
- package/dist/commands/dataset/visibility/__tests__/get.test.js +48 -67
- package/dist/commands/dataset/visibility/__tests__/get.test.js.map +1 -1
- package/dist/commands/dataset/visibility/__tests__/set.test.js +76 -123
- package/dist/commands/dataset/visibility/__tests__/set.test.js.map +1 -1
- package/dist/commands/dev.js +0 -1
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/docs/__tests__/search.test.js +8 -7
- package/dist/commands/docs/__tests__/search.test.js.map +1 -1
- package/dist/commands/documents/__tests__/create.test.js +328 -265
- package/dist/commands/documents/__tests__/create.test.js.map +1 -1
- package/dist/commands/documents/__tests__/delete.test.js +119 -87
- package/dist/commands/documents/__tests__/delete.test.js.map +1 -1
- package/dist/commands/documents/__tests__/get.test.js +68 -95
- package/dist/commands/documents/__tests__/get.test.js.map +1 -1
- package/dist/commands/documents/__tests__/query.test.js +87 -192
- package/dist/commands/documents/__tests__/query.test.js.map +1 -1
- package/dist/commands/documents/__tests__/validate.test.js +52 -29
- package/dist/commands/documents/__tests__/validate.test.js.map +1 -1
- package/dist/commands/documents/create.d.ts +1 -0
- package/dist/commands/documents/create.js +10 -9
- package/dist/commands/documents/create.js.map +1 -1
- package/dist/commands/documents/delete.js +2 -3
- package/dist/commands/documents/delete.js.map +1 -1
- package/dist/commands/documents/get.js +2 -3
- package/dist/commands/documents/get.js.map +1 -1
- package/dist/commands/documents/query.js +2 -3
- package/dist/commands/documents/query.js.map +1 -1
- package/dist/commands/documents/validate.js +0 -20
- package/dist/commands/documents/validate.js.map +1 -1
- package/dist/commands/graphql/__tests__/list.test.js +57 -45
- package/dist/commands/graphql/__tests__/list.test.js.map +1 -1
- package/dist/commands/graphql/__tests__/undeploy.test.js +85 -59
- package/dist/commands/graphql/__tests__/undeploy.test.js.map +1 -1
- package/dist/commands/graphql/list.js +2 -2
- package/dist/commands/graphql/list.js.map +1 -1
- package/dist/commands/graphql/undeploy.js +4 -9
- package/dist/commands/graphql/undeploy.js.map +1 -1
- package/dist/commands/hook/__tests__/attempt.test.js +48 -33
- package/dist/commands/hook/__tests__/attempt.test.js.map +1 -1
- package/dist/commands/hook/__tests__/create.test.js +49 -51
- package/dist/commands/hook/__tests__/create.test.js.map +1 -1
- package/dist/commands/hook/__tests__/delete.test.js +43 -30
- package/dist/commands/hook/__tests__/delete.test.js.map +1 -1
- package/dist/commands/hook/__tests__/list.test.js +38 -31
- package/dist/commands/hook/__tests__/list.test.js.map +1 -1
- package/dist/commands/hook/__tests__/logs.test.js +68 -40
- package/dist/commands/hook/__tests__/logs.test.js.map +1 -1
- package/dist/commands/hook/create.js +2 -6
- package/dist/commands/hook/create.js.map +1 -1
- package/dist/commands/hook/delete.js +5 -17
- package/dist/commands/hook/delete.js.map +1 -1
- package/dist/commands/hook/list.js +2 -8
- package/dist/commands/hook/list.js.map +1 -1
- package/dist/commands/init.d.ts +4 -0
- package/dist/commands/init.js +151 -18
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/login.js +1 -1
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/manifest/__tests__/extract.test.js +22 -13
- package/dist/commands/manifest/__tests__/extract.test.js.map +1 -1
- package/dist/commands/media/__tests__/create-aspect.test.js +41 -28
- package/dist/commands/media/__tests__/create-aspect.test.js.map +1 -1
- package/dist/commands/media/__tests__/delete-aspect.test.js +44 -35
- package/dist/commands/media/__tests__/delete-aspect.test.js.map +1 -1
- package/dist/commands/media/__tests__/deploy-aspect.test.js +67 -80
- package/dist/commands/media/__tests__/deploy-aspect.test.js.map +1 -1
- package/dist/commands/media/__tests__/export.test.js +365 -66
- package/dist/commands/media/__tests__/export.test.js.map +1 -1
- package/dist/commands/media/__tests__/import.test.js +171 -105
- package/dist/commands/media/__tests__/import.test.js.map +1 -1
- package/dist/commands/media/export.js +2 -2
- package/dist/commands/media/export.js.map +1 -1
- package/dist/commands/media/import.js +2 -2
- package/dist/commands/media/import.js.map +1 -1
- package/dist/commands/projects/__tests__/list.test.js +5 -4
- package/dist/commands/projects/__tests__/list.test.js.map +1 -1
- package/dist/commands/projects/list.js +2 -6
- package/dist/commands/projects/list.js.map +1 -1
- package/dist/commands/schema/__tests__/delete.test.js +396 -151
- package/dist/commands/schema/__tests__/delete.test.js.map +1 -1
- package/dist/commands/schema/__tests__/deploy.test.js +348 -0
- package/dist/commands/schema/__tests__/deploy.test.js.map +1 -0
- package/dist/commands/schema/__tests__/extract.test.js +19 -11
- package/dist/commands/schema/__tests__/extract.test.js.map +1 -1
- package/dist/commands/schema/__tests__/list.test.js +399 -0
- package/dist/commands/schema/__tests__/list.test.js.map +1 -0
- package/dist/commands/schema/__tests__/validate.test.js +27 -10
- package/dist/commands/schema/__tests__/validate.test.js.map +1 -1
- package/dist/commands/schema/delete.d.ts +1 -1
- package/dist/commands/schema/delete.js +20 -23
- package/dist/commands/schema/delete.js.map +1 -1
- package/dist/commands/schema/deploy.d.ts +16 -0
- package/dist/commands/schema/deploy.js +98 -0
- package/dist/commands/schema/deploy.js.map +1 -0
- package/dist/commands/schema/list.d.ts +15 -0
- package/dist/commands/schema/list.js +104 -0
- package/dist/commands/schema/list.js.map +1 -0
- package/dist/commands/telemetry/__tests__/disable.test.js +7 -5
- package/dist/commands/telemetry/__tests__/disable.test.js.map +1 -1
- package/dist/commands/telemetry/__tests__/enable.test.js +7 -5
- package/dist/commands/telemetry/__tests__/enable.test.js.map +1 -1
- package/dist/commands/telemetry/__tests__/status.test.js +7 -5
- package/dist/commands/telemetry/__tests__/status.test.js.map +1 -1
- package/dist/commands/tokens/__tests__/add.test.js +55 -40
- package/dist/commands/tokens/__tests__/add.test.js.map +1 -1
- package/dist/commands/tokens/__tests__/delete.test.js +72 -42
- package/dist/commands/tokens/__tests__/delete.test.js.map +1 -1
- package/dist/commands/tokens/__tests__/list.test.js +87 -60
- package/dist/commands/tokens/__tests__/list.test.js.map +1 -1
- package/dist/commands/tokens/add.js +3 -5
- package/dist/commands/tokens/add.js.map +1 -1
- package/dist/commands/users/__tests__/invite.test.js +100 -79
- package/dist/commands/users/__tests__/invite.test.js.map +1 -1
- package/dist/commands/users/__tests__/list.test.js +186 -180
- package/dist/commands/users/__tests__/list.test.js.map +1 -1
- package/dist/commands/users/invite.js +6 -17
- package/dist/commands/users/invite.js.map +1 -1
- package/dist/commands/users/list.js +4 -7
- package/dist/commands/users/list.js.map +1 -1
- package/dist/config/createCliConfig.d.ts +4 -4
- package/dist/services/backup.d.ts +8 -0
- package/dist/services/backup.js +19 -0
- package/dist/services/backup.js.map +1 -1
- package/dist/services/cors.d.ts +23 -0
- package/dist/services/cors.js +38 -0
- package/dist/services/cors.js.map +1 -0
- package/dist/services/graphql.d.ts +7 -0
- package/dist/services/graphql.js +11 -0
- package/dist/services/graphql.js.map +1 -1
- package/dist/services/hooks.d.ts +2 -0
- package/dist/services/hooks.js +19 -0
- package/dist/services/hooks.js.map +1 -1
- package/dist/services/organizations.d.ts +40 -0
- package/dist/services/organizations.js +41 -0
- package/dist/services/organizations.js.map +1 -0
- package/dist/services/projects.d.ts +31 -0
- package/dist/services/projects.js +71 -1
- package/dist/services/projects.js.map +1 -1
- package/dist/services/schemas.d.ts +4 -0
- package/dist/services/schemas.js +40 -0
- package/dist/services/schemas.js.map +1 -0
- package/dist/services/user.d.ts +10 -0
- package/dist/services/user.js +24 -0
- package/dist/services/user.js.map +1 -0
- package/dist/util/__tests__/getCliVersion.test.js +2 -2
- package/dist/util/__tests__/getCliVersion.test.js.map +1 -1
- package/dist/util/errorMessages.d.ts +1 -0
- package/dist/util/errorMessages.js +1 -0
- package/dist/util/errorMessages.js.map +1 -1
- package/dist/util/getCliVersion.js +1 -1
- package/dist/util/getCliVersion.js.map +1 -1
- package/dist/util/readPackageJson.d.ts +1 -15
- package/dist/util/readPackageJson.js +1 -1
- package/dist/util/readPackageJson.js.map +1 -1
- package/dist/util/uniqBy.d.ts +1 -0
- package/dist/util/uniqBy.js +14 -0
- package/dist/util/uniqBy.js.map +1 -0
- package/oclif.config.js +6 -1
- package/oclif.manifest.json +152 -158
- package/package.json +30 -31
- package/dist/actions/cors/constants.d.ts +0 -1
- package/dist/actions/cors/constants.js +0 -3
- package/dist/actions/cors/constants.js.map +0 -1
- package/dist/actions/cors/types.d.ts +0 -9
- package/dist/actions/cors/types.js +0 -3
- package/dist/actions/cors/types.js.map +0 -1
- package/dist/actions/migration/getMigrationRootDirectory.d.ts +0 -2
- package/dist/actions/migration/getMigrationRootDirectory.js +0 -14
- package/dist/actions/migration/getMigrationRootDirectory.js.map +0 -1
- package/dist/actions/migration/resolveMigrations.d.ts +0 -19
- package/dist/actions/migration/resolveMigrations.js +0 -43
- package/dist/actions/migration/resolveMigrations.js.map +0 -1
- package/dist/actions/migration/templates/__tests__/minimalAdvanced.test.js +0 -65
- package/dist/actions/migration/templates/__tests__/minimalAdvanced.test.js.map +0 -1
- package/dist/actions/migration/templates/__tests__/minimalSimple.test.js +0 -145
- package/dist/actions/migration/templates/__tests__/minimalSimple.test.js.map +0 -1
- package/dist/actions/migration/templates/__tests__/renameField.test.js +0 -63
- package/dist/actions/migration/templates/__tests__/renameField.test.js.map +0 -1
- package/dist/actions/migration/templates/__tests__/renameType.test.js +0 -61
- package/dist/actions/migration/templates/__tests__/renameType.test.js.map +0 -1
- package/dist/actions/migration/templates/__tests__/stringToPTE.test.js +0 -87
- package/dist/actions/migration/templates/__tests__/stringToPTE.test.js.map +0 -1
- package/dist/actions/migration/templates/index.d.ts +0 -5
- package/dist/actions/migration/templates/index.js +0 -7
- package/dist/actions/migration/templates/index.js.map +0 -1
- package/dist/actions/migration/templates/minimalAdvanced.d.ts +0 -4
- package/dist/actions/migration/templates/minimalAdvanced.js +0 -21
- package/dist/actions/migration/templates/minimalAdvanced.js.map +0 -1
- package/dist/actions/migration/templates/minimalSimple.d.ts +0 -4
- package/dist/actions/migration/templates/minimalSimple.js +0 -61
- package/dist/actions/migration/templates/minimalSimple.js.map +0 -1
- package/dist/actions/migration/templates/renameField.d.ts +0 -4
- package/dist/actions/migration/templates/renameField.js +0 -20
- package/dist/actions/migration/templates/renameField.js.map +0 -1
- package/dist/actions/migration/templates/renameType.d.ts +0 -4
- package/dist/actions/migration/templates/renameType.js +0 -19
- package/dist/actions/migration/templates/renameType.js.map +0 -1
- package/dist/actions/migration/templates/stringToPTE.d.ts +0 -4
- package/dist/actions/migration/templates/stringToPTE.js +0 -32
- package/dist/actions/migration/templates/stringToPTE.js.map +0 -1
- package/dist/actions/schema/__tests__/deleteSchemaAction.test.js +0 -294
- package/dist/actions/schema/__tests__/deleteSchemaAction.test.js.map +0 -1
- package/dist/actions/schema/schemaStoreConstants.d.ts +0 -1
- package/dist/actions/schema/schemaStoreConstants.js +0 -4
- package/dist/actions/schema/schemaStoreConstants.js.map +0 -1
- package/dist/actions/schema/utils/schemaActionHelpers.d.ts +0 -1
- package/dist/actions/schema/utils/schemaActionHelpers.js +0 -5
- package/dist/actions/schema/utils/schemaActionHelpers.js.map +0 -1
- package/dist/actions/schema/utils/schemaApiClient.d.ts +0 -6
- package/dist/actions/schema/utils/schemaApiClient.js +0 -17
- package/dist/actions/schema/utils/schemaApiClient.js.map +0 -1
- package/dist/actions/users/apiVersion.d.ts +0 -6
- package/dist/actions/users/apiVersion.js +0 -7
- package/dist/actions/users/apiVersion.js.map +0 -1
- package/dist/commands/__tests__/init.test.js +0 -411
- package/dist/commands/__tests__/init.test.js.map +0 -1
- package/dist/commands/migration/__tests__/create.test.js +0 -296
- package/dist/commands/migration/__tests__/create.test.js.map +0 -1
- package/dist/commands/migration/__tests__/list.test.js +0 -166
- package/dist/commands/migration/__tests__/list.test.js.map +0 -1
- package/dist/commands/migration/__tests__/run.test.js +0 -481
- package/dist/commands/migration/__tests__/run.test.js.map +0 -1
- package/dist/commands/migration/create.d.ts +0 -17
- package/dist/commands/migration/create.js +0 -143
- package/dist/commands/migration/create.js.map +0 -1
- package/dist/commands/migration/list.d.ts +0 -9
- package/dist/commands/migration/list.js +0 -61
- package/dist/commands/migration/list.js.map +0 -1
- package/dist/commands/migration/run.d.ts +0 -26
- package/dist/commands/migration/run.js +0 -271
- package/dist/commands/migration/run.js.map +0 -1
- package/dist/util/migration/constants.d.ts +0 -3
- package/dist/util/migration/constants.js +0 -10
- package/dist/util/migration/constants.js.map +0 -1
- package/dist/util/migration/ensureApiVersionFormat.d.ts +0 -9
- package/dist/util/migration/ensureApiVersionFormat.js +0 -16
- package/dist/util/migration/ensureApiVersionFormat.js.map +0 -1
- package/dist/util/migration/prettyMutationFormatter.d.ts +0 -8
- package/dist/util/migration/prettyMutationFormatter.js +0 -141
- package/dist/util/migration/prettyMutationFormatter.js.map +0 -1
- package/dist/utils/migration/resolveMigrationScript.d.ts +0 -44
- package/dist/utils/migration/resolveMigrationScript.js +0 -74
- package/dist/utils/migration/resolveMigrationScript.js.map +0 -1
- /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
|