-
Notifications
You must be signed in to change notification settings - Fork 0
140 lines (125 loc) · 5.22 KB
/
build_test.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
# You can have multiple workflows that are triggered by different
# events (eg a workflow that runs on branch pushes, versus a
# workflow that runs when a GitHub issue is created). Give your
# workflow a descriptive name so that you know what it is.
name: build_test
# What is the event that triggers this workflow? Options include
# push, pull_request, create, issues, etc. This configuration says
# that you should run on pushes to the main branch (ie after a PR
# is merged), or when a pull request is created to merge into main.
on:
push:
branches:
- main
pull_request:
# Configuring this means that your PRs will get a GitHub comment
# from Coveralls with your coverage.
branches:
- main
# enable tests to be manually triggered
workflow_dispatch:
# A list of jobs to run as part of the workflow
jobs:
# Each job gets a name. This one builds/tests all branches.
build_test:
# Provide a runner. Options are listed on GitHub, but include
# windows, ubuntu, and macos (latest, as well as specific versions)
runs-on: ubuntu-latest
# In order to get Conda environments to work properly, we need to
# tell the runner to start up the bash shell in a way that respects
# the changes Conda makes to bash profile files.
# More at:
# https://github.com/marketplace/actions/setup-miniconda#use-a-default-shell
defaults:
run:
shell: bash -el {0}
# We specify all versions of Python that we want to validate.
# GitHub will run the tests for each of these Python versions.
strategy:
matrix:
python-version: ["3.9", "3.10", "3.11"]
# The actual workflow steps!
steps:
- uses: actions/checkout@v3
- name: Get API Key
run: echo "API KEY is $API_KEY"
env:
API_KEY: ${{ secrets.API_KEY }}
# Then set up Python with a python version from the matrix.
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
# This is an Action published by the Conda team to get your
# Conda environment set up using your environment.yml file.
# More at https://github.com/marketplace/actions/setup-miniconda
- name: Set up conda
uses: conda-incubator/setup-miniconda@v2
with:
# Use the environment name from your environment.yml file
activate-environment: bookworm_env
# The name of the environment file you want conda to use
environment-file: env.yml
# Whether you want conda to automatically update the conda
# version (helpful when some runners have old versions of
# conda)
auto-update-conda: true
# Which version of python you want conda to use
python-version: ${{ matrix.python-version }}
# We don't need the base environment, so don't activate it
auto-activate-base: false
# You don't normally need test coverage information when
# developing locally - we just want it in CI - so we install
# it here instead of in our environment file (which we also
# use locally).
- name: Install additional development dependencies
run: |
conda install --yes coverage
# If there are any other steps in order for your tests to
# run successfully, you can add those steps here!
# Next step: run pylint. Anything less than 10/10 will fail.
- name: Lint with pylint
run: |
pylint bookworm/**/*.py
pylint bookworm/*.py
# Next step: run the unit tests with code coverage.
- name: Unit tests
run: |
cd bookworm
coverage run -m unittest discover
coverage report
coverage lcov
env:
API_KEY: ${{ secrets.API_KEY }}
# Lastly: report code coverage to Coveralls.
- name: Report code coverage to Coveralls
uses: coverallsapp/github-action@master
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
base-path: bookworm
path-to-lcov: bookworm/coverage.lcov
# The following two options are needed for "parallel"
# runs - ie if you have a matrix of python versions.
# This holds off on reporting code coverage to
# coveralls until all runs are done. If you don't have
# a matrix, this isn't needed.
flag-name: run ${{ join(matrix.*, ' - ') }}
parallel: true
# After all the parallel matrix runs for build_test are done
# for the various python versions, we run this job to send the
# final code coverage to Coveralls.
finish:
# This job requires that build_test be finished before it
# can run.
needs: build_test
if: ${{ always() }}
runs-on: ubuntu-latest
steps:
- name: Coveralls Finished
uses: coverallsapp/github-action@master
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
parallel-finished: true
# This says finish the parallel runs that we did above
# and send to Coveralls.
carryforward: "run-3.9,run-3.10"