First things first: thank you for contributing! This project will be succesful thanks to everyone who contributes, and we're happy to have you.
To raise a bug or issue please use our GitHub.
Please check the issue has not be raised before by using the search feature.
When submitting an issue or bug, please make sure you provide thorough detail on:
- The version of clientele you are using
- Any errors or outputs you see in your terminal
- The OpenAPI schema you are using (this is particularly important).
If you want to directly contribute you can do so in two ways:
- Documentation
- Code
We use mkdocs and GitHub pages to deploy our docs.
Fixing grammar, spelling mistakes, or expanding the documentation to cover features that are not yet documented, are all valuable contributions.
Please see the Set up instructions below to run the docs locally on your computer.
Contribution by writing code for new features, or fixing bugs, is a great way to contribute to the project.
Clone the repo:
[email protected]:phalt/clientele.git
cd clientele
Move to a feature branch:
git branch -B my-branch-name
Install all the dependencies:
python3.11 -m venv .venv
source .venv/bin/activate
make install
To make sure you have things set up correctly, please run the tests:
make test
Once you have made changes, here is a good check list to run through to get it published for review:
Regenerate the test clients to see what has changed, and if tests pass:
make generate-test-clients
make test
Check your git diff
to see if anything drastic has changed. If changes happen that you did not expect, something has gone wrong. We want to make sure the clients do not change drastically when adding new features unless it is intended.
Format and lint the code:
make format
Note that, the auto-generated black formatted code will be changed again because this project uses ruff
for additional formatting. That's okay.
Make sure you add to CHANGELOG.md
and docs/CHANGELOG.md
what changes you have made.
Make sure you add your name to CONTRIBUTORS.md
as well!
Please push your changes up to a feature branch and make a new pull request on GitHub.
Please add a description to the PR and some information about why the change is being made.
After a review you might need to make more changes.
Once accepted, a core contributor will merge your changes!