Skip to content

feat: return Datetime for TimestampTz in python. #1249

feat: return Datetime for TimestampTz in python.

feat: return Datetime for TimestampTz in python. #1249

Workflow file for this run

name: Bindings Python
on:
push:
branches:
- main
tags:
- v*
pull_request:
branches:
- main
paths:
- "core/**"
- "sql/**"
- "driver/**"
- "bindings/python/**"
- ".github/workflows/bindings.python.yml"
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.event_name }}
cancel-in-progress: true
jobs:
check:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Setup Rust toolchain
uses: ./.github/actions/setup
with:
cache-key: bindings-python-check
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install dependencies
working-directory: bindings/python
run: pip install ruff
- name: Check format
working-directory: bindings/python
run: ruff format --check .
build:
name: build-${{ matrix.os }}-${{ matrix.arch }}-${{ matrix.wheel }}
needs: check
runs-on: ${{ matrix.runner }}
strategy:
matrix:
include:
- os: linux
arch: x86_64
target: x86_64-unknown-linux-gnu
runner: ubuntu-latest
wheel: py39-abi
- os: linux
arch: x86_64
target: x86_64-unknown-linux-gnu
runner: ubuntu-latest
wheel: cp38
- os: linux
arch: aarch64
target: aarch64-unknown-linux-gnu
runner: ubuntu-latest
wheel: py39-abi
- os: linux
arch: aarch64
target: aarch64-unknown-linux-gnu
runner: ubuntu-latest
wheel: cp38
# FIXME: Windows build is broken
# - os: windows
# arch: x86_64
# target: x86_64-pc-windows-msvc
# runner: windows-latest
- os: macos
arch: x86_64
target: x86_64-apple-darwin
runner: macos-latest
wheel: py39-abi
- os: macos
arch: x86_64
target: x86_64-apple-darwin
runner: macos-latest
wheel: cp38
- os: macos
arch: aarch64
target: aarch64-apple-darwin
runner: macos-latest
wheel: py39-abi
- os: macos
arch: aarch64
target: aarch64-apple-darwin
runner: macos-latest
wheel: cp38
steps:
- uses: actions/checkout@v4
- name: Get opts
id: opts
shell: bash
run: |
if [[ "${{ github.event_name }}" == "pull_request" ]]; then
base_args="--strip --out dist"
else
base_args="--release --strip --out dist"
fi
if [[ "${{ matrix.wheel }}" == "py39-abi" ]]; then
wheel_args="--features py39-abi"
else
wheel_args="--no-default-features --features cp38 --interpreter python3.8"
fi
echo "BUILD_ARGS=${base_args} ${wheel_args}" >> $GITHUB_OUTPUT
if [[ "${{ matrix.target }}" == "aarch64-unknown-linux-gnu" ]]; then
echo "MANYLINUX=2_28" >> $GITHUB_OUTPUT
else
echo "MANYLINUX=auto" >> $GITHUB_OUTPUT
fi
- name: Setup Rust toolchain
uses: ./.github/actions/setup
with:
cache-key: bindings-python-${{ matrix.os }}-${{ matrix.arch }}
target: ${{ matrix.target }}
- name: Setup Python 3.8 (cp38 wheels)
if: matrix.wheel == 'cp38' && matrix.os != 'linux'
uses: actions/setup-python@v5
with:
python-version: "3.8"
- name: Build wheels
uses: PyO3/maturin-action@v1
with:
working-directory: bindings/python
target: ${{ matrix.target }}
manylinux: ${{ steps.opts.outputs.MANYLINUX }}
sccache: "true"
args: ${{ steps.opts.outputs.BUILD_ARGS }}
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: bindings-python-${{ matrix.os }}-${{ matrix.arch }}-${{ matrix.wheel }}
path: bindings/python/dist/*.whl
integration:
name: integration-${{ matrix.pyver }}-${{matrix.body}}
needs: build
runs-on: ubuntu-latest
strategy:
matrix:
pyver: ["3.8", "3.9", "3.10", "3.11", "3.12", "3.13"]
body: ["arrow", "json"]
steps:
- uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.pyver }}
- name: Prepare
working-directory: tests
run: make up
- name: Download artifact
uses: actions/download-artifact@v4
with:
pattern: bindings-python-linux-x86_64-*
path: bindings/python/artifacts
merge-multiple: true
- name: Install dependencies
working-directory: bindings/python
run: |
pip install behave
if [[ "${{ matrix.pyver }}" == "3.8" ]]; then
pip install artifacts/*cp38*.whl
else
pip install artifacts/*abi3*.whl
fi
- name: Test AsyncIO
working-directory: bindings/python
run: behave tests/asyncio
env:
BODY_FORMAT: ${{ matrix.body }}
- name: Test Blocking
working-directory: bindings/python
run: behave tests/blocking
env:
BODY_FORMAT: ${{ matrix.body }}
- name: Test Cursor
working-directory: bindings/python
run: behave tests/cursor
env:
BODY_FORMAT: ${{ matrix.body }}
compat:
name: Compat Test
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: "3.13"
- uses: wntrblm/[email protected]
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: bindings-python-linux-x86_64-py39-abi
path: bindings/python/dist
- name: Run Nox
run: nox -f tests/nox/noxfile.py
publish:
if: startsWith(github.ref, 'refs/tags/v')
needs: [check, build, integration]
runs-on: ubuntu-latest
permissions:
id-token: write
environment:
name: pypi.org
url: https://pypi.org/p/databend-driver/
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v4
with:
path: bindings/python/artifacts
pattern: bindings-python-*
merge-multiple: true
- name: Publish package distributions to PyPI
uses: pypa/gh-action-pypi-publish@unstable/v1
with:
skip-existing: true
packages-dir: bindings/python/artifacts