-
Notifications
You must be signed in to change notification settings - Fork 0
73 lines (62 loc) · 2.06 KB
/
ci.yml
File metadata and controls
73 lines (62 loc) · 2.06 KB
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
name: CI
on:
push:
branches:
- main
pull_request: {}
jobs:
ci:
strategy:
fail-fast: false
matrix:
python-version: ["3.12"]
uv-version: ["0.8.14"]
os: [ubuntu-latest, macos-latest]
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Install uv
uses: astral-sh/setup-uv@v4
with:
version: ${{ matrix.uv-version }}
- name: Install Task
uses: arduino/setup-task@v2
with:
version: 3.38.0
- uses: actions/cache@v4
name: Cache uv dependencies
with:
path: |
~/.cache/uv
.venv
key: ${{ runner.os }}-uv-${{ hashFiles('uv.lock') }}
restore-keys: |
${{ runner.os }}-uv-
- name: Install dependencies
run: uv sync --all-groups
- uses: pre-commit/action@v3.0.1
- name: Run the automated tests(using pytest)
run: uv run pytest ./src/test -sv --durations=0
- uses: pyupio/safety-action@v1
if: runner.os == 'Linux'
name: Run Safety check(using safety)
with:
api-key: ${{ secrets.SAFETY_API_KEY }}
args: --detailed-output # To always see detailed output from this action
- name: Check for dependency updates
id: check_updates
run: |
echo "Checking for dependency updates..."
echo "Current dependency constraints:"
grep -A 10 "^dependencies" pyproject.toml || true
echo ""
echo "Current dev dependencies:"
grep -A 10 "^\[dependency-groups\]" pyproject.toml || true
echo ""
echo "💡 To upgrade dependencies within constraints, run: uv sync --upgrade"
echo "💡 To check for newer versions, manually review PyPI for each package"
echo "💡 Remember to update ~= constraints in pyproject.toml for new minor versions"
# ref: https://github.com/astral-sh/setup-uv