This repository provides a multi-language reference implementation of the variants proposal for the Model Context Protocol (MCP), as described in SEP-2053.
| Language | Directory | Package | Status |
|---|---|---|---|
| Go | go/sdk/ |
github.com/modelcontextprotocol/experimental-ext-variants/go/sdk |
Planned |
| Python | python/sdk/ |
mcp-ext-variants |
Planned |
| TypeScript | typescript/sdk/ |
@ext-modelcontextprotocol/variants |
Planned |
This monorepo uses path-based CI workflows to efficiently test only what changes:
-
Language-specific workflows (
python.yml,go.yml,typescript.yml)- Only trigger when their language directory or workflow file changes
- Run all tests, linting, and checks for that language
-
Status check workflow (
status-check.yml)- Runs on every PR to verify required checks passed
- Determines what needs to pass based on which files changed
- This is the only required check in branch protection
- Change
python/sdk/file.py→ Only Python CI runs → PR requires Python checks to pass - Change both Go and TypeScript files → Both CIs run → PR requires both to pass
- Change only
README.md→ No language CIs run → PR can merge immediately
To run all language checks regardless of changed files:
- In a PR: Comment
/test all(only works for repo owners/members/collaborators) - Manually: Use GitHub Actions UI or CLI to trigger individual workflows
-
Add your check to the appropriate language workflow (e.g.,
python.yml):python-security-scan: name: "Security Scan" runs-on: ubuntu-latest steps: - name: Run security checks run: # your commands here
-
Update the status check in
.github/workflows/status-check.yml:const requiredChecks = { python: [ 'Python CI / Linting', 'Python CI / Unit Tests (3.10)', // ... existing checks ... 'Python CI / Security Scan' // ← Add your new check ],
-
Submit PR - Your new check is now required for all relevant changes!
Apache License 2.0 - See LICENSE file for details
- Variants Proposal Specification (SEP-2053) - Full specification and design details
- Model Context Protocol