From 87bd5ba8e515f1888fd1248ef3b2e6ee00a6c9a8 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Thu, 24 Aug 2023 08:27:34 -0500 Subject: [PATCH] fix(versions): fix ability to set main version --- __tests__/cmds/versions/create.test.ts | 28 +++++++++++++++++++ __tests__/cmds/versions/update.test.ts | 38 +++++++++++++++++++++++++- src/cmds/versions/create.ts | 3 +- src/cmds/versions/update.ts | 3 +- src/lib/prompts.ts | 4 +-- 5 files changed, 71 insertions(+), 5 deletions(-) diff --git a/__tests__/cmds/versions/create.test.ts b/__tests__/cmds/versions/create.test.ts index a5a058e47..9ca0208a1 100644 --- a/__tests__/cmds/versions/create.test.ts +++ b/__tests__/cmds/versions/create.test.ts @@ -98,6 +98,34 @@ describe('rdme versions:create', () => { mockRequest.done(); }); + it('should create successfully a main version', async () => { + const newVersion = '1.0.1'; + + const mockRequest = getAPIMock() + .post('/api/v1/version', { + version: newVersion, + from: '1.0.0', + is_beta: false, + is_stable: true, + }) + .basicAuth({ user: key }) + .reply(201, { version: newVersion }); + + await expect( + createVersion.run({ + key, + version: newVersion, + fork: version, + beta: 'false', + main: 'true', + isPublic: 'false', + deprecated: 'true', + }), + ).resolves.toBe(`Version ${newVersion} created successfully.`); + + mockRequest.done(); + }); + it('should catch any post request errors', async () => { const errorResponse = { error: 'VERSION_EMPTY', diff --git a/__tests__/cmds/versions/update.test.ts b/__tests__/cmds/versions/update.test.ts index 5577c0641..80c135e34 100644 --- a/__tests__/cmds/versions/update.test.ts +++ b/__tests__/cmds/versions/update.test.ts @@ -211,6 +211,41 @@ describe('rdme versions:update', () => { mockRequest.done(); }); + it('should update a version to be the main one', async () => { + const versionToChange = '1.1.0'; + const renamedVersion = '1.1.0-update'; + + const updatedVersionObject = { + version: renamedVersion, + is_beta: false, + is_stable: true, + }; + + const mockRequest = getAPIMock() + .get(`/api/v1/version/${versionToChange}`) + .basicAuth({ user: key }) + .reply(200, { version: versionToChange }) + .get(`/api/v1/version/${versionToChange}`) + .basicAuth({ user: key }) + .reply(200, { version: versionToChange }) + .put(`/api/v1/version/${versionToChange}`, updatedVersionObject) + .basicAuth({ user: key }) + .reply(201, updatedVersionObject); + + await expect( + updateVersion.run({ + key, + version: versionToChange, + newVersion: renamedVersion, + deprecated: 'true', + beta: 'false', + main: 'true', + isPublic: 'false', + }), + ).resolves.toBe(`Version ${versionToChange} updated successfully.`); + mockRequest.done(); + }); + // Note: this test is a bit bizarre since the flag management // in our version commands is really confusing to follow. // I'm not sure if it's technically possible to demote a stable version @@ -222,11 +257,12 @@ describe('rdme versions:update', () => { const updatedVersionObject = { version: renamedVersion, is_beta: true, + is_deprecated: true, is_hidden: true, is_stable: false, }; - prompts.inject([renamedVersion, true]); + prompts.inject([renamedVersion, true, false, true]); const errorResponse = { error: 'VERSION_CANT_DEMOTE_STABLE', diff --git a/src/cmds/versions/create.ts b/src/cmds/versions/create.ts index ffeaa1c0e..5b79854e2 100644 --- a/src/cmds/versions/create.ts +++ b/src/cmds/versions/create.ts @@ -82,7 +82,8 @@ export default class CreateVersionCommand extends Command { from: promptResponse.from, is_beta: promptResponse.is_beta, is_deprecated: promptResponse.is_deprecated, - is_hidden: !promptResponse.is_public, + // if the "is public" question was never asked, we should omit that from the payload + is_hidden: typeof promptResponse.is_public === 'undefined' ? undefined : !promptResponse.is_public, is_stable: promptResponse.is_stable, }; diff --git a/src/cmds/versions/update.ts b/src/cmds/versions/update.ts index dc4e3cdfb..fd587985b 100644 --- a/src/cmds/versions/update.ts +++ b/src/cmds/versions/update.ts @@ -69,7 +69,8 @@ export default class UpdateVersionCommand extends Command { version: promptResponse.newVersion || version, is_beta: promptResponse.is_beta, is_deprecated: promptResponse.is_deprecated, - is_hidden: !promptResponse.is_public, + // if the "is public" question was never asked, we should omit that from the payload + is_hidden: typeof promptResponse.is_public === 'undefined' ? undefined : !promptResponse.is_public, is_stable: promptResponse.is_stable, }; diff --git a/src/lib/prompts.ts b/src/lib/prompts.ts index 1d4d1b56c..331b41960 100644 --- a/src/lib/prompts.ts +++ b/src/lib/prompts.ts @@ -179,7 +179,7 @@ export function versionPrompt( }, { type: (prev, values) => { - // if user previously wanted this version to be the main version + // if user wants this version to be the main version // it can't also be hidden. return values.is_stable ? null : 'confirm'; }, @@ -188,7 +188,7 @@ export function versionPrompt( }, { type: (prev, values) => { - // if user previously wanted this version to be the main version + // if user wants this version to be the main version // it can't also be deprecated. return values.is_stable ? null : 'confirm'; },