Skip to content

Commit e70175b

Browse files
committed
adjust GitHub actions to test Django versions
1 parent 22dd853 commit e70175b

File tree

2 files changed

+53
-18
lines changed

2 files changed

+53
-18
lines changed

.github/workflows/main.yml

Lines changed: 43 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -8,17 +8,36 @@ on:
88

99
jobs:
1010
tests:
11-
name: Python ${{ matrix.python-version }}
11+
name: Python ${{ matrix.python-version }}, Django ${{ matrix.django-version }}
1212
runs-on: ubuntu-20.04
1313

1414
strategy:
15+
fail-fast: false
1516
matrix:
17+
django-version:
18+
- '3.1'
19+
- '3.2'
1620
python-version:
1721
- '3.6'
1822
- '3.7'
1923
- '3.8'
2024
- '3.9'
2125

26+
include:
27+
# Old Django LTS only on older Pythons
28+
- django-version: '2.2'
29+
python-version: '3.6'
30+
31+
- django-version: '2.2'
32+
python-version: '3.7'
33+
34+
# Pre-release Django only on new Pythons
35+
- django-version: 'main'
36+
python-version: '3.8'
37+
38+
- django-version: 'main'
39+
python-version: '3.9'
40+
2241
steps:
2342
- uses: actions/checkout@v2
2443

@@ -33,25 +52,33 @@ jobs:
3352
restore-keys: |
3453
${{ runner.os }}-pip-
3554
36-
- name: Upgrade packaging tools
37-
run: python -m pip install --upgrade pip setuptools virtualenv wheel
38-
3955
- name: Install dependencies
40-
run: python -m pip install --upgrade codecov tox
41-
42-
- name: Run tox targets for ${{ matrix.python-version }}
4356
run: |
44-
ENV_PREFIX=$(tr -C -d "0-9" <<< "${{ matrix.python-version }}")
45-
TOXENV=$(tox --listenvs | grep "^py$ENV_PREFIX" | tr '\n' ',') tox
57+
python -m pip install --upgrade pip setuptools virtualenv wheel
58+
python -m pip install --upgrade codecov tox tox-gh-actions
4659
47-
- name: Run extra tox targets
48-
if: ${{ matrix.python-version == '3.9' }}
60+
- name: Run tox
4961
run: |
50-
python setup.py bdist_wheel
51-
rm -r djangorestframework.egg-info # see #6139
52-
tox -e base,dist,docs
53-
tox -e dist --installpkg ./dist/djangorestframework-*.whl
62+
tox
63+
TOX_EXIT=$?
64+
65+
if [[ $DJANGO == '3.2' && ${{ matrix.python-version }} == '3.9' ]]; then
66+
# Run extra tox targets
67+
# This would not be needed after https://github.com/ymyzk/tox-gh-actions/pull/60
68+
tox -e base,dist,docs
69+
TOX_EXTRA_EXIT=$?
70+
71+
if [[ $TOX_EXIT == 0 ]]; then
72+
TOX_EXIT=$TOX_EXTRA_EXIT
73+
fi
74+
fi
75+
76+
exit $TOX_EXIT
77+
env:
78+
DJANGO: ${{ matrix.django-version }}
5479

5580
- name: Upload coverage
5681
run: |
57-
codecov -e TOXENV,DJANGO
82+
codecov -e DJANGO
83+
env:
84+
DJANGO: ${{ matrix.django-version }}

tox.ini

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -7,10 +7,18 @@ envlist =
77
{py38,py39}-djangomain,
88
base,dist,docs,
99

10-
[travis:env]
10+
[gh-actions]
11+
python =
12+
3.6: py36
13+
3.7: py37
14+
3.8: py38
15+
3.9: py39
16+
# This needs https://github.com/ymyzk/tox-gh-actions/pull/60
17+
# 3.9: py39,base,dist,docs
18+
19+
[gh-actions:env]
1120
DJANGO =
1221
2.2: django22
13-
3.0: django30
1422
3.1: django31
1523
3.2: django32
1624
main: djangomain

0 commit comments

Comments
 (0)