python/ Improve documentation of classes following scikit-learn. #227
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Python | |
on: | |
push: | |
branches-ignore: [gh-pages] | |
paths: | |
- ".github/workflows/python.yml" | |
- "python/**" | |
- "!python/README.md" | |
- 'c/Make*' | |
- 'c/*.mk' | |
- 'c/**/*.[ch]p?p?' | |
pull_request: | |
branches-ignore: [gh-pages] | |
paths: | |
- ".github/workflows/python.yml" | |
- "python/**" | |
- "!python/README.md" | |
- 'c/Make*' | |
- 'c/*.mk' | |
- 'c/**/*.[ch]p?p?' | |
# Manual run | |
workflow_dispatch: | |
release: | |
types: | |
- published | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
lint-ruff: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Linter 🧹 for event_name = ${{ github.event_name }}, action = ${{ github.event.action }}, ref = ${{ github.ref }} | |
uses: chartboost/ruff-action@v1 | |
with: | |
src: "./python" | |
version: 0.3.5 | |
run-tests: | |
timeout-minutes: 15 | |
needs: lint-ruff | |
if: "! contains(github.event.head_commit.message, '[skip ci]')" | |
name: Test ${{ matrix.os }} (${{ matrix.python-version }}) | |
runs-on: ${{ matrix.os }} | |
strategy: | |
# When set to true, GitHub cancels all in-progress jobs if any matrix job fails. | |
fail-fast: false | |
matrix: | |
os: [ ubuntu-latest ] | |
# This must be kept in sync with pyproject.toml and mooplot | |
# macos-13 is an intel runner, macos-14 is apple silicon | |
python-version: ['3.10', '3.11', '3.12'] | |
include: | |
- os: windows-latest | |
python-version: '3.10' | |
- os: macos-14 | |
python-version: '3.10' | |
- os: macos-13 | |
python-version: '3.10' | |
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' | |
- name: Install dependencies | |
run: | | |
python3 -m pip install --upgrade pip | |
python3 -m pip install tox tox-gh-actions | |
- name: Run tox | |
run: tox | |
working-directory: python | |
build_sdist: | |
timeout-minutes: 10 | |
needs: run-tests | |
if: "! contains(github.event.head_commit.message, '[skip ci]')" | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
python-version: ["3.10"] | |
os: [ubuntu-latest] | |
steps: | |
- name: Checkout sources | |
uses: actions/checkout@v4 | |
- name: Setup Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install dependencies | |
run: | | |
python3 -m pip install --upgrade pip | |
python3 -m pip install --upgrade build | |
- name: Build the packages | |
run: python3 -m build | |
working-directory: python | |
- name: Publish artifacts | |
uses: actions/upload-artifact@v4 | |
with: | |
name: moocore-wheels-${{ matrix.os }}-${{ matrix.python-version }} | |
path: python/dist/*.tar.gz | |
build-doc: | |
name: Build documentation | |
timeout-minutes: 10 | |
needs: build_sdist | |
permissions: | |
contents: write | |
concurrency: web # Recommended if you intend to make multiple deployments in quick succession. | |
if: "! contains(github.event.head_commit.message, '[skip ci]')" | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout sources 🛎️ | |
uses: actions/checkout@v4 | |
- name: Setup Python 3.10 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: "3.10" | |
- name: Ensure Pip and Build | |
run: | | |
python3 -m pip install --upgrade pip | |
python3 -m pip install --upgrade build | |
- name: Build the package | |
run: python3 -m build | |
working-directory: python | |
- name: install the package | |
run: python3 -m pip install . | |
working-directory: python | |
- name: install the doc build requirements | |
run: | | |
python3 -m pip install -r requirements_dev.txt | |
working-directory: python | |
- name: Build the docs 🔧 | |
run: | | |
make -C doc clean | |
tox -e docs | |
make -C doc html | |
working-directory: python | |
- name: Deploy 🚀 | |
if: success() && runner.os == 'Linux' && github.event_name == 'push' && github.ref == 'refs/heads/main' | |
uses: JamesIves/github-pages-deploy-action@v4 | |
with: | |
folder: python/doc/_build/html/ # The folder the action should deploy. | |
target-folder: python | |
single-commit: true | |
clean: true | |
coverage: | |
timeout-minutes: 15 | |
needs: build-doc | |
if: "! contains(github.event.head_commit.message, '[skip ci]')" | |
name: Coverage ${{ matrix.os }} (${{ matrix.python-version }}) | |
runs-on: ${{ matrix.os }} | |
env: | |
CODECOV_TOKEN: ${{secrets.CODECOV_TOKEN}} | |
strategy: | |
# When set to true, GitHub cancels all in-progress jobs if any matrix job fails. | |
matrix: | |
os: [ubuntu-latest] | |
python-version: ['3.10'] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install dependencies | |
run: | | |
python3 -m pip install --upgrade pip | |
python3 -m pip install tox tox-gh-actions | |
working-directory: python | |
- name: Run coverage using tox | |
run: tox -e cov | |
working-directory: python | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v3 | |
with: | |
fail_ci_if_error: true | |
verbose: true | |
flags: python | |
token: ${{secrets.CODECOV_TOKEN}} | |
directory: python | |
wheels: | |
name: Build wheels on ${{ matrix.os }} | |
needs: coverage | |
runs-on: ${{ matrix.os }} | |
if: "! contains(github.event.head_commit.message, '[skip ci]')" | |
strategy: | |
fail-fast: false | |
matrix: | |
# macos-13 is an intel runner, macos-14 is apple silicon | |
os: [ubuntu-latest, windows-latest, macos-14] | |
python-version: ['3.10'] | |
CIBW_ARCHS_MACOS: ['auto universal2'] | |
include: | |
- os: macos-13 | |
python-version: '3.10' | |
# Silence: While universal2 wheels can be built on x86_64, the | |
# arm64 part of the wheel cannot be tested on x86_64. Consider | |
# building universal2 wheels on an arm64 runner, if your CI | |
# provider offers this. Notably, an arm64 runner can also test the | |
# x86_64 part of the wheel, through Rosetta emulation. | |
CIBW_TEST_SKIP: '*-macosx_universal2:arm64' | |
CIBW_ARCHS_MACOS: 'auto' | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-python@v5 | |
name: Install Python | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Set up QEMU | |
if: runner.os == 'Linux' | |
uses: docker/setup-qemu-action@v3 | |
with: | |
platforms: all | |
- name: Build wheels | |
uses: pypa/[email protected] | |
env: | |
CIBW_ARCHS_MACOS: ${{ matrix.CIBW_ARCHS_MACOS }} | |
CIBW_TEST_SKIP: ${{ matrix.CIBW_TEST_SKIP }} | |
with: | |
package-dir: python | |
output-dir: wheelhouse | |
- name: List wheels | |
run: ls wheelhouse/*.whl | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: moocore-wheels-${{ matrix.os }}-${{ matrix.python-version }}-${{ strategy.job-index }} | |
path: wheelhouse/*.whl | |
upload_pypi: | |
name: Publish Python 🐍 distribution 📦 to PyPI | |
needs: [wheels, build_sdist] | |
runs-on: ubuntu-latest | |
environment: | |
name: pypi | |
url: https://pypi.org/p/moocore | |
permissions: | |
id-token: write | |
if: github.event_name == 'release' && github.event.action == 'published' && startsWith(github.ref, 'refs/tags/v') | |
# or, alternatively, upload to PyPI on every tag starting with 'v' (remove on: release above to use this) | |
# if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/v') | |
steps: | |
- uses: actions/download-artifact@v4 | |
with: | |
# unpacks all moocore artifacts into dist/ | |
pattern: moocore-wheels-* | |
path: dist | |
merge-multiple: true | |
- name: Display structure of downloaded files | |
run: ls -R dist | |
- uses: pypa/gh-action-pypi-publish@release/v1 | |
with: | |
verbose: true | |
# To test: repository-url: https://test.pypi.org/legacy/ | |
upload: | |
name: Store wheels | |
needs: wheels | |
if: github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v') | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/download-artifact@v4 | |
with: | |
path: wheelhouse | |
pattern: moocore-wheels-* | |
merge-multiple: true | |
- name: List wheels | |
run: ls -l wheelhouse/*.whl | |
- name: Upload wheels | |
if: success() && runner.os == 'Linux' && github.event_name == 'push' | |
run: | | |
git config --local user.email "[email protected]" | |
git config --local user.name "GitHub Actions" | |
git checkout --orphan new-wheels | |
git rm -rf . | |
mv wheelhouse/*.whl . | |
git add *.whl | |
git commit --allow-empty -m "Store Python wheels from @ $GITHUB_SHA" | |
git branch -D wheels | |
git branch -m wheels | |
git push --force origin wheels | |
shell: bash {0} |