Skip to content

chore(deps): bump urllib3 from 2.5.0 to 2.6.2 #24

chore(deps): bump urllib3 from 2.5.0 to 2.6.2

chore(deps): bump urllib3 from 2.5.0 to 2.6.2 #24

Workflow file for this run

name: Tests
on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]
# Cancel outdated workflow runs to save CI minutes
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
# Least-privilege security model
permissions:
contents: read
pull-requests: write # For coverage comments
checks: write # For test results
jobs:
test:
runs-on: ubuntu-latest
timeout-minutes: 15
strategy:
fail-fast: false # Continue all Python versions even if one fails
matrix:
python-version: ['3.8', '3.9', '3.10', '3.11', '3.12']
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
cache: 'pip' # Built-in caching
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -e .
pip install pytest pytest-cov pytest-mock
- name: Run tests with coverage and JUnit output
run: |
pytest --cov=sha --cov-report=xml --cov-report=term-missing --cov-report=html \
--junitxml=test-results-${{ matrix.python-version }}.xml
- name: Upload test results
if: always()
uses: actions/upload-artifact@v4
with:
name: test-results-${{ matrix.python-version }}
path: test-results-${{ matrix.python-version }}.xml
retention-days: 30
- name: Upload coverage to Codecov
if: matrix.python-version == '3.12'
uses: codecov/codecov-action@v4
with:
file: ./coverage.xml
flags: unittests
name: codecov-umbrella
fail_ci_if_error: false
- name: Archive coverage report
if: matrix.python-version == '3.12'
uses: actions/upload-artifact@v4
with:
name: coverage-report
path: htmlcov/
retention-days: 30
pre-commit:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'pip'
- name: Install pre-commit
run: pip install pre-commit
- name: Run pre-commit hooks
run: pre-commit run --all-files
build:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'pip'
- name: Install build tools
run: pip install build twine
- name: Build package
run: python -m build
- name: Check package metadata
run: twine check dist/*
- name: Test install from wheel
run: |
pip install dist/*.whl
sha --version
- name: Upload built package
uses: actions/upload-artifact@v4
with:
name: dist
path: dist/
retention-days: 30
lint:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'pip'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install black isort flake8 mypy bandit[toml]
pip install -e .
- name: Check code formatting with black
run: black --check sha/ tests/
- name: Check import sorting with isort
run: isort --check-only sha/ tests/
- name: Lint with flake8
run: |
# Stop the build if there are Python syntax errors or undefined names
flake8 sha/ tests/ --count --select=E9,F63,F7,F82 --show-source --statistics
# Exit-zero treats all errors as warnings. Max line length 100 chars
flake8 sha/ tests/ --count --max-complexity=10 --max-line-length=100 --statistics
- name: Type check with mypy
run: mypy sha/
- name: Security check with bandit
run: bandit -r sha/ -c pyproject.toml
security:
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.12'
cache: 'pip'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install pip-audit safety
pip install -e .
- name: Run pip-audit
run: pip-audit
- name: Run safety check
run: safety check --json
continue-on-error: true # Don't fail on safety issues, just report them