-
Notifications
You must be signed in to change notification settings - Fork 4
80 lines (80 loc) · 3.1 KB
/
docs.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
name: Documentation
on: [push, pull_request]
jobs:
build_docs:
runs-on: ubuntu-latest
container: ghcr.io/ganeshgore/sdpphy-docs-image:latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Setup doc enviroment
shell: bash
run: |
source /tmp/buildenv/bin/activate
bash ./.github/build_env.sh
if [ -f "docs/requirements.txt" ]; then
python3 -m pip install --upgrade \
--no-cache-dir -r docs/requirements.txt
fi
export PYTHONPATH=$PYTHONPATH:${PWD}
- name: Build Examples
shell: bash
run: |
source /tmp/buildenv/bin/activate
cd docs && PYTHON_EXEC=/tmp/buildenv/bin/python3 make run_examples
- name: Build Documentation
shell: bash
id: build
run: |
source /tmp/buildenv/bin/activate
cd docs && PYTHON_EXEC=/tmp/buildenv/bin/python3 make html
sed -i "/.*docs.*build.*/d" .gitignore
cat .gitignore
- name: Upload regression results
if: ${{ failure() }}
uses: actions/upload-artifact@v4
with:
name: docs_build
retention-days: 2
path: |
/tmp/sphinx-err*
docs/**/*
examples/**/*
- name: Prepare pre_release documentation
if: ${{ ((steps.build.outcome == 'success') && (github.ref == 'refs/heads/pre_release')) }}
shell: bash
id: prepare_pre_release
run: |
mv docs/build/html docs/build/html_pre_release
find ./docs/build/html_pre_release -name "*.html*" -exec sed -i "s/<head>/<head><base href=\"pre_release\">/" {} \;
echo "body{border-top: 20px solid #FF9800;}" > ./docs/build/html_pre_release/_static/custom.css
- name: Deploy pre_release documentation
if: ${{ ((steps.build.outcome == 'success') && (github.ref == 'refs/heads/pre_release')) }}
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_branch: docs
publish_dir: docs/build/html_pre_release
destination_dir: docs/pre_release
exclude_assets: "doctrees"
- name: Deploy documentation
if: ${{ ((steps.build.outcome == 'success') && (github.ref == 'refs/heads/main')) }}
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_branch: docs
publish_dir: docs/build/html
destination_dir: docs
exclude_assets: "doctrees"
# https://github.community/t/triggering-by-other-repository/16163/12
# - name: Workflow Dispatch Notification
# # if: ${{ ((steps.build.outcome == 'success') && (github.ref == 'refs/heads/main')) }}
# uses: actions/github-script@v6
# with:
# github-token: ${{ secrets.PAT_TOKEN }}
# script: |
# await github.rest.repos.createDispatchEvent({
# owner: 'ganeshgore',
# repo: 'spydrnet-physical',
# event_type: 'deployment',
# });