-
Notifications
You must be signed in to change notification settings - Fork 24
96 lines (81 loc) · 2.95 KB
/
check-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
name: Check Docs Manually
on:
workflow_dispatch:
inputs:
build_plugins:
description: 'Build API Docs with Plug-Ins'
required: true
default: true
type: boolean
build_examples:
description: 'Build API Docs with Examples'
required: true
default: true
type: boolean
jobs:
api:
name: Check API Documentation
runs-on: self-hosted
env:
gh_root: https://github.com/CEA-COSMIC/
tag_path: /archive/refs/tags/
gh_download: https://codeload.github.com/CEA-COSMIC/
develop_path: /tar.gz/refs/heads/develop
sphinx_opts: -t docs/_templates -feTMo docs/source
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Set up Python 3.10
uses: actions/setup-python@v5
with:
python-version: "3.10.12"
- name: Check Python Version
run: python --version
- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install pandoc
python -m pip install git+https://github.com/cea-cosmic/modopt@develop # Workaround, to be removed
python -m pip install -r docs/requirements.txt
python -m pip install .
- name: Download plug-ins
if: ${{ inputs.build_plugins }}
run: |
while read _plugin; do
plugin_name="$(echo ${_plugin} | awk -F== '{print $1}')"
plugin_version="$(echo ${_plugin} | awk -F== '{print $2}')"
wget ${gh_download}${plugin_name}${develop_path} -O ${plugin_name}.tar.gz
done < plugins.txt
for file in *.tar.gz; do
tar xzf "$file";
python -m pip install "$file"
done
rm *.tar.gz
- name: Extract plug-in examples
if: ${{ inputs.build_examples }}
run: |
while read _plugin; do
plugin_name="$(echo ${_plugin} | awk -F== '{print $1}')"
cp -r ${plugin_name}-*/examples examples/${plugin_name} || echo "Warning: no examples found for ${plugin_name}"
done < plugins.txt
- name: Build PySAP source files
run: sphinx-apidoc ${sphinx_opts} pysap
- name: Build plug-in source files
if: ${{ inputs.build_plugins }}
run: |
while read _plugin; do
plugin_name="$(echo ${_plugin} | awk -F== '{print $1}')"
package_name="$(echo ${plugin_name} | awk -F- '{print $2}')"
sphinx-apidoc ${sphinx_opts} ${plugin_name}-*/${package_name}
done < plugins.txt
- name: Install GPU specific requirements
run: |
python -m pip install -r pysap-mri-*/gpu_requirements.txt
- name: Build API documentation
run: sphinx-build -E docs/source docs/_build
- name: Archive API build
uses: actions/upload-artifact@v2
with:
name: api-docs
retention-days: 14
path: docs/_build