Skip to content

Commit

Permalink
Merge pull request ethereum#6431 from ethereum/external-tests-split
Browse files Browse the repository at this point in the history
Split up external tests
  • Loading branch information
chriseth authored Apr 2, 2019
2 parents 7b0f7eb + 20216f3 commit 7c880a2
Show file tree
Hide file tree
Showing 5 changed files with 364 additions and 218 deletions.
33 changes: 25 additions & 8 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ jobs:
command: |
test/solcjsTests.sh /tmp/workspace/soljson.js $(cat /tmp/workspace/version.txt)
test_emscripten_external:
test_emscripten_external_gnosis:
docker:
- image: circleci/node:10
environment:
Expand All @@ -96,14 +96,23 @@ jobs:
- attach_workspace:
at: /tmp/workspace
- run:
name: Install external tests deps
name: External GnosisSafe tests
command: |
node --version
npm --version
test/externalTests/gnosis.sh /tmp/workspace/soljson.js || test/externalTests/gnosis.sh /tmp/workspace/soljson.js
test_emscripten_external_zeppelin:
docker:
- image: circleci/node:10
environment:
TERM: xterm
steps:
- checkout
- attach_workspace:
at: /tmp/workspace
- run:
name: External tests
name: External Zeppelin tests
command: |
test/externalTests.sh /tmp/workspace/soljson.js || test/externalTests.sh /tmp/workspace/soljson.js
test/externalTests/zeppelin.sh /tmp/workspace/soljson.js || test/externalTests/zeppelin.sh /tmp/workspace/soljson.js
build_x86_linux:
docker:
Expand Down Expand Up @@ -393,7 +402,11 @@ workflows:
<<: *build_on_tags
requires:
- build_emscripten
- test_emscripten_external:
- test_emscripten_external_zeppelin:
<<: *build_on_tags
requires:
- build_emscripten
- test_emscripten_external_gnosis:
<<: *build_on_tags
requires:
- build_emscripten
Expand Down Expand Up @@ -431,7 +444,11 @@ workflows:
- develop
jobs:
- build_emscripten: *build_on_tags
- test_emscripten_external:
- test_emscripten_external_zeppelin:
<<: *build_on_tags
requires:
- build_emscripten
- test_emscripten_external_gnosis:
<<: *build_on_tags
requires:
- build_emscripten
215 changes: 5 additions & 210 deletions test/externalTests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -28,226 +28,21 @@

set -e

if [ "$CIRCLECI" ]
then
function printTask() { echo ""; echo "$(tput bold)$(tput setaf 2)$1$(tput setaf 7)"; }
function printError() { echo ""; echo "$(tput setaf 1)$1$(tput setaf 7)"; }
function printLog() { echo "$(tput setaf 3)$1$(tput setaf 7)"; }
else
function printTask() { echo ""; echo "$(tput bold)$(tput setaf 2)$1$(tput sgr0)"; }
function printError() { echo ""; echo "$(tput setaf 1)$1$(tput sgr0)"; }
function printLog() { echo "$(tput setaf 3)$1$(tput sgr0)"; }
fi

if [ ! -f "$1" ]
then
echo "Usage: $0 <path to soljson.js>"
exit 1
fi

SOLJSON="$1"
SOLCVERSION="UNDEFINED"

function setup_solcjs
{
printLog "Setting up solc-js..."
cd "$1"
git clone --depth 1 -b v0.5.0 https://github.com/ethereum/solc-js.git solc

cd solc
npm install
cp "$SOLJSON" soljson.js
SOLCVERSION=$(./solcjs --version)
cd ..
echo "Using solcjs version $SOLCVERSION"
}

function download_project
{
local repo="$1"
local branch="$2"
local dir="$3"

printLog "Cloning $branch of $repo..."
git clone --depth 1 "$repo" -b "$branch" "$dir/ext"
cd ext
echo "Current commit hash: `git rev-parse HEAD`"
}

function setup
{
local repo="$1"
local branch="$2"
local dir="$3"

setup_solcjs "$dir"
download_project "$repo" "$branch" "$dir"

replace_version_pragmas
}

function replace_version_pragmas
{
# Replace fixed-version pragmas in Gnosis (part of Consensys best practice)
printLog "Replacing fixed-version pragmas..."
find contracts test -name '*.sol' -type f -print0 | xargs -0 sed -i -e 's/pragma solidity [\^0-9\.]*/pragma solidity >=0.0/'
}

function force_abi_v2
{
# Add "pragma experimental ABIEncoderV2" to all files.
printLog "Forcibly enabling ABIEncodreV2..."
find contracts test -name '*.sol' -type f -print0 | \
while IFS= read -r -d '' file
do
# Only add the pragma if it is not already there.
if grep -q -v 'pragma experimental ABIEncoderV2' "$file"
then
sed -i -e '1 i pragma experimental ABIEncoderV2;' "$file"
fi
done
}

function replace_libsolc_call
{
# Change "compileStandard" to "compile" (needed for pre-5.x Truffle)
printLog "Replacing libsolc compile call in Truffle..."
sed -i s/solc.compileStandard/solc.compile/ "node_modules/truffle/build/cli.bundled.js"
}

function find_truffle_config
{
local config_file="truffle.js"
local alt_config_file="truffle-config.js"

if [ ! -f "$config_file" ] && [ ! -f "$alt_config_file" ]; then
printError "No matching Truffle config found."
fi
if [ ! -f "$config_file" ]; then
config_file=alt_config_file
fi
echo "$config_file"
}

function force_solc_truffle_modules
{
# Replace solc package by v0.5.0 and then overwrite with current version.
printLog "Forcing solc version for all Truffle modules..."
for d in node_modules node_modules/truffle/node_modules
do
(
if [ -d "$d" ]
then
cd $d
rm -rf solc
git clone --depth 1 -b v0.5.0 https://github.com/ethereum/solc-js.git solc
cp "$1" solc/soljson.js
fi
)
done
}

function force_solc
{
local config_file="$1"
local dir="$2"

printLog "Forcing solc version..."
cat >> "$config_file" <<EOF
module.exports['compilers'] = {solc: {version: "$dir/solc"} };
EOF
}

function force_solc_settings
{
local config_file="$1"
local settings="$2"
local evmVersion="$3"

printLog "Forcing solc settings..."
echo "-------------------------------------"
echo "Config file: $config_file"
echo "Optimizer settings: $settings"
echo "EVM version: $evmVersion"
echo "-------------------------------------"

# Forcing the settings should always work by just overwriting the solc object. Forcing them by using a
# dedicated settings objects should only be the fallback.
echo "module.exports['solc'] = { optimizer: $settings, evmVersion: \"$evmVersion\" };" >> "$config_file"
echo "module.exports['compilers']['solc']['settings'] = { optimizer: $settings, evmVersion: \"$evmVersion\" };" >> "$config_file"
}

function verify_compiler_version
{
local solc_version="$1"

printLog "Verify that the correct version ($solc_version) of the compiler was used to compile the contracts..."
grep -e "$solc_version" -r build/contracts > /dev/null
}

function clean
{
rm -rf build || true
}

# Since Zeppelin 2.1.1 it supports Solidity 0.5.0.
printTask "Testing Zeppelin..."
echo "==========================="
DIR=$(mktemp -d)
(
setup https://github.com/OpenZeppelin/openzeppelin-solidity.git master "$DIR"

npm install

CONFIG="truffle-config.js"

replace_libsolc_call
force_solc_truffle_modules "$SOLJSON"
force_solc "$CONFIG" "$DIR"

for optimize in "{ enabled: false }" "{ enabled: true }" "{ enabled: true, details: { yul: true } }"
do
clean
force_solc_settings "$CONFIG" "$optimize" "petersburg"
# Force ABIEncoderV2 in the last step. Has to be the last because code is modified.
[[ "$optimize" =~ yul ]] && force_abi_v2

npx truffle compile
verify_compiler_version "$SOLCVERSION"
npm run test
done
)
rm -rf "$DIR"
echo "Done."

printTask "Testing GnosisSafe..."
echo "==========================="
DIR=$(mktemp -d)
(
setup https://github.com/gnosis/safe-contracts.git development "$DIR"

npm install

CONFIG=$(find_truffle_config)
REPO_ROOT="$(dirname "$0")"

force_solc_truffle_modules "$SOLJSON"
force_solc "$CONFIG" "$DIR"
source test/externalTests/common.sh

for optimize in "{ enabled: false }" "{ enabled: true }" "{ enabled: true, details: { yul: true } }"
do
clean
force_solc_settings "$CONFIG" "$optimize" "petersburg"
# Force ABIEncoderV2 in the last step. Has to be the last because code is modified.
[[ "$optimize" =~ yul ]] && force_abi_v2
printTask "Running external tests..."

npx truffle compile
verify_compiler_version "$SOLCVERSION"
npm test
done
)
rm -rf "$DIR"
echo "Done."
echo "All external tests passed."
$REPO_ROOT/externalTests/zeppelin.sh "$SOLJSON"
$REPO_ROOT/externalTests/gnosis.sh "$SOLJSON"

# Disabled temporarily as it needs to be updated to latest Truffle first.
#test_truffle Gnosis https://github.com/axic/pm-contracts.git solidity-050
Loading

0 comments on commit 7c880a2

Please sign in to comment.