[Automated] Update documentation requirements #700
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: 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() |