Contributions are welcome, and they are greatly appreciated! Every little bit helps and credit will always be given.
Please do read through this first before you start contributing code. The Feature Scope section will be of particular interest to those looking to expand on this app's functionality, and the Pull Request Guidelines explain how I add code contributions.
Report bugs at https://github.com/bennylope/django-organizations/issues.
If you are reporting a bug, please include:
- Your operating system name and version.
- Python version
- Django version
- Django Organizations version
- Any additional details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Look through the GitHub issues for bugs. Anything tagged with "bug" is open to whoever wants to implement it.
Look through the GitHub issues for features. Anything tagged with "feature" is open to whoever wants to implement it.
Django-organizations could always use more documentation, whether as part of the official Django-organizations docs, in docstrings, or even on the web in blog posts, articles, and such.
The best way to send feedback is to file an issue at https://github.com/bennylope/django-organizations/issues.
If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
- Remember that this is a volunteer-driven project, and that contributions are welcome
Ready to contribute? Here's how to set up django-organizations for local development.
Fork the django-organizations repo on GitHub.
Clone your fork locally:
$ git clone [email protected]:your_name_here/django-organizations.git
Install your local copy into a virtualenv. Assuming you have virtualenvwrapper installed, this is how you set up your fork for local development:
$ mkvirtualenv django-organizations $ cd django-organizations/ $ pip install -r requirements-dev.txt
Create a branch for local development:
$ git checkout -b name-of-your-bugfix-or-feature
Now you can make your changes locally.
When you're done making changes, check that your changes pass flake8 and the tests, including testing other Python versions with tox:
$ tox
To get flake8 and tox, just pip install them into your virtualenv.
Commit your changes and push your branch to GitHub:
$ git add . $ git commit -m "Your detailed description of your changes." $ git push origin name-of-your-bugfix-or-feature
Submit a pull request through the GitHub website.
Django Organizations should make working with group account simple by providing patterns and code to perform core functionality. There's potential overlap with user management, authentication, etc, and it should do none of those things.
Most feature suggestions can be accomplished with basic customization in an end-user's project. If something requires a bit more work, it'd be better to modify Django Organizations to allow new custom functionality, rather than adding that in directly.
Before you submit a pull request, check that it meets these guidelines:
- The pull request should include tests.
- If the pull request adds functionality, the docs should be updated. Put your new functionality into a function with a docstring, and add the feature to the list in README.rst. Any new functionality should align with the project goals (see README).
- The pull request should work for Python 2.6, 2.7, and 3.3, and for PyPy. Check https://travis-ci.org/bennylope/django-organizations/pull_requests and make sure that the tests pass for all supported Python versions.
- The pull request must also work with Django 1.4-1.7.
- Please try to follow Django coding style.
- Pull requests should include an amount of code and commits that are reasonable to review, are logically grouped, and based off clean feature branches. Commits should be identifiable to the original author by name/username and email.
In a nutshell, changes must not break compatability with older installed versions of the software. You should be able to upgrade an installed version of Django Organizations by doing nothing more than upgrading the package and running South's migration command.
I am aiming to support each major Django version for as long as it is supported.