Skip to content

feat: enhance repository search with relevance scoring and diversity #23

feat: enhance repository search with relevance scoring and diversity

feat: enhance repository search with relevance scoring and diversity #23

Workflow file for this run

name: CI
on:
push:
branches: [ main, develop ]
pull_request:
branches: [ main, develop ]
jobs:
test:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
python-version: ['3.8', '3.9', '3.10', '3.11', '3.12']
exclude:
# Reduce matrix size for faster builds
- os: macos-latest
python-version: '3.9'
- os: windows-latest
python-version: '3.9'
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # Needed for setuptools-scm
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
- name: Cache pip dependencies
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/pyproject.toml') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -e ".[dev,test]"
- name: Run linting
run: |
black --check --diff sai saigen tests
isort --check-only --diff sai saigen tests
flake8 sai saigen tests
- name: Run type checking
run: |
mypy sai saigen
- name: Run tests
run: |
pytest --cov=sai --cov=saigen --cov-report=xml --cov-report=term-missing
- name: Upload coverage to Codecov
if: matrix.os == 'ubuntu-latest' && matrix.python-version == '3.11'
uses: codecov/codecov-action@v3
with:
file: ./coverage.xml
flags: unittests
name: codecov-umbrella
security:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install bandit safety
- name: Run security checks with bandit
run: |
bandit -r sai saigen -f json -o bandit-report.json || true
bandit -r sai saigen
- name: Check dependencies for known vulnerabilities
run: |
safety check --json --output safety-report.json || true
safety check
build:
runs-on: ubuntu-latest
needs: [test, security]
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0 # Needed for setuptools-scm
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Install build dependencies
run: |
python -m pip install --upgrade pip
pip install build twine
- name: Build package
run: |
python -m build
- name: Check package
run: |
twine check dist/*
- name: Upload build artifacts
uses: actions/upload-artifact@v3
with:
name: dist
path: dist/
integration-test:
runs-on: ${{ matrix.os }}
needs: build
strategy:
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.11'
- name: Download build artifacts
uses: actions/download-artifact@v3
with:
name: dist
path: dist/
- name: Install from wheel
shell: bash
run: |
pip install dist/*.whl
- name: Test CLI commands
shell: bash
run: |
sai --help
saigen --help
sai providers list || true # May fail if no providers available
sai config show || true # May fail if no config exists
- name: Test basic functionality
shell: bash
run: |
# Test configuration
python -c "
from sai.models.config import Config
config = Config()
print(f'Config loaded: {config.log_level}')
"
# Test provider loading
python -c "
from sai.providers.loader import ProviderLoader
loader = ProviderLoader()
providers = loader.load_providers()
print(f'Loaded {len(providers)} providers')
"