62 lines
1.4 KiB
YAML
62 lines
1.4 KiB
YAML
|
|
||
|
name: Linters
|
||
|
|
||
|
on:
|
||
|
pull_request:
|
||
|
workflow_dispatch:
|
||
|
|
||
|
permissions:
|
||
|
contents: read
|
||
|
|
||
|
concurrency:
|
||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||
|
cancel-in-progress: true
|
||
|
|
||
|
jobs:
|
||
|
linter:
|
||
|
name: 'Frappe Linter'
|
||
|
runs-on: ubuntu-latest
|
||
|
if: github.event_name == 'pull_request'
|
||
|
|
||
|
steps:
|
||
|
- uses: actions/checkout@v4
|
||
|
- uses: actions/setup-python@v5
|
||
|
with:
|
||
|
python-version: '3.10'
|
||
|
cache: pip
|
||
|
- uses: pre-commit/action@v3.0.0
|
||
|
|
||
|
- name: Download Semgrep rules
|
||
|
run: git clone --depth 1 https://github.com/frappe/semgrep-rules.git frappe-semgrep-rules
|
||
|
|
||
|
- name: Run Semgrep rules
|
||
|
run: |
|
||
|
pip install semgrep
|
||
|
semgrep ci --config ./frappe-semgrep-rules/rules --config r/python.lang.correctness
|
||
|
|
||
|
deps-vulnerable-check:
|
||
|
name: 'Vulnerable Dependency Check'
|
||
|
runs-on: ubuntu-latest
|
||
|
|
||
|
steps:
|
||
|
- uses: actions/setup-python@v5
|
||
|
with:
|
||
|
python-version: '3.10'
|
||
|
|
||
|
- uses: actions/checkout@v4
|
||
|
|
||
|
- name: Cache pip
|
||
|
uses: actions/cache@v3
|
||
|
with:
|
||
|
path: ~/.cache/pip
|
||
|
key: ${{ runner.os }}-pip-${{ hashFiles('**/*requirements.txt', '**/pyproject.toml', '**/setup.py') }}
|
||
|
restore-keys: |
|
||
|
${{ runner.os }}-pip-
|
||
|
${{ runner.os }}-
|
||
|
|
||
|
- name: Install and run pip-audit
|
||
|
run: |
|
||
|
pip install pip-audit
|
||
|
cd ${GITHUB_WORKSPACE}
|
||
|
pip-audit --desc on .
|