-
Notifications
You must be signed in to change notification settings - Fork 1
70 lines (61 loc) · 2.17 KB
/
python-validate.yml
File metadata and controls
70 lines (61 loc) · 2.17 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
name: Python Validate & Build
permissions:
contents: read
pull-requests: write
on:
push:
paths:
- 'requirements.txt'
- 'pyproject.toml'
- '.github/workflows/python-validate.yml'
pull_request:
paths:
- 'requirements.txt'
- 'pyproject.toml'
jobs:
validate:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: 3.12
- name: Install system dependencies
run: |
sudo apt-get update
sudo apt-get install -y \
pkg-config \
libcairo2-dev \
libpango1.0-dev \
libpangocairo-1.0-0 \
libgdk-pixbuf2.0-dev \
libffi-dev \
shared-mime-info \
libao-dev \
python3-dev \
build-essential
- name: Install pip-tools
run: pip install --upgrade pip pip-tools
- name: Validate requirements
id: validate
run: |
# Try pip-compile first, but fall back to pip install validation
if pip-compile --dry-run --resolver=backtracking -o requirements.out requirements.txt 2>/dev/null; then
echo "::debug::Python validate no broken dependencies (pip-compile)"
echo "valid=true" >> "$GITHUB_OUTPUT"
elif pip install --dry-run -q -r requirements.txt 2>/dev/null; then
echo "::debug::Python validate no broken dependencies (pip install)"
echo "valid=true" >> "$GITHUB_OUTPUT"
else
echo "valid=false" >> "$GITHUB_OUTPUT"
echo "### :warning: Python validation failed in repository root" >> $GITHUB_STEP_SUMMARY
echo "We were unable to validate the Python dependencies. Please check requirements.txt." >> $GITHUB_STEP_SUMMARY
exit 1
fi
- name: Auto-approve Dependabot PRs
if: github.actor == 'dependabot[bot]' && steps.validate.outputs.valid == 'true'
uses: hmarr/auto-approve-action@v4
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
review-message: "Auto-approved Dependabot PR ✅"