Inkscope fuzzer can also be used entirely within a Docker container. If you don’t have it, Docker can be installed directly from Docker’s website.
You have to build the docker image locally. From the inkscope-fuzzer repository, execute:
docker build -t inkscope-fuzzer -f ./.docker/inkscope-fuzzer/Dockerfile .
After that, you are all set to use the fuzzer. To run it:
docker run -v ".:/contract" inkscope-fuzzer file.contract fuzz
Optionally, you can add an alias to make it easier to run the fuzzer.
alias inkscope-fuzzer-docker="docker run -v ".:/contract" inkscope-fuzzer"
inkscope-fuzzer-docker file.contract fuzz
You will need the Rust compiler and Cargo, the Rust package manager. The easiest way to install both is with rustup.rs.
You can install it directly from crates.io
cargo install inkscope-fuzzer
The inkscope-fuzzer executable will be ready to use in your system.
cargo inkscope-fuzzer
Or, by manually building from a local copy of the inkscope-fuzzer repository:
# Clone the repository
git clone https://github.com/inkscopexyz/inkscope-fuzzer.git
cd inkscope-fuzzer
# Build the project
cargo build --release
The inkscope-fuzzer executable will be ready to use in the following path:
./target/release/inkscope-fuzzer