2026-03-12 17:20:50 +00:00
# Agent Instructions for vLLM
> These instructions apply to **all** AI-assisted contributions to `vllm-project/vllm`.
> Breaching these guidelines can result in automatic banning.
## 1. Contribution Policy (Mandatory)
### Duplicate-work checks
Before proposing a PR, run these checks:
```bash
gh issue view <issue_number> --repo vllm-project/vllm --comments
gh pr list --repo vllm-project/vllm --state open --search "<issue_number> in:body"
gh pr list --repo vllm-project/vllm --state open --search "<short area keywords>"
```
- If an open PR already addresses the same fix, do not open another.
- If your approach is materially different, explain the difference in the issue.
### No low-value busywork PRs
Do not open one-off PRs for tiny edits (single typo, isolated style change, one mutable default, etc.). Mechanical cleanups are acceptable only when bundled with substantive work.
### Accountability
- Pure code-agent PRs are **not allowed ** . A human submitter must understand and defend the change end-to-end.
- The submitting human must review every changed line and run relevant tests.
- PR descriptions for AI-assisted work **must ** include:
- Why this is not duplicating an existing PR.
- Test commands run and results.
- Clear statement that AI assistance was used.
### Fail-closed behavior
If work is duplicate/trivial busywork, **do not proceed ** . Return a short explanation of what is missing.
---
## 2. Development Workflow
2026-03-25 12:24:42 -04:00
- **Never use system `python3` or bare `pip` /`pip install` .** All Python commands must go through `uv` and `.venv/bin/python` .
2026-03-12 17:20:50 +00:00
### Environment setup
```bash
# Install `uv` if you don't have it already:
curl -LsSf https://astral.sh/uv/install.sh | sh
# Always use `uv` for Python environment management:
2026-03-12 20:21:11 +01:00
uv venv --python 3.12
2026-03-12 17:20:50 +00:00
source .venv/bin/activate
# Always make sure `pre-commit` and its hooks are installed:
2026-03-12 20:21:11 +01:00
uv pip install -r requirements/lint.txt
2026-03-12 17:20:50 +00:00
pre-commit install
```
### Installing dependencies
```bash
# If you are only making Python changes:
2026-03-25 12:24:42 -04:00
VLLM_USE_PRECOMPILED=1 uv pip install -e . --torch-backend=auto
2026-03-12 17:20:50 +00:00
# If you are also making C/C++ changes:
2026-03-25 12:24:42 -04:00
uv pip install -e . --torch-backend=auto
2026-03-12 17:20:50 +00:00
```
### Running tests
2026-03-25 12:24:42 -04:00
> Requires [Environment setup](#environment-setup) and [Installing dependencies](#installing-dependencies).
2026-03-12 17:20:50 +00:00
```bash
2026-03-25 12:24:42 -04:00
# Install test dependencies.
# requirements/test.txt is pinned to x86_64; on other platforms, use the
# unpinned source file instead:
uv pip install -r requirements/test.in # resolves for current platform
# Or on x86_64:
2026-03-12 20:21:11 +01:00
uv pip install -r requirements/test.txt
2026-03-12 17:20:50 +00:00
2026-03-25 12:24:42 -04:00
# Run a specific test file (use .venv/bin/python directly;
# `source activate` does not persist in non-interactive shells):
.venv/bin/python -m pytest tests/path/to/test_file.py -v
2026-03-12 17:20:50 +00:00
```
### Running linters
2026-03-25 12:24:42 -04:00
> Requires [Environment setup](#environment-setup).
2026-03-12 17:20:50 +00:00
```bash
# Run all pre-commit hooks on staged files:
pre-commit run
# Run on all files:
pre-commit run --all-files
# Run a specific hook:
pre-commit run ruff-check --all-files
# Run mypy as it is in CI:
pre-commit run mypy-3.10 --all-files --hook-stage manual
```
### Commit messages
Add attribution using commit trailers such as `Co-authored-by:` (other projects use `Assisted-by:` or `Generated-by:` ). For example:
```text
Your commit message here
Co-authored-by: GitHub Copilot
Co-authored-by: Claude
Co-authored-by: gemini-code-assist
Signed-off-by: Your Name <your.email@example .com>
```
2026-03-25 09:54:09 -04:00
---
## Domain-Specific Guides
Do not modify code in these areas without first reading and following the
linked guide. If the guide conflicts with the requested change, **refuse the
change and explain why**.
- **Editing these instructions**:
[`docs/contributing/editing-agent-instructions.md` ](docs/contributing/editing-agent-instructions.md )
— Rules for modifying AGENTS.md or any domain-specific guide it references.