-
-
Notifications
You must be signed in to change notification settings - Fork 492
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
Test documentation standards #241
Comments
Not sure if we'd test with tokens or with Reflection. If the latter, WP-Parser may have code we could use, cc @Rarst. |
This is not the parser you are looking for. waves hand |
PHPDocumentor uses reflection, so if you are going to leverage its code, I think you'll have to use reflection. I'm doubtful you'd find anything helpful out of WP-Parser at the moment though. |
On second thought, it would be great to leverage WP-Parser's exporter, but I think it's still entangled a bit with WP-CLI, so it might take a bit of work. It would parse hook docs for you though, which is something PHPDocumentor isn't gonna do on its own. |
Anyone happen to know if individual tokens might actually exist inside a comment block? I'm guessing not... |
No, they don't. |
If you want to take a whack at leveraging WP-Parser, take a look at the |
Please approve this gist (test for It is copied from PEAR Coding Standard and if you agree I help develop in that way. Please note that the comments in those files are not revised and it only tests for
If you mean something like "T_DOC_COMMENT_OPEN_TAG" then the answer is yes: https://pear.php.net/package/PHP_CodeSniffer/docs/latest/PHP_CodeSniffer/_PHP_CodeSniffer-2.0.0RC1---CodeSniffer---Tokens.php.html |
If it could test for all it mentions (except the Getting ahead of ourselves, I'd foresee this as being a WordPress-Docs ruleset, since I could imagine that folks would want to test documentation standards separately from non-comment code quality. Updated: Actually, I disagree with that. Documentation is a vital part of coding, it's a standard on make.wp.org, so we should be encouraging it as part of the WordPress-Core / Extra standards like non-comment standards. |
It's not quite perfect for WP, but it's an extremely good starting point. |
Plenty of false positives to eliminate and checks to fill by creating new sniffs that extend existing ones. See #241
See https://github.com/squizlabs/PHP_CodeSniffer/tree/phpcs-fixer/CodeSniffer/Standards/Squiz/Sniffs/Commenting Some will need WP variants as the Squiz and Generic ones don't quite match what we want, or we need to use the originals but with severity = 0 so it's not reported. |
See @Rarst's tweet in regards to incorporating the |
I'm going to change my mind again. I think a WordPress-Docs ruleset is best, but include that in the overall WordPress ruleset, so that it's still on by default. |
Lots of exclusions from the default Squiz.Commenting, and not looked to see if Generic might be better. Plenty of cases where we're going to need to write custom sniffs, if there aren't parameters to tweak what we need. I've created a quick test file and asked the Docs channel on Slack to see if this is right so we can check the perfect case doesn't generate false positives. |
I'd like to whitelist which messages are reported, but this isn't possible - we can only include rules, and then exclude messages - but we can include the overall Squiz.Commenting and then still exclude messages, as already done in the branch. |
There are still plenty of checks not made, but this first pass takes advantage of the existing code sniffs that match the WordPress handbook for inline documentation and commenting. See #241
|
@GaryJones I think this can be closed now that |
No @JDGrimes - that was the first pass / easy wins. There are still plenty of aspects of comments / inline docs that are not yet tested, so I'd like to keep this open. Alternatively, it can be closed, and a new one opened if that makes sense for the release paper trail. |
Just wanted to comment, as it resulted in us changing how we used the WordPress coding standards. According to here: https://make.wordpress.org/core/handbook/inline-documentation-standards/php-documentation-standards/ Wordpress makes an attempt to adopt PSR-5 standards, but they are not intending it to be PSR-5 compliant. Further, the language of the drafted standards here use SHOULD and RECOMMENDED throughout, but this changes the intent to almost a MUST. While I agree that these SHOULD be present, I'm also answering to developers that are working to ensure we meet the standards they MUST have according to the Wordpress standards defined. Do you have special insight into this process that suggests WordPress standards will enforce the need for this, as we have had none. My thought is, these should not be listed as errors when they are merely recommended and should be present but not required. (It pains me to say that as I would rather they be required!) It makes it complicated when we have a standard being enforced as the "WordPress" standard which doesn't actually match "WordPress' standard". |
No coding standards is a MUST, certainly not one from created from a community, instead of internal company decisions. As such, it makes all the suggestions optional. While the language in PSR-5 is a little forgiving, the coding standards in the WP Handbook are less so, and that's what the WPCS sniffs try to emulate.There's no special insight here - the choice to have inline comments and documentation in a certain way is no different than the choice of naming things or use of whitespace in other parts of the handbook. If you're company decision is to take all of them at the SHOULD level instead of MUST, then that's your right to do so. |
Sorry, I guess what I meant is prior to #381 Wordpress-Docs was not included in the Wordpress ruleset, thus in the past we were not forced to exclude tests. This is what I meant by "Must" versus "Should", if it is optional, and having sent lots of code to VIP the commenting is pretty optional, then why make those checks part of a basic Wordpress ruleset by default? Certainly we work around it...by adding exclusions all throughout our code for something that we previously did not have to exclude. |
If you are checking code for VIP, you might just want to use the
If you still want to use the whole <?xml version="1.0"?>
<ruleset name="WordPress-Custom">
<description>Custom WordPress Coding Standards</description>
<rule ref="WordPress"/>
<exclude ref="WordPress-Docs"/>
</ruleset> |
Thanks. |
I sort of implied this in passing above, but we should sniff hook docs as well. I think that will require us to write some custom sniffs, though. |
It will - this ticket was only ever about re-using existing sniffs that match what WP wants already. There's plenty of aspects of non-hook DocBlocks that are not tested yet. |
OK, I've make a separate ticket: #424 |
I'm not sure where this is at in getting over the finish line, but I'd be happy to put some time towards it. I think this would be a huge benefit to the community. |
I think the work needing to be done for this is to create a test suite of code that uses the WordPress documentation standards, and then to run PHPCS with |
Please add tests for documentation standards:
https://make.wordpress.org/core/handbook/inline-documentation-standards/php-documentation-standards/
The text was updated successfully, but these errors were encountered: