Contributing¶
Contributions are welcome, and they are greatly appreciated! Every little bit helps, and credit will always be given.
Bug reports¶
When reporting a bug please include:
- Your operating system name and version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Documentation improvements¶
Pyncette could always use more documentation, whether as part of the official Pyncette docs, in docstrings, or even on the web in blog posts, articles, and such.
Feature requests and feedback¶
The best way to send feedback is to file an issue at https://github.com/tibordp/pyncette/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 code contributions are welcome :)
Development¶
To set up pyncette for local development:
-
Fork pyncette (look for the "Fork" button).
-
Clone your fork locally:
- Create a branch for local development:
Now you can make your changes locally.
- Set up your development environment:
- Running integration tests assumes that there will be Redis, PostgreSQL, MySQL and Localstack (for DynamoDB) running on localhost. Alternatively, there is a Docker Compose environment that will set up all the backends so that integration tests can run seamlessly:
- When you're done making changes, run all the checks:
# Run linting and formatting
uv run pre-commit run --all-files
# Run type checking
uv run ty check src examples
# Run tests
uv run pytest tests
# Build documentation
uv run mkdocs build
- 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.
If you run into issues setting up a local environment or testing the code locally, feel free to submit the PR anyway and GitHub Actions will test it for you.
Pull Request Guidelines¶
If you need some code review or feedback while you're developing the code just make the pull request.
For merging, you should:
- Update documentation when there's new API, functionality etc.
- Add a note to
docs/changelog.mdabout the changes.
Tips¶
To run a subset of tests:
To run tests for a specific Python version:
To run tests in parallel