Skip to content

fix: improve python api & packaging #452

fix: improve python api & packaging

fix: improve python api & packaging #452

Workflow file for this run

# 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: CI
on:
push:
branches:
- main
- release/**
paths-ignore:
- '**.md'
- '.github/ISSUE_TEMPLATE/**'
- '.github/PULL_REQUEST_TEMPLATE.md'
- '.asf.yaml'
- '.licenserc.yaml'
- '.commitlintrc.yaml'
- 'LICENSE'
- 'NOTICE'
pull_request:
branches:
- main
paths-ignore:
- '**.md'
- '.github/ISSUE_TEMPLATE/**'
- '.github/PULL_REQUEST_TEMPLATE.md'
- '.asf.yaml'
- '.licenserc.yaml'
- '.commitlintrc.yaml'
- 'LICENSE'
- 'NOTICE'
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.event_name }}
cancel-in-progress: true
jobs:
rust-tests:
strategy:
fail-fast: false
matrix:
# TODO: add windows which does not support container
os: [ ubuntu-22.04 ]
runs-on: ${{ matrix.os }}
container:
image: xd009642/tarpaulin:0.30.0
options: --security-opt seccomp=unconfined
steps:
- uses: actions/checkout@v4
- name: Rust unit tests with coverage report
# https://github.com/xd009642/tarpaulin/issues/1092#issuecomment-1407739176
run: cargo tarpaulin --engine llvm --no-dead-code --no-fail-fast --all-features --workspace -o xml --output-dir ./cov-reports
- name: Upload coverage report
uses: actions/upload-artifact@v4
with:
name: cov-report-rust-tests-${{ runner.os }}
path: ./cov-reports
if-no-files-found: 'error'
python-tests:
strategy:
fail-fast: false
matrix:
# TODO: add windows
os: [ ubuntu-22.04, macos-14 ]
python-version: [ '3.9', '3.12' ]
exclude:
- os: macos-14
python-version: '3.9'
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: pip
cache-dependency-path: pyproject.toml
- name: Setup Python venv
working-directory: ./python
run: |
make setup-venv
source venv/bin/activate
make develop
- name: Python unit tests with coverage report
run: |
pushd python
source venv/bin/activate
coverage run --include 'hudi/*' -m pytest -v
# move to parent so the reported file paths will match the actual repo paths
popd
coverage xml --data-file=python/.coverage -o ./cov-reports/cov-report-python-tests-${{ join(matrix.*, '-') }}.xml
- name: Upload coverage report
uses: actions/upload-artifact@v4
with:
name: cov-report-python-tests-${{ join(matrix.*, '-') }}
path: ./cov-reports
if-no-files-found: 'error'
publish-coverage:
name: Publish coverage reports to codecov.io
runs-on: ubuntu-latest
needs: [ rust-tests, python-tests ]
steps:
- uses: actions/download-artifact@v4
with:
pattern: cov-report-*
merge-multiple: true
path: ./cov-reports
- name: Upload coverage reports to codecov.io
uses: codecov/codecov-action@v4
with:
fail_ci_if_error: true
token: ${{ secrets.CODECOV_TOKEN }}
files: ./cov-reports/*
release-pypi-manylinux:
name: PyPI release manylinux
needs: [ rust-tests, python-tests ]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: '3.12'
- name: Publish manylinux to pypi x86_64 (with sdist)
uses: PyO3/maturin-action@v1
env:
MATURIN_PYPI_TOKEN: 'pypi-AgENdGVzdC5weXBpLm9yZwIkNGM4ZTRmMDAtMTAyMS00NWM1LWE0MmEtNWU4ODQwNzc5M2VkAAIMWzEsWyJodWRpIl1dAAIsWzIsWyJmM2Y1YjcwYy1mYmYzLTQ1YzEtYWZhNC0zZTc0MWU4Yjk4MmIiXV0AAAYgh2Rbybc6sknkmXvXsB5Lm0entwffseBFby4VXo6Ww4U'
MATURIN_REPOSITORY: testpypi
with:
target: x86_64-unknown-linux-gnu
command: publish
args: --skip-existing -m python/Cargo.toml
# for openssl build
before-script-linux: yum install -y perl-IPC-Cmd
- name: Publish manylinux to pypi aarch64 (without sdist)
uses: PyO3/maturin-action@v1
env:
MATURIN_PYPI_TOKEN: 'pypi-AgENdGVzdC5weXBpLm9yZwIkNGM4ZTRmMDAtMTAyMS00NWM1LWE0MmEtNWU4ODQwNzc5M2VkAAIMWzEsWyJodWRpIl1dAAIsWzIsWyJmM2Y1YjcwYy1mYmYzLTQ1YzEtYWZhNC0zZTc0MWU4Yjk4MmIiXV0AAAYgh2Rbybc6sknkmXvXsB5Lm0entwffseBFby4VXo6Ww4U'
MATURIN_REPOSITORY: testpypi
with:
target: aarch64-unknown-linux-gnu
command: publish
args: --skip-existing -m python/Cargo.toml --no-sdist
before-script-linux: |
# We can remove this once we upgrade to 2_28.
# https://github.com/briansmith/ring/issues/1728
export CFLAGS_aarch64_unknown_linux_gnu="-D__ARM_ARCH=8"