hypothesis

Hypothesis is a powerful, flexible, and easy to use library for property-based testing.

Github stars Tracking Chart

==========
Hypothesis

Hypothesis is a family of testing libraries which let you write tests parametrized
by a source of examples. A Hypothesis implementation then generates simple and
comprehensible examples that make your tests fail.
This simplifies writing your tests and makes them more powerful at the same time,
by letting software automate the boring bits and do them to a higher standard than a human would,
freeing you to focus on the higher level test logic.

This sort of testing is often called "property-based testing",
and the most widely known implementation of the concept is the Haskell
library QuickCheck <https://hackage.haskell.org/package/QuickCheck>_,
but Hypothesis differs significantly from QuickCheck and is designed to fit
idiomatically and easily into existing styles of testing that you are used to,
with absolutely no familiarity with Haskell or functional programming needed.

Hypothesis for Python <hypothesis-python>_ is the original implementation,
and the only one that is currently fully production ready and actively maintained.


Hypothesis for Other Languages

The core ideas of Hypothesis are language agnostic and in principle it is
suitable for any language. We are interested in developing and supporting
implementations for a wide variety of languages, but currently lack the
resources to do so, so our porting efforts are mostly prototypes.

The two prototype implementations of Hypothesis for other languages are:

  • Hypothesis for Ruby <hypothesis-ruby>_
    is a reasonable start on a port of Hypothesis to Ruby. It worked pretty well,
    but uses a core Rust implementation that is unfortunately not compatible with
    recent versions of Rust, due to its dependency on Helix (which now seems to
    be mostly unmaintained) and as a result is currently unsupported pending a
    rewrite of the bridging code between Rust and Ruby. We don't at present have
    the time or funding for this project, but it is likely not a massive undertaking
    if anyone would like to provide either of these.
  • Hypothesis for Java <https://github.com/HypothesisWorks/hypothesis-java>_
    is a prototype written some time ago. It's far from feature complete and is
    not under active development, but was intended to prove the viability of the
    concept.

Additionally there is a port of the core engine of Hypothesis, Conjecture, to
Rust. It is not feature complete but in the long run we are hoping to move
much of the existing functionality to Rust and rebuild Hypothesis for Python
on top of it, greatly lowering the porting effort to other languages.

Any or all of these could be turned into full fledged implementations with relatively
little effort (no more than a few months of full time work), but as well as the
initial work this would require someone prepared to provide or fund ongoing
maintenance efforts for them in order to be viable.

Main metrics

Overview
Name With OwnerHypothesisWorks/hypothesis
Primary LanguagePython
Program languageShell (Language Count: 11)
Platform
License:Other
所有者活动
Created At2013-03-10 13:51:19
Pushed At2025-07-06 00:09:35
Last Commit At2025-07-05 04:59:35
Release Count1705
Last Release Namehypothesis-python-6.135.26 (Posted on )
First Release Namev0.0.1 (Posted on )
用户参与
Stargazers Count7.9k
Watchers Count71
Fork Count616
Commits Count16.2k
Has Issues Enabled
Issues Count1684
Issue Open Count67
Pull Requests Count2257
Pull Requests Open Count6
Pull Requests Close Count508
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private