From 4616b78f2d9564c11af82f3d9ba30b0b57d3cf24 Mon Sep 17 00:00:00 2001 From: Gabriel Ratcliff Date: Thu, 8 Aug 2019 10:01:13 -0700 Subject: [PATCH 1/3] Fixed documentation for version usage, and bug with cli-arg package that incorrectly dealt with booleans --- README.md | 8 ++++---- cmds/versions/create.js | 18 ++++++++++-------- cmds/versions/delete.js | 2 +- cmds/versions/update.js | 16 +++++++++------- 4 files changed, 24 insertions(+), 20 deletions(-) diff --git a/README.md b/README.md index 237a8b947..b4d3f5402 100644 --- a/README.md +++ b/README.md @@ -105,7 +105,7 @@ If you wish to see the raw output from our API in this response, supply the `-- #### Create a new version ```sh -rdme versions:create +rdme versions:create --version={project-version} ``` ##### Automating this process @@ -114,14 +114,14 @@ If you wish to automate the process of creating a new project version, and not h For example: ```sh -rdme versions:create --fork={version-fork} --codename={version-name} --main --beta +rdme versions:create --version={project-version} --fork={version-fork} --main={boolean} --beta={boolean} --isPublic={boolean} ``` See `rdme versions:create --help` for a full list of flags. #### Update a version ```sh -rdme versions:update +rdme versions:update --version={project-version} ``` Like `versions:create`, if you wish to automate this process and not be blocked by CLI input, you can supply the necessary flags to this command. See `rdme versions:update --help` or [automating this process](#automating-this-process) for more information. @@ -130,7 +130,7 @@ Like `versions:create`, if you wish to automate this process and not be blocked You can remove a specific version from your project, as well as all of the attached specs ```sh -rdme versions:delete +rdme versions:delete --version={project-version} ``` ### Open your ReadMe project in your browser diff --git a/cmds/versions/create.js b/cmds/versions/create.js index 308755bdf..c135bf676 100644 --- a/cmds/versions/create.js +++ b/cmds/versions/create.js @@ -4,7 +4,7 @@ const { prompt } = require('enquirer'); const promptOpts = require('../../lib/prompts'); exports.command = 'versions:create'; -exports.usage = 'versions:create [options]'; +exports.usage = 'versions:create --version={project-version} [options]'; exports.description = 'Create a new version for your project.'; exports.category = 'versions'; exports.position = 2; @@ -33,17 +33,17 @@ exports.args = [ }, { name: 'main', - type: Boolean, + type: String, description: 'Should this version be the primary (default) version for your project?', }, { name: 'beta', - type: Boolean, + type: String, description: 'Is this version in beta?', }, { name: 'isPublic', - type: Boolean, + type: String, description: 'Would you like to make this version public? Any primary version must be public.', }, ]; @@ -51,7 +51,7 @@ exports.args = [ exports.run = async function(opts) { let versionList; const { key, version, codename, fork, main, beta, isPublic } = opts; - + console.log(isPublic); if (!key) { return Promise.reject(new Error('No project API key provided. Please use `--key`.')); } @@ -78,10 +78,12 @@ exports.run = async function(opts) { json: { version, codename: codename || '', - is_stable: main || promptResponse.is_stable, - is_beta: beta || promptResponse.is_beta, + is_stable: main === 'true' || promptResponse.is_stable, + is_beta: beta === 'true' || promptResponse.is_beta, from: fork || promptResponse.from, - is_hidden: promptResponse.is_stable ? false : !(isPublic || promptResponse.is_hidden), + is_hidden: promptResponse.is_stable + ? false + : !(isPublic === 'true' || promptResponse.is_hidden), }, auth: { user: key }, }; diff --git a/cmds/versions/delete.js b/cmds/versions/delete.js index 625fa7344..eddbe2bde 100644 --- a/cmds/versions/delete.js +++ b/cmds/versions/delete.js @@ -2,7 +2,7 @@ const request = require('request-promise-native'); const config = require('config'); exports.command = 'versions:delete'; -exports.usage = 'versions:delete [options]'; +exports.usage = 'versions:delete --version={project-version} [options]'; exports.description = 'Delete a version associated with your ReadMe project.'; exports.category = 'versions'; exports.position = 4; diff --git a/cmds/versions/update.js b/cmds/versions/update.js index f342a7170..7fefddfb3 100644 --- a/cmds/versions/update.js +++ b/cmds/versions/update.js @@ -4,7 +4,7 @@ const { prompt } = require('enquirer'); const promptOpts = require('../../lib/prompts'); exports.command = 'versions:update'; -exports.usage = 'versions:update [options]'; +exports.usage = 'versions:update --version={project-version} [options]'; exports.description = 'Update an existing version for your project.'; exports.category = 'versions'; exports.position = 3; @@ -27,17 +27,17 @@ exports.args = [ }, { name: 'main', - type: Boolean, + type: String, description: 'Should this version be the primary (default) version for your project?', }, { name: 'beta', - type: Boolean, + type: String, description: 'Is this version in beta?', }, { name: 'isPublic', - type: Boolean, + type: String, description: 'Would you like to make this version public? Any primary version must be public.', }, ]; @@ -69,10 +69,12 @@ exports.run = async function(opts) { json: { codename: codename || '', version: newVersion || promptResponse.newVersion, - is_stable: foundVersion.is_stable || main || promptResponse.is_stable, - is_beta: beta || promptResponse.is_beta, + is_stable: foundVersion.is_stable || main === 'true' || promptResponse.is_stable, + is_beta: beta === 'true' || promptResponse.is_beta, is_deprecated: deprecated || promptResponse.is_deprecated, - is_hidden: promptResponse.is_stable ? false : !(isPublic || promptResponse.is_hidden), + is_hidden: promptResponse.is_stable + ? false + : !(isPublic === 'true' || promptResponse.is_hidden), }, auth: { user: key }, }; From 4b8e4a1bd2b0d7934f3192f6767b87ce0ffc7062 Mon Sep 17 00:00:00 2001 From: Gabriel Ratcliff Date: Thu, 8 Aug 2019 10:03:06 -0700 Subject: [PATCH 2/3] removed console.log statement --- cmds/versions/create.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmds/versions/create.js b/cmds/versions/create.js index c135bf676..74aad24d3 100644 --- a/cmds/versions/create.js +++ b/cmds/versions/create.js @@ -51,7 +51,7 @@ exports.args = [ exports.run = async function(opts) { let versionList; const { key, version, codename, fork, main, beta, isPublic } = opts; - console.log(isPublic); + if (!key) { return Promise.reject(new Error('No project API key provided. Please use `--key`.')); } From 29f7d00129d12ddc348bbdfa307c1500d7d367c4 Mon Sep 17 00:00:00 2001 From: Gabriel Ratcliff Date: Thu, 8 Aug 2019 10:21:00 -0700 Subject: [PATCH 3/3] updated docs to reflect multiple interactions with version create --- README.md | 4 ++-- cmds/versions/create.js | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index b4d3f5402..7262bee84 100644 --- a/README.md +++ b/README.md @@ -105,7 +105,7 @@ If you wish to see the raw output from our API in this response, supply the `-- #### Create a new version ```sh -rdme versions:create --version={project-version} +rdme versions:create | --version={project-version} ``` ##### Automating this process @@ -114,7 +114,7 @@ If you wish to automate the process of creating a new project version, and not h For example: ```sh -rdme versions:create --version={project-version} --fork={version-fork} --main={boolean} --beta={boolean} --isPublic={boolean} +rdme versions:create | --version={project-version} --fork={version-fork} --main={boolean} --beta={boolean} --isPublic={boolean} ``` See `rdme versions:create --help` for a full list of flags. diff --git a/cmds/versions/create.js b/cmds/versions/create.js index 74aad24d3..3b9c5af5d 100644 --- a/cmds/versions/create.js +++ b/cmds/versions/create.js @@ -4,7 +4,7 @@ const { prompt } = require('enquirer'); const promptOpts = require('../../lib/prompts'); exports.command = 'versions:create'; -exports.usage = 'versions:create --version={project-version} [options]'; +exports.usage = 'versions:create | --version={project-version} [options]'; exports.description = 'Create a new version for your project.'; exports.category = 'versions'; exports.position = 2;