From d03bc47a6e89f35b7ab5614157068d435b1a4824 Mon Sep 17 00:00:00 2001 From: Lorenzo Manacorda Date: Wed, 29 Mar 2023 09:26:29 +0200 Subject: [PATCH] cvc4 -> cvc5 --- .github/scripts/install-cvc4.sh | 33 ----------------------------- .github/scripts/install-cvc5.sh | 33 +++++++++++++++++++++++++++++ .github/workflows/release.yml | 2 +- src/dapp-tests/integration/tests.sh | 8 +++---- src/dapp/CHANGELOG.md | 4 ++++ src/dapp/README.md | 4 ++-- src/dapp/libexec/dapp/dapp | 4 ++-- src/dapp/libexec/dapp/dapp-test | 2 +- 8 files changed, 47 insertions(+), 43 deletions(-) delete mode 100755 .github/scripts/install-cvc4.sh create mode 100755 .github/scripts/install-cvc5.sh diff --git a/.github/scripts/install-cvc4.sh b/.github/scripts/install-cvc4.sh deleted file mode 100755 index 150a727f1..000000000 --- a/.github/scripts/install-cvc4.sh +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/bash - - -set -eux - -mkdir -p $HOME/.local/bin; - -travis_retry() { - cmd=$* - $cmd || (sleep 2 && $cmd) || (sleep 10 && $cmd) -} - -fetch_cvc4_linux() { - VER="$1" - wget "https://github.com/CVC4/CVC4/releases/download/$VER/cvc4-$VER-x86_64-linux-opt" - chmod +x "cvc4-$VER-x86_64-linux-opt" - mv "cvc4-$VER-x86_64-linux-opt" "$HOME/.local/bin/cvc4" - echo "Downloaded cvc4 $VER" -} - -fetch_cvc4_macos() { - VER="$1" - wget "https://github.com/CVC4/CVC4/releases/download/$VER/cvc4-$VER-macos-opt" - chmod +x "cvc4-$VER-macos-opt" - mv "cvc4-$VER-macos-opt" "$HOME/.local/bin/cvc4" - echo "Downloaded cvc4 $VER" -} - -if [ "$HOST_OS" = "Linux" ]; then - travis_retry fetch_cvc4_linux "1.8" -else - travis_retry fetch_cvc4_macos "1.8" -fi diff --git a/.github/scripts/install-cvc5.sh b/.github/scripts/install-cvc5.sh new file mode 100755 index 000000000..16dca22e4 --- /dev/null +++ b/.github/scripts/install-cvc5.sh @@ -0,0 +1,33 @@ +#!/bin/bash + + +set -eux + +mkdir -p $HOME/.local/bin; + +travis_retry() { + cmd=$* + $cmd || (sleep 2 && $cmd) || (sleep 10 && $cmd) +} + +fetch_cvc5_linux() { + VER="$1" + wget "https://github.com/cvc5/cvc5/releases/download/$VER/cvc5-$VER-x86_64-linux-opt" + chmod +x "cvc5-$VER-x86_64-linux-opt" + mv "cvc5-$VER-x86_64-linux-opt" "$HOME/.local/bin/cvc5" + echo "Downloaded cvc5 $VER" +} + +fetch_cvc5_macos() { + VER="$1" + wget "https://github.com/cvc5/cvc5/releases/download/$VER/cvc5-$VER-macos-opt" + chmod +x "cvc5-$VER-macos-opt" + mv "cvc5-$VER-macos-opt" "$HOME/.local/bin/cvc5" + echo "Downloaded cvc5 $VER" +} + +if [ "$HOST_OS" = "Linux" ]; then + travis_retry fetch_cvc5_linux "1.8" +else + travis_retry fetch_cvc5_macos "1.8" +fi diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index b5a472749..b68ff6a7e 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -50,7 +50,7 @@ jobs: run: | .github/scripts/install-solc.sh .github/scripts/install-z3.sh - .github/scripts/install-cvc4.sh + .github/scripts/install-cvc5.sh env: HOST_OS: ${{ runner.os }} diff --git a/src/dapp-tests/integration/tests.sh b/src/dapp-tests/integration/tests.sh index 1b3ac5b26..ff961ef84 100755 --- a/src/dapp-tests/integration/tests.sh +++ b/src/dapp-tests/integration/tests.sh @@ -190,16 +190,16 @@ test_hevm_symbolic() { solc --bin-runtime -o . --overwrite "$CONTRACTS/factor.sol" # should find counterexample - hevm symbolic --code "$( /dev/null || fail solc --bin-runtime -o . --overwrite "$CONTRACTS/token.sol" - # This one explores all paths (cvc4 is better at this) - hevm symbolic --code "$( timeout passed to the smt solver in ms (default 60000) - --solver name of the smt solver to use (either "z3" or "cvc4") + --solver name of the smt solver to use (either "z3" or "cvc5") --max-iterations number of times we may revisit a particular branching point during symbolic execution dapp tests are written in Solidity using the `ds-test` module. To install it, run diff --git a/src/dapp/libexec/dapp/dapp b/src/dapp/libexec/dapp/dapp index c8021135b..2a332fe59 100755 --- a/src/dapp/libexec/dapp/dapp +++ b/src/dapp/libexec/dapp/dapp @@ -31,7 +31,7 @@ ### ### SMT options: ### smttimeout= timeout passed to the smt solver in ms (default 60000) -### solver= name of the smt solver to use (either 'z3' or 'cvc4') +### solver= name of the smt solver to use (either 'z3' or 'cvc5') ### max-iterations= number of times we may revisit a particular branching point ### smtdebug print the SMT queries produced by hevm ### @@ -80,7 +80,7 @@ rpc-block= block number (latest if not specified) SMT options: smttimeout= timeout passed to the smt solver in ms (default 60000) -solver= name of the smt solver to use (either 'z3' or 'cvc4') +solver= name of the smt solver to use (either 'z3' or 'cvc5') max-iterations= number of times we may revisit a particular branching point smtdebug print the SMT queries produced by hevm diff --git a/src/dapp/libexec/dapp/dapp-test b/src/dapp/libexec/dapp/dapp-test index f7ddebd54..210d8e89c 100755 --- a/src/dapp/libexec/dapp/dapp-test +++ b/src/dapp/libexec/dapp/dapp-test @@ -18,7 +18,7 @@ ### ### SMT options: ### --smttimeout timeout passed to the smt solver in ms (default 600000) -### --solver name of the smt solver to use (either "z3" or "cvc4") +### --solver name of the smt solver to use (either "z3" or "cvc5") ### --max-iterations number of times we may revisit a particular branching point set -e have() { command -v "$1" >/dev/null; }