Merge pull request #1206 from xmatthias/contributing
Improve Contributing documentation
This commit is contained in:
commit
cc3d05488b
@ -1,15 +1,17 @@
|
|||||||
# Contribute to freqtrade
|
# Contributing
|
||||||
|
|
||||||
|
## Contribute to freqtrade
|
||||||
|
|
||||||
Feel like our bot is missing a feature? We welcome your pull requests! Few pointers for contributions:
|
Feel like our bot is missing a feature? We welcome your pull requests! Few pointers for contributions:
|
||||||
|
|
||||||
- Create your PR against the `develop` branch, not `master`.
|
- Create your PR against the `develop` branch, not `master`.
|
||||||
- New features need to contain unit tests and must be PEP8
|
- New features need to contain unit tests and must be PEP8
|
||||||
|
|
||||||
conformant (max-line-length = 100).
|
conformant (max-line-length = 100).
|
||||||
|
|
||||||
If you are unsure, discuss the feature on our [Slack](https://join.slack.com/t/highfrequencybot/shared_invite/enQtMjQ5NTM0OTYzMzY3LWMxYzE3M2MxNDdjMGM3ZTYwNzFjMGIwZGRjNTc3ZGU3MGE3NzdmZGMwNmU3NDM5ZTNmM2Y3NjRiNzk4NmM4OGE)
|
If you are unsure, discuss the feature on our [Slack](https://join.slack.com/t/highfrequencybot/shared_invite/enQtMjQ5NTM0OTYzMzY3LWMxYzE3M2MxNDdjMGM3ZTYwNzFjMGIwZGRjNTc3ZGU3MGE3NzdmZGMwNmU3NDM5ZTNmM2Y3NjRiNzk4NmM4OGE)
|
||||||
or in a [issue](https://github.com/freqtrade/freqtrade/issues) before a PR.
|
or in a [issue](https://github.com/freqtrade/freqtrade/issues) before a PR.
|
||||||
|
|
||||||
|
|
||||||
**Before sending the PR:**
|
**Before sending the PR:**
|
||||||
|
|
||||||
## 1. Run unit tests
|
## 1. Run unit tests
|
||||||
@ -17,27 +19,34 @@ or in a [issue](https://github.com/freqtrade/freqtrade/issues) before a PR.
|
|||||||
All unit tests must pass. If a unit test is broken, change your code to
|
All unit tests must pass. If a unit test is broken, change your code to
|
||||||
make it pass. It means you have introduced a regression.
|
make it pass. It means you have introduced a regression.
|
||||||
|
|
||||||
**Test the whole project**
|
### Test the whole project
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
pytest freqtrade
|
pytest freqtrade
|
||||||
```
|
```
|
||||||
|
|
||||||
**Test only one file**
|
### Test only one file
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
pytest freqtrade/tests/test_<file_name>.py
|
pytest freqtrade/tests/test_<file_name>.py
|
||||||
```
|
```
|
||||||
|
|
||||||
**Test only one method from one file**
|
### Test only one method from one file
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
pytest freqtrade/tests/test_<file_name>.py::test_<method_name>
|
pytest freqtrade/tests/test_<file_name>.py::test_<method_name>
|
||||||
```
|
```
|
||||||
|
|
||||||
## 2. Test if your code is PEP8 compliant
|
## 2. Test if your code is PEP8 compliant
|
||||||
**Install packages** (If not already installed)
|
|
||||||
|
### Install packages
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
pip3.6 install flake8 coveralls
|
pip3.6 install flake8 coveralls
|
||||||
```
|
```
|
||||||
**Run Flake8**
|
|
||||||
|
### Run Flake8
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
flake8 freqtrade
|
flake8 freqtrade
|
||||||
```
|
```
|
||||||
@ -49,14 +58,68 @@ Guide for installing them is [here](http://flake8.pycqa.org/en/latest/user/using
|
|||||||
|
|
||||||
## 3. Test if all type-hints are correct
|
## 3. Test if all type-hints are correct
|
||||||
|
|
||||||
**Install packages** (If not already installed)
|
### Install packages
|
||||||
|
|
||||||
``` bash
|
``` bash
|
||||||
pip3.6 install mypy
|
pip3.6 install mypy
|
||||||
```
|
```
|
||||||
|
|
||||||
**Run mypy**
|
### Run mypy
|
||||||
|
|
||||||
``` bash
|
``` bash
|
||||||
mypy freqtrade
|
mypy freqtrade
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## (Core)-Committer Guide
|
||||||
|
|
||||||
|
### Process: Pull Requests
|
||||||
|
|
||||||
|
How to prioritize pull requests, from most to least important:
|
||||||
|
|
||||||
|
1. Fixes for broken tests. Broken means broken on any supported platform or Python version.
|
||||||
|
1. Extra tests to cover corner cases.
|
||||||
|
1. Minor edits to docs.
|
||||||
|
1. Bug fixes.
|
||||||
|
1. Major edits to docs.
|
||||||
|
1. Features.
|
||||||
|
|
||||||
|
Ensure that each pull request meets all requirements in the Contributing document.
|
||||||
|
|
||||||
|
### Process: Issues
|
||||||
|
|
||||||
|
If an issue is a bug that needs an urgent fix, mark it for the next patch release.
|
||||||
|
Then either fix it or mark as please-help.
|
||||||
|
|
||||||
|
For other issues: encourage friendly discussion, moderate debate, offer your thoughts.
|
||||||
|
|
||||||
|
### Process: Your own code changes
|
||||||
|
|
||||||
|
All code changes, regardless of who does them, need to be reviewed and merged by someone else.
|
||||||
|
This rule applies to all the core committers.
|
||||||
|
|
||||||
|
Exceptions:
|
||||||
|
|
||||||
|
- Minor corrections and fixes to pull requests submitted by others.
|
||||||
|
- While making a formal release, the release manager can make necessary, appropriate changes.
|
||||||
|
- Small documentation changes that reinforce existing subject matter. Most commonly being, but not limited to spelling and grammar corrections.
|
||||||
|
|
||||||
|
### Responsibilities
|
||||||
|
|
||||||
|
- Ensure cross-platform compatibility for every change that's accepted. Windows, Mac & Linux.
|
||||||
|
- Ensure no malicious code is introduced into the core code.
|
||||||
|
- Create issues for any major changes and enhancements that you wish to make. Discuss things transparently and get community feedback.
|
||||||
|
- Keep feature versions as small as possible, preferably one new feature per version.
|
||||||
|
- Be welcoming to newcomers and encourage diverse new contributors from all backgrounds. See the Python Community Code of Conduct (https://www.python.org/psf/codeofconduct/).
|
||||||
|
|
||||||
|
### Becoming a Committer
|
||||||
|
|
||||||
|
Contributors may be given commit privileges. Preference will be given to those with:
|
||||||
|
|
||||||
|
1. Past contributions to FreqTrade and other related open-source projects. Contributions to FreqTrade include both code (both accepted and pending) and friendly participation in the issue tracker and Pull request reviews. Quantity and quality are considered.
|
||||||
|
1. A coding style that the other core committers find simple, minimal, and clean.
|
||||||
|
1. Access to resources for cross-platform development and testing.
|
||||||
|
1. Time to devote to the project regularly.
|
||||||
|
|
||||||
|
Beeing a Committer does not grant write permission on `develop` or `master` for security reasons (Users trust FreqTrade with their Exchange API keys).
|
||||||
|
|
||||||
|
After beeing Committer for some time, a Committer may be named Core Committer and given full repository access.
|
||||||
|
Loading…
Reference in New Issue
Block a user