Skip to main content

No project description provided

Project description

Tests & Lint PyPI Downloads Monthly Downloads License Documentation

✨ Introduction

I created this repository to automatically test my MCP tool servers.

pytest --mcp-tools=http://localhost:8000

Will create some tests, automatically, and you will get an output that looks like this:

🔍 MCP Tools: Discovering endpoints at http://test-server:8000...
   Retry 1/10: Checking http://test-server:8000...
   ✓ Server reachable (status: 404)
   ✓ Found endpoint: /mcp (status: 406)
   ✗ Endpoint /sse not found (status: 404)
   ✗ Endpoint /messages not found (status: 404)
✅ MCP Tools: Discovered endpoints: /mcp

============================= test session starts ==============================
platform linux -- Python 3.11.14, pytest-9.0.2, pluggy-1.6.0 -- /usr/local/bin/python3.11
cachedir: .pytest_cache
rootdir: /app
configfile: pyproject.toml
plugins: cov-7.0.0, anyio-4.12.1, depends-1.0.1, mock-3.15.1, mcp-tools-0.1.0
collecting ... collected 3 items

✅ MCP tools test created for discovered endpoints: /mcp
   📡 HTTP streaming support detected

test_samples/test_sample_math.py::test_sample_addition PASSED            [ 25%]
test_samples/test_sample_math.py::test_sample_multiplication PASSED      [ 50%]
.::test_mcp_tools[POST /mcp] PASSED                                      [ 75%]
test_samples/test_sample_math.py::test_sample_string_operations PASSED   [100%]

============================== 4 passed in 0.03s ===============================

Note the test called .::test_mcp_tools[POST /mcp] PASSED [ 75%]. This is automatically generated by the plugin, and the plan is to make more of these automatically-generated tests based on descriptions of the tools.

Reporting Issues

If you tested this on your server, and think that there is an issue, just give me the docker image of your server in the issue, and tell me what you are expecting, what you got.

If you don't have a docker hub image, give me a minimal example. That's all I need.

🛠️ Development

The only requirement is 🐳 Docker. (The .devcontainer and tasks.json are prepared assuming a *nix system, but if you know the commands, this will work on Windows, too.)

  1. Clone the repo.
  2. Branch out.
  3. Open in "devcontainer" on VS Code and start developing. Run pytest under tests to test.
  4. Akternatively, if you are a fan of Test-Driven Development like me, you can run the tests without getting on a container. .vscode/tasks.json has the command to do so, but it's also listed here:
docker compose -f tests/docker-compose.yaml up --build --abort-on-container-exit --exit-code-from test

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytest_mcp_tools-0.1.1.dev202602230244.tar.gz (9.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file pytest_mcp_tools-0.1.1.dev202602230244.tar.gz.

File metadata

File hashes

Hashes for pytest_mcp_tools-0.1.1.dev202602230244.tar.gz
Algorithm Hash digest
SHA256 2890cb093466c33e70d7f2a2d2d83df8515403fba1667f3da07ac86689f6bf08
MD5 bd36b6f9fa3857fdc7e3c3e1097c6978
BLAKE2b-256 f51c68429ea9ce3769ff0db0219c8a63301ab8b177eb3f1a68aeede3cb4bc8f1

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_mcp_tools-0.1.1.dev202602230244.tar.gz:

Publisher: ci.yaml on sinan-ozel/pytest-mcp-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pytest_mcp_tools-0.1.1.dev202602230244-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_mcp_tools-0.1.1.dev202602230244-py3-none-any.whl
Algorithm Hash digest
SHA256 1050ee22ef6a55866a1afd01563342577c8177e4bb8972846f229443196185c6
MD5 f30d991c9c4eac7d9ffa78ebe3909260
BLAKE2b-256 7087725c449765bc28cee4479f16cb2dcb8ba7128002bbbd64c63b55220bbbf1

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_mcp_tools-0.1.1.dev202602230244-py3-none-any.whl:

Publisher: ci.yaml on sinan-ozel/pytest-mcp-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page