2013-10-29 20:57:49 +00:00
# How to contribute
CakePHP loves to welcome your contributions. There are several ways to help out:
* Create an [issue ](https://github.com/cakephp/cakephp/issues ) on GitHub, if you have found a bug
2014-03-22 02:55:28 +00:00
* Write test cases for open bug issues
* Write patches for open bug/feature issues, preferably with test cases included
2013-10-29 20:57:49 +00:00
* Contribute to the [documentation ](https://github.com/cakephp/docs )
There are a few guidelines that we need contributors to follow so that we have a
chance of keeping on top of things.
## Getting Started
* Make sure you have a [GitHub account ](https://github.com/signup/free ).
* Submit an [issue ](https://github.com/cakephp/cakephp/issues ), assuming one does not already exist.
* Clearly describe the issue including steps to reproduce when it is a bug.
* Make sure you fill in the earliest version that you know has the issue.
* Fork the repository on GitHub.
## Making Changes
* Create a topic branch from where you want to base your work.
* This is usually the master branch.
* Only target release branches if you are certain your fix must be on that
branch.
* To quickly create a topic branch based on master; `git branch
master/my_contribution master` then checkout the new branch with `git
checkout master/my_contribution`. Better avoid working directly on the
`master` branch, to avoid conflicts if you pull in updates from origin.
* Make commits of logical units.
* Check for unnecessary whitespace with `git diff --check` before committing.
* Use descriptive commit messages and reference the #issue number.
2014-03-22 02:55:28 +00:00
* Core test cases should continue to pass. You can run tests locally or enable
2013-10-29 20:57:49 +00:00
[travis-ci ](https://travis-ci.org/ ) for your fork, so all tests and codesniffs
will be executed.
2014-07-14 08:37:50 +00:00
* Your work should apply the [CakePHP coding standards ](http://book.cakephp.org/2.0/en/contributing/cakephp-coding-conventions.html ).
2013-10-29 20:57:49 +00:00
## Which branch to base the work
* Bugfix branches will be based on master.
* New features that are backwards compatible will be based on next minor release
branch.
2014-07-14 08:37:50 +00:00
* New features or other non backwards compatible changes will go in the next major release branch.
2013-10-29 20:57:49 +00:00
## Submitting Changes
* Push your changes to a topic branch in your fork of the repository.
* Submit a pull request to the repository in the cakephp organization, with the
correct target branch.
2014-03-22 02:55:28 +00:00
## Test cases and codesniffer
2013-10-29 20:57:49 +00:00
CakePHP tests requires [PHPUnit ](http://www.phpunit.de/manual/current/en/installation.html )
2014-07-14 08:37:50 +00:00
3.7, version 4 is not compatible. To run the test cases locally use the following command:
2013-10-29 20:57:49 +00:00
./lib/Cake/Console/cake test core AllTests --stderr
To run the sniffs for CakePHP coding standards:
phpcs -p --extensions=php --standard=CakePHP ./lib/Cake
Check the [cakephp-codesniffer ](https://github.com/cakephp/cakephp-codesniffer )
2014-07-14 08:37:50 +00:00
repository to setup the CakePHP standard. The [README ](https://github.com/cakephp/cakephp-codesniffer/blob/master/README.mdown ) contains installation info
2013-10-29 20:57:49 +00:00
for the sniff and phpcs.
# Additional Resources
* [CakePHP coding standards ](http://book.cakephp.org/2.0/en/contributing/cakephp-coding-conventions.html )
* [Existing issues ](https://github.com/cakephp/cakephp/issues )
2013-10-29 21:04:09 +00:00
* [Development Roadmaps ](https://github.com/cakephp/cakephp/wiki#roadmaps )
2013-10-29 20:57:49 +00:00
* [General GitHub documentation ](https://help.github.com/ )
* [GitHub pull request documentation ](https://help.github.com/send-pull-requests/ )
* #cakephp IRC channel on freenode.org