Skip to content
This repository has been archived by the owner on Dec 13, 2020. It is now read-only.

Latest commit

 

History

History
35 lines (25 loc) · 1.5 KB

CONTRIBUTING.md

File metadata and controls

35 lines (25 loc) · 1.5 KB

Contributing

Everyone that wants to contribute to the project should read this document.

Getting Started

You may follow these steps if you wish to create a pull request. Fork the repo and clone it on your local machine. Then in the project's directory:

virtualenv env  # Create a virtualenv for the project's dependencies.
source env/bin/activate  # Activate the virtualenv.
pip install tox  # Install tox, which runs linting and tests.
tox  # This runs all tests on your local machine. Make sure they pass.

If you don't have Python 2.6, 2.7, and 3.4 installed, you can manually run tests on one specific version by running tox -e lint,py27 (for Python 2.7) instead.

Consistency and Style

Keep code style consistent with the rest of the project. Some suggestions:

  1. Write tests for your new features. if new_feature else Write tests for bug-causing scenarios.
  2. Write docstrings for all classes, functions, methods, modules, etc.
  3. Document all function/method arguments and return values.
  4. Document all class variables instance variables.
  5. Documentation guidelines also apply to tests, though not as strict.
  6. Keep code style consistent, such as the kind of quotes to use and spacing.
  7. Don't use except: or except Exception: unless you have a raise in the block. Be specific about error handling.
  8. Don't use isinstance() (it breaks duck typing).

Thanks

Thanks for fixing bugs or adding features to the project!