Hypothesis is a powerful, flexible, and easy to use library for property-based testing.
Switch branches/tags
Clone or download
Permalink
Failed to load latest commit information.
.circleci Bump circleci cache generation Oct 23, 2018
conjecture-rust Bump conjecture-rust version to 0.4.0 and update changelog Oct 24, 2018
guides Update pass name in internal docs Oct 27, 2018
hypothesis-python Bump hypothesis-python version to 3.82.1 and update changelog Oct 29, 2018
hypothesis-ruby Bump hypothesis-ruby version to 0.2.0 and update changelog Oct 24, 2018
notebooks Final table Jun 27, 2015
requirements Update dependencies Oct 16, 2018
scripts Change top level build system to custom runner Apr 21, 2018
tooling Avoid sys.exit in potential tests Sep 26, 2018
whole-repo-tests Add release notes and fix some markup Oct 27, 2018
.flake8 Use flake8-alfred to forbid use of bytes() Oct 7, 2018
.gitattributes Support for Windows development using Vagrant May 15, 2016
.gitignore Make Sphinx really nit-picky Sep 16, 2018
.isort.cfg fix build errors Jun 8, 2018
.pyup.yml Remove benchmarks Dec 20, 2017
.readthedocs.yml Fix readthedocs build Apr 13, 2018
.rtfd-reqs.txt Fix RTFD build for Numpy, Pandas, dateutil Jul 22, 2018
.travis.yml Move docs and reqs checks to whole-repo-tests Sep 26, 2018
CITATION Automatically mint DOIs for new releases Sep 11, 2018
CODE_OF_CONDUCT.rst The code of conduct is not just for the Python community Apr 11, 2018
CONTRIBUTING.rst Update pass name in internal docs Oct 27, 2018
LICENSE.txt Add pretty printer vendor Mar 6, 2016
Makefile Fix typo Apr 21, 2018
README.rst Update URLs May 21, 2018
appveyor.yml Skip redundant wheel upload Aug 22, 2018
azure-pipelines.yml Set up CI with Azure Pipelines Oct 23, 2018
build.sh Use PYTHONPATH rather than less reliable install -e Aug 5, 2018
mypy.ini Ignore vendored type issues for downstream Jun 26, 2018
pytest.ini Change top level build system to custom runner Apr 21, 2018
secrets.tar.enc Update secrets for cargo Jun 23, 2018

README.rst

Hypothesis

Hypothesis is 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, 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.

The currently available implementations of Hypothesis are:

  • Hypothesis for Python is the original implementation, and the only one that is currently fully production ready.
  • Hypothesis for Ruby is an ongoing project that we intend to eventually reach parity with Hypothesis for Python.
  • Hypothesis for 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.

This repository will eventually house all implementations of Hypothesis, but we are currently in the process of consolidating the existing repositories into a single one.