-
Notifications
You must be signed in to change notification settings - Fork 13
101 lines (80 loc) · 2.48 KB
/
ci.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
# We need a multi-job workflow file (in contrast to a multi-workflow setup with
# gh-pages.yml + tests.yml, as in https://github.com/elcorto/psweep for
# instance) to test job dependencies (pages depends on tests) on branches (such
# as test-ci) which are not the default branch. Well OK.
#
# https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#workflow_run
# https://stackoverflow.com/a/65081720
name: tests
on:
push:
branches:
- master
- test-ci
jobs:
tests:
runs-on: ubuntu-latest
strategy:
matrix:
python-version:
- "3.8"
- "3.9"
- "3.10"
- "3.11"
- "3.12"
fail-fast: false
steps:
- name: checkout
uses: actions/checkout@v4
- name: pysetup
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: install
run: |
sudo apt update
# For Fortran extensions
sudo apt install -y --no-install-recommends \
python3-dev gfortran liblapack-dev ninja-build
sudo apt install -y --no-install-recommends \
lammps quantum-espresso
# The meson Ubuntu package is outdated, so install via pip.
pip install meson meson-python
pip install -e .
pip install -r requirements_optional.txt
pip install -r requirements_test.txt
- name: run tests
run: |
cd test
# dcd test fails in CI, passes locally, skip for now
./runtests.sh --nobuild -n8 --ignore=test_dcd.py
pages:
needs: tests
runs-on: ubuntu-latest
steps:
- name: checkout
uses: actions/checkout@v4
- name: pysetup
uses: actions/setup-python@v5
with:
python-version: "3.10"
- name: install
run: |
sudo apt update
# For Fortran extensions
sudo apt install -y --no-install-recommends \
python3-dev gfortran liblapack-dev
# sphinx related
pip install -r requirements_doc.txt
# sphinx-autodoc needs target package to be installed
pip install -e .
- name: build
run: |
cd doc
sh generate-doc.sh
- name: deploy
uses: peaceiris/actions-gh-pages@v4
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
# base dir is checkout: /path/to/psweep
publish_dir: doc/build/html