# [HypoFuzz](https://hypofuzz.com/)
*Adaptive fuzzing of [Hypothesis](https://hypothesis.readthedocs.io) 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](https://hypothesis.readthedocs.io/en/latest/details.html#use-with-external-fuzzers)
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](https://pytrace.com/)
(automatic if you `pip install hypofuzz[pytrace]`)
Read more about HypoFuzz at https://hypofuzz.com/docs/, including
[the changelog](https://hypofuzz.com/docs/changelog.html).
Raw data
{
"_id": null,
"home_page": "https://hypofuzz.com/",
"name": "hypofuzz",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "python testing fuzzing property-based-testing",
"author": "Zac Hatfield-Dodds",
"author_email": "zac@hypofuzz.com",
"download_url": "https://files.pythonhosted.org/packages/c5/fd/3c4f246773126443836275a041b72b8748830b1d032db5f90ba0ff0d2a76/hypofuzz-25.1.3.tar.gz",
"platform": null,
"description": "# [HypoFuzz](https://hypofuzz.com/)\n\n*Adaptive fuzzing of [Hypothesis](https://hypothesis.readthedocs.io) tests.*\n\n\nProperty-based approaches help you to write better tests which find more bugs,\nbut don't have great ways to exchange much more CPU time for more bugs.\nThe goal of this project is to bring togther the best parts of fuzzing and PBT.\n\n\n## Motivation\n\nYou can [run a traditional fuzzer](https://hypothesis.readthedocs.io/en/latest/details.html#use-with-external-fuzzers)\nlike AFL on Hypothesis tests to get basic coverage guidance. This works OK, but there's\na lot of performance overhead. Installing, configuring, and connecting all the parts is\na pain, and because it assumes one fuzz target per core you probably can't scale up far\nenough to fuzz your whole test suite.\n\nAlternatively, you can just run Hypothesis with a large `max_examples` setting.\nThis also works pretty well, but doesn't get the benefits of coverage guidance and\nyou have to guess how long it'll take to run the tests - each gets the same budget.\n\nHypoFuzz solves all of these problems, and more!\n\n\n## Features\n\n- Interleave execution of many test functions\n- Prioritise functions where we expect to make progress\n- Coverage-guided exploration of your system-under-test\n- Seamless python-native and CLI integrations (replaces the `pytest` command)\n- Web-based time-travel debugging with [PyTrace](https://pytrace.com/)\n (automatic if you `pip install hypofuzz[pytrace]`)\n\nRead more about HypoFuzz at https://hypofuzz.com/docs/, including\n[the changelog](https://hypofuzz.com/docs/changelog.html).\n",
"bugtrack_url": null,
"license": "AGPL-3.0",
"summary": "Adaptive fuzzing for property-based tests",
"version": "25.1.3",
"project_urls": {
"Changelog": "https://hypofuzz.com/docs/changelog.html",
"Documentation": "https://hypofuzz.com/docs/",
"Homepage": "https://hypofuzz.com/"
},
"split_keywords": [
"python",
"testing",
"fuzzing",
"property-based-testing"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ba1c88363e7b7d876c78d77da0b8ccff75e0d595df6f951e7d5693fe315dccef",
"md5": "6811742a01f12b7bd938643e5ac24124",
"sha256": "d14c8a7d4b0ccdcffbf57263db2df652fdc2725053073a0d5dfccdf8fa906ed4"
},
"downloads": -1,
"filename": "hypofuzz-25.1.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "6811742a01f12b7bd938643e5ac24124",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 40257,
"upload_time": "2025-01-21T02:37:14",
"upload_time_iso_8601": "2025-01-21T02:37:14.720337Z",
"url": "https://files.pythonhosted.org/packages/ba/1c/88363e7b7d876c78d77da0b8ccff75e0d595df6f951e7d5693fe315dccef/hypofuzz-25.1.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c5fd3c4f246773126443836275a041b72b8748830b1d032db5f90ba0ff0d2a76",
"md5": "657da24fa286a9566b6e7e3f690b6be5",
"sha256": "cbcb42342b4a8e523c1b72706f58c047bdb6c874fa8668684c2314073ea20efd"
},
"downloads": -1,
"filename": "hypofuzz-25.1.3.tar.gz",
"has_sig": false,
"md5_digest": "657da24fa286a9566b6e7e3f690b6be5",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 42623,
"upload_time": "2025-01-21T02:37:15",
"upload_time_iso_8601": "2025-01-21T02:37:15.944748Z",
"url": "https://files.pythonhosted.org/packages/c5/fd/3c4f246773126443836275a041b72b8748830b1d032db5f90ba0ff0d2a76/hypofuzz-25.1.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-21 02:37:15",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "hypofuzz"
}