Blame view

vendor/robmorgan/phinx/CONTRIBUTING.md 2.69 KB
6c4edfa3   Alexandre   First Commit LabI...
1
2
3
# How to contribute to Phinx

Phinx relies heavily on external contributions in order to make it the best database migration
c3f2e5a1   Thibaud Ajas   MAJ DE PHP v5.6 -...
4
tool possible. Without the support of our 115+ contributors we wouldn't be where we are today!
6c4edfa3   Alexandre   First Commit LabI...
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
We encourage anyone to submit documentation enhancements and code.

Issues, feature requests and bugs should be submitted using the Github issue tool:
https://github.com/robmorgan/phinx/issues.

This document briefly outlines the requirements to contribute code to Phinx.

## Considerations

Before you submit your pull request take a moment to answer the following questions.

Answering '**YES**' to all questions will increase the likelihood of your PR being accepted!

* Have I implemented my feature for as many database adapters as possible?
* Does my new feature improve Phinx's performance or keep it consistent?
* Does my feature fit within the database migration space?
* Is the code entirely my own and free from any commercial licensing?
* Am I happy to release my code under the MIT license?
* Is my code formatted using the [PSR-2](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md) coding standard?

**Note:** We accept bug fixes much faster into our development branch than features.

## Getting Started

Great, so you want to contribute. Let's get started:

1. Start by forking Phinx on GitHub: https://github.com/robmorgan/phinx

1. Clone your repository to a local directory on your development box.

1. If you do not have Composer set up already, install it:

    ```
    curl -sS https://getcomposer.org/installer | php
    ```

1. Change to your Phinx clone directory and pull the necessary dependencies:

    ```
    php composer.phar install
    ```

1. Copy the `phpunit.xml.dist` template to `phpunit.xml` and change the configuration to suit your environment. If you are not using any particular adapter you can disable it in the `phpunit.xml` file.

1. Run the unit tests locally to ensure they pass:

    ```
    php vendor/bin/phpunit --config phpunit.xml
    ```

1. Write the code and unit tests for your bug fix or feature.

1. Add any relevant documentation.

1. Run the unit tests again and ensure they pass.

1. Open a pull request on the Github project page. Ensure the code is being merged into the latest development branch (e.g: `0.5.x-dev`) and not `master`.

## Documentation

The Phinx documentation is stored in the **docs** directory using the [RestructedText](http://docutils.sourceforge.net/rst.html) format. All documentation merged to `master` is automatically published to the Phinx documentation site available
at: http://docs.phinx.org. Keep this in mind when submitting your PR, or ask someone to merge the development branch back down to master.