Skip to content

Commit

Permalink
Merge pull request #137 from rmartin16/hynek-build
Browse files Browse the repository at this point in the history
Implement `hynek/build-and-inspect-python-package` in `python-package-create.yml`
  • Loading branch information
freakboy3742 authored May 30, 2024
2 parents 724f15f + 5b6e556 commit 04c7038
Show file tree
Hide file tree
Showing 5 changed files with 74 additions and 85 deletions.
4 changes: 3 additions & 1 deletion .github/workflows/app-build-verify.yml
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,9 @@ jobs:
if: endsWith(inputs.repository, 'briefcase')
uses: actions/[email protected]
with:
name: packages-briefcase
# artifact name is derived in python-package-create.yml
pattern: "Packages-briefcase*"
merge-multiple: true
path: dist

- name: Install Briefcase Artefacts
Expand Down
19 changes: 12 additions & 7 deletions .github/workflows/app-create-verify.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,10 @@ on:
description: "Framework to use to build the App, e.g. toga."
required: true
type: string
repository:
description: "GitHub repository to checkout; defaults to repo running this workflow."
default: ${{ github.repository }}
type: string
workflow-repo:
# Only needed for PRs in other repos wanting to test new workflow changes before they are merged.
# These inputs should not be specified by another repo on their main branch.
Expand All @@ -44,10 +48,10 @@ jobs:
timeout-minutes: 30
steps:

- name: Checkout ${{ github.repository }}
- name: Checkout ${{ inputs.repository }}
uses: actions/[email protected]
with:
repository: ${{ github.repository }}
repository: ${{ inputs.repository }}
fetch-depth: 0

- name: Checkout ${{ inputs.workflow-repo }}${{ inputs.workflow-repo-ref && format('@{0}', inputs.workflow-repo-ref) || '' }}
Expand Down Expand Up @@ -79,18 +83,19 @@ jobs:

- name: Get Briefcase Package
# Briefcase will build and package itself in a previous step in its CI
if: endsWith(github.repository, 'briefcase')
if: endsWith(inputs.repository, 'briefcase')
uses: actions/[email protected]
with:
name: packages-briefcase
# artifact name is derived in python-package-create.yml
name: "Packages-briefcase"
path: dist

- name: Install Briefcase Artefact
if: endsWith(github.repository, 'briefcase')
if: endsWith(inputs.repository, 'briefcase')
run: python -m pip install -U dist/briefcase-*.whl --upgrade-strategy eager

- name: Install Briefcase
if: ${{ !endsWith(github.repository, 'briefcase') }}
if: ${{ !endsWith(inputs.repository, 'briefcase') }}
uses: ./beeware-.github/.github/actions/install-briefcase

- name: Create Briefcase Project
Expand All @@ -99,7 +104,7 @@ jobs:
with:
framework: ${{ inputs.framework }}
# use the current repo checkout if briefcase-template is being tested
briefcase-template-source: ${{ endsWith(github.repository, 'briefcase-template') && github.workspace || '' }}
briefcase-template-source: ${{ endsWith(inputs.repository, 'briefcase-template') && github.workspace || '' }}

- name: Run Flake8
working-directory: ${{ steps.create.outputs.project-path }}
Expand Down
36 changes: 18 additions & 18 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ on:
- main

concurrency:
group: ${{ github.ref }}
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

defaults:
Expand Down Expand Up @@ -161,29 +161,28 @@ jobs:
needs: pre-commit
uses: ./.github/workflows/python-package-create.yml
with:
repository: beeware/${{ matrix.repo }}
tox-source: ${{ matrix.tox-source }}
tox-factors: ${{ matrix.tox-factors }}
distribution-path: ${{ matrix.dist-path }}
repository: beeware/${{ matrix.repo || matrix.name }}
build-subdirectory: ${{ matrix.build-subdir }}
strategy:
fail-fast: false
matrix:
repo: [ briefcase, gbulb, rubicon-objc, toga ]
name:
- briefcase
- briefcase-automation
- gbulb
- rubicon-objc
- toga-core
- toga-android
include:
- tox-source: .[dev]
- dist-path: dist
- repo: briefcase
tox-source: .[dev]
tox-factors: -with-automation
dist-path: dist
- repo: gbulb
tox-source: tox
dist-path: dist
- repo: toga
tox-source: ./core[dev]
dist-path: "*/dist/*"
- name: briefcase-automation
repo: briefcase
build-subdir: automation
- name: toga-core
repo: toga
build-subdir: core
- name: toga-android
repo: toga
build-subdir: android

test-install-requirements:
name: Install Requirements
Expand Down Expand Up @@ -259,6 +258,7 @@ jobs:
uses: ./.github/workflows/app-create-verify.yml
with:
python-version: "3.10" # must match system python for ubuntu version
repository: beeware/briefcase
runner-os: ${{ matrix.runner-os }}
framework: ${{ matrix.framework }}
strategy:
Expand Down
100 changes: 41 additions & 59 deletions .github/workflows/python-package-create.yml
Original file line number Diff line number Diff line change
@@ -1,98 +1,80 @@
name: Create Python Package

#######
# Creates a Python package via `tox -e package` and uploads it as an artifact named 'packages-<repo name>'.
# Creates a Python package for an arbitrary repository and subdirectory with optional attestation.
#######

on:
workflow_call:
inputs:
python-version:
description: "Python version to use; defaults to latest Python release."
default: "3.X"
type: string
repository:
description: "GitHub repository to checkout; defaults to repo running this workflow."
default: ${{ github.repository }}
type: string
tox-source:
description: "The arguments for `pip install` to install tox; use ./path/to/package[dev] for the repo's pinned version."
default: ".[dev]"
type: string
tox-factors:
description: "The tox factors to append to the package command."
default: ""
type: string
build-subdirectory:
description: "The subdirectory to build as a wheel."
default: ""
type: string
distribution-path:
description: "Relative filepath to distribution(s); e.g. */dist/*"
default: "dist"
type: string
runner-os:
description: "Runner OS to use to run tox; defaults to ubuntu-latest"
default: "ubuntu-latest"
attest:
description: "Create GitHub provenance attestation for the package."
default: "false"
type: string
outputs:
artifact-name:
description: >
Name of the uploaded artifact; use for artifact retrieval.
Note that if a `build-subdirectory` is specified, this value will be the "base" of the artifact name.
For instance, if the `core` subdirectory of Toga is being built, then this value will be `packages-toga`
but the name of the uploaded artifact will be `packages-toga-core`.
Therefore, when a `build-subdirectory` is used with this workflow, the `pattern` input for the
`actions\download-artifact` should be used to specify `${ needs.package.outputs.artifact-name }-*`.
description: "Name of the uploaded artifact; use for artifact retrieval."
value: ${{ jobs.package.outputs.artifact-name }}
artifact-basename:
description: >
The base name for a group of related package artifacts.
When several packages are created from a single repo, such as for Toga, a separate artifact
will be created for each package, e.g. Packages-toga-core, Packages-toga-android, etc.
Therefore, the base name for these artifacts is Packages-toga. This output allows the caller
to retrieve all of these related artifacts with one call to actions/download-artifact.
value: ${{ jobs.package.outputs.artifact-basename }}

env:
FORCE_COLOR: "1"

jobs:
package:
name: Create Python Package
runs-on: ${{ inputs.runner-os }}
runs-on: ubuntu-latest
permissions:
id-token: write
contents: read
attestations: write
outputs:
artifact-name: packages-${{ steps.package.outputs.name }}
artifact-name: ${{ steps.package.outputs.artifact-name }}
artifact-basename: ${{ steps.artifact.outputs.basename }}
steps:

- name: Determine Package Name
id: package
run: echo "name=$(basename '${{ inputs.repository }}')" >> ${GITHUB_OUTPUT}
- name: Determine Artifact Differentiators
id: config
env:
REPO: ${{ inputs.repository }}
DIFFERENTIATOR: ${{ inputs.build-subdirectory && format('-{0}', inputs.build-subdirectory) || '' }}
run: |
echo "repo-name=$(basename "${REPO}")" | tee -a ${GITHUB_OUTPUT}
echo "differentiator=${DIFFERENTIATOR}" | tee -a ${GITHUB_OUTPUT}
- name: Checkout
uses: actions/[email protected]
with:
repository: ${{ inputs.repository }}
fetch-depth: 0 # Fetch all refs so setuptools_scm can generate the correct version number

- name: Setup Python
uses: actions/[email protected]
- name: Build Package & Upload Artifact
id: package
uses: hynek/[email protected]
with:
python-version: ${{ inputs.python-version }}
cache: pip
cache-dependency-path: |
**/setup.cfg
**/pyproject.toml
- name: Update pip
run: python -m pip install -U pip

- name: Install tox
run: python -m pip install ${{ inputs.tox-source }}
path: ${{ inputs.build-subdirectory || '.' }}
upload-name-suffix: ${{ format('-{0}{1}', steps.config.outputs.repo-name, steps.config.outputs.differentiator) }}
attest-build-provenance-github: ${{ inputs.attest }}

- name: Build Wheels
if: inputs.build-subdirectory == ''
run: tox -e package${{ inputs.tox-factors }}

- name: Build Wheels from Subdirectory
if: inputs.build-subdirectory != ''
run: tox -e package${{ inputs.tox-factors }} -- ${{ inputs.build-subdirectory }}

- name: Upload Package
uses: actions/[email protected]
with:
name: packages-${{ steps.package.outputs.name }}${{ inputs.build-subdirectory && format('-{0}', inputs.build-subdirectory) || '' }}
path: ${{ inputs.distribution-path }}
if-no-files-found: error
- name: Determine Artifact Basename
id: artifact
env:
BASENAME: ${{ steps.package.outputs.artifact-name }}
run: |
# trim the differentiator to generate the artifact's basename
echo "basename=${BASENAME%${{ steps.config.outputs.differentiator }}}" | tee -a ${GITHUB_OUTPUT}
Binary file not shown.

0 comments on commit 04c7038

Please sign in to comment.