If you're reading this, it means that you want to contribute to Atomic Reactor. Great! Here are some tips to make sure your pull request gets accepted.
Note: there are quite a few tools mentioned through this tutorial. To get them all, including Atomic Reactor dependencies, you can run pip install -r requirements-devel.txt
.
Also note: while this seems to be an awfully long text, chances are you adhere to most of it just because you're a great developer. And don't worry! Us, core devs, must send code through pull requests, too (well, assuming it isn't an obvious oneliner).
- We all know that there is an exception to every rule. Sometimes it might happen that your pull request doesn't satisfy all the below points. This is fine, assuming there's a good reason for this - and assuming you tell us the reason.
- If you want to implement major new functionality, we'd like to ask you to open a bug with proposal to discuss it with us. We're nice folks and we don't bite - we just want to see what you're up to and have some suggestions to save your time as well as ours.
- New features must have user documentation.
- All new code, both bugfixes and new features, must have tests.
- Pull requests must be cleanly rebased on top of master without multiple branches mixed together.
Please read the review checklist.
We try to write good code. This is what it means to us:
- Maximum line length is 100 characters
- Pull Request must pass following checks:
- Travis CI test - This means that no tests fail on Python 2.7 and >= 3.4
- You can run tests locally using
pytest
- You can run tests locally using
- Landscape test - This means that code follows pep8 and is otherwise sane. To check this, run this command:
flake8 atomic_reactor
- Landscape runs some more tests, which aren't reproducible locally (as far as we know). Feel free to rebase your pull request if Landscape finds issues that you couldn't find while testing on your machine
- Travis CI test - This means that no tests fail on Python 2.7 and >= 3.4
- Pull Request should pass following checks:
- Coveralls test - This means that code coverage doesn't decrease. You can check that by running
py.test --cov atomic_reactor
without your patch and then with it. Coveralls tend to give false positives, so even if they report failure, we will still accept your pull request assuming it has decent tests
- Coveralls test - This means that code coverage doesn't decrease. You can check that by running
- Methods and functions that are to be called from different modules in Atomic Reactor must have docstrings.
- Code should be readable, meaning:
- Comment where appropriate
- Separate logical parts of methods/functions by newline
- Use meaningful names for methods/functions/classes/variables
Assuming your pull request fulfilled all the above criteria, your code is almost ready to merge. You just need to wait for one of the core developers of Atomic Reactor to give your pull request a "LGTM" and do the actual merge. If the core developer thinks something is wrong with your pull request, they'll tell you and let you fix it. Discussion is always welcome!