-
Notifications
You must be signed in to change notification settings - Fork 0
223 lines (189 loc) · 7.6 KB
/
docs.yml
File metadata and controls
223 lines (189 loc) · 7.6 KB
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
name: Build and Deploy Documentation
on:
# Runs on pushes targeting the default branch (main or master)
push:
branches: ["main", "master"]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
# Build job for GitHub
build-github:
runs-on: ubuntu-latest
if: ${{ github.server_url == 'https://github.com' }}
# Set ENV vars at the job level to be inherited by all steps, including actions
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
SSL_CERT_FILE: /etc/ssl/certs/ca-certificates.crt
REQUESTS_CA_BUNDLE: /etc/ssl/certs/ca-certificates.crt
# Use CPU-only PyTorch to save disk space
PIP_EXTRA_INDEX_URL: https://download.pytorch.org/whl/cpu
TORCH_CPU_ONLY: "true"
steps:
- name: Checkout repository
uses: actions/checkout@v4
# Install Act dependencies FIRST (before any apt-get commands)
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
# Ensure apt-get is available and install sudo for 'act' environments
if ! command -v apt-get &> /dev/null; then
echo "apt-get not found, cannot proceed"
exit 1
fi
# Install apt-utils first to avoid debconf warnings, then sudo
DEBIAN_FRONTEND=noninteractive apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y apt-utils sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
# Install lsb-release, Node.js, and ca-certificates all at once
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release nodejs ca-certificates default-jre build-essential
# Trust your mounted certificate (from the act command)
sudo update-ca-certificates
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12.3'
cache: 'pip'
- name: Install dependencies
run: |
# Ensure setuptools and wheel are present before installing the project
pip install --upgrade pip setuptools wheel
# psutil/ipython required for imports during autodoc (H2OBaseClassifier, pipeline.data)
# torch is needed for some model classes that are imported during autodoc
pip install torch
pip install psutil ipython
pip install .[docs]
- name: Verify PyTorch installation
run: |
python -c "import torch; print(f'PyTorch version: {torch.__version__}'); print(f'CUDA available: {torch.cuda.is_available()}')"
- name: Build documentation
run: sphinx-build -b html -D html_baseurl="" docs/source docs/build
- name: Upload artifact for GitHub Pages
if: ${{ !env.ACT }}
uses: actions/upload-pages-artifact@v3
with:
path: ./docs/build
- name: Upload artifact for GitHub
uses: actions/upload-artifact@v4
with:
name: docs-artifact
path: ./docs/build
# Build job for Gitea
build-gitea:
runs-on: ubuntu-latest
if: ${{ github.server_url != 'https://github.com' }}
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
SSL_CERT_FILE: /etc/ssl/certs/ca-certificates.crt
REQUESTS_CA_BUNDLE: /etc/ssl/certs/ca-certificates.crt
PIP_EXTRA_INDEX_URL: https://download.pytorch.org/whl/cpu
TORCH_CPU_ONLY: "true"
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
if ! command -v apt-get &> /dev/null; then
echo "apt-get not found, cannot proceed"
exit 1
fi
DEBIAN_FRONTEND=noninteractive apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y apt-utils sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release nodejs ca-certificates default-jre build-essential
sudo update-ca-certificates
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12.3'
cache: 'pip'
- name: Install dependencies
run: |
pip install --upgrade pip setuptools wheel
# psutil/ipython required for imports during autodoc (H2OBaseClassifier, pipeline.data)
# torch is needed for some model classes that are imported during autodoc
pip install torch
pip install psutil ipython
pip install .[docs]
- name: Verify PyTorch installation
run: |
python -c "import torch; print(f'PyTorch version: {torch.__version__}'); print(f'CUDA available: {torch.cuda.is_available()}')"
- name: Build documentation
run: sphinx-build -b html -D html_baseurl="" docs/source docs/build
- name: Upload artifact for Gitea
uses: actions/upload-artifact@v3
with:
name: docs-artifact
path: ./docs/build
# Deploy job for GitHub Pages
deploy-github:
needs: build-github
if: ${{ github.server_url == 'https://github.com' }}
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
apt-get update && apt-get install -y sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y nodejs ca-certificates
sudo update-ca-certificates
- name: Deploy to GitHub Pages
id: deployment
if: ${{ !env.ACT }}
uses: actions/deploy-pages@v4
# Deploy job for Gitea
deploy-gitea:
needs: build-gitea
if: ${{ github.server_url != 'https://github.com' }}
runs-on: ubuntu-latest
env:
NODE_EXTRA_CA_CERTS: /etc/ssl/certs/ca-certificates.crt
steps:
- name: Install Act dependencies
if: ${{ env.ACT }}
run: |
apt-get update && apt-get install -y sudo
- name: Install Runner Dependencies & Configure CA
run: |
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y nodejs ca-certificates
sudo update-ca-certificates
- name: Download artifact
# Use a GHES-compatible version of download-artifact
uses: actions/download-artifact@v3
with:
name: docs-artifact
path: ./docs-site
- name: Deploy to Gitea docs location
run: |
echo "Deploying documentation to Gitea's special directory..."
# upload-artifact@v3 does not create a tarball, so no extraction is needed.
# The '/pages' directory is a mounted volume on the Gitea runner for serving static content.
# Deploy to a subfolder named after the repository
TARGET_DIR="/pages/docs/${{ github.event.repository.name }}"
# Clean, recreate, copy, and set permissions
sudo rm -rf "$TARGET_DIR"
sudo mkdir -p "$TARGET_DIR"
sudo cp -r ./docs-site/. "$TARGET_DIR/"
sudo chmod -R 755 "$TARGET_DIR"