Skip to main content

Testcontainers module for MockServer

Project description

testcontainers-mockserver

A Testcontainers module for MockServer in Python.

Starts a mockserver/mockserver Docker container, waits for readiness, and provides convenient accessors for the mapped host, port, and URL.

Installation

pip install testcontainers-mockserver

Usage

from testcontainers_mockserver import MockServerContainer
import requests

with MockServerContainer() as mockserver:
    url = mockserver.get_url()  # e.g. "http://localhost:49152"

    # Create an expectation
    requests.put(f"{url}/mockserver/expectation", json={
        "httpRequest": {"method": "GET", "path": "/hello"},
        "httpResponse": {"statusCode": 200, "body": "world"},
    })

    # Match it
    resp = requests.get(f"{url}/hello")
    assert resp.text == "world"

API

MockServerContainer(image=..., port=1080)

  • image — Docker image to use. Defaults to mockserver/mockserver:mockserver-7.1.0.
  • port — Container port MockServer listens on. Defaults to 1080.

Methods

Method Returns Description
get_url() str HTTP base URL (e.g. http://localhost:49152)
get_secure_url() str HTTPS base URL (same port, https:// scheme)
get_host() str Mapped host IP
get_port() int Mapped host port
with_server_port(port) self Override the listen port
with_log_level(level) self Set MOCKSERVER_LOG_LEVEL
with_property(key, value) self Set any MockServer env var
with_initialization_json(path) self Point to a startup expectations JSON file

Building and Testing

# Install in editable mode with test dependencies
pip install -e .[test]

# Run unit tests (no Docker needed)
pytest tests/test_container_config.py

# Run all tests including integration (requires Docker)
pytest

# Skip Docker-dependent tests
pytest -m "not docker"

Requirements

  • Python >= 3.9
  • Docker (for integration tests and actual usage)
  • testcontainers >= 4.0.0

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

testcontainers_mockserver-7.1.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

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

testcontainers_mockserver-7.1.0-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file testcontainers_mockserver-7.1.0.tar.gz.

File metadata

File hashes

Hashes for testcontainers_mockserver-7.1.0.tar.gz
Algorithm Hash digest
SHA256 3723fee03e46d2412ed30735bf58b82979df9ebafc6d76ed56395c4a2d425560
MD5 8a28319ab59280558c922dc91a8342a1
BLAKE2b-256 b7f03d3651dee2b3ed863d06a79cbd3ab5b1a4d48c76336c3062a7278b5b5d6c

See more details on using hashes here.

File details

Details for the file testcontainers_mockserver-7.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for testcontainers_mockserver-7.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 656d7685cd870357a794e51e6300b38fa93a822e4a1d3f2ee25acc5eabe7030c
MD5 41a14e05ef9f79b20612e19c1324d0a3
BLAKE2b-256 a445041bb3c3f98bc9ce5d559d07fcdf43e50d66745955ba1e78e33de0500ad4

See more details on using hashes here.

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