Skip to main content

Adaptive fuzzing for property-based tests

Project description

HypoFuzz

Adaptive fuzzing of Hypothesis tests.

Property-based approaches help you to write better tests which find more bugs, but don't have great ways to exchange much more CPU time for more bugs. The goal of this project is to bring togther the best parts of fuzzing and PBT.

Motivation

You can run a traditional fuzzer like AFL on Hypothesis tests to get basic coverage guidance. This works OK, but there's a lot of performance overhead. Installing, configuring, and connecting all the parts is a pain, and because it assumes one fuzz target per core you probably can't scale up far enough to fuzz your whole test suite.

Alternatively, you can just run Hypothesis with a large max_examples setting. This also works pretty well, but doesn't get the benefits of coverage guidance and you have to guess how long it'll take to run the tests - each gets the same budget.

HypoFuzz solves all of these problems, and more!

Features

  • Interleave execution of many test functions
  • Prioritise functions where we expect to make progress
  • Coverage-guided exploration of your system-under-test
  • Seamless python-native and CLI integrations (replaces the pytest command)
  • Web-based time-travel debugging with PyTrace (automatic if you pip install hypofuzz[pytrace])

Read more about HypoFuzz at https://hypofuzz.com/docs/, including the changelog.

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

hypofuzz-24.9.1.tar.gz (39.1 kB view details)

Uploaded Source

Built Distribution

hypofuzz-24.9.1-py3-none-any.whl (38.1 kB view details)

Uploaded Python 3

File details

Details for the file hypofuzz-24.9.1.tar.gz.

File metadata

  • Download URL: hypofuzz-24.9.1.tar.gz
  • Upload date:
  • Size: 39.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.10

File hashes

Hashes for hypofuzz-24.9.1.tar.gz
Algorithm Hash digest
SHA256 cc767b60fc02da882b79ef5bbda34e66ff41673b7e6794dd1f235bfa015027fb
MD5 142f43c3e532c2c08ccd0b407f25b666
BLAKE2b-256 5f46ba844936e378ed233414d63b48dc4d732ead38a879ce9b7c534af5556058

See more details on using hashes here.

File details

Details for the file hypofuzz-24.9.1-py3-none-any.whl.

File metadata

  • Download URL: hypofuzz-24.9.1-py3-none-any.whl
  • Upload date:
  • Size: 38.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.10

File hashes

Hashes for hypofuzz-24.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 432240977a192f76deb3f9b77014b6ac7b02daafa521ac0386c8dd41c699ca33
MD5 1f1f68b5a575e6fb39b4ccb46d07ceb7
BLAKE2b-256 e5e28e87b864bad493d45476a1706b6afec7911099e1de1b16b7cc4207464125

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