Skip to main content

Level-up your Hypothesis tests with CrossHair.

Project description

hypothesis-crosshair

Downloads

Add the power of solver-based symbolic execution to your Hypothesis tests with CrossHair.

Just

pip install hypothesis-crosshair

and then add a backend="crosshair" setting, like so:

from hypothesis import given, settings, strategies as st

@settings(backend="crosshair")
@given(st.integers())
def test_needs_solver(x):
    assert x != 123456789

Docs hopefully coming soon. In the meantime, start a discussion or file an issue.

FAQ

Can I try using crosshair for ALL my hypothesis tests?

Yes! Create or edit your pytest conftest.py file to register a profile like the following:

from hypothesis import settings

settings.register_profile(
    "crosshair",
    backend="crosshair",
)

And then run pytest using the profile you've defined:

pytest . --hypothesis-profile=crosshair 

Changelog

0.0.17

  • Do not interpret Unsatisfiable errors as user exceptions; just re-throw, so that hypothesis can act appropriately.
  • Report CrossHair path abortions to hypothesis as discard_test_case instead of verified. This lets Hypothesis report unsatisfiable strategies correctly when run under crosshair.

0.0.16

  • Integrate hypothesis's new BackCannotProceed exception, which will reduce the likelihood of FlakeyReplay errors.
  • Validate suspected counterexamples with concrete executions.
  • Treat nondeterminism as an unexplored path rather than a user error. (though we might change this back later)
  • Ensure realization logic called by hypothesis cannot grow the path tree.
  • Allow for collapsing more SMT expressions when drawing strings and floats.

0.0.15

  • (was never released)

0.0.14

  • Support the revised hypothesis provider draw interfaces as of hypothesis v6.112.0.

0.0.13

0.0.12

  • Error early when trying to nest hypothesis tests. (which will otherwise put CrossHair into a bad state)

0.0.11

  • Address errors when the solver can't keep up (fixes #20)

0.0.10

  • Reduce the numebr of iterations required to generate valid datetimes

0.0.9

  • Quietly ignore iterations that appear to be failing due to symbolic intolerance.

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

hypothesis_crosshair-0.0.17.tar.gz (9.4 kB view details)

Uploaded Source

Built Distribution

hypothesis_crosshair-0.0.17-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file hypothesis_crosshair-0.0.17.tar.gz.

File metadata

  • Download URL: hypothesis_crosshair-0.0.17.tar.gz
  • Upload date:
  • Size: 9.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.20

File hashes

Hashes for hypothesis_crosshair-0.0.17.tar.gz
Algorithm Hash digest
SHA256 5d2f4ad0498781305cf51f57b036470ba33d58fc73196ee182d02ecd3a9828e7
MD5 a63345d728fa23144b5dc44bd51e2390
BLAKE2b-256 d2203ec993cc86efb83c397dec2d74ac2ab6ddc1b25078696555cb165233429c

See more details on using hashes here.

File details

Details for the file hypothesis_crosshair-0.0.17-py3-none-any.whl.

File metadata

File hashes

Hashes for hypothesis_crosshair-0.0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 e1f156d25c583afacab21326d1e9ad4322ffc8157c3c5943392b08839f1de8a9
MD5 fdfa7210a5ad867d635b5f5cf9c33d65
BLAKE2b-256 fe02dcf77e531b1479fcf514ab28a4f5fce1e8cbe45ab2fdfbce223e0c1d51d2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page