Skip to content

Commit

Permalink
Make simplification steps configurable
Browse files Browse the repository at this point in the history
Closes #54
  • Loading branch information
senier committed May 15, 2024
1 parent 9e8cc70 commit da29ef0
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added

- Crash result simplification (#30)
- Configurable simplification steps (#54)

### Changed

Expand Down
4 changes: 4 additions & 0 deletions cobrafuzz/fuzzer.py
Original file line number Diff line number Diff line change
Expand Up @@ -221,6 +221,7 @@ def __init__( # noqa: PLR0913
state_file: Optional[Path] = None,
load_crashes: bool = True,
simplify: Optional[Path] = None,
simp_steps: int = 10000,
):
"""
Fuzz-test target and store crash artifacts into crash_dir.
Expand Down Expand Up @@ -248,6 +249,7 @@ def __init__( # noqa: PLR0913
seeds: List of files and directories to seed the fuzzer with.
simplify: When set, run simplifier and store simplified crash results in
directory.
simp_steps: Number of unsuccessful steps before stopping simplification.
start_method: Multiprocessing start method to use (spawn, forkserver or fork).
Defaults to "spawn". Do not use "fork" as it is unreliable and may lead
to deadlocks.
Expand Down Expand Up @@ -293,6 +295,7 @@ def __init__( # noqa: PLR0913
file=state_file,
)
self._simplify = simplify
self._simp_steps = simp_steps

if load_crashes:
self._load_crashes(regression=regression)
Expand Down Expand Up @@ -485,6 +488,7 @@ def start(self) -> None: # noqa: PLR0912
crash_dir=self._crash_dir,
target=self._target,
output_dir=self._simplify,
steps=self._simp_steps,
).simplify()
sys.exit(1)

Expand Down
22 changes: 21 additions & 1 deletion cobrafuzz/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,15 @@ def __call__(self) -> None:
required=True,
help="Simplified output directory.",
)
parser_simp.add_argument(
"--steps",
type=int,
help=(
"Number of unsuccessful steps before stopping simplification "
"(default: %(default)d)."
),
default=10000,
)
parser_simp.set_defaults(func=self.simp)

parser_fuzz = subparsers.add_parser(
Expand All @@ -57,7 +66,7 @@ def __call__(self) -> None:
"--max-input-size",
type=int,
default=4096,
help="Max input size to be generated in bytes.",
help="Max input size to be generated in bytes (default: %(default)d).",
)
parser_fuzz.add_argument(
"--close-stdout",
Expand Down Expand Up @@ -101,6 +110,15 @@ def __call__(self) -> None:
type=Path,
help="Run simplifier and store results in directory.",
)
parser_fuzz.add_argument(
"--simp-steps",
type=int,
help=(
"Number of unsuccessful steps before stopping simplification "
"(default: %(default)d)."
),
default=10000,
)

parser_fuzz.add_argument(
"seeds",
Expand Down Expand Up @@ -134,6 +152,7 @@ def fuzz(self, args: argparse.Namespace) -> None:
start_method=args.start_method,
state_file=args.state_file,
simplify=args.simplify,
simp_steps=args.simp_steps,
)
logging.basicConfig(format="[%(asctime)s] %(message)s")
try:
Expand All @@ -146,4 +165,5 @@ def simp(self, args: argparse.Namespace) -> None:
crash_dir=args.crash_dir,
target=self.function,
output_dir=args.output_dir,
steps=args.steps,
).simplify()

0 comments on commit da29ef0

Please sign in to comment.