2016-08-01 05:25:37 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
# Bash script to execute the Solidity tests.
|
|
|
|
#
|
|
|
|
# The documentation for solidity is hosted at:
|
|
|
|
#
|
|
|
|
# https://solidity.readthedocs.org
|
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# This file is part of solidity.
|
|
|
|
#
|
|
|
|
# solidity is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# solidity is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with solidity. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
#
|
|
|
|
# (c) 2016 solidity contributors.
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
|
2016-08-01 13:33:01 +00:00
|
|
|
set -e
|
|
|
|
|
2019-04-26 09:57:49 +00:00
|
|
|
REPO_ROOT="$(dirname "$0")/.."
|
|
|
|
|
|
|
|
source "${REPO_ROOT}/scripts/common.sh"
|
2016-11-02 11:32:55 +00:00
|
|
|
|
2018-07-27 08:32:04 +00:00
|
|
|
WORKDIR=`mktemp -d`
|
2019-04-02 09:07:00 +00:00
|
|
|
# Will be printed in case of a test failure
|
|
|
|
ALETH_TMP_OUT=`mktemp`
|
2018-04-26 11:38:20 +00:00
|
|
|
IPC_ENABLED=true
|
2018-07-27 08:32:04 +00:00
|
|
|
ALETH_PID=
|
|
|
|
CMDLINE_PID=
|
|
|
|
|
2018-04-26 11:38:20 +00:00
|
|
|
if [[ "$OSTYPE" == "darwin"* ]]
|
|
|
|
then
|
|
|
|
SMT_FLAGS="--no-smt"
|
|
|
|
fi
|
|
|
|
|
2018-07-27 08:32:04 +00:00
|
|
|
cleanup() {
|
2019-04-03 08:59:22 +00:00
|
|
|
# ensure failing commands don't cause termination during cleanup (especially within safe_kill)
|
|
|
|
set +e
|
2018-07-27 08:32:04 +00:00
|
|
|
|
|
|
|
if [[ "$IPC_ENABLED" = true ]] && [[ -n "${ALETH_PID}" ]]
|
|
|
|
then
|
|
|
|
safe_kill $ALETH_PID $ALETH_PATH
|
|
|
|
fi
|
|
|
|
if [[ -n "$CMDLINE_PID" ]]
|
|
|
|
then
|
|
|
|
safe_kill $CMDLINE_PID "Commandline tests"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "Cleaning up working directory ${WORKDIR} ..."
|
|
|
|
rm -rf "$WORKDIR" || true
|
2019-04-02 09:07:00 +00:00
|
|
|
rm $ALETH_TMP_OUT
|
2018-07-27 08:32:04 +00:00
|
|
|
}
|
|
|
|
trap cleanup INT TERM
|
|
|
|
|
2018-02-13 10:54:22 +00:00
|
|
|
if [ "$1" = --junit_report ]
|
|
|
|
then
|
|
|
|
if [ -z "$2" ]
|
|
|
|
then
|
|
|
|
echo "Usage: $0 [--junit_report <report_directory>]"
|
|
|
|
exit 1
|
|
|
|
fi
|
2018-02-22 16:21:26 +00:00
|
|
|
log_directory="$2"
|
2018-02-13 10:54:22 +00:00
|
|
|
else
|
2018-02-22 16:21:26 +00:00
|
|
|
log_directory=""
|
2018-02-13 10:54:22 +00:00
|
|
|
fi
|
|
|
|
|
2018-04-17 06:53:21 +00:00
|
|
|
printTask "Running commandline tests..."
|
2018-02-26 19:41:18 +00:00
|
|
|
# Only run in parallel if this is run on CI infrastructure
|
2018-07-27 08:32:04 +00:00
|
|
|
if [[ -n "$CI" ]]
|
2018-02-26 19:41:18 +00:00
|
|
|
then
|
2018-07-27 08:32:04 +00:00
|
|
|
"$REPO_ROOT/test/cmdlineTests.sh" &
|
|
|
|
CMDLINE_PID=$!
|
|
|
|
else
|
|
|
|
if ! $REPO_ROOT/test/cmdlineTests.sh
|
2018-04-17 06:53:21 +00:00
|
|
|
then
|
|
|
|
printError "Commandline tests FAILED"
|
|
|
|
exit 1
|
|
|
|
fi
|
2018-02-26 19:41:18 +00:00
|
|
|
fi
|
2017-07-05 10:28:15 +00:00
|
|
|
|
2018-06-20 15:26:27 +00:00
|
|
|
function check_aleth() {
|
|
|
|
printTask "Running IPC tests with $ALETH_PATH..."
|
|
|
|
if ! hash $ALETH_PATH 2>/dev/null; then
|
|
|
|
printError "$ALETH_PATH not found"
|
2018-07-03 01:23:49 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2018-04-26 11:38:20 +00:00
|
|
|
if [ "$IPC_ENABLED" = true ];
|
|
|
|
then
|
2018-06-20 15:26:27 +00:00
|
|
|
download_aleth
|
|
|
|
check_aleth
|
2018-07-27 08:32:04 +00:00
|
|
|
ALETH_PID=$(run_aleth)
|
2018-04-26 11:38:20 +00:00
|
|
|
fi
|
2018-02-26 19:41:18 +00:00
|
|
|
|
2018-04-06 10:20:01 +00:00
|
|
|
EVM_VERSIONS="homestead byzantium"
|
|
|
|
|
2019-04-26 09:57:49 +00:00
|
|
|
if [ -z "$CI" ]
|
2018-04-06 10:20:01 +00:00
|
|
|
then
|
2019-04-26 09:57:49 +00:00
|
|
|
EVM_VERSIONS+=" constantinople petersburg"
|
2018-04-06 10:20:01 +00:00
|
|
|
fi
|
|
|
|
|
2018-02-22 16:21:26 +00:00
|
|
|
# And then run the Solidity unit-tests in the matrix combination of optimizer / no optimizer
|
|
|
|
# and homestead / byzantium VM, # pointing to that IPC endpoint.
|
|
|
|
for optimize in "" "--optimize"
|
|
|
|
do
|
2018-04-06 10:20:01 +00:00
|
|
|
for vm in $EVM_VERSIONS
|
2018-02-22 16:21:26 +00:00
|
|
|
do
|
2018-09-26 17:09:10 +00:00
|
|
|
FORCE_ABIV2_RUNS="no"
|
|
|
|
if [[ "$vm" == "constantinople" ]]
|
2018-02-22 16:21:26 +00:00
|
|
|
then
|
2018-09-26 17:09:10 +00:00
|
|
|
FORCE_ABIV2_RUNS="no yes" # run both in constantinople
|
2018-02-22 16:21:26 +00:00
|
|
|
fi
|
2018-09-26 17:09:10 +00:00
|
|
|
for abiv2 in $FORCE_ABIV2_RUNS
|
|
|
|
do
|
|
|
|
force_abiv2_flag=""
|
|
|
|
if [[ "$abiv2" == "yes" ]]
|
|
|
|
then
|
2019-04-02 15:36:03 +00:00
|
|
|
force_abiv2_flag="--abiencoderv2 --optimize-yul"
|
2018-09-26 17:09:10 +00:00
|
|
|
fi
|
|
|
|
printTask "--> Running tests using "$optimize" --evm-version "$vm" $force_abiv2_flag..."
|
|
|
|
|
|
|
|
log=""
|
|
|
|
if [ -n "$log_directory" ]
|
|
|
|
then
|
2019-04-26 09:57:49 +00:00
|
|
|
if [ -n "$optimize" ]
|
|
|
|
then
|
|
|
|
log=--logger=JUNIT,error,$log_directory/opt_$vm.xml $testargs
|
|
|
|
else
|
|
|
|
log=--logger=JUNIT,error,$log_directory/noopt_$vm.xml $testargs_no_opt
|
|
|
|
fi
|
2018-09-26 17:09:10 +00:00
|
|
|
fi
|
|
|
|
|
2019-04-02 09:07:00 +00:00
|
|
|
set +e
|
2019-04-26 09:57:49 +00:00
|
|
|
"$REPO_ROOT"/build/test/soltest --show-progress $log -- --testpath "$REPO_ROOT"/test "$optimize" --evm-version "$vm" $SMT_FLAGS $IPC_FLAGS $force_abiv2_flag --ipcpath "${WORKDIR}/geth.ipc"
|
2019-04-02 09:07:00 +00:00
|
|
|
|
|
|
|
if test "0" -ne "$?"; then
|
|
|
|
if [ -n "$log_directory" ]
|
|
|
|
then
|
|
|
|
# Need to kill aleth first so the log is written
|
|
|
|
safe_kill $ALETH_PID $ALETH_PATH
|
|
|
|
cp $ALETH_TMP_OUT $log_directory/aleth.log
|
|
|
|
printError "Some test failed, wrote aleth.log"
|
|
|
|
fi
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
set -e
|
|
|
|
|
2018-09-26 17:09:10 +00:00
|
|
|
done
|
2018-02-22 16:21:26 +00:00
|
|
|
done
|
|
|
|
done
|
2018-02-26 19:41:18 +00:00
|
|
|
|
2018-07-27 08:32:04 +00:00
|
|
|
if [[ -n $CMDLINE_PID ]] && ! wait $CMDLINE_PID
|
2018-04-17 06:53:21 +00:00
|
|
|
then
|
|
|
|
printError "Commandline tests FAILED"
|
2018-07-27 08:32:04 +00:00
|
|
|
CMDLINE_PID=
|
2018-04-17 06:53:21 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2018-02-26 19:41:18 +00:00
|
|
|
|
2018-07-27 08:32:04 +00:00
|
|
|
cleanup
|