npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

mcp-protocol-conformance

v0.1.1

Published

Conformance test harness for Model Context Protocol servers. Validates JSON-RPC 2.0, spec-version handshake, transport, OAuth 2.1 PKCE, tool schemas, capabilities, smoke roundtrip, and annotations against MCP spec 2024-11-05 / 2025-03-26 / 2025-06-18.

Downloads

238

Readme

mcp-protocol-conformance

Conformance test harness for Model Context Protocol servers. Validates JSON-RPC 2.0 wire compliance, spec-version handshake, transport behaviour, OAuth 2.1 PKCE, tool schemas, capability advertisement, smoke roundtrip, and annotation hygiene against MCP spec 2024-11-05, 2025-03-26, and 2025-06-18.

This is a Foundation build of the StudioMeyer MCP Factory: every other Factory build runs through this harness before promotion (npm publish, marketplace submit, upstream PR).

Install

npm install --save-dev mcp-protocol-conformance

The package ships both a CLI (mcp-conformance) and a TypeScript library entry (import ... from "mcp-protocol-conformance").

CLI usage

Run against a stdio server

mcp-conformance run \
  --target stdio \
  --cmd node \
  --cmd-arg dist/server.js \
  --spec 2025-06-18 \
  --suite all \
  --format terminal

Run against an HTTP server (Streamable HTTP, 2025-03-26+)

mcp-conformance run \
  --target http \
  --url https://memory.studiomeyer.io/mcp \
  --header "Authorization:Bearer ${TOKEN}" \
  --spec 2025-06-18 \
  --suite full \
  --format json --out report.json

Run only a subset of suites

mcp-conformance run --target stdio --cmd ./server --spec 2025-06-18 \
  --suite jsonrpc,version,schema

Compare two manifests

mcp-conformance compare \
  --expected manifests/v1.json \
  --actual   manifests/v2.json

Assert no breaking changes between two reports

mcp-conformance assert-no-breaking \
  --baseline reports/main.json \
  --current  reports/pr-42.json

Exit codes: 0 clean, 1 failures, 2 invocation error.

Library usage

import {
  runFullSuite,
  generateReport,
} from "mcp-protocol-conformance";

const report = await runFullSuite(
  { kind: "stdio", cmd: "node", args: ["dist/server.js"] },
  "2025-06-18",
  { suite: "all" },
);

console.log(generateReport(report, "terminal"));
if (report.status === "fail") process.exit(1);

MCP server usage

The harness is itself an MCP server. Start it over stdio and any MCP client can call its 12 tools:

node dist/server.js

Tools (all read-only, all destructiveHint: false):

| # | Tool | Purpose | |---|------|---------| | 1 | runJsonRpcCompliance | JSON-RPC 2.0 error-code suite | | 2 | runSpecVersionAssertion | Verify advertised protocolVersion | | 3 | runTransportSuite | Transport-layer ping + session-id | | 4 | runOauthPkceFlow | OAuth 2.1 PKCE S256 (mock-AS or real-tenant) | | 5 | runToolSchemaValidation | inputSchema is valid JSON-Schema | | 6 | runCapabilityIntrospection | initialize.capabilities matches behaviour | | 7 | runRoundtripSmoke | One tools/call per advertised tool | | 8 | runAnnotationsAudit | readOnlyHint / destructiveHint hygiene | | 9 | runFullSuite | All suites + summary | | 10 | generateReport | Render JUnit / JSON / terminal | | 11 | compareManifests | Diff two tool manifests | | 12 | assertNoBreakingChanges | Diff two FullReports |

Compatibility matrix

| | 2024-11-05 | 2025-03-26 | 2025-06-18 | |--------------------|:----------:|:----------:|:----------:| | jsonrpc | yes | yes | yes | | version (handshake)| yes | yes | yes | | transport (stdio) | yes | yes | yes | | transport (http) | n/a | yes | yes | | oauth (mock) | n/a | yes | yes | | oauth (real) | n/a | yes | yes | | schema | yes | yes | yes | | capability | yes | yes | yes | | smoke | yes | yes | yes | | annotations | warn-only | warn-only | yes |

yes = suite runs and produces actionable results. n/a = capability not in spec; suite skips automatically. warn-only = suite runs but the spec does not formally require the feature.

Integration in Factory builds

In every Factory build's package.json:

{
  "scripts": {
    "factory:conformance": "mcp-conformance run --target stdio --cmd 'node dist/server.js' --spec 2025-06-18 --suite full"
  }
}

In CI:

- run: npm run factory:conformance

Spec references

  • JSON-RPC 2.0: https://www.jsonrpc.org/specification
  • MCP 2024-11-05: https://modelcontextprotocol.io/specification/2024-11-05
  • MCP 2025-03-26: https://modelcontextprotocol.io/specification/2025-03-26
  • MCP 2025-06-18: https://modelcontextprotocol.io/specification/2025-06-18
  • RFC 7636 (PKCE): https://datatracker.ietf.org/doc/html/rfc7636

License

MIT — Copyright (c) 2026 Matthias Meyer (StudioMeyer)