Testing
The process of automated testing is a little more involved, and we now introduce GitHub Actions.
The testing workflow
Create a new directory
mkdir -p .github/workflows # (1)!
- The
-p
flag creates the entire directory structure if it does not exist.
and add a file in this directory called tests.yml
. Now add the following
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 |
|
Let's walk through what we have done here.
Choose when the workflow runs
1 2 3 4 5 6 |
|
We give the workflow a name Run Tests
. Then we say, whenever a push is made to any branch other than main
, run this workflow.
The jobs
Next, we define what jobs
we want to run. In this case we have two: the pre-commit
, and the tests
.
The pre-commit checks
pre-commit:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install poetry
run: pipx install poetry
- uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'poetry'
- run: poetry install
- name: Run pre-commit checks
run: |
poetry run pre-commit run --all-files
We choose what OS we want to run on, in this case the latest version of Ubuntu. Then we define what steps to take:
- Install poetry with python version 3.10
- Install the package with
poetry install
- Run the pre-commit on our files.
So this entire thing is the equivalent to us saying poetry run pre-commit run --all-files
from before.
The test cases
tests:
needs: pre-commit
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install poetry
run: pipx install poetry
- uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'poetry'
- run: poetry install
- name: Run tests
run: |
poetry run python -m unittest discover tests/
We have defined an extra field here needs: pre-commit
. This ensures that this part of the workflow will not run unless the pre-commit checks all pass. If there are problems with our code, what's the point of running the tests? Fix the issues first, then resubmit.
We then install poetry and python again, and run the unittests. So now, everytime we push changes to the dev
branch, we will initilize this workflow!
Tip
It is also possible to use multiple versions of python and even different operating systems using the matrix
strategy:
jobs:
example_matrix:
strategy:
matrix:
os: [ubuntu-latest, macos-latest]
version: [3.10, 3.11, 3.12]
runs-on: ${{ matrix.os }}
steps:
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.version }}
The world of GitHub Actions workflows is complex and full of danger. My advice is to keep it simple.
Now that we have our tests set up, let's try pushing these changes to our remote. You can head over to the Actions
tab on your GitHub repository to see the workflow in action.
Further reading
-
Information on GitHub Workflows