Contributing to MCP Apps SDK
We welcome contributions to the MCP Apps SDK! This document outlines the process for contributing to the project.
Getting Started
- Fork the repository
- Clone your fork:
git clone https://github.com/YOUR-USERNAME/ext-apps.git - Install dependencies:
npm install - Build the project:
npm run build - Run tests:
npm test
Development Process
- Create a new branch for your changes
- Make your changes
- Run
npm run prettierto ensure code style compliance - Run
npm testto verify all tests pass - Submit a pull request
Pull Request Guidelines
- Follow the existing code style
- Include tests for new functionality
- Update documentation as needed
- Keep changes focused and atomic
- Provide a clear description of changes
Running Examples
Start the development environment with hot reloading:
npm run examples:dev
Or build and run examples:
npm run examples:start
Testing
Unit Tests
Run unit tests with Bun:
npm test
E2E Tests
E2E tests use Playwright to verify all example servers work correctly with screenshot comparisons.
# Run all E2E tests
npm run test:e2e
# Run a specific server's tests
npm run test:e2e -- --grep "Budget Allocator"
# Run tests in interactive UI mode
npm run test:e2e:ui
Updating Golden Screenshots
When UI changes are intentional, update the golden screenshots:
# Update all screenshots
npm run test:e2e:update
# Update screenshots for a specific server
npm run test:e2e:update -- --grep "Three.js"
Note: Golden screenshots are platform-agnostic. Tests use canvas masking and tolerance thresholds to handle minor cross-platform rendering differences.
Code of Conduct
This project follows our Code of Conduct. Please review it before contributing.
Reporting Issues
- Use the GitHub issue tracker
- Search existing issues before creating a new one
- Provide clear reproduction steps
Security Issues
Please review our Security Policy for reporting security vulnerabilities.
For Maintainers
Repository Setup
This repository uses npm trusted publishing with OIDC - no secrets required.
Before publishing releases, ensure the following are configured:
Trusted publisher on npm: Configure the package to trust this GitHub repository
- Go to https://www.npmjs.com/package/@modelcontextprotocol/ext-apps/access
- Under "Trusted Publishers", click "Add trusted publisher"
- Select "GitHub Actions"
- Repository:
modelcontextprotocol/ext-apps - Workflow filename:
npm-publish.yml - Environment:
Release(optional, for additional protection)
Releaseenvironment (optional): Create a protected environment for additional safeguards- Go to Settings > Environments > New environment
- Name it
Release - Add required reviewers or other protection rules as needed
Publishing a Release
Releases are published automatically via GitHub Actions when a GitHub Release is created.
Steps to publish:
Update the version in
package.json:# For a regular release npm version patch # or minor, or major # For a beta release npm version prerelease --preid=betaCommit the version bump (if not done by
npm version):git add package.json git commit -m "Bump version to X.Y.Z" git push origin mainCreate a GitHub Release:
- Go to Releases
- Click "Draft a new release"
- Create a new tag matching the version (e.g.,
v0.1.0) - Set the target branch (usually
main) - Write release notes describing the changes
- Click "Publish release"
Monitor the workflow:
- The npm-publish workflow will trigger automatically
- It runs build and test jobs before publishing
- On success, the package is published to npm with provenance
npm Tags
The workflow automatically determines the npm dist-tag:
| Version Pattern | npm Tag | Install Command |
|---|---|---|
X.Y.Z (from main) |
latest |
npm install @modelcontextprotocol/ext-apps |
X.Y.Z-beta.N |
beta |
npm install @modelcontextprotocol/ext-apps@beta |
X.Y.Z (from release branch) |
release-X.Y |
npm install @modelcontextprotocol/ext-apps@release-X.Y |
Maintenance Releases
To release a patch for an older version:
- Create a release branch from the tag:
git checkout -b release-0.1 v0.1.0 - Cherry-pick or apply fixes
- Bump the patch version
- Create a GitHub Release targeting the release branch
- The package will be published with tag
release-0.1
Testing Pre-releases
Every commit and PR automatically publishes a preview package via pkg-pr-new. Check the PR comments or workflow logs for the install command.
License
By contributing, you agree that your contributions will be licensed under the MIT License.