-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use reusable workflow from hyperspy organisation for the doc workflow
- Loading branch information
Showing
1 changed file
with
9 additions
and
89 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,97 +1,17 @@ | ||
name: Docs | ||
name: Documentation | ||
|
||
on: [push, pull_request] | ||
|
||
jobs: | ||
build_docs: | ||
# This build is to make PR comments for the sphinx warning and check if | ||
# web links are not broken | ||
name: Check links and make PR comments | ||
runs-on: ubuntu-latest | ||
env: | ||
DOCS_PATH: ./doc/_build/html/ | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
Build: | ||
# Use the "reusable workflow" from the hyperspy organisation | ||
uses: hyperspy/.github/.github/workflows/doc.yml@main | ||
|
||
- uses: actions/setup-python@v4 | ||
name: Install Python | ||
with: | ||
python-version: '3.11' | ||
|
||
- name: Install build docs | ||
shell: bash -l {0} | ||
run: | | ||
pip install .'[doc]' | ||
# Add sphinx warnings as PR comments | ||
- uses: sphinx-doc/sphinx-problem-matcher@master | ||
|
||
- name: Build docs | ||
shell: bash -l {0} | ||
run: | | ||
cd doc | ||
make SPHINXOPTS="-W --keep-going" html | ||
- uses: actions/upload-artifact@v3 | ||
with: | ||
path: ${{ env.DOCS_PATH }} | ||
name: docs_html | ||
|
||
- name: Check links | ||
shell: bash -l {0} | ||
run: | | ||
cd doc | ||
make linkcheck | ||
push_docs: | ||
# This build is to push changes to gh-pages branch (https://hyperspy.org/exspy) | ||
needs: build_docs | ||
name: Push to gh-pages | ||
runs-on: ubuntu-latest | ||
if: ${{ github.event_name != 'pull_request' && github.repository == 'hyperspy/exspy' }} | ||
Push: | ||
needs: Build | ||
if: ${{ github.event_name != 'pull_request' && github.repository_owner == 'hyperspy' }} | ||
permissions: | ||
# needs write permission to push the docs to gh-pages | ||
contents: write | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
ref: gh-pages | ||
|
||
- uses: actions/download-artifact@v3 | ||
with: | ||
name: docs_html | ||
path: . | ||
|
||
- name: list files | ||
run: | | ||
ls | ||
- name: Git status | ||
run: | | ||
git status | ||
git status -s | ||
if [[ $(git status -s) ]]; then | ||
HAS_CHANGES='true' | ||
else | ||
HAS_CHANGES='false' | ||
fi | ||
echo "HAS_CHANGES=${HAS_CHANGES}" >> $GITHUB_ENV | ||
- name: Commit files | ||
# Skip when there is nothing to commit | ||
if: ${{ env.HAS_CHANGES == 'true' }} | ||
run: | | ||
git config --local user.email "github-actions[bot]@users.noreply.github.com" | ||
git config --local user.name "github-actions[bot]" | ||
git add -A | ||
git commit -m "Update docs build" -a | ||
- name: Push changes | ||
if: ${{ env.HAS_CHANGES == 'true' }} | ||
uses: ad-m/github-push-action@d91a481090679876dfc4178fef17f286781251df | ||
with: | ||
github_token: ${{ secrets.GITHUB_TOKEN }} | ||
branch: gh-pages | ||
# Use the "reusable workflow" from the hyperspy organisation | ||
uses: hyperspy/.github/.github/workflows/push_doc.yml@main |