Official Python client for MockServer — create expectations, verify requests, and register dynamic callbacks via WebSocket
Project description
MockServer Python Client
Python client for MockServer with full WebSocket callback support.
Features
- Full REST API: Create expectations, verify requests, clear/reset, retrieve recorded data
- Response Callbacks: Register Python functions that dynamically generate responses via WebSocket
- Forward Callbacks: Modify requests before they are forwarded to the real server
- Forward+Response Callbacks: Modify both the forwarded request and the response
- Fluent API:
client.when(request).respond(callback)— mirrors the Java client - Async + Sync: Native asyncio API with a synchronous wrapper for non-async code
- Minimal Dependencies: Only
websockets(for callback support)
Installation
pip install mockserver-client
Quick Start
Synchronous API
from mockserver import MockServerClient, HttpRequest, HttpResponse
client = MockServerClient("localhost", 1080)
# Static expectation
client.when(
HttpRequest.request("/api/users").with_method("GET")
).respond(
HttpResponse.response('{"users": []}', status_code=200)
)
# Verify
client.verify(
HttpRequest.request("/api/users").with_method("GET"),
VerificationTimes.at_least(1)
)
# Clean up
client.reset()
client.close()
Context Manager
with MockServerClient("localhost", 1080) as client:
client.when(
HttpRequest.request("/hello")
).respond(
HttpResponse.response("world")
)
Async API
import asyncio
from mockserver import AsyncMockServerClient, HttpRequest, HttpResponse
async def main():
async with AsyncMockServerClient("localhost", 1080) as client:
await client.when(
HttpRequest.request("/api/data")
).respond(
HttpResponse.response('{"key": "value"}')
)
asyncio.run(main())
Response Callbacks
Register a Python function that generates responses dynamically when matching requests arrive:
from mockserver import MockServerClient, HttpRequest, HttpResponse
def handle_request(request):
if request.method == "POST":
return HttpResponse.response("created", status_code=201)
return HttpResponse.not_found_response()
client = MockServerClient("localhost", 1080)
client.mock_with_callback(
HttpRequest.request("/api/callback"),
handle_request
)
Or with the fluent API:
client.when(
HttpRequest.request("/api/callback")
).respond(handle_request)
Forward Callbacks
Modify requests before they are forwarded to the real server:
def modify_request(request):
return request.with_header("X-Forwarded", "true").with_path("/modified" + request.path)
client.mock_with_forward_callback(
HttpRequest.request("/proxy/.*"),
modify_request
)
Forward+Response Callbacks
Modify both the forwarded request and the response:
def modify_request(request):
return request.with_header("X-Proxied", "true")
def modify_response(request, response):
return response.with_header("X-Modified", "true")
client.mock_with_forward_callback(
HttpRequest.request("/proxy/.*"),
modify_request,
modify_response
)
Verification
from mockserver import VerificationTimes
# Verify a request was received at least once
client.verify(
HttpRequest.request("/api/users").with_method("GET"),
VerificationTimes.at_least(1)
)
# Verify exact count
client.verify(
HttpRequest.request("/api/users"),
VerificationTimes.exactly(3)
)
# Verify request sequence (order matters)
client.verify_sequence(
HttpRequest.request("/first"),
HttpRequest.request("/second"),
HttpRequest.request("/third"),
)
# Verify no interactions
client.verify_zero_interactions()
Retrieval
# Get recorded requests
requests = client.retrieve_recorded_requests(
HttpRequest.request("/api/.*")
)
# Get active expectations
expectations = client.retrieve_active_expectations()
# Get log messages
logs = client.retrieve_log_messages()
Control
# Clear specific expectations
client.clear(HttpRequest.request("/api/users"))
# Clear by type
client.clear(HttpRequest.request("/api/users"), clear_type="LOG")
# Reset everything
client.reset()
# Bind additional ports
client.bind(1081, 1082)
# Check if running
if client.has_started():
print("MockServer is running")
# Stop
client.stop()
TLS Support
# Uses system trust store (default — verifies certificates)
client = MockServerClient("localhost", 1080, secure=True)
# Custom CA certificate
client = MockServerClient(
"localhost", 1080,
secure=True,
ca_cert_path="/path/to/ca.pem"
)
# Disable certificate verification (testing only — NOT recommended for production)
client = MockServerClient(
"localhost", 1080,
secure=True,
tls_verify=False
)
Domain Model
All domain model classes support builder-style chaining:
request = (
HttpRequest.request("/api/users")
.with_method("POST")
.with_header("Content-Type", "application/json")
.with_header("Authorization", "Bearer token")
.with_body('{"name": "test"}')
.with_query_param("page", "1")
.with_secure(True)
)
response = (
HttpResponse.response()
.with_status_code(201)
.with_header("Location", "/api/users/1")
.with_body('{"id": 1, "name": "test"}')
.with_delay(Delay(time_unit="SECONDS", value=1))
)
Interactive Breakpoints
The client supports matcher-driven interactive breakpoints over the callback WebSocket. Register a breakpoint matcher to pause forwarded/proxied exchanges at specific phases and inspect/modify/continue them via callback handlers.
Register a breakpoint (sync client)
from mockserver import MockServerClient, HttpRequest, HttpResponse
client = MockServerClient("localhost", 1080)
# REQUEST phase only
bp_id = client.add_request_breakpoint(
HttpRequest(path="/api/.*"),
lambda request: request, # continue unchanged (or return HttpResponse to abort)
)
# REQUEST + RESPONSE
bp_id = client.add_request_and_response_breakpoint(
HttpRequest(path="/api/.*"),
lambda request: request, # REQUEST handler
lambda request, response: response, # RESPONSE handler
)
# All phases with stream frame handler
bp_id = client.add_breakpoint(
HttpRequest(path="/stream/.*"),
["REQUEST", "RESPONSE", "RESPONSE_STREAM", "INBOUND_STREAM"],
request_handler=lambda request: request,
response_handler=lambda request, response: response,
stream_frame_handler=lambda frame: {"action": "CONTINUE"},
# Other actions: MODIFY (with body), DROP, INJECT (with body), CLOSE
)
Manage breakpoints
# List all matchers
matchers = client.list_breakpoint_matchers() # {"matchers": [...]}
# Remove a specific matcher
client.remove_breakpoint_matcher(bp_id)
# Clear all matchers
client.clear_breakpoint_matchers()
The async client (AsyncMockServerClient) exposes the same methods as coroutines.
Start / Launch MockServer
The Python client can download and launch a local MockServer instance directly -- no Java installation and no Docker required. The launcher downloads a self-contained platform bundle (mockserver-<version>-<os>-<arch>) from the GitHub Release, verifies its SHA-256, caches it per-user, and starts it.
Quick start
from mockserver.launcher import start, MockServerProcess
# Download (first run) and start MockServer on port 1080
with start(port=1080) as server:
print(f"MockServer running on port {server.port}, PID {server.pid}")
# ... use MockServer ...
# Server is stopped automatically when the context manager exits
Just ensure the binary is present
from mockserver.launcher import ensure_binary
launcher_path = ensure_binary() # returns Path to the launcher executable
Specify a version
from mockserver.launcher import start
server = start(port=1080, version="7.1.0")
# ...
server.stop()
API reference
| Function / Class | Description |
|---|---|
ensure_binary(version=None, *, log=True) |
Download, verify, cache, and return the launcher Path. Defaults to the client's own version. |
start(port, version=None, *, extra_args=None, log=True) |
Ensure the binary and start MockServer. Returns a MockServerProcess. |
MockServerProcess |
Handle to the running process. Properties: port, pid, launcher, returncode. Methods: stop(timeout=10.0). Supports with statement. |
Supported platforms
| OS | Architecture |
|---|---|
| Linux | x86_64, aarch64 |
| macOS (darwin) | x86_64, aarch64 |
| Windows | x86_64, aarch64 |
Environment variables
| Variable | Purpose |
|---|---|
MOCKSERVER_BINARY_BASE_URL |
Mirror host for the release assets (corporate / air-gapped networks) |
MOCKSERVER_BINARY_CACHE |
Override the cache directory (default: ~/.cache/mockserver/binaries on Unix) |
MOCKSERVER_SKIP_BINARY_DOWNLOAD |
Fail instead of downloading (use with a pre-seeded cache in CI) |
Version
By default the launcher downloads the MockServer version matching this client package (currently the version set in pyproject.toml). Pass an explicit version argument to override.
Requirements
- Python 3.9+
websockets>= 12.0 (for callback support)
License
Apache 2.0
AI Assistant Integration
MockServer includes a built-in MCP (Model Context Protocol) server that enables AI coding assistants to create expectations, verify requests, and debug HTTP traffic programmatically.
- MCP Endpoint:
http://localhost:1080/mockserver/mcp - AI Documentation: llms.txt
- Setup Guide: AI Integration
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mockserver_client-7.1.0.tar.gz.
File metadata
- Download URL: mockserver_client-7.1.0.tar.gz
- Upload date:
- Size: 72.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d767e19d6322ece177a93313489f1aef6e883de8604ecd2315a3d24cc91c4628
|
|
| MD5 |
5da6290fcdcc1592a8389b9ba9593518
|
|
| BLAKE2b-256 |
3d9390f1802f0b520cbf2763e826745dc752b8a1cc5b3dd0f76a74100ed26355
|
File details
Details for the file mockserver_client-7.1.0-py3-none-any.whl.
File metadata
- Download URL: mockserver_client-7.1.0-py3-none-any.whl
- Upload date:
- Size: 35.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd37f755352c78711671b5d8a3806bafd3ac6e3f243dea28ee66559476f199c6
|
|
| MD5 |
161e3d4129f2cc6e40bbbb77b84d4eb5
|
|
| BLAKE2b-256 |
0ec63104bd08a0156158d7a9c1068aa48f6457fb08cd561ae2ac8d65ae78545a
|