Skip to content

crytic/medusa

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ef1f31d · Mar 28, 2025
Mar 3, 2025
Mar 26, 2025
Mar 28, 2025
Mar 26, 2025
Mar 27, 2025
Nov 15, 2022
Mar 27, 2025
Jul 17, 2024
Jul 25, 2024
Mar 26, 2025
Feb 2, 2025
Feb 2, 2025
Feb 3, 2025
Mar 24, 2025
Jul 25, 2024
Mar 26, 2025
Dec 1, 2022
Mar 26, 2025
Feb 2, 2025
Mar 28, 2025
Mar 28, 2025
Mar 26, 2025
Mar 27, 2024

Repository files navigation

medusa

medusa is a cross-platform go-ethereum-based smart contract fuzzer inspired by Echidna. It provides parallelized fuzz testing of smart contracts through CLI, or its Go API that allows custom user-extended testing methodology.

Disclaimer: The Go-level testing API is still under development and is subject to breaking changes.

Features

medusa provides support for:

  • ✔️Parallel fuzzing and testing methodologies across multiple workers (threads)
  • ✔️Assertion and property testing: built-in support for writing basic Solidity property tests and assertion tests
  • ✔️Mutational value generation: fed by compilation and runtime values.
  • ✔️Coverage collecting: Coverage increasing call sequences are stored in the corpus
  • ✔️Coverage guided fuzzing: Coverage increasing call sequences from the corpus are mutated to further guide the fuzzing campaign
  • ✔️Extensible low-level testing API through events and hooks provided throughout the fuzzer, workers, and test chains.
  • Extensible high-level testing API allowing for the addition of per-contract or global post call/event property tests with minimal effort.

Documentation

To learn more about how to install and use medusa, please refer to our documentation.

For a better viewing experience, we recommend you install mdbook and then running the following steps from medusa's source directory:

cd docs
mdbook serve

Install

Run the following command to install the latest version of medusa:

go install github.com/crytic/medusa@latest

For more information on building from source, using package managers, or obtaining binaries for Windows and Linux, please refer to the installation guide.

Contributing

For information about how to contribute to this project, check out the CONTRIBUTING guidelines.

License

medusa is licensed and distributed under the AGPLv3.