Workflow file for this run
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
# Build documentation | |
# The build is uploaded as artifact if the triggering event is a push for a pull request | |
# The build is published to github pages if the triggering event is a push to the master branch (PR merge) | |
name: Build and upload documentation | |
defaults: | |
run: | |
shell: bash | |
on: # Runs on any push event in a PR or any push event to master | |
pull_request: | |
push: | |
branches: | |
- 'master' | |
jobs: | |
documentation: | |
name: ${{ matrix.os }} / ${{ matrix.python-version }} | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: # only lowest supported Python on latest ubuntu | |
os: [ubuntu-latest] | |
python-version: [3.8] | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
cache: 'pip' | |
cache-dependency-path: '**/setup.py' | |
- name: Get full Python version | |
id: full-python-version | |
run: echo ::set-output name=version::$(python -c "import sys; print('-'.join(str(v) for v in sys.version_info))") | |
- name: Upgrade pip, setuptools and wheel | |
run: python -m pip install --upgrade pip setuptools wheel | |
- name: Install package | |
run: python -m pip install '.[doc]' | |
- name: Build documentation | |
run: python -m sphinx -b html doc ./doc_build -d ./doc_build | |
- name: Upload build artifacts # upload artifacts so reviewers can have a quick look without building documentation from the branch locally | |
uses: actions/upload-artifact@v2 | |
if: success() && github.event_name == 'pull_request' # only for pushes in PR | |
with: | |
name: site-build | |
path: doc_build | |
retention-days: 5 | |
- name: Upload documentation to gh-pages | |
if: success() && github.ref == 'refs/heads/master' # only for pushes to master | |
uses: JamesIves/[email protected] | |
with: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
BRANCH: gh-pages | |
FOLDER: doc_build |