Skip to content

Python Build Release Candidate #76

Python Build Release Candidate

Python Build Release Candidate #76

#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#
name: "Python Build Release Candidate"
on:
push:
tags:
# Trigger this workflow when tag follows the versioning format: pyiceberg-<major>.<minor>.<patch>rc<release_candidate>
# Example valid tags: pyiceberg-0.8.0rc2, pyiceberg-1.0.0rc1
- 'pyiceberg-[0-9]+.[0-9]+.[0-9]+rc[0-9]+'
workflow_dispatch:
inputs:
version:
description: 'Version (e.g., 0.8.0)'
type: string
required: true
rc:
description: 'Release Candidate (RC) (e.g., 1)'
type: number
required: true
jobs:
validate-inputs:
runs-on: ubuntu-latest
outputs:
VERSION: ${{ steps.validate-inputs.outputs.VERSION }} # e.g. 0.8.0
RC: ${{ steps.validate-inputs.outputs.RC }} # e.g. 1
steps:
- name: Validate and Extract Version and RC
id: validate-inputs
run: |
if [ "$GITHUB_EVENT_NAME" = "push" ]; then
echo "Workflow triggered by tag push."
TAG=${GITHUB_REF#refs/tags/} # Extract the tag name
VERSION_AND_RC=${TAG#pyiceberg-} # Remove the 'pyiceberg-' prefix
VERSION=${VERSION_AND_RC%rc*} # Extract VERSION by removing everything after 'rc'
RC=${VERSION_AND_RC#*rc} # Extract RC by keeping everything after 'rc'
if [[ -z "$VERSION" || -z "$RC" ]]; then
echo "Error: Unable to parse VERSION or RC from tag ($TAG). Ensure the tag format is correct."
exit 1
fi
else
echo "Workflow triggered manually via workflow_dispatch."
VERSION="${{ github.event.inputs.version }}"
RC="${{ github.event.inputs.rc }}"
# Validate version (e.g., 1.0.0)
if [[ ! "$VERSION" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "Error: version ($VERSION) must be in the format: <number>.<number>.<number>"
exit 1
fi
# Validate rc (e.g., 1)
if [[ ! "$RC" =~ ^[0-9]+$ ]]; then
echo "Error: rc ($RC) must be in the format: <number>"
exit 1
fi
fi
# Export variables for future steps
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
echo "RC=$RC" >> $GITHUB_OUTPUT
- name: Display Extracted Version and RC
run: |
echo "Using Version: ${{ steps.validate-inputs.outputs.VERSION }}"
echo "Using RC: ${{ steps.validate-inputs.outputs.RC }}"
validate-library-version:
runs-on: ubuntu-latest
needs:
- validate-inputs
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 1
- uses: actions/setup-python@v5
with:
python-version: 3.12
- name: Install Poetry
run: |
pip install poetry
- name: Validate current pyiceberg version
env:
VERSION: ${{ needs.validate-inputs.outputs.VERSION }}
run: |
# Extract the current version from Poetry
current_pyiceberg_version=$(poetry version --short)
echo "Detected Poetry version: $current_pyiceberg_version"
# Compare the input version with the Poetry version
if [[ "$VERSION" != "$current_pyiceberg_version" ]]; then
echo "Error: Input version ($VERSION) does not match the Poetry version ($current_pyiceberg_version)"
exit 1
fi
# SVN
svn_build_artifacts:
name: Build artifacts for SVN on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
needs:
- validate-inputs
- validate-library-version
strategy:
matrix:
os: [ ubuntu-22.04, windows-2022, macos-13, macos-14, macos-15 ]
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 1
- uses: actions/setup-python@v5
with:
python-version: |
3.9
3.10
3.11
3.12
- name: Install poetry
run: pip install poetry
# Publish the source distribution with the version that's in
# the repository, otherwise the tests will fail
- name: Compile source distribution
run: python3 -m poetry build --format=sdist
if: startsWith(matrix.os, 'ubuntu')
- name: Build wheels
uses: pypa/[email protected]
with:
output-dir: wheelhouse
config-file: "pyproject.toml"
env:
# Ignore 32 bit architectures
CIBW_ARCHS: "auto64"
CIBW_PROJECT_REQUIRES_PYTHON: ">=3.9,<3.13"
CIBW_TEST_REQUIRES: "pytest==7.4.2 moto==5.0.1"
CIBW_TEST_EXTRAS: "s3fs,glue"
CIBW_TEST_COMMAND: "pytest {project}/tests/avro/test_decoder.py"
# There is an upstream issue with installing on MacOSX
# https://github.com/pypa/cibuildwheel/issues/1603
# Ignore tests for pypy since not all dependencies are compiled for it
# and would require a local rust build chain
CIBW_TEST_SKIP: "pp* *macosx*"
- name: Add source distribution
if: startsWith(matrix.os, 'ubuntu')
run: ls -lah dist/* && cp dist/* wheelhouse/
- uses: actions/upload-artifact@v4
with:
name: "svn-release-candidate-${{ matrix.os }}"
path: ./wheelhouse/*
svn_merge_artifacts:
runs-on: ubuntu-latest
needs:
- validate-inputs
- svn_build_artifacts
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@v4
with:
name: "svn-release-candidate-${{ needs.validate-inputs.outputs.VERSION }}-rc${{ needs.validate-inputs.outputs.RC }}"
pattern: svn-release-candidate*
delete-merged: true
# PyPi
pypi_build_artifacts:
name: Build artifacts for PyPi on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
needs:
- validate-inputs
- validate-library-version
strategy:
matrix:
os: [ ubuntu-22.04, windows-2022, macos-13, macos-14, macos-15 ]
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 1
- uses: actions/setup-python@v5
with:
python-version: |
3.9
3.10
3.11
3.12
- name: Install poetry
run: pip install poetry
- name: Set version with RC
env:
VERSION: ${{ needs.validate-inputs.outputs.VERSION }}
RC: ${{ needs.validate-inputs.outputs.RC }}
run: python -m poetry version "${{ env.VERSION }}rc${{ env.RC }}" # e.g., 0.8.0rc1
# Publish the source distribution with the version that's in
# the repository, otherwise the tests will fail
- name: Compile source distribution
run: python3 -m poetry build --format=sdist
if: startsWith(matrix.os, 'ubuntu')
- name: Build wheels
uses: pypa/[email protected]
with:
output-dir: wheelhouse
config-file: "pyproject.toml"
env:
# Ignore 32 bit architectures
CIBW_ARCHS: "auto64"
CIBW_PROJECT_REQUIRES_PYTHON: ">=3.9,<3.13"
CIBW_TEST_REQUIRES: "pytest==7.4.2 moto==5.0.1"
CIBW_TEST_EXTRAS: "s3fs,glue"
CIBW_TEST_COMMAND: "pytest {project}/tests/avro/test_decoder.py"
# There is an upstream issue with installing on MacOSX
# https://github.com/pypa/cibuildwheel/issues/1603
# Ignore tests for pypy since not all dependencies are compiled for it
# and would require a local rust build chain
CIBW_TEST_SKIP: "pp* *macosx*"
- name: Add source distribution
if: startsWith(matrix.os, 'ubuntu')
run: ls -lah dist/* && cp dist/* wheelhouse/
- uses: actions/upload-artifact@v4
with:
name: "pypi-release-candidate-${{ matrix.os }}"
path: ./wheelhouse/*
pypi_merge_artifacts:
runs-on: ubuntu-latest
needs:
- validate-inputs
- pypi_build_artifacts
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@v4
with:
name: "pypi-release-candidate-${{ needs.validate-inputs.outputs.VERSION }}-rc${{ needs.validate-inputs.outputs.RC }}"
pattern: pypi-release-candidate*
delete-merged: true