Skip to content

Latest commit

 

History

History
121 lines (83 loc) · 4.02 KB

CONTRIBUTING.md

File metadata and controls

121 lines (83 loc) · 4.02 KB

Contributing

As Feud is an open source library, any contributions from the community are greatly appreciated. This document details the guidelines for making contributions to Feud.

Reporting issues

Prior to reporting an issue, please ensure:

  • You have used the search utility provided on GitHub issues to look for similar issues.
  • You have checked the documentation (for the version of Feud you are using).
  • You are using the latest stable version of Feud (if possible).

Making changes to Feud

  • Add tests: Your pull request won't be accepted if it doesn't have any tests (if necessary).

  • Document any change in behaviour: Make sure all relevant documentation is kept up-to-date.

  • Create topic branches: Will not pull from your master branch!

  • One pull request per feature: If you wish to add more than one new feature, make multiple pull requests.

  • Meaningful commit messages: Each commit in your pull request should have a meaningful message.

  • De-clutter commit history: If you had to make multiple intermediate commits while developing, please squash them before making your pull request. Or add a note on the PR specifying to squash and merge your changes when ready to be merged.

Making pull requests

Please make new branches based on the current dev branch, and merge your PR back into dev (making sure you have fetched the latest changes).

Installing dependencies

To install all dependencies and pre-commit hooks for development, ensure you have Poetry (1.6.1+) installed and run:

make

Running tests

This repository relies on the use of Tox for running tests in virtual environments.

  • Run ALL tests in a virtual environment:
    # a.k.a. poetry run invoke tests.install tests.doctest tests.unit
    poetry run tox -e tests
  • Run ONLY unit tests in a virtual environment:
    # a.k.a. poetry run invoke tests.install tests.unit
    poetry run tox -e tests.unit
  • Run ONLY doctests in a virtual environment:
    # a.k.a. poetry run invoke tests.install tests.doctest
    poetry run tox -e tests.doctest

Linting and formatting

This repository relies on the use of:

  • Ruff for linting and formatting Python source code,
  • Pydoclint for linting docstrings,
  • Tox for running linting and formatting in a virtual environment.

To lint the source code using Ruff and Pydoclint with Tox:

# a.k.a poetry run invoke lint.install lint.check
poetry run tox -e lint

To format the source code and attempt to auto-fix any linting issues using Ruff with Tox:

# a.k.a. poetry run invoke lint.install lint.format
poetry run tox -e format

Pre-commit hooks will prevent you from making a commit if linting fails or your code is not formatted correctly.

Documentation

Package documentation is automatically produced from docstrings using Sphinx. The package also uses Tox for building documentation inside a virtual environment.

To build package documentation and automatically serve the files as a HTTP server while watching for source code changes, run:

# a.k.a. poetry run invoke docs.install docs.build
poetry run tox -e docs

This will start a server running on localhost:8000 by default.

To only build the static documentation HTML files without serving them or watching for changes, run:

# a.k.a. poetry run invoke docs.install docs.build --no-watch
poetry run tox -e docs -- --no-watch

License

By contributing, you agree that your contributions will be licensed under the repository's MIT License.


Feud © 2023, Edwin Onuonga - Released under the MIT license.
Authored and maintained by Edwin Onuonga.