Skip to content

[Automated] Update documentation requirements #689

[Automated] Update documentation requirements

[Automated] Update documentation requirements #689

Workflow file for this run

name: CI
permissions:
pull-requests: write
contents: read
issues: write
on:
push:
branches:
- main
paths:
- 'src/**'
- 'tests/**'
- '.github/workflows/CI.yml'
- 'pyproject.toml'
- 'docs/**'
pull_request:
branches:
- main
- 'release**'
paths:
- 'src/**'
- 'tests/**'
- '.github/workflows/CI.yml'
- 'pyproject.toml'
- 'docs/**'
jobs:
test-nodevdeps:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: 3.11
- name: Display Python version
run: |
python -c "import sys; print(sys.version)"
- name: Install uv
run: |
curl -LsSf https://astral.sh/uv/install.sh | sh
echo "$(python -m site --user-base)/bin" >> $GITHUB_PATH
- name: Create virtual environment
run: |
uv venv .venv
- name: Show which python is being used
run: |
source .venv/bin/activate
which python
- name: Show dependencies
run: |
source .venv/bin/activate
uv pip list
- name: Install package and core dependencies
run: |
source .venv/bin/activate
uv pip install .
- name: Run pytest-free tests
run: |
source .venv/bin/activate
python tests/_nopytest_tests.py
test-no-softdeps:
needs: test-nodevdeps
strategy:
fail-fast: false
matrix:
python-version: ['3.9', '3.10', '3.11', '3.12']
os: [ubuntu-latest, macos-13, windows-latest]
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Display Python version
run: python -c "import sys; print(sys.version)"
- name: Install uv on Windows
if: runner.os == 'Windows'
run: irm https://astral.sh/uv/install.ps1 | iex
shell: pwsh
- name: Install uv on Linux and macOS
if: runner.os != 'Windows'
run: curl -LsSf https://astral.sh/uv/install.sh | sh
shell: bash
- name: Update PATH
run: echo "$(python -m site --user-base)/bin" >> $GITHUB_PATH
shell: pwsh
- name: Install uv on Windows
if: runner.os == 'Windows'
run: irm https://astral.sh/uv/install.ps1 | iex
shell: pwsh
- name: Install uv on Linux and macOS
if: runner.os != 'Windows'
run: curl -LsSf https://astral.sh/uv/install.sh | sh
shell: bash
- name: Update PATH
run: echo "$(python -m site --user-base)/bin" >> $GITHUB_PATH
shell: pwsh
- name: Create virtual environment
run: |
uv venv .venv
- name: Install package and dependencies on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
uv pip install .[dev] --no-cache-dir
shell: bash
- name: Install package and dependencies on Windows
if: runner.os == 'Windows'
run: |
.\.venv\Scripts\Activate.ps1
uv pip install .[dev] --no-cache-dir
shell: pwsh
- name: Show dependencies on Windows
if: runner.os == 'Windows'
run: |
.\.venv\Scripts\Activate.ps1
uv pip list
shell: pwsh
- name: Show dependencies on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
uv pip list
shell: bash
- name: Show available branches
run: |
git branch -a
- name: Run tests on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
python -m pytest src/ tests/ -vv
shell: bash
- name: Run tests on Windows
if: runner.os == 'Windows'
run: |
.\.venv\Scripts\Activate.ps1
python -m pytest src/ tests/ -vv
shell: pwsh
test-all-softdeps:
needs: test-no-softdeps
strategy:
fail-fast: false
matrix:
python-version: ['3.9', '3.10', '3.11', '3.12']
os: [ubuntu-latest, macos-13, windows-latest]
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Display Python version
run: |
python -c "import sys; print(sys.version)"
- name: Install uv on Windows
if: runner.os == 'Windows' && matrix.python-version != '3.12'
run: irm https://astral.sh/uv/install.ps1 | iex
shell: pwsh
- name: Install uv on Linux and macOS
if: runner.os != 'Windows'
run: curl -LsSf https://astral.sh/uv/install.sh | sh
shell: bash
- name: Update PATH
if: runner.os != 'Windows' || matrix.python-version != '3.12'
run: echo "$(python -m site --user-base)/bin" >> $GITHUB_PATH
shell: pwsh
- name: Create virtual environment
if: runner.os != 'Windows' || matrix.python-version != '3.12'
run: uv venv .venv
- name: Install package and dependencies on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
uv pip install .[all_extras,dev] --no-cache-dir
shell: bash
- name: Install package and dependencies on Windows
if: runner.os == 'Windows' && matrix.python-version != '3.12'
run: |
.\.venv\Scripts\Activate.ps1
uv pip install .[all_extras,dev] --no-cache-dir
shell: pwsh
- name: Show dependencies on Windows
if: runner.os == 'Windows' && matrix.python-version != '3.12'
run: |
.\.venv\Scripts\Activate.ps1
uv pip list
shell: pwsh
- name: Show dependencies on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
uv pip list
shell: bash
- name: Show available branches
run: |
git branch -a
- name: Run tests on Linux and macOS
if: runner.os != 'Windows'
run: |
source .venv/bin/activate
python -m pytest src/ tests/ -vv
shell: bash
- name: Run tests on Windows
if: runner.os == 'Windows' && matrix.python-version != '3.12'
run: |
.\.venv\Scripts\Activate.ps1
python -m pytest src/ tests/ -vv
shell: pwsh
# Upload code coverage report to github artifacts
- name: Upload coverage report
if: runner.os != 'Windows' || matrix.python-version != '3.12'
uses: actions/upload-artifact@v4
with:
name: coverage
path: coverage.md
# Publish code coverage to codecov
- name: Publish code coverage
if: runner.os != 'Windows' || matrix.python-version != '3.12'
uses: codecov/codecov-action@v4
with:
token: ${{secrets.CODECOV_TOKEN}} # Use the secret token
fail_ci_if_error: true
verbose: true
docs:
name: Test docs build
runs-on: ubuntu-latest
steps:
- name: Check out Git repository
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: 3.11
- name: Install uv
run: |
pip install uv
echo "$(python -m site --user-base)/bin" >> $GITHUB_PATH
- name: Create virtual environment
run: |
uv venv .venv
# Install package and dependencies
- name: Install package and dependencies
run: |
source .venv/bin/activate
uv pip install .[dev,docs] --no-cache-dir
# Build sphinx documentation
- name: Build sphinx documentation
run: |
source .venv/bin/activate
cd docs
make clean
make html --debug --jobs 2 SPHINXOPTS=" -W -v"
# Upload built docs
- name: Upload built docs
uses: actions/upload-artifact@v4
with:
name: docs-results-${{ runner.os }}
path: docs/build/html/
# Use always() to always run this step to publish test results when there are test failures
if: success()