Skip to main content

Mocking library for Python and Pytest

Project description

Chainmock

pypi ci documentation license


Mocking library for Python and Pytest.

Chainmock is a wrapper for Python unittest unit testing library. It provides an alternative syntax to create mocks and assertions with some additional features to make testing faster and more straightforward. The syntax works especially well with pytest fixtures.

Documentation: https://chainmock.readthedocs.io/

Installation

Install with pip:

pip install chainmock

Features

Chainmock supports all the same features that Python standard library unittest supports and adds some convenient extra functionality.

  • Mocking: Create mocks and assert call counts and arguments or replace return values.
  • Spying: Spying proxies the calls to the original function or method. With spying you can assert call counts and arguments without mocking.
  • Stubs: Easily create stub objects that can be used in tests as fake data or to replace real objects.
  • Async support: Chainmock supports mocking and spying async functions and methods. Most of the time it also recognizes automatically when async mocking should be used so it is not any harder than mocking sync code.
  • Fully type annotated: The whole codebase is fully type annotated so Chainmock works well with static analysis tools and editor autocomplete.
  • Works with Python 3.8+ and PyPy3.

Examples

The entrypoint to Chainmock is the mocker function. Import the mocker function as follows:

from chainmock import mocker

Mocking

To mock you just give the object that you want to mock to the mocker function. After this you can start mocking individual attributes and methods as follows:

# Assert that a certain method has been called exactly once
mocker(Teapot).mock("add_tea").called_once()

# Provide a return value and assert that method has been called twice
mocker(Teapot).mock("brew").return_value("mocked").called_twice()

# Assert that a method has been called with specific arguments at most twice
mocker(Teapot).mock("add_tea").all_calls_with("green").call_count_at_most(2)

Spying

Spying is not any harder than mocking. You just need to call the spy method instead of the mock method. After spying a callable, it works just like before spying and you can start making assertions on it.

# Assert that a certain method has been called at least once
mocker(Teapot).spy("add_tea").called()

# Check that a method has been called at most twice and has
# at least one call with the given argument
mocker(Teapot).spy("add_tea").any_call_with("green").call_count_at_most(2)

Stubs

To create a stub object, just call mocker function without any arguments.

# Create a stub with a method called "my_method"
stub = mocker().mock("my_method").return_value("it works!").self()
assert stub.my_method() == "it works!"

# You can give keyword arguments to the mocker function to quickly set properties
stub = mocker(my_property=10)
assert stub.my_property == 10

For more details and examples, see the documentation.

Similar projects

If chainmock is not what you need, check out also these cool projects:

  • flexmock: Chainmock's API is heavily inspired by flexmock. Flexmock doesn't use standard library unittest and it has fully custom mocking implementation. Compared to flexmock, chainmock has more familiar API if you have been using standard library unittest. Chainmock also supports async mocking and partial argument matching.
  • pytest-mock: Similar to chainmock, pytest-mock is a wrapper for standard library unittest. However, pytest-mock doesn't provide any extra functionality and it exposes unittest mocks directly to the user.

Contributing

Do you like this project and want to help? If you need ideas, check out the open issues and feel free to open a new pull request. Bug reports and feature requests are also very welcome.

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

chainmock-0.8.2.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

chainmock-0.8.2-py3-none-any.whl (17.4 kB view details)

Uploaded Python 3

File details

Details for the file chainmock-0.8.2.tar.gz.

File metadata

  • Download URL: chainmock-0.8.2.tar.gz
  • Upload date:
  • Size: 18.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.9.10 Linux/6.0.12-76060006-generic

File hashes

Hashes for chainmock-0.8.2.tar.gz
Algorithm Hash digest
SHA256 e1070c773e96db170020225bb8e0a1cfd9865f82a07506aee17a2294f8a6a8a0
MD5 7d1d4537991d515589a12da70af28122
BLAKE2b-256 d8d6aba77f387049b350e873115a4a93464e9d188a6ec026af26273ad89f68ba

See more details on using hashes here.

File details

Details for the file chainmock-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: chainmock-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 17.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.9.10 Linux/6.0.12-76060006-generic

File hashes

Hashes for chainmock-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 81e738e46eb563e3b04e0e1a8a9b547fbd8900348e6828b0e54d6303d2d709df
MD5 5ae94dea65206fd40df1d4b0d01e2bdd
BLAKE2b-256 95015914dd7cbf225f0b9143fe925bd31b5b6d1eabbee58098e1d35d01b0183a

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