-
Notifications
You must be signed in to change notification settings - Fork 330
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixes providing value for required option. Closes #6518 #6520
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Copilot reviewed 1 out of 1 changed files in this pull request and generated no comments.
Comments suppressed due to low confidence (1)
src/cli/cli.ts:201
- Ensure that the new behavior introduced by the getCommandOptionsFromArgs function is covered by tests to verify correct parsing and coercion of the answer.
const parsed = getCommandOptionsFromArgs([`--${optionName}`, answer], cli.commandToExecute);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's working great. Although I found a small issue. When a boolean option is required, as mentioned in the issue, the CLI prompts for a value if it's not passed. However, I've noticed that if you just press enter, and thus not providing a value, you are getting an uncaught exception.
This behavior does not happen when you type the required option as number
or string
, only when it's typed as boolean
. Maybe we should just use a default value just like we do for other option types.
Good catch! I updated the code with handling coercion errors and throwing the same error as you'd get if you'd specify the value in args. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Apart from a tiny remark, it looks good to me!
@@ -1093,6 +1115,29 @@ describe('cli', () => { | |||
}); | |||
}); | |||
|
|||
it(`throws error if coercing value fails when validating schema`, (done) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let use async/await for new tests.
Fixes providing value for required option. Closes #6518