Skip to content

Enhance security testing and fuzzing capabilities #34

Enhance security testing and fuzzing capabilities

Enhance security testing and fuzzing capabilities #34

Workflow file for this run

# This workflow will install Python dependencies, run tests and lint with multiple Python versions
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-python
name: CI
on:
push:
branches: ["main"]
pull_request:
branches: ["main"]
workflow_dispatch:
permissions:
contents: read
jobs:
test:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ["3.11", "3.12", "3.13"]
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5.2.0
with:
python-version: ${{ matrix.python-version }}
- name: Install uv
uses: astral-sh/setup-uv@v4
with:
version: "latest"
- name: Cache uv dependencies
uses: actions/cache@v4
with:
path: ~/.cache/uv
key: ${{ runner.os }}-uv-py${{ matrix.python-version }}-${{ hashFiles('uv.lock') }}
restore-keys: |
${{ runner.os }}-uv-py${{ matrix.python-version }}-
- name: Install dependencies
run: |
uv sync --all-extras
- name: Run tests
run: |
uv run pytest
- name: Upload coverage report
if: ${{ matrix.python-version == '3.13' && !env.ACT }}
uses: actions/upload-artifact@v4.4.0
with:
name: coverage-report
path: |
coverage.xml
build:
runs-on: ubuntu-latest
needs: test
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Python 3.13
uses: actions/setup-python@v5.2.0
with:
python-version: "3.13"
- name: Install uv
uses: astral-sh/setup-uv@v4
with:
version: "latest"
- name: Build package
run: |
uv build
- name: Verify package installation
run: |
python -m pip install dist/*.whl
superbom --version
- name: Upload build artifacts
uses: actions/upload-artifact@v4.4.0
with:
name: dist
path: dist/