A composite GitHub Action that sets up both Python and poetry with virtual environment caching in a single step.
This Action was started because I found myself repeating the same steps over and over again across jobs. Since Actions don't currently support YAML anchors, this was my next best option.
- uses actions/setup-python to setup Python and cache poetry
- uses pipx to install poetry
- as of implementation, this is poetry's recommended install method
- uses pipx that comes pre-installed on all GitHub Runner images
- caches pipx directories
- sets the following global poetry configuration values:
virtualenvs.create = true
virtualenvs.in-project = true
virtualenvs.prefer-active-python = true
- injects poetry-plugin-export into the pipx install of poetry
- in the future this plugin will not be installed by default with poetry
- disables poetry's warning regarding the future remove of this plugin
- (optional) checks the constancy of
poetry.lock
- (optional) installs dependencies using poetry
- actions/checkout needs to be run before this Action
- the virtual environment needs to be created within the project for it to be cached (
poetry config --local virtualenvs.in-project true
)- this is set globally by the action but if it is set to
false
locally, it will take precedence
- this is set globally by the action but if it is set to
steps:
- uses: actions/checkout@v2
- uses: finleyfamily/[email protected] # it is HIGHLY recommended to pin this to a release
with:
python-version: 3.9
Key | Description |
---|---|
architecture | The target architecture (x86, x64) of the Python interpreter. The target architecture (x86, x64) of the Python interpreter. |
poetry-check | Whether validate the content of the pyproject.toml file and its consistency with the poetry.lock file. |
poetry-check-cmd | The poetry command to run when checking the lock file (e.g. check ). This command was changed in poetry 1.6 (default used by this action). To support older versions of poetry, provide a value for this input. |
poetry-install | Whether to run poetry install (or the value of poetry-install-cmd ). Defaults to true . |
poetry-install-args | Additional args to pass to poetry install . Defaults to -vvv --remove-untracked |
poetry-install-cmd | Command for installing poetry project. Can be used to provide a custom install command. The value of poetry-install-args is appended after this. Defaults to poetry install . This is also a check for the existence of a Makefile with a setup-poetry target. If found, using it takes precedence. |
poetry-plugins | A whitespace seperated list of poetry plugins to be installed (e.g. plugin0 plugin1 ). Note that poetry-plugin-export is installed by default and can be left out of this list. |
poetry-preview | Allow install of prerelease versions of Poetry. |
poetry-version | Poetry version to use. If version is not provided then latest stable version will be used. Should be provided as a version specifier that can be passed to pipx or latest |
python-version | Version range or exact version of a Python version to use, using semver version range syntax. Reads from pyproject.toml if unset. |
python-version-file | File containing the Python version to use. |
token | Used to pull python distributions from actions/python-versions. Since there's a default, this is typically not supplied by the user. |
Key | Description |
---|---|
cache-hit | Whether there was a cache hit for the Python virtual environment. |
python-path | The absolute path to the Python or PyPy executable. |
python-version | The installed Python version. Useful when given a version range as input. |