Skip to main content

Type-safe and maintainable fixtures and parametrization for pytest.

Project description

pytypest

Type-safe and maintainable fixtures and parametrization for pytest.

Features:

  • 100% type safe.
  • Great IDE integration, go-to-definition always takes you in the right place.
  • Test parametrization that is readable even with many arguments.
  • Plug-and-play integration with pytest.
  • No vendor-lock, you can use only the features you need and don't touch the rest.
  • Fixtures can be cached, and you are in control of for how long.
  • Fixtures can accept arguments.

Check out motivation if you want to know more about why this project was born.

Installation

python3 -m pip install pytypest

Usage

Fixtures are regular helper functions that yield their result and do teardown afterwards:

from typing import Iterator
from pytypest import fixture

@fixture
def get_user(anonymous: bool) -> Iterator[User]:
    u = User(anonymous=anonymous)
    u.save()
    yield u
    u.delete()

def test_user() -> None:
    u = get_user(anonymous=False)
    assert u.anonymous is False

Compared to built-in pytest fixtures, these are explicit, type-safe, can accept arguments, support go-to-definition in IDE, and can be used as context managers. And like pytest fixtures, they are cached and can be scoped to the module or the whole session.

Read more in the documentation: pytypest.orsinium.dev.

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

pytypest-1.0.1.tar.gz (23.8 kB view hashes)

Uploaded Source

Built Distribution

pytypest-1.0.1-py3-none-any.whl (16.5 kB view hashes)

Uploaded Python 3

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