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.dev202602230009.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.dev202602230009.tar.gz.

File metadata

File hashes

Hashes for pytest_mcp_tools-0.1.1.dev202602230009.tar.gz
Algorithm Hash digest
SHA256 ae98d9a148174033156f9741429df6da62b232484602799332609ddc531f6b07
MD5 637a62a098c2955899803afabfb1f9d0
BLAKE2b-256 e9a697efd84b74717ae8c4831620433327a9e6ad3499bb30940b7af7a3f83e58

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_mcp_tools-0.1.1.dev202602230009.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.dev202602230009-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_mcp_tools-0.1.1.dev202602230009-py3-none-any.whl
Algorithm Hash digest
SHA256 b2fb52a77a4725b47bcddb9d56495b1b7473dabc00c32d01afe9d4ddd73c15f0
MD5 4faddafc7ccc8485d798957a5327249d
BLAKE2b-256 571fca23b96b3e7bbf4f745135fbd260d99f79c136d68924cad02b832eb3341d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_mcp_tools-0.1.1.dev202602230009-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