Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
102 changes: 102 additions & 0 deletions .github/workflows/python-client-release-pypi-artifact.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
#
# 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: "Build Python Client Release Pypi Artifacts"

on:
workflow_call:
inputs:
VERSION:
required: true
type: string

jobs:
pypi-build-artifacts:
name: Build artifacts for SVN on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ ubuntu-24.04, macos-14, macos-15] # current build script is not compatible with windows

steps:
- uses: actions/checkout@v5
with:
fetch-depth: 1

- name: Set up Python
uses: actions/setup-python@v6
with:
python-version: |
3.10
3.11
3.12
3.13
- name: Set up JDK for openapi-generator-cli
uses: actions/setup-java@dded0888837ed1f317902acf8a20df0ad188d165 # v5
with:
distribution: 'temurin'
java-version: '21'

- name: Set version with RC
run:

- name: Set version with RC
env:
VERSION: ${{ inputs.VERSION }}
run: make client-set-version VERSION="${{ env.VERSION }}"

- name: Build source distribution
run: |
make client-build FORMAT=sdist

- name: Build wheels
uses: pypa/cibuildwheel@v3.1.4
with:
output-dir: wheelhouse
package-dir: "./client/python"
config-file: "{package}/pyproject.toml"
env:
# Ignore 32 bit architectures
CIBW_ARCHS: "auto64"
CIBW_PROJECT_REQUIRES_PYTHON: ">=3.9,<3.14"
CIBW_REPAIR_WHEEL_COMMAND_MACOS: "" # Disable wheel repair since there will be no binary in the wheel
CIBW_REPAIR_WHEEL_COMMAND_LINUX: ""
CIBW_ENVIRONMENT: POLARIS_CLI_SKIP_CLIENT_GENERATION="true" # java is not available in linux containers during wheel build, skip client generation

- name: Add source distribution
if: startsWith(matrix.os, 'ubuntu-24.04')
run: ls -lah ./client/python/dist/* && cp ./client/python/dist/* wheelhouse/


- uses: actions/upload-artifact@v4
with:
name: "python-client-pypi-release-candidate-${{ matrix.os }}"
path: ./wheelhouse/*

pypi-merge-artifacts:
runs-on: ubuntu-latest
needs:
- pypi-build-artifacts
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@v4
with:
name: "python-client-pypi-release-candidate-${{ inputs.VERSION }}"
pattern: python-client-pypi-release-candidate*
delete-merged: true
94 changes: 94 additions & 0 deletions .github/workflows/python-client-release-svn-artifact.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
#
# 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: "Build Python Client Release SVN Artifacts"

on:
workflow_call:
inputs:
VERSION:
required: true
type: string

jobs:
svn-build-artifacts:
name: Build artifacts for SVN on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ ubuntu-24.04, macos-14, macos-15] # current build script is not compatible with windows

steps:
- uses: actions/checkout@v5
with:
fetch-depth: 1

- name: Set up Python
uses: actions/setup-python@v6
with:
python-version: |
3.10
3.11
3.12
3.13
- name: Set up JDK for openapi-generator-cli
uses: actions/setup-java@dded0888837ed1f317902acf8a20df0ad188d165 # v5
with:
distribution: 'temurin'
java-version: '21'

- name: Build source distribution
run: |
make client-build FORMAT=sdist

- name: Build wheels
uses: pypa/cibuildwheel@v3.1.4
with:
output-dir: wheelhouse
package-dir: "./client/python"
config-file: "{package}/pyproject.toml"
env:
# Ignore 32 bit architectures
CIBW_ARCHS: "auto64"
CIBW_PROJECT_REQUIRES_PYTHON: ">=3.9,<3.14"
CIBW_REPAIR_WHEEL_COMMAND_MACOS: "" # Disable wheel repair since there will be no binary in the wheel
CIBW_REPAIR_WHEEL_COMMAND_LINUX: ""
CIBW_ENVIRONMENT: POLARIS_CLI_SKIP_CLIENT_GENERATION="true" # java is not available in linux containers during wheel build, skip client generation

- name: Add source distribution
if: startsWith(matrix.os, 'ubuntu-24.04')
run: ls -lah ./client/python/dist/* && cp ./client/python/dist/* wheelhouse/


- uses: actions/upload-artifact@v4
with:
name: "python-client-svn-release-candidate-${{ matrix.os }}"
path: ./wheelhouse/*

svn-merge-artifacts:
runs-on: ubuntu-latest
needs:
- svn-build-artifacts
steps:
- name: Merge Artifacts
uses: actions/upload-artifact/merge@v4
with:
name: "python-client-svn-release-candidate-${{ inputs.VERSION }}"
pattern: python-client-svn-release-candidate*
delete-merged: true
123 changes: 123 additions & 0 deletions .github/workflows/python-release-build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
#
# 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 Client Build Release Candidate"

on:
workflow_dispatch:
inputs:
version:
description: 'Version (e.g. 1.1.0)'
type: string
required: true
rc:
description: 'Release Candidate (RC) (e.g. 1)'
type: number
required: true
pull_request:
paths:
- '.github/workflows/python-release-build.yml'
- '.github/workflows/python-client-release-svn-artifact.yml'
- 'client/python/**'

jobs:
validate-inputs:
runs-on: ubuntu-latest
outputs:
VERSION: ${{ steps.validate-inputs.outputs.VERSION }}
RC: ${{ steps.validate-inputs.outputs.RC }}
steps:
- name: Validate Version and RC
id: validate-inputs
run: |
# Use test values for pull_request trigger, actual inputs for workflow_dispatch
if [[ "${{ github.event_name }}" == "pull_request" ]]; then
echo "Workflow triggered by pull_request - using test values"
VERSION="1.2.0"
RC="1"
else
echo "Workflow triggered manually via workflow_dispatch."
VERSION="${{ github.event.inputs.version }}"
RC="${{ github.event.inputs.rc }}"
fi

# 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

# 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-client-version:
runs-on: ubuntu-latest
needs:
- validate-inputs
steps:
- uses: actions/checkout@v5
with:
fetch-depth: 1

- uses: actions/setup-python@v6
with:
python-version: 3.12

- name: Setup Environment
run: |
export POETRY_VERSION=$(cat client/python/pyproject.toml | grep requires-poetry | sed 's/requires-poetry *= *"\(.*\)"/\1/')
python3 -m pip install poetry$POETRY_VERSION
- name: Validate Current Client Version
working-directory: ./client/python
env:
VERSION: ${{ needs.validate-inputs.outputs.VERSION }}
run: |
current_polaris_client_version=$(poetry version --short)
echo "Detected Poetry version: $current_polaris_client_version"

# Compare the input version with the Poetry version
if [[ "$VERSION" != "$current_polaris_client_version" ]]; then
echo "Error: Input version ($VERSION) does not match the Poetry version ($current_polaris_client_version)"
exit 1
fi

svn-build-artifacts:
needs:
- validate-inputs
- validate-client-version
uses: ./.github/workflows/python-client-release-svn-artifact.yml
with:
VERSION: ${{ needs.validate-inputs.outputs.VERSION }}rc${{ needs.validate-inputs.outputs.RC }}

pypi-build-artifacts:
needs:
- validate-inputs
- validate-client-version
uses: ./.github/workflows/python-client-release-pypi-artifact.yml
with:
VERSION: ${{ needs.validate-inputs.outputs.VERSION }}rc${{ needs.validate-inputs.outputs.RC }}
10 changes: 10 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,16 @@ client-lint: client-setup-env ## Run linting checks for Polaris client
@$(ACTIVATE_AND_CD) && poetry run pre-commit run --files integration_tests/* python/cli/*
@echo "--- Client linting checks complete ---"

.PHONY: client-set-version
client-set-version: client-setup-env ## Set Python client version using poetry. Usage: make client-set-version VERSION=<version>
@echo "--- Setting client version ---"
@if [ -z "$(VERSION)" ]; then \
echo "Error: VERSION is required. Usage: make client-set-version VERSION=<version>" >&2; \
exit 1; \
fi
@$(ACTIVATE_AND_CD) && poetry version "$(VERSION)"
@echo "--- Client version set to $(VERSION) ---"

.PHONY: client-regenerate
client-regenerate: client-setup-env ## Regenerate the client code
@echo "--- Regenerating client code ---"
Expand Down
1 change: 0 additions & 1 deletion client/python/apache_polaris/sdk/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,3 @@
# specific language governing permissions and limitations
# under the License.
#

3 changes: 3 additions & 0 deletions client/python/generate_clients.py
Original file line number Diff line number Diff line change
Expand Up @@ -324,6 +324,9 @@ def main():
else:
logging.basicConfig(level=logging.INFO, format="%(message)s")

if os.environ.get("POLARIS_CLI_SKIP_CLIENT_GENERATION", "false").lower() == "true":
logger.info("POLARIS_CLI_SKIP_CLIENT_GENERATION is set to true, skipping client generation.")
return
build()


Expand Down