-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Coding style policy #362
Comments
To enforce the policy, you have to use tools like https://github.com/squizlabs/PHP_CodeSniffer with some sort of CI like travis. |
This should be defined in conjunction with a maximum line width, so stuff like this becomes history: throw new \HttpException('"PHP Simple HTML DOM Parser" library is missing. Get it from http://simplehtmldom.sourceforge.net and place the script "simple_html_dom.php" in '.substr(PATH_VENDOR,4) . '/simplehtmldom/', 500); It is 220 chars long! To make the line width predictable I think spaces are the best way to go. Also spaces don't require any special editor setup, so... +1 for spaces I guess 👍
@aledeg: Do you, or anyone here, have experience with travis? This would actually help a great deal!
Is this of any use: https://developer.github.com/v3/repos/hooks/? |
I may be wrong but I think it is only for the enterprise version |
I started a page in the wiki |
@logmanoriginal I do have experience with travis. I am using it at work. I only have experience with the enterprise version though. But from my experience, travis documentations are well written. |
@logmanoriginal |
Good to know 😄
To make it short: The file was a complete mess and I went with the indentation which was present the most - which turned out to be 4 spaces 😄 Which brings me to:
There is not much else we can do until we got something automated up and running. Once we got an automated service like TravisCI we can discuss these things via Issues and PRs. Right now we should focus on stuff that really breaks experience which is: indentation, line length and naming conventions. I see you have made a proposal for trailing white spaces. I would like to keep that out for now (feel free to use it though), because this is something that doesn't actually troubles us, right? That being said, naming conventions are already used throughout the core, with some exceptions it's camelCase. Of course class names should be PascalCase (UpperCamelCase). Your proposal goes in that direction (except class names) and I see no technical reason to do it otherwise. Line length of 80 chars is considered good practice since... ever. There are reasons to go beyond, though there should be a hard-cap at say 120 chars. I like what Linus Torvalds once wrote:
Regarding indentation let's just go for 2 spaces. As you said there is no technical reason to have 4 spaces except preferences. One thing I feel is important: For the core we should enforce these policies (via Travis or such), for bridges these should be guidelines. Since bridges are not part of the core this is acceptable in my opinion. |
with phpcs, you can decide what you can enforce as a coding style. |
@logmanoriginal |
I think I got you now, thanks again 😆 |
Here's an example of what I've set at work. I cannot share much but I think it could give you an insight of what is possible. phpcs configuration: <?xml version="1.0" encoding="UTF-8"?>
<ruleset name="Project custom standard">
<description>Current project custom standard</description>
<exclude-pattern>./vendor</exclude-pattern>
<exclude-pattern>./web</exclude-pattern>
<exclude-pattern>./var</exclude-pattern>
<rule ref="PSR2"/>
<rule ref="PSR1.Classes.ClassDeclaration.MissingNamespace">
<exclude-pattern>./tests/features/bootstrap/FeatureContext.php</exclude-pattern>
<exclude-pattern>./app/AppKernel.php</exclude-pattern>
<exclude-pattern>./app/AppCache.php</exclude-pattern>
</rule>
</ruleset> travis configuration: ...
script:
- vendor/bin/phpunit
- vendor/bin/phpcs . --standard=phpcs.ruleset.xml --warning-severity=0 --extensions=php -p
- vendor/bin/behat -fprogress -v
... |
Thanks to @aledeg I found a way to introduce TravisCI with PHP_CodeSniffer. Not sure if you have access, but here is what the results look like. https://travis-ci.org/LogMANOriginal/rss-bridge Based on this branch: https://github.com/LogMANOriginal/rss-bridge/tree/ContinuousIntegration I'll push these changes directly to master in a few minutes, but one of the admins needs to authorize Travis to access RSS-Bridge. Which I request next. Stay tuned 😊 Merged: accbe8c, authorization for Travis pending... |
Good job. Now there is a lot of corrections to add :) |
Boo spaces. Go tabs! :-P I always display my tabs as two spaces though, so there's that. |
I have already prepared, most can be solved via simple regex search & replace operations, which is what I'll push once Travis is online... 😄
That is actually an amazing feature, which left me 😮 the first time I read about it 😄
I'm with you 😢 😉 The reason for spaces is to avoid problems with editors and make the line width more calculable. Another reason is because @pmaziere was first 😆 My editor auto-adapts, so I don't really care much. Also I can easily convert between tabs/spaces (this could also be automated on load/save) 😇
It might be possible to do that directly via git, though I have never tried: http://stackoverflow.com/a/2318063 |
@mitsukarenai / @ArthurHoaro: Did one of you receive a notification from Travis regarding the access request? This requires an admin of the RSS-Bridge organization. Would be great if we could get this running soon 😀 I'm not entirely sure how this is setup with organizations, though it is possible: |
I am more with tabs as well, as it allows everyone to display the code the way they prefer. As for the line size, I think that phpcs makes the calculation automatically. |
if the majority goes for tabs let's go for tabs |
@logmanoriginal : We can't set up Travis, as we are not Owners of the organization, but only members. This requires @mitsukarenai or @ArthurHoaro |
Yes it does
Yes, I know. However we are able to select the repository in our Travis accounts and request access, which notifies the admins. I did that, so let's wait for the things to come. |
@logmanoriginal I've checked the travis configuration you wrote. For example: matrix:
fast_finish: true
allow_failures:
- php: nightly
- php: hhvm It will allow to fail some tests without failing the whole suite. For now, it is not really important as you only test for coding standard. But in the future, if you want to include some unit tests and/or test scenarii, it could be useful. |
I started with this and never changed it later. Right now we only test coding standards, so PHP 5.4 should be enough. I really have to find some time to read their documentation (It's very well written btw 👍), but I'm very busy for the rest of this week, so I'll have to do that on the weekend.
Check out #379 |
I think we should test on all the supported version of PHP, as our users may be using any of these versions. |
@teromene For unit test for sure. But as mentioned @logmanoriginal, for coding standard, you could test only on one version. |
Hmm, you are right, it seems phpcs can detect deprecated functions: https://github.com/squizlabs/PHP_CodeSniffer/blob/master/CodeSniffer/Standards/Generic/Sniffs/PHP/DeprecatedFunctionsSniff.php This means we have to run it on multiple versions to get notified... Know what, the current script is working, so let's keep it as it is. We can add the idea from @aledeg to allow failures of |
@aledeg Please correct me if I'm wrong: phpcs can detect deprecated functions (there is even this project for extension 😮). Since .travis.yml supports conditional statements and phpcs allows for multiple standards, we can check coding standards on one particular PHP version (5.4) and check for deprecated functions on all. Of course 'nightly' and 'hhvm' may fail if they so desire. Of course this Issue #362 is about the coding standard, so for that particular requirement only one PHP version is necessary. We can all agree indentation isn't going to break in future versions 😈 |
I wasn't aware of that extension. I will report that at work, it can become handy. I never had to use it, because I code only on PHP 7. My guess is that you have to run it on any version of PHP and configure it to check the supported versions.
You'll never know ^^ |
I have just applied some coding styles and updated the phpcs checks, such that travis will at least pass (once we got it running that is -- hint @mitsukarenai 😀) For now I decided to go with:
Function names and such are still as before. However the phpcs.xml defines some additional checks, so have a look if you are interested. I did this in order to get at least ANY style into the core framework, which was a complete mess before 😡 Please have a look and if you find anything absolutely not acceptable let's discuss it here. If there are no objections, I'll begin writing the phpcs configuration as rules into the Wiki after a few days/weeks (depends on my free time ⌚) Oh, yeah, here is the passing travis on my branch: https://travis-ci.org/LogMANOriginal/rss-bridge/builds/159008586 --- It's so green ❤️ |
wakes up |
@mitsukarenai |
Travis-CI allows to perform automated checks on source code from GitHub. It basically is a server running lots of virtual machines that clone your repository and perform checks based on what you configure in your travis.yml file. Here is an live example of Travis doing checks on PRs, which actually gives you a nice indicator and some feedback on what actually went wrong: https://github.com/travis-ci-examples/php/pulls Last but not least we can then add another banner to the readme file to indicate the working state of the master branch like this: Not sure if you received the notification or not, but in order to grant access for travis to RSS-Bridge you'll have to login at https://travis-ci.org/ with your GitHub account and grant access to the RSS-Bridge repostory via the menus. It's basically turning a switch like this under your "organization" settings: |
We use Travis in KOReader. It can be quite a useful way to prevent regressions. |
Shaarli uses Travis to run its unit tests, if you want another PHP example. Setting up Travis isn't really difficult, writing unit tests can take a bit longer. 😃 |
@ArthurHoaro : You have admin access to rss-bridge, but we haven't. We just need you or @mitsukarenai to flip the switch in Travis interface 😄 |
Done! |
I have created a first base of a Contributing file here. Please tell me what you think. |
I assume "squash your commits" isn't meant to imply one issue, one commit but merely to squash, e.g., minor typo fix commits? Because I think it's much easier to dissect or follow along with multiple smaller commits. What I mean is illustrated quite nicely in #341. I don't think that would be improved either by squashing or by splitting it up into multiple PRs. It could also be useful to give some guidelines about how to write the commit message. I've personally used |
Yes, that's what I mean when I say "squash the commits". |
Updated again using @logmanoriginal remarks. |
Okay, this has been sitting around for quite a while now. I'm fine with the proposed styles and I don't think it gets any better by ignoring it any longer 😁 I just compared the current phpcs.xml against the definitions in the contributions.md. The current version works if we add @teromene For the contributions.md please consider my last comment. I'll create a PR to add the contributions.md, update phpcs.xml and fix everything. That way we don't break master and we can squash and merge everything in one go. |
Okay, the PR passed Travis 🎉 Please have a look at #475 and let me know what you think. Especially about forcibly camel-casing function names. In my opinion we should allow (partial) upper-case names where it makes sense (like 'RSS' instead of 'Rss'). Unfortunately I couldn't find a sniff that allows partial upper-cases, so yeah... If there are no objections I'll merge someday next week, before master diverges 😨 |
761c66d happened. The only thing missing is the CONTRIBUTIONS.md |
CONTRIBUTING.md has been added in 2dda74d. |
Indentation is a mess all over the place.
Maybe we could start defining some policy regarding this issue and others, so that every one can stick to it.
Concerning indentation, I'm on spaces side rather than tabs.
But I guess I could find a way for vim to display the number of columns by indentation level that I like even with tabs.
Anyway, I think it really has to be consistent all over the project files.
I don't know much about git hooks, but that could be a good starting point to enforce this policy before integrating a patch.
client side example
Any ideas on how to enforce such a policy ?
The text was updated successfully, but these errors were encountered: