Skip to main content

Enhance the standard unittest package with features for testing asyncio libraries

Project description

PyPI Travis AppVeyor Supported Python versions

asynctest

The package asynctest is built on top of the standard unittest module and cuts down boilerplate code when testing libraries for asyncio.

Currently, asynctest targets the “selector” model, hence, some features will not (yet?) work with Windows’ proactor.

Author & license

Authored by Martin Richard <martius@martiusweb.net> and licensed under the Apache 2 license.

See the AUTHORS file for a comprehensive list of the authors.

Documentation

https://readthedocs.org/projects/asynctest/badge/

Full documentation is available at http://asynctest.readthedocs.org/en/latest/. It includes a tutorial with tested examples of how to use TestCase or mocks.

Features

TestCases

  • Initialize and close a loop created for each test (it can be configurated), if the loop uses a selector, it will be updated with a TestSelector object wrapping the original selector (see below),

  • if the test function is a coroutine function or returns a coroutine, it will run on the loop,

  • TestCase.setUp() and TestCase.tearDown() can be coroutine functions,

  • control post-test checks with @fail_on, for instance, the test fail if the loop didn’t run, some optional checks can be activated,

  • ClockedTestCase allows to control the loop clock and run timed events without waiting the wall clock.

Mock and CoroutineMock

  • CoroutineMock is a new Mock class which mocks a coroutine function, and returns a coroutine when called,

  • MagicMock supports asynchronous context managers and asynchronous iterators,

  • NonCallableMock, Mock and CoroutineMock can return CoroutineMock objects when its attributes are get if there is a matching attribute in the spec (or spec_set) object which is a coroutine function,

  • patch(), patch.object(), patch.multiple() return a MagickMock or CoroutineMock object by default, according to the patched target,

  • patch(), patch.object(), patch.multiple() handle generators and coroutines and their behavior can be controled when the generator or coroutine pauses,

  • all the patch() methods can decorate coroutine functions,

  • mock_open() returns a MagickMock object by default.

  • return_once() can be used with Mock.side_effect to return a value only once when a mock is called.

Selectors

The module asynctest.selector provides classes to mock objects performing IO (files, sockets, etc).

  • FileMock is a special type of mock which represents a file. FileMock.fileno() returns a special value which allows to identify uniquely the mock,

  • SocketMock is a special type of FileMock which uses socket.socket as spec,

  • TestSelector is a custom selector able to wrap a real selector implementation and deal with FileMock objects, it can replace a selector loop by calling loop._selector = TestSelector(loop._selector), and will intercept mock so they don’t get registered to the actual selector.

  • set_read_ready() and set_write_ready() to force read and write event callbacks to be scheduled on the loop, as if the selector scheduled them.

Helpers

  • the coroutine exhaust_callbacks(loop) returns once all the callbacks which should be called immediately are executed, which is useful when the test author needs to assert things which are not yet executed by the loop.

Roadmap

I hope I will find time to develop and release the following features:

  • set of warnings against common mistakes

  • proactor support

Tests

asynctest is unit tested. You can run asynctest test suite with this command:

$ PYTHONPATH=. python -m unittest 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

asynctest-0.13.0.tar.gz (42.3 kB view details)

Uploaded Source

Built Distribution

asynctest-0.13.0-py3-none-any.whl (26.4 kB view details)

Uploaded Python 3

File details

Details for the file asynctest-0.13.0.tar.gz.

File metadata

  • Download URL: asynctest-0.13.0.tar.gz
  • Upload date:
  • Size: 42.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.1

File hashes

Hashes for asynctest-0.13.0.tar.gz
Algorithm Hash digest
SHA256 c27862842d15d83e6a34eb0b2866c323880eb3a75e4485b079ea11748fd77fac
MD5 b616fb83a225dcfa74b365deb40b8a64
BLAKE2b-256 0c0f6056f4435923d2f8c89ac9ef2d18506a569348d8f9cc827b0dd7a4c8acc4

See more details on using hashes here.

File details

Details for the file asynctest-0.13.0-py3-none-any.whl.

File metadata

  • Download URL: asynctest-0.13.0-py3-none-any.whl
  • Upload date:
  • Size: 26.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.1

File hashes

Hashes for asynctest-0.13.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5da6118a7e6d6b54d83a8f7197769d046922a44d2a99c21382f0a6e4fadae676
MD5 82ac26a6b42400fb636817e130f70b6d
BLAKE2b-256 e8b68d17e169d577ca7678b11cd0d3ceebb0a6089a7f4a2de4b945fe4b1c86db

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