Skip to content

feat: add priority mechinism in multi model proxy to load model by pr… #25

feat: add priority mechinism in multi model proxy to load model by pr…

feat: add priority mechinism in multi model proxy to load model by pr… #25

Workflow file for this run

name: CI
on:
push:
branches: [ main, develop ]
paths-ignore:
- '**.md'
- 'asset/**'
- 'internal_docs/**'
- '.gitignore'
pull_request:
branches: [ main ]
paths-ignore:
- '**.md'
- 'asset/**'
- 'internal_docs/**'
- '.gitignore'
workflow_dispatch:
jobs:
test:
name: Test Python ${{ matrix.python-version }}
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest]
python-version: ['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 }}
- name: Cache pip packages
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt', '**/pyproject.toml') }}
restore-keys: |
${{ runner.os }}-pip-
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -e .[test]
pip install hf-model-tool
- name: Run tests
run: |
pytest tests/ -v --tb=short
continue-on-error: false # Tests should pass
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Cache pip packages
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-lint-${{ hashFiles('**/requirements.txt', '**/pyproject.toml') }}
restore-keys: |
${{ runner.os }}-pip-lint-
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install flake8
- name: Lint with flake8
run: |
# Stop the build if there are Python syntax errors or undefined names
flake8 src/vllm_cli --count --select=E9,F63,F7,F82 --show-source --statistics
# Check for complexity and style issues (non-blocking)
flake8 src/vllm_cli --count --exit-zero --max-complexity=15 --max-line-length=120 --statistics
continue-on-error: true # Don't block on style issues
format:
name: Format Check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install black
run: |
python -m pip install --upgrade pip
pip install black
- name: Check formatting with black
run: |
black --check --diff src/vllm_cli --line-length 88
continue-on-error: true # Formatting issues are non-blocking
type-check:
name: Type Check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Cache pip packages
uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-type-${{ hashFiles('**/requirements.txt', '**/pyproject.toml') }}
restore-keys: |
${{ runner.os }}-pip-type-
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -e .
pip install mypy types-PyYAML types-psutil
- name: Run mypy
run: |
mypy src/vllm_cli --python-version 3.11 --ignore-missing-imports --allow-untyped-calls --allow-untyped-defs
continue-on-error: true # Type checking is informational
build:
name: Build Package
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install build tools
run: |
python -m pip install --upgrade pip
pip install build setuptools wheel
- name: Build distribution
run: |
python -m build
- name: Check distribution
run: |
pip install twine
twine check dist/*
- name: Upload artifacts
uses: actions/upload-artifact@v4
with:
name: dist-packages
path: dist/
retention-days: 7