-
Notifications
You must be signed in to change notification settings - Fork 33
105 lines (89 loc) · 3.28 KB
/
build-and-publish-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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
name: Docs Build and Publish
on:
push:
branches:
- master
- qy/add-plantseg-v1-installation
permissions:
contents: write
jobs:
deploy-docs:
runs-on: ubuntu-latest
env:
DISPLAY: ":99.0"
steps:
# Checkout the repository
- name: Checkout Repository
uses: actions/checkout@v4
with:
fetch-depth: 0
# Set up Qt libraries (required for PyQt applications)
- name: Set Up Qt Libraries
uses: tlambert03/setup-qt-libs@v1
# Start X virtual framebuffer for GUI testing
- name: Start Xvfb
run: |
/sbin/start-stop-daemon --start --quiet --pidfile /tmp/custom_xvfb_99.pid \
--make-pidfile --background --exec /usr/bin/Xvfb -- :99 -screen 0 1920x1200x24 -ac +extension GLX
# Set the documentation release version
- name: Set Documentation Version
run: echo "RELEASE_VERSION=DOC_RELEASE" >> $GITHUB_ENV
# Print the documentation version name (for debugging purposes)
- name: Print Documentation Version
run: echo $RELEASE_VERSION
# Configure Git credentials for deployment
- name: Configure Git Credentials
run: |
git config user.name "github-actions[bot]"
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
# Set up Miniconda
- name: Set Up Miniconda
uses: conda-incubator/setup-miniconda@v2
with:
auto-activate-base: true
activate-environment: ""
channels: local,conda-forge,defaults
channel-priority: false
# Display available Conda environments (for debugging purposes)
- name: List Conda Environments
shell: bash -l {0}
run: conda info --envs
# Build the PlantSeg Conda package (for screenshots in documentation)
- name: Build PlantSeg Package
shell: bash -l {0}
run: |
conda install -q conda-build
conda build -c conda-forge conda-recipe
# Create a Conda environment for PlantSeg
- name: Create PlantSeg Environment
run: |
conda create -n plant-seg -c local -c conda-forge pyqt plantseg
# Activate the PlantSeg environment
- name: Activate PlantSeg Environment
shell: bash -l {0}
run: conda activate plant-seg
# Set a cache ID based on the current UTC week number
- name: Set Cache ID
run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV
# Cache MkDocs build artifacts
- name: Cache MkDocs Artifacts
uses: actions/cache@v4
with:
key: mkdocs-material-${{ env.cache_id }}
path: .cache
restore-keys: |
mkdocs-material-
# Install MkDocs and deploy the documentation to GitHub Pages
- name: Install MkDocs and Deploy
shell: bash -l {0}
run: |
conda activate plant-seg
pip install mkdocs-material \
mkdocs-git-revision-date-localized-plugin \
mkdocs-git-committers-plugin-2 \
mkdocs-autorefs \
mkdocstrings[python] \
markdown-exec
mkdocs gh-deploy --force
env:
MKDOCS_GIT_COMMITTERS_APIKEY: ${{ secrets.MKDOCS_GIT_COMMITTERS_APIKEY }}