Skip to main content

Friendly python client to James D. Bloom's awesome MockServer

Project description

MockServer Python Client

Build Status

Python client to James D. Bloom's awesome MockServer : http://www.mock-server.com/

Philosophy

Tests should be readable and Mock Server is already very complete and customizable. This library tries to keep it simple and straight-forward using python's kwargs to avoid big declarations.

We think a mock should be able to fit into one 120 char line of code should the expectation be simple enough :)

client.stub(request(method="GET", path="/auth"), response(code=401, body="unauthorized"))

Installation

WARNING: THIS IS A VERY EARLY VERSION THE API IS MOST LIKELY TO CHANGE

From source:

git clone https://github.com/internap/python-mockserver-friendly-client.git
cd python-mockserver-friendly-client
python setup.py install

From PyPi directly:

pip install mockserver-friendly-client

Prerequisite

You need a running MockServer running, see http://www.mock-server.com/mock_server/getting_started.html#start_mockserver

This project's tests uses the docker image : https://github.com/internap/python-mockserver-friendly-client/blob/master/docker-compose.yml

Usage

The whole Mock Server API is not all covered. We just implemented what we needed, if you need something not yet implemented you can open an issue and/or contribute

Stubbing

(For when you are testing what your code DOES with another component's data)

from mockserver import MockServerClient, request, response

client = MockServerClient("http://localhost:1080")

client.stub(
    request(method="GET", path="/that/thing", querystring={"is": "good"}, headers={"so": "good"}),
    response(code=418, body="i'm a teapot", headers={"hi": "haa"})
)
  • You can also add a times(N) as a third parameter to limit how many times this stub can be called, default is unlimited
  • All parameters are always optional. When not specified, the match everything.

Expecting

(For when calling another component IS what you are testing)

Using the expect will remember the request and verify it when verify_expectations is called.

import json
from mockserver import MockServerClient, request, response, times

client = MockServerClient("http://localhost:1080")

client.expect(
    request(method="POST", path="/postme", body=json.dumps({"some": "json"})),
    response(code=204, body=json.dumps({"return": "something"}), headers={"Content-Type": "application/json"}),
    times(1)
)

client.verify_expectations()  # AssertionError !
  • The times(N) parameter is mandatory for expect

Resetting

(Because tests shouldn't impact each other)

from mockserver import MockServerClient

client = MockServerClient("http://localhost:1080")

client.reset()

Customizing and shortcuts

This client consumes Mock Server's REST API : https://app.swaggerhub.com/apis/jamesdbloom/mock-server-openapi

Here's a few shortcuts already ready, there may be more to come

Mocking a form post

from mockserver import MockServerClient, request, response, form

client = MockServerClient("http://localhost:1080")

client.stub(
    request(method="POST", body=form({"user": "foo", "pass": "bar"})),
    response(code=201)
)

This currently takes a 1 level dict. For array mocking, use {"key[index]": "value"}

Returning JSON

from mockserver import MockServerClient, request, json_response

client = MockServerClient("http://localhost:1080")

client.stub(
    request(path="/stuff"),
    json_response(code=200, body={"full": "json", "structure": ["with", "stuff", 1]})
)

This automatically dumps the body in json and appends the application/json Content-Type to the headers.

Expecting JSON request

from mockserver import MockServerClient, request, json_equals

client = MockServerClient("http://localhost:1080")
client.expect(
    request(body=json_equals({"key": "value"})),
    response(),
    times(1)
)

This only matches requests with the provided json body. Json conversation is done automatically. If you only want to match parts of a given JSON you can provide only the matching parts using json_contains:

from mockserver import MockServerClient, request, json_contains

client = MockServerClient("http://localhost:1080")
client.expect(
    request(body=json_contains({"key": "value"})),
    response(),
    times(1)
)

I.e. this will match {"key": "value"} or {"key": "value", "another": "key"}

Verifying request

from mockserver import MockServerClient, request, times

client = MockServerClient("http://localhost:1080")
client.verify(
    request(path="/some_path", querystring({"key": "value"})),
    times(1)
)

Verify will check request on MockServer and raise AssertionError if request not found.

More documentation

There is currently no official documentation, however you can consider the tests as a type of documentation, they are pretty explicit and simple to follow and help to clarify the purpose of each feature.

Good practices

Having your test setup/teardown like this is probably a good idea.

class ServerMockingTestBase(...):
    def setUp(self):
        super(ServerMockingTestBase, self).setUp()
        
        self.client = MockServerClient(MOCK_SERVER_URL)
        self.client.reset()

    def tearDown(self):
        super(ServerMockingTestBase, self).tearDown()
        
        self.client.verify_expectations()

Troubleshooting

Checking MockServer's logs is the first place to go. If you don't see any logs, try another LOG_LEVEL such as INFO.

If the problem is in the code, please open an issue :)

Contributing

The form may not be final, we would love to hear what you think of the client!

Feel free to raise issues and send some pull request, we'll be happy to look at them!

Make sure all new code is tested, current tests run against a MockServer container.

Running tests

You can easily run the tests with https://pypi-hypernode.com/pypi/tox

tox -e py34

You can also call the test-runner.sh directly, you will need https://pypi-hypernode.com/pypi/nose installed

You can also launch the container

docker-compose up-d

and run the tests in your favorite IDE :)

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

mockserver-friendly-client-0.4.1.tar.gz (13.7 kB view details)

Uploaded Source

File details

Details for the file mockserver-friendly-client-0.4.1.tar.gz.

File metadata

  • Download URL: mockserver-friendly-client-0.4.1.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.6.7

File hashes

Hashes for mockserver-friendly-client-0.4.1.tar.gz
Algorithm Hash digest
SHA256 1af06a077c9a5ed3c94e1eb1ee264716ef8fa67f0f483a1f02e089ccd3a3bfc5
MD5 178a3a6fed73f16017836f395f26d6f4
BLAKE2b-256 ae881dca7839aa24f41cc038d6f33c9d266a10fd92541e61c02dc34d7f7913ee

See more details on using hashes here.

Supported by

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