-
Notifications
You must be signed in to change notification settings - Fork 12
141 lines (132 loc) · 4.24 KB
/
pythonpackage.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
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
# This workflow will install Python dependencies, run tests and lint with a variety of Python versions
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions
name: Python package
on:
workflow_dispatch:
push:
branches: [ master ]
tags: [ '*' ]
pull_request:
branches: [ master ]
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
permissions:
contents: read
jobs:
build:
runs-on: ubuntu-latest
outputs:
version: ${{ steps.get_version.outputs.version }}
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: actions/setup-python@v5
with:
python-version: 3
- uses: actions/cache@v4
with:
path: ~/.cache/pip
key: pip-cache-v1
restore-keys: |
pip-cache-
- run: pip install --upgrade build twine
- name: Build sdist and wheel
run: python -m build
- run: twine check dist/*
- uses: actions/upload-artifact@v4
with:
name: dist
path: dist/
- name: Interpolate version in confined environment
id: get_version
run: |
python -m venv /tmp/buildenv
source /tmp/buildenv/bin/activate
python -m pip install -U build hatch hatchling nipreps-versions
if [[ "$GITHUB_REF" == refs/tags/* ]]; then
TAG=${GITHUB_REF##*/}
fi
THISVERSION=$( python -m hatch version | tail -n1 | xargs )
THISVERSION=${TAG:-$THISVERSION}
echo "Expected VERSION: \"${THISVERSION}\""
echo "version=${THISVERSION}" >> $GITHUB_OUTPUT
test-install:
runs-on: ubuntu-latest
needs: build
strategy:
matrix:
python-version: ['3.8', '3.9', '3.10', '3.11', '3.12']
mode: ['wheel']
include:
- {python-version: '3.11', mode: 'repo'}
- {python-version: '3.11', mode: 'sdist'}
- {python-version: '3.11', mode: 'editable'}
env:
TEMPLATEFLOW_HOME: /tmp/home
THISVERSION: ${{ needs.build.outputs.version }}
steps:
- uses: actions/checkout@v4
if: matrix.mode == 'repo' || matrix.mode == 'editable'
with:
fetch-depth: 0
- uses: actions/download-artifact@v4
if: matrix.mode == 'sdist' || matrix.mode == 'wheel'
with:
name: dist
path: /tmp/package/
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- uses: actions/cache@v4
with:
path: ~/.cache/pip
key: pip-cache-v1
restore-keys: |
pip-cache-
- name: Upgrade pip
run: pip install --upgrade pip wheel
- name: Set install command
run: |
case ${{ matrix.mode }} in
repo)
echo "TARGET=." >> $GITHUB_ENV
;;
editable)
echo "TARGET=-e ." >> $GITHUB_ENV
;;
sdist)
echo "TARGET=$( ls /tmp/package/templateflow*.tar.gz )" >> $GITHUB_ENV
;;
wheel)
echo "TARGET=$( ls /tmp/package/templateflow*.whl )" >> $GITHUB_ENV
;;
esac
- name: Install and check version
run: |
pip install $TARGET
INSTALLED_VERSION=$(python -c 'import templateflow as tf; print(tf.__version__, end="")')
echo "VERSION: \"${THISVERSION}\""
echo "INSTALLED: \"${INSTALLED_VERSION}\""
test "${INSTALLED_VERSION}" = "${THISVERSION}"
- name: Re-install
run: |
pip install $TARGET --force-reinstall
find ${TEMPLATEFLOW_HOME} >> /tmp/.install.txt
- name: Re-install [missing template]
run: |
rm -rf ${TEMPLATEFLOW_HOME}/tpl-MNI152NLin2009cAsym
pip install $TARGET --force-reinstall
python -c "import templateflow; templateflow.update(overwrite=False)"
find ${TEMPLATEFLOW_HOME} >> /tmp/.install-2.txt
diff /tmp/.install.txt /tmp/.install-2.txt
exit $?
flake8:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
- run: pipx run flake8-pyproject templateflow/