Skip to content

Commit

Permalink
Merge branch 'topic/default/pixi-and-wheels' into 'branch/default'
Browse files Browse the repository at this point in the history
Setup Pixi and add 2 Github workflows (pixi and wheels)

See merge request fluiddyn/fluidimage!61
  • Loading branch information
paugier committed Feb 18, 2024
2 parents cd9ba20 + a1f3c8e commit 39ca6a7
Show file tree
Hide file tree
Showing 27 changed files with 21,479 additions and 117 deletions.
5 changes: 3 additions & 2 deletions .gitattributes
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,6 @@ pixi.lock linguist-language=YAML
.hgignore export-ignore

old export-ignore
./try export-ignore
./bench export-ignore
try export-ignore
bench export-ignore
image_samples export-ignore
29 changes: 29 additions & 0 deletions .github/workflows/ci-pixi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
name: CI Pixi

on:
- push
- pull_request

jobs:
tests:
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: ["windows-2022", "macos-latest"]
python-version: ["3.9", "3.10", "3.11"]
defaults:
run:
shell: bash -l {0}
steps:
- uses: actions/checkout@v3
- uses: prefix-dev/[email protected]
with:
pixi-version: v0.11.1
cache: false
- name: Install
run: |
pixi run install-editable
- name: Tests
run: |
pixi run test
123 changes: 123 additions & 0 deletions .github/workflows/wheels.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
name: Build
on:
- push
- pull_request

jobs:

wheels:
runs-on: ${{ matrix.os }}-latest
strategy:
fail-fast: false
matrix:
include:
- os: ubuntu
architecture: x86_64
# really long (2 hours), see next job wheel-ubuntu-aarch64
# - os: ubuntu
# architecture: aarch64
- os: macos
architecture: x86_64
- os: macos
architecture: arm64
- os: windows
architecture: AMD64
steps:
- uses: actions/checkout@v4
- uses: docker/setup-qemu-action@v2
with:
platforms: arm64
if: runner.os == 'Linux' && matrix.architecture == 'aarch64'

- uses: actions/setup-python@v5
with:
python-version: 3.x

- name: Build wheels
uses: pypa/[email protected]
env:
CIBW_SKIP: pp* cp36-* cp37-* cp38-* *-musllinux*
CIBW_ARCHS: ${{ matrix.architecture }}
- uses: actions/upload-artifact@v4
with:
name: wheel-${{ matrix.os }}-${{ matrix.architecture }}
path: wheelhouse/*.whl

wheel-ubuntu-aarch64:
if: |
github.event_name == 'push' &&
startsWith(github.ref, 'refs/tags/')
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: docker/setup-qemu-action@v2
with:
platforms: arm64

- uses: actions/setup-python@v5
with:
python-version: 3.x

- name: Build wheels
uses: pypa/[email protected]
env:
CIBW_SKIP: pp* cp36-* cp37-* cp38-* *-musllinux*
CIBW_ARCHS: aarch64
- uses: actions/upload-artifact@v4
with:
name: wheel-ubuntu-aarch64
path: wheelhouse/*.whl

sdist:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- run: echo ${{ github.ref }}
- run: python -m pip install build twine
- run: python -m build --sdist
- run: twine check --strict dist/*
- uses: actions/upload-artifact@v4
with:
name: sdist
path: dist/*.tar.gz

check-sdist:
runs-on: ubuntu-latest
needs:
- sdist
steps:
- uses: actions/download-artifact@v4
with:
name: sdist
- uses: actions/setup-python@v5
with:
python-version: 3.11
- run: |
pip install pip -U
ls
pip install fluidimage-*.tar.gz -v --no-deps -C setup-args=-Dtransonic-backend=python
pypi-publish:
name: Upload release to PyPI
if: |
github.event_name == 'push' &&
startsWith(github.ref, 'refs/tags/')
needs:
- wheels
- wheel-ubuntu-aarch64
- sdist
- check-sdist
runs-on: ubuntu-latest
environment:
name: publish
url: https://pypi.org/p/fluidimage
permissions:
id-token: write # IMPORTANT: this permission is mandatory for trusted publishing
steps:
- uses: actions/download-artifact@v4
with:
path: dist
merge-multiple: true
- run: ls dist
- name: Publish package distributions to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
11 changes: 10 additions & 1 deletion .gitlab-ci.yml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
stages:
# - pixi
- pixi
- image
- lint
- test
Expand All @@ -22,6 +22,15 @@ workflow:
- if: $CI_COMMIT_TAG


pixi-test:
stage: pixi
image: registry.heptapod.net:443/fluiddyn/fluiddyn/ci/default:pixi
script:
- pixi info
- pixi run install-editable
- pixi run test


# Build an image for the other tasks; this should be a scheduled job, as
# it is quite unnecessary to run on every invocation.
image:build:
Expand Down
1 change: 1 addition & 0 deletions .hgignore
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ fluidimage/_hg_rev.py

.venv
.nox
.pixi

.pdm-python

Expand Down
8 changes: 2 additions & 6 deletions noxfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ def __call__(self, task: str):
def test(session):
"""Execute unit-tests using pytest"""

command = "pdm sync --clean -G test -G qt --no-self"
command = "pdm sync --clean -G test --no-self"
session.run_always(*command.split(), external=True)
session.install(".", "--no-deps")

Expand Down Expand Up @@ -142,11 +142,7 @@ def add_tag_for_release(session):
session.run("hg", "update", "default", external=True)

version = _get_version_from_pyproject()
version_core = _get_version_from_pyproject("lib")

print(f"{version = }, {version_core = }")
if version != version_core:
session.error("version != version_core")
print(f"{version = }")

result = session.run("hg", "tags", "-T", "{tag},", external=True, silent=True)
last_tag = result.split(",", 2)[1]
Expand Down
20 changes: 10 additions & 10 deletions pdm.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit 39ca6a7

Please sign in to comment.