test_ok2/doc/en/development_guide.rst

61 lines
2.3 KiB
ReStructuredText
Raw Normal View History

=================
2017-09-08 04:48:34 +08:00
Development Guide
=================
2017-09-08 04:48:34 +08:00
Some general guidelines regarding development in pytest for maintainers and contributors. Nothing here
2017-09-08 04:48:34 +08:00
is set in stone and can't be changed, feel free to suggest improvements or changes in the workflow.
Code Style
----------
* `PEP-8 <https://www.python.org/dev/peps/pep-0008>`_
* `flake8 <https://pypi.org/project/flake8/>`_ for quality checks
2017-09-08 04:48:34 +08:00
* `invoke <http://www.pyinvoke.org/>`_ to automate development tasks
Branches
--------
We have two long term branches:
2020-01-24 03:34:21 +08:00
* ``master``: contains the code for the next bug-fix release.
2017-09-08 04:48:34 +08:00
* ``features``: contains the code with new features for the next minor release.
The official repository usually does not contain topic branches, developers and contributors should create topic
branches in their own forks.
Exceptions can be made for cases where more than one contributor is working on the same
topic or where it makes sense to use some automatic capability of the main repository, such as automatic docs from
`readthedocs <readthedocs.org>`_ for a branch dealing with documentation refactoring.
Issues
------
Any question, feature, bug or proposal is welcome as an issue. Users are encouraged to use them whenever they need.
GitHub issues should use labels to categorize them. Labels should be created sporadically, to fill a niche; we should
avoid creating labels just for the sake of creating them.
Each label should include a description in the GitHub's interface stating its purpose.
2017-09-08 04:48:34 +08:00
Labels are managed using `labels <https://github.com/hackebrot/labels>`_. All the labels in the repository
are kept in ``.github/labels.toml``, so any changes should be via PRs to that file.
After a PR is accepted and merged, one of the maintainers must manually synchronize the labels file with the
GitHub repository.
Temporary labels
~~~~~~~~~~~~~~~~
2017-09-08 04:48:34 +08:00
To classify issues for a special event it is encouraged to create a temporary label. This helps those involved to find
the relevant issues to work on. Examples of that are sprints in Python events or global hacking events.
2017-09-08 04:48:34 +08:00
* ``temporary: EP2017 sprint``: candidate issues or PRs tackled during the EuroPython 2017
2017-09-08 04:48:34 +08:00
Issues created at those events should have other relevant labels added as well.
2017-09-08 04:48:34 +08:00
Those labels should be removed after they are no longer relevant.
2017-09-08 04:48:34 +08:00
.. include:: ../../HOWTORELEASE.rst