Skip to content

finleyfamily/action-setup-python

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

action-setup-python

pre-commit renovate

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.

Features

  • uses actions/setup-python to setup Python and cache poetry
  • uses pipx to install poetry
  • 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

Requirements

  • 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

Usage

steps:
  - uses: actions/checkout@v2
  - uses: finleyfamily/[email protected] # it is HIGHLY recommended to pin this to a release
    with:
      python-version: 3.9

Inputs

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.

Outputs

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.