Bug Reports & Feedback¶
If you discover a bug, want to propose a new feature, or have other feedback about requests-cache, please create an issue!
If you want to discuss ideas about the project in general, or if you have an issue or PR that hasn’t received a response in a timely manner, please reach out on the Code Shelter chat server, under projects/requests-cache.
If there is a new feature you would like to see, the best way to make that happen is to submit a PR for it!
If you want to test out the latest in-development changes, you can install pre-release versions:
pip install --pre requests-cache
Pre-release documentation can be found here: https://requests-cache.readthedocs.io/en/latest/
To set up for local development (requires poetry):
git clone https://github.com/reclosedev/requests-cache.git cd requests-cache poetry install -v -E all
CI jobs will run code style checks, type checks, linting, etc. If you would like to run these same checks locally, you can use pre-commit. This is optional but recommended.
To install pre-commit hooks:
To manually run checks on all files:
pre-commit run --all-files # Alternative alias with nox: nox -e lint
To disable pre-commit hooks:
Tests are divided into unit and integration tests:
Unit tests can be run without any additional setup, and don’t depend on any external services.
Integration tests depend on additional services, which are easiest to run using Docker (see Integration Tests section below).
pytestto run all tests
pytest tests/unitto run only unit tests
pytest tests/integrationto run only integration tests
For CI jobs (including PRs), these tests will be run for each supported python version. You can use nox to do this locally, if needed:
nox -e test
Or to run tests for a specific python version:
nox -e test-3.10
To generate a coverage report:
nox -e cov
nox --list for a ful list of available commands.
Integration Test Containers¶
docker-compose up -d pytest tests/integration
Integration Test Alternatives¶
If you can’t easily run Docker containers in your environment but still want to run some of the integration tests, you can use pytest-httpbin instead of the httpbin container. This just requires installing an extra package and setting an environment variable:
pip install pytest-httpbin export USE_PYTEST_HTTPBIN=true pytest tests/integration/test_cache.py
For backend databases, you can install and run them on the host instead of in a container, as long as they are running on the default port.
Sphinx is used to generate documentation.
To build the docs locally:
nox -e docs
# MacOS: open docs/_build/html/index.html # Linux: xdg-open docs/_build/html/index.html
You can also use sphinx-autobuild to rebuild the docs and live reload in the browser whenver doc contents change:
nox -e livedocs
Sometimes, there are differences in the Readthedocs build environment that can cause builds to
succeed locally but fail remotely. To help debug this, you can use the
readthedocs/build container to build
the docs. A configured build container is included in
docs/docker-compose.yml to simplify this.
# Optionally add --build to rebuild with updated dependencies docker-compose -f docs/docker-compose.yml up -d docker exec readthedocs make all
Here are some general guidelines for submitting a pull request:
If the changes are trivial, just briefly explain the changes in the PR description.
Otherwise, please submit an issue describing the proposed change prior to submitting a PR.
Please add unit test coverage and updated docs (if applicable) for your changes.
Submit the PR to be merged into the
Notes for Maintainers¶
Releases are built and published to pypi based on git tags.
Milestones will be used to track progress on major and minor releases.
GitHub Actions will build and deploy packages to PyPi on tagged commits on the
Update the version in
Update the release notes in
Generate a sample cache for the new version (used by unit tests) with
Merge changes into the
Push a new tag, e.g.:
git tag v0.1 && git push origin --tags
This will trigger a deployment. Verify that this completes successfully and that the new version can be installed from pypi with
Pre-release builds are convenient for letting testers try out in-development changes. Versions with
.dev (among others) can be deployed to PyPI and installed by users with
pip install --pre,
and are otherwise ignored by
# Install latest pre-release build: pip install -U --pre requests-cache # Install latest stable build pip install -U requests-cache