-
Notifications
You must be signed in to change notification settings - Fork 0
55 lines (47 loc) · 1.93 KB
/
main.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
# This is a basic workflow to help you get started with Actions
name: CI
# Controls when the workflow will run
on:
# Triggers the workflow on push or pull request events but only for the main branch
push:
branches: [ main ]
pull_request:
branches: [ main ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Python Linter
run: |
pip install pylint
pylint --rcfile=.pylintrc *
test:
# The type of runner that the job will run on
runs-on: ubuntu-latest
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
- name: Python test
uses: actions/setup-python@v4.0.0
with:
# Version range or exact version of Python to use, using SemVer's version range syntax. Reads from .python-version if unset.
python-version: 3.9
# Used to specify a package manager for caching in the default directory. Supported values: pip, pipenv, poetry.
cache: pip
# The script does the following:
# For files in /test directory (** means recursive) with .py extension, run python unittest.
# sed command replaces every forward slash ('/') with a dot('.')("s/\//./g"),
# and removes the .py extension ("s/\.py$//").
# This makes the filename conform to the python package naming scheme,
# and therefore understood by unittest module.
- run: |
python -V
pip install -r requirements.txt
for file in test/**.py;
do python -m unittest "$(sed "{s/\//./g; s/\.py$//}" <<< "$file")";
done