Skip to content

.github/workflows/build-doc.yml #4

.github/workflows/build-doc.yml

.github/workflows/build-doc.yml #4

Workflow file for this run

name: Build Doc & Deploy
on:
workflow_run:
workflows: [Build Python Package]
types: [completed]
jobs:
build-doc-deploy:
name: Build doc and deploy
runs-on: ubuntu-latest
if: ${{ github.event.workflow_run.conclusion == 'success' }}
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v4
with:
python-version: "3.x"
- name: Install pip packages
working-directory: docs
run: |
pip install pip --upgrade
pip install -r requirements.txt --upgrade
- name: Build doc
working-directory: docs
run: |
make html SPHINXOPTS='-W --keep-going'
- name: Commit doc to gh-pages
run: |
author=$(git log -1 --pretty=format:'%an')
email=$(git log -1 --pretty=format:'%ae')
commit=$(git rev-parse --short HEAD)
mkdir /tmp/doc
rm -r docs/_build/html/_sources
cp -r docs/_build/html/* /tmp/doc
git stash --all
git fetch origin gh-pages
git checkout -b gh-pages origin/gh-pages
git rm -r . --quiet
cp -r /tmp/doc/* .
touch .nojekyll
git add . >> /dev/null
git config --global user.name "$author"
git config --global user.email "$email"
git commit -m "deploy: $commit" --allow-empty
- name: Push to gh-pages
run: >-
git push origin gh-pages:gh-pages
- name: Clean-up
run: >-
rm -r /tmp/doc
build-doc-min:
name: Build doc on min requirements
runs-on: ubuntu-20.04
if: ${{ github.event.workflow_run.conclusion == 'success' }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v4
with:
python-version: "3.8"
- name: Install pip packages
working-directory: docs
run: |
pip install pip --upgrade
pip install -r requirements.txt --upgrade
- name: Build doc
working-directory: docs
run: |
make html SPHINXOPTS='-W --keep-going'