Securely install the latest pip-tools release from PyPI.
This action installs a pinned version of pip-tools and all its dependencies, making sure that file hashes match. Pinning your dependencies:
- Stops software supply chain attacks.
- Makes sure your CI does not break unexpectedly.
In your GitHub Actions workflow, use this action like so:
- name: Install pip-tools from PyPI
uses: install-pinned/pip-tools@666fc0d04076592472aa3ae695c2e84121d5c51c # 7.4.1
You can set up Dependabot so that your pins are updated regularly.
This action is a relatively simple wrapper around uv and is most useful if there is no existing requirements.txt
/uv.lock
/... infrastructure in place. If you already pin all your dependencies in a single place, you don't need it!
See the @install-pinned README for details.