GitHub Action
Install Python Tools
This action installs Python tools using pipx.
- Packages are specified in the
pyproject.toml
file. - Installed files are cached, so that subsequent runs simply restore from the cache for the same package version.
- Pipx
inject
is supported, allowing you to also install plugins for tools that support it.
Tools like Poetry and PDM do a great job of managing Python application dependencies, but something has to install those tools globally in the GitHub runner before they can be used. There's also other types of tools that require or prefer a global install, such as tox and pothepoet.
pipx-install
aims to fill that gap by providing Python developers an easy and familiar way to specify tooling
prerequisites needed to perform CI/CD operations on a Python project.
Here's an example of how to use this action in a workflow file:
steps:
- name: Install Python Tools
uses: BrandonLWhite/pipx-install-action
Tool packages are expressed in your project's pyproject.toml
file [tool.pipx-install]
section like this:
[tool.pipx-install]
poetry = "==1.7.1"
tox = "~=4.11.4"
Version specifiers are passed directly to pipx
, so you can use anything that works with pipx
, which should be any
scheme supported by pip
, which are defined in PEP-440.
Note
While you can, and probably should, pin/lock your CI tools to exact versions (eg "==1.7.1"
) it is important to note
that the dependencies of those tools will not be locked to exact versions. This is because pipx
has no concept of a
lockfile at this time. Should such functionality ever become available in pipx
, support will be added to
pipx-install
.
Some tools support adding third-party plugins by installing them into the same virtual environment as the parent tool.
pipx
supports this through its inject
operation and pipx-install
allows you to specify any number of plugins to
inject for a tool. Here is an example of the pyproject.toml [tool.pipx-install]
syntax for adding plugins:
poetry = {version = "==1.7.1", inject = {poetry-plugin-bundle = "==1.3.0", poetry-plugin-export = "==1.6.0"} }
This example would install poetry
at version 1.7.1 and then inject 2 plugins: poetry-plugin-bundle
version 1.3.0
and poetry-plugin-export
version 1.6.0.
pipx
is the de facto Python tool to globally install CLI applications in isolated virtual environments. The minimum
required version is 1.1.0
for use with pipx-install
. Fortunately, pipx
is already installed in the standard
GitHub hosted runners!
Note
pipx-install
is only tested on Ubuntu Linux based runners at this time. "It should work" on Windows and MacOS
runners, but if you encounter an issue please file a bug report with all the details!
Here's a list of tools that are examples of what pipx-install
is built to handle. (This list is mostly here to help
folks searching for a solution to get their tool installed in their GHA workflow):
Input | Default | Description |
---|---|---|
install-config-file |
pyproject.toml |
Path to the TOML file that specifies the [tool.pipx-install] section |
cache-packages |
true |
When 'true', packages will be saved to the repository's GitHub Action cache and restored whenever possible to avoid downloading from the upstream package repository (eg. PyPI) |
None at this time.