Update PR guide and add a "short" version

This commit is contained in:
Bruno Oliveira 2017-07-22 15:58:12 -03:00
parent 1cf826624e
commit 61219da0e2
1 changed files with 46 additions and 23 deletions

View File

@ -158,19 +158,39 @@ As stated, the objective is to share maintenance and avoid "plugin-abandon".
.. _`pull requests`: .. _`pull requests`:
.. _pull-requests: .. _pull-requests:
Preparing Pull Requests on GitHub Preparing Pull Requests
--------------------------------- -----------------------
.. note:: Short version
What is a "pull request"? It informs project's core developers about the ~~~~~~~~~~~~~
changes you want to review and merge. Pull requests are stored on
`GitHub servers <https://github.com/pytest-dev/pytest/pulls>`_.
Once you send a pull request, we can discuss its potential modifications and
even add more commits to it later on.
There's an excellent tutorial on how Pull Requests work in the #. Fork the repository;
`GitHub Help Center <https://help.github.com/articles/using-pull-requests/>`_, #. Target ``master`` for bug-fix and doc changes;
but here is a simple overview: #. Target ``features`` for new features or functionality changes.
#. Follow **PEP-8**. There's a ``tox`` command to help fixing it: ``tox -e fix-lint``.
#. Tests are run using ``tox``::
tox -e linting,py27,py36
The test environments above are usually enough to to cover most cases locally.
#. Write a ``changelog`` entry: ``changelog/2574.bugfix``, use issue id number and one of
``bugfix``, ``removal``, ``feature``, ``vendor``, ``doc`` or ``trivial`` for the issue type.
#. Add yourself to ``AUTHORS`` file if not there yet, in alphabetical order.
Long version
~~~~~~~~~~~~
What is a "pull request"? It informs project's core developers about the
changes you want to review and merge. Pull requests are stored on
`GitHub servers <https://github.com/pytest-dev/pytest/pulls>`_.
Once you send a pull request, we can discuss its potential modifications and
even add more commits to it later on. There's an excellent tutorial on how Pull Requests work in the
`GitHub Help Center <https://help.github.com/articles/using-pull-requests/>`_.
Here is a simple overview, with pytest-specific bits:
#. Fork the #. Fork the
`pytest GitHub repository <https://github.com/pytest-dev/pytest>`__. It's `pytest GitHub repository <https://github.com/pytest-dev/pytest>`__. It's
@ -212,19 +232,20 @@ but here is a simple overview:
$ tox -e linting,py27,py36 $ tox -e linting,py27,py36
This command will run tests via the "tox" tool against Python 2.7 and 3.6 This command will run tests via the "tox" tool against Python 2.7 and 3.6
and also perform "lint" coding-style checks. If you have too much linting errors, and also perform "lint" coding-style checks.
try running::
#. You can now edit your local working copy. Please follow PEP-8.
You can now make the changes you want and run the tests again as necessary.
If you have too much linting errors, try running::
$ tox -e fix-lint $ tox -e fix-lint
To fix pep8 related errors. To fix pep8 related errors.
#. You can now edit your local working copy. You can pass different options to ``tox``. For example, to run tests on Python 2.7 and pass options to pytest
(e.g. enter pdb on failure) to pytest you can do::
You can now make the changes you want and run the tests again as necessary.
To run tests on Python 2.7 and pass options to pytest (e.g. enter pdb on
failure) to pytest you can do::
$ tox -e py27 -- --pdb $ tox -e py27 -- --pdb
@ -237,9 +258,11 @@ but here is a simple overview:
$ git commit -a -m "<commit message>" $ git commit -a -m "<commit message>"
$ git push -u $ git push -u
Make sure you add a message to ``CHANGELOG.rst`` and add yourself to #. Create a new changelog entry in ``changelog``. The file should be named ``<issueid>.<type>``,
``AUTHORS``. If you are unsure about either of these steps, submit your where *issueid* is the number of the issue related to the change and *type* is one of
pull request and we'll help you fix it up. ``bugfix``, ``removal``, ``feature``, ``vendor``, ``doc`` or ``trivial``.
#. Add yourself to ``AUTHORS`` file if not there yet, in alphabetical order.
#. Finally, submit a pull request through the GitHub website using this data:: #. Finally, submit a pull request through the GitHub website using this data::