-
Notifications
You must be signed in to change notification settings - Fork 553
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
Add validator to method_options with type :string, :numeric, :array and :hash #485
base: main
Are you sure you want to change the base?
Conversation
@sferik Is there any chance that you take a little bit of your time and review this? Thanks a lot in advance. |
@sferik Anything missing here? |
👍 |
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.
LGTM. I added a comment about missing tests and it needs a rebase
|
||
it "accepts value when value 't match validator" do | ||
create :attributes => Thor::Option.new("attributes", :type => :hash, :validator => proc { |k,v| /name/ === k && /string/ === v}, :validator_desc => 'description') | ||
expect { parse("--attributes", "name:string") }.not_to raise_error |
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 is missing tests to arguments_spec like those one.
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.
What do you expect to be tested:
- Option valditaor also works if arguments are given?
- Adds validator to arguments as well?
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.
You changed lib/thor/argument.rb to add validator support already. You add tests on this file to make sure when parsing the options the validators are respected, but there are no tests for when an argument is being parsed.
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.
@rafaelfranca I'd love to see this code merged, and have some time available to work on it. I'm not understanding what kind of tests you would like to see.
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.
Test for the argument parser that now also accepts validators.
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.
@rafaelfranca The argument parser seems contradictory. It accepts an Array
of Argument
objects, then assigns those to a @switches
variable, then later checks if that variable contains a Hash
. The iteration within the file also seems very strange, and it's difficult to see how the "enum" argument functionality could be working. The argument code seems to need revision and clarification.
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.
@rafaelfranca Is this the test that is missing? Perhaps I have misunderstood: benkoshy@b9a735d
(btw thank you for your open source contributions)
Is
You can control what values of arguments/options
thor
accepts via:string
,:boolean
(options only),:numeric
,:array
and:hash
. Sometimes that's not enough.Given you've got an application like
middleman
I used regularly - a static site generator similar tojekyll
- which has aserver
-command. This command has at least two options "relevant" for this use case:host
port
A host name is defined in RFC 952 and is not allowed to include blanks or space characters -- look for "No blank or space characters are permitted as part of a name". It needs to match
^(?=.{1,255}$)[0-9A-Za-z](?:(?:[0-9A-Za-z]|-){0,61}[0-9A-Za-z])?(?:\.[0-9A-Za-z](?:(?:[0-9A-Za-z]|-){0,61}[0-9A-Za-z])?)*\.?$
to be valid. Using just:string
is not enough to validate a host name.A TCP port is defined as an integer from 0 to 65536 - see more in RFC6056. It needs to match
(0..65535).include?(port)
. Just checking if it's a number is not enough either.Today those checks are not possible, unfortunately.
Should
It should be possible to define a more granular check for
:string
,:numeric
,:array
and:hash
. It should iterate over all values of an:array
- and over all keys/values of a:hash
-option/argument. The validator should have an easy to use API, e.g.validator#call
-- if#call
is used, you can use a proc/lambda-object as validator. To make it clear to users, that there are some more checks a validator must also have a description for those checks. Because a proc/lambda should be supported as well, this should be another option for#method_option
.Using the examples from above the validator, a validator should look like this:
Port Example
Hostname Example
This PR implements this.
To be discussed
:validator
+:validator_desc
?:validator
and:validator_desc
I used
_desc
because there's an option named:desc
for a option-description already:validator_desc
will be enforced, otherwise the developer may forget to add a clear description for end users, that a validator is in use and what the requirements of this validator arevalidation
. I thought that it might be helpful to make the user aware of a validation by adding the relevant information to the help command#call
-method? I thought that this is the most flexible and easy to use solutionsource_code
-documentation. Is there any other place - besides the wiki - where I need to document the new options? I will update the wiki, if this PR is accepted.Checklist From CONTRIBUTING
waiting for CI to be finished.