-
Notifications
You must be signed in to change notification settings - Fork 0
94 lines (80 loc) · 2.04 KB
/
algorithm.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
name: Algorithm
on:
push:
branches: ["master"]
pull_request:
env:
PYTHON_VERSION: "3.12"
jobs:
lint:
name: lint
runs-on: ubuntu-latest
strategy:
matrix:
service: [search, recommend]
fail-fast: false
steps:
- uses: actions/checkout@v4
- uses: chartboost/ruff-action@v1
with:
src: "./apps/algorithm/${{ matrix.service }}"
args: 'check'
format:
name: Format
runs-on: ubuntu-latest
strategy:
matrix:
service: [search, recommend]
fail-fast: false
steps:
- uses: actions/checkout@v4
- uses: chartboost/ruff-action@v1
with:
src: "./apps/algorithm/${{ matrix.service }}"
args: 'format --check'
test:
name: Test
runs-on: ubuntu-latest
strategy:
matrix:
service: [search, recommend]
fail-fast: false
defaults:
run:
working-directory: apps/algorithm/${{ matrix.service }}
steps:
- uses: actions/checkout@v4
- name: Docker Compose Up
run: docker compose up -d ${{ matrix.service }} datalayer database elasticsearch
- name: Test
run: docker compose exec ${{ matrix.service }} pytest
sast:
name: Static Application Security Testing
runs-on: ubuntu-latest
strategy:
matrix:
service: [search, recommend]
fail-fast: false
defaults:
run:
working-directory: apps/algorithm/${{ matrix.service }}
steps:
- uses: actions/checkout@v4
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Test
run: bandit -c .bandit -ll -ii -n 3 -a file -r src/
supply:
name: Supply Chain Security
runs-on: ubuntu-latest
strategy:
matrix:
service: [search, recommend]
fail-fast: false
steps:
- uses: actions/checkout@v4
- uses: pypa/[email protected]
with:
inputs: apps/algorithm/${{ matrix.service }}/requirements.txt