2017-01-24 22:36:35 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
# Bash script to run commandline Solidity tests.
|
|
|
|
#
|
|
|
|
# The documentation for solidity is hosted at:
|
|
|
|
#
|
2020-11-18 14:20:34 +00:00
|
|
|
# https://docs.soliditylang.org
|
2017-01-24 22:36:35 +00:00
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# 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.
|
|
|
|
#------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2018-12-20 11:17:33 +00:00
|
|
|
## GLOBAL VARIABLES
|
|
|
|
|
2017-07-12 17:06:36 +00:00
|
|
|
REPO_ROOT=$(cd $(dirname "$0")/.. && pwd)
|
2020-04-17 13:02:40 +00:00
|
|
|
SOLIDITY_BUILD_DIR=${SOLIDITY_BUILD_DIR:-${REPO_ROOT}/build}
|
2019-04-26 09:57:49 +00:00
|
|
|
source "${REPO_ROOT}/scripts/common.sh"
|
2020-01-28 15:34:38 +00:00
|
|
|
source "${REPO_ROOT}/scripts/common_cmdline.sh"
|
2020-02-11 00:47:57 +00:00
|
|
|
|
2021-01-19 12:52:04 +00:00
|
|
|
(( $# <= 1 )) || { printError "Too many arguments"; exit 1; }
|
|
|
|
(( $# == 0 )) || [[ $1 == '--update' ]] || { printError "Invalid argument: '$1'"; exit 1; }
|
|
|
|
|
|
|
|
AUTOUPDATE=false
|
|
|
|
[[ $1 == --update ]] && AUTOUPDATE=true
|
|
|
|
|
2020-02-11 00:47:57 +00:00
|
|
|
case "$OSTYPE" in
|
|
|
|
msys)
|
2020-04-17 13:02:40 +00:00
|
|
|
SOLC="${SOLIDITY_BUILD_DIR}/solc/Release/solc.exe"
|
2020-02-11 00:47:57 +00:00
|
|
|
|
|
|
|
# prevents msys2 path translation for a remapping test
|
|
|
|
export MSYS2_ARG_CONV_EXCL="="
|
|
|
|
;;
|
|
|
|
*)
|
2020-04-17 13:02:40 +00:00
|
|
|
SOLC="${SOLIDITY_BUILD_DIR}/solc/solc"
|
2020-02-11 00:47:57 +00:00
|
|
|
;;
|
|
|
|
esac
|
2020-01-28 15:34:38 +00:00
|
|
|
echo "${SOLC}"
|
2020-02-11 00:47:57 +00:00
|
|
|
|
2019-04-15 21:51:31 +00:00
|
|
|
INTERACTIVE=true
|
|
|
|
if ! tty -s || [ "$CI" ]
|
|
|
|
then
|
|
|
|
INTERACTIVE=""
|
|
|
|
fi
|
2017-01-24 22:36:35 +00:00
|
|
|
|
2019-04-26 09:57:49 +00:00
|
|
|
# extend stack size in case we run via ASAN
|
|
|
|
if [[ -n "${CIRCLECI}" ]] || [[ -n "$CI" ]]; then
|
|
|
|
ulimit -s 16384
|
|
|
|
ulimit -a
|
2018-09-28 21:31:23 +00:00
|
|
|
fi
|
2017-10-05 18:46:38 +00:00
|
|
|
|
2019-04-26 09:57:49 +00:00
|
|
|
## FUNCTIONS
|
2017-10-05 18:46:38 +00:00
|
|
|
|
2021-01-19 12:52:04 +00:00
|
|
|
function update_expectation {
|
|
|
|
local newExpectation="${1}"
|
|
|
|
local expectationFile="${2}"
|
|
|
|
|
|
|
|
echo "$newExpectation" > "$expectationFile"
|
|
|
|
printLog "File $expectationFile updated to match the expectation."
|
|
|
|
}
|
|
|
|
|
|
|
|
function ask_expectation_update
|
2019-04-07 16:24:14 +00:00
|
|
|
{
|
2021-01-19 12:52:04 +00:00
|
|
|
if [[ $INTERACTIVE != "" ]]
|
2019-04-15 21:51:31 +00:00
|
|
|
then
|
|
|
|
local newExpectation="${1}"
|
|
|
|
local expectationFile="${2}"
|
2021-01-19 12:52:04 +00:00
|
|
|
|
|
|
|
if [[ $AUTOUPDATE == true ]]
|
|
|
|
then
|
|
|
|
update_expectation "$newExpectation" "$expectationFile"
|
|
|
|
else
|
2021-01-21 12:40:18 +00:00
|
|
|
local editor="${FCEDIT:-${VISUAL:-${EDITOR:-vi}}}"
|
|
|
|
|
2021-01-19 12:52:04 +00:00
|
|
|
while true
|
|
|
|
do
|
2021-01-21 12:40:18 +00:00
|
|
|
read -N 1 -p "(e)dit/(u)pdate expectations/(s)kip/(q)uit? "
|
2021-01-19 12:52:04 +00:00
|
|
|
echo
|
|
|
|
case $REPLY in
|
2021-01-21 12:40:18 +00:00
|
|
|
e*) "$editor" "$expectationFile"; break;;
|
2021-01-19 12:52:04 +00:00
|
|
|
u*) update_expectation "$newExpectation" "$expectationFile"; break;;
|
2021-01-21 12:40:18 +00:00
|
|
|
s*) return;;
|
2021-01-19 12:52:04 +00:00
|
|
|
q*) exit 1;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
fi
|
2019-06-12 17:03:45 +00:00
|
|
|
else
|
|
|
|
exit 1
|
2019-04-15 21:51:31 +00:00
|
|
|
fi
|
2019-04-07 16:24:14 +00:00
|
|
|
}
|
|
|
|
|
2018-08-06 16:52:49 +00:00
|
|
|
# General helper function for testing SOLC behaviour, based on file name, compile opts, exit code, stdout and stderr.
|
|
|
|
# An failure is expected.
|
2018-12-20 11:08:42 +00:00
|
|
|
function test_solc_behaviour()
|
|
|
|
{
|
2018-08-06 16:52:49 +00:00
|
|
|
local filename="${1}"
|
|
|
|
local solc_args="${2}"
|
2018-12-11 14:47:19 +00:00
|
|
|
local solc_stdin="${3}"
|
2019-04-16 13:17:33 +00:00
|
|
|
[ -z "$solc_stdin" ] && solc_stdin="/dev/stdin"
|
2018-12-11 14:47:19 +00:00
|
|
|
local stdout_expected="${4}"
|
|
|
|
local exit_code_expected="${5}"
|
2021-01-21 13:00:38 +00:00
|
|
|
local exit_code_expectation_file="${6}"
|
|
|
|
local stderr_expected="${7}"
|
|
|
|
local stdout_expectation_file="${8}" # the file to write to when user chooses to update stdout expectation
|
|
|
|
local stderr_expectation_file="${9}" # the file to write to when user chooses to update stderr expectation
|
2018-08-06 16:52:49 +00:00
|
|
|
local stdout_path=`mktemp`
|
|
|
|
local stderr_path=`mktemp`
|
2019-04-07 16:24:14 +00:00
|
|
|
|
|
|
|
trap "rm -f $stdout_path $stderr_path" EXIT
|
|
|
|
|
2018-12-06 11:31:27 +00:00
|
|
|
if [[ "$exit_code_expected" = "" ]]; then exit_code_expected="0"; fi
|
2018-08-06 16:52:49 +00:00
|
|
|
|
2019-04-16 13:17:33 +00:00
|
|
|
local solc_command="$SOLC ${filename} ${solc_args} <$solc_stdin"
|
2018-08-06 16:52:49 +00:00
|
|
|
set +e
|
2019-04-16 13:17:33 +00:00
|
|
|
"$SOLC" "${filename}" ${solc_args} <"$solc_stdin" >"$stdout_path" 2>"$stderr_path"
|
2018-08-06 16:52:49 +00:00
|
|
|
exitCode=$?
|
|
|
|
set -e
|
|
|
|
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ "$solc_args" == *"--standard-json"* ]]
|
|
|
|
then
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e 's/{[^{]*Warning: This is a pre-release compiler version[^}]*},\{0,1\}//' "$stdout_path"
|
2019-08-12 15:23:38 +00:00
|
|
|
sed -i.bak -E -e 's/ Consider adding \\"pragma solidity \^[0-9.]*;\\"//g' "$stdout_path"
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e 's/"errors":\[\],\{0,1\}//' "$stdout_path"
|
2020-11-05 16:57:46 +00:00
|
|
|
sed -i.bak -E -e 's/\"opcodes\":\"[^"]+\"/\"opcodes\":\"<OPCODES REMOVED>\"/g' "$stdout_path"
|
|
|
|
sed -i.bak -E -e 's/\"sourceMap\":\"[0-9:;-]+\"/\"sourceMap\":\"<SOURCEMAP REMOVED>\"/g' "$stdout_path"
|
2020-11-04 18:34:53 +00:00
|
|
|
|
|
|
|
# Remove bytecode (but not linker references).
|
|
|
|
sed -i.bak -E -e 's/(\"object\":\")[0-9a-f]+([^"]*\")/\1<BYTECODE REMOVED>\2/g' "$stdout_path"
|
|
|
|
sed -i.bak -E -e 's/(\"object\":\"[^"]+\$__)[0-9a-f]+(\")/\1<BYTECODE REMOVED>\2/g' "$stdout_path"
|
2020-11-13 22:37:29 +00:00
|
|
|
sed -i.bak -E -e 's/([0-9a-f]{34}\$__)[0-9a-f]+(__\$[0-9a-f]{17})/\1<BYTECODE REMOVED>\2/g' "$stdout_path"
|
2020-11-04 18:34:53 +00:00
|
|
|
|
2019-07-03 07:59:36 +00:00
|
|
|
# Replace escaped newlines by actual newlines for readability
|
|
|
|
sed -i.bak -E -e 's/\\n/\'$'\n/g' "$stdout_path"
|
2019-07-03 09:26:28 +00:00
|
|
|
rm "$stdout_path.bak"
|
2018-12-13 12:31:12 +00:00
|
|
|
else
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e '/^Warning: This is a pre-release compiler version, please do not use it in production./d' "$stderr_path"
|
2020-06-04 01:19:47 +00:00
|
|
|
sed -i.bak -e '/^Warning (3805): This is a pre-release compiler version, please do not use it in production./d' "$stderr_path"
|
2020-11-05 16:57:46 +00:00
|
|
|
sed -i.bak -e 's/\(^[ ]*auxdata: \)0x[0-9a-f]*$/\1<AUXDATA REMOVED>/' "$stdout_path"
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e 's/ Consider adding "pragma .*$//' "$stderr_path"
|
2020-11-12 10:54:37 +00:00
|
|
|
sed -i.bak -e 's/\(Unimplemented feature error.* in \).*$/\1<FILENAME REMOVED>/' "$stderr_path"
|
2020-11-05 16:57:46 +00:00
|
|
|
sed -i.bak -e 's/"version": "[^"]*"/"version": "<VERSION REMOVED>"/' "$stdout_path"
|
2020-11-04 18:34:53 +00:00
|
|
|
|
|
|
|
# Remove bytecode (but not linker references). Since non-JSON output is unstructured,
|
|
|
|
# use metadata markers for detection to have some confidence that it's actually bytecode
|
|
|
|
# and not some random word.
|
|
|
|
# 64697066735822 = hex encoding of 0x64 'i' 'p' 'f' 's' 0x58 0x22
|
|
|
|
# 64736f6c63 = hex encoding of 0x64 's' 'o' 'l' 'c'
|
|
|
|
sed -i.bak -E -e 's/[0-9a-f]*64697066735822[0-9a-f]+64736f6c63[0-9a-f]+/<BYTECODE REMOVED>/g' "$stdout_path"
|
2020-11-13 22:37:29 +00:00
|
|
|
sed -i.bak -E -e 's/([0-9a-f]{17}\$__)[0-9a-f]+(__\$[0-9a-f]{17})/\1<BYTECODE REMOVED>\2/g' "$stdout_path"
|
2020-11-04 18:34:53 +00:00
|
|
|
sed -i.bak -E -e 's/[0-9a-f]+((__\$[0-9a-f]{34}\$__)*<BYTECODE REMOVED>)/<BYTECODE REMOVED>\1/g' "$stdout_path"
|
|
|
|
|
2019-09-06 09:52:58 +00:00
|
|
|
# Remove trailing empty lines. Needs a line break to make OSX sed happy.
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e '1{/^$/d
|
2019-09-06 09:52:58 +00:00
|
|
|
}' "$stderr_path"
|
2020-04-24 08:30:19 +00:00
|
|
|
rm "$stderr_path.bak" "$stdout_path.bak"
|
2018-12-13 12:31:12 +00:00
|
|
|
fi
|
2019-03-11 16:30:46 +00:00
|
|
|
# Remove path to cpp file
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e 's/^\(Exception while assembling:\).*/\1/' "$stderr_path"
|
2019-03-21 16:17:42 +00:00
|
|
|
# Remove exception class name.
|
2019-09-06 12:19:49 +00:00
|
|
|
sed -i.bak -e 's/^\(Dynamic exception type:\).*/\1/' "$stderr_path"
|
|
|
|
rm "$stderr_path.bak"
|
2018-09-10 19:22:13 +00:00
|
|
|
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ $exitCode -ne "$exit_code_expected" ]]
|
|
|
|
then
|
2018-12-06 11:31:27 +00:00
|
|
|
printError "Incorrect exit code. Expected $exit_code_expected but got $exitCode."
|
2021-01-21 13:00:38 +00:00
|
|
|
|
|
|
|
[[ $exit_code_expectation_file != "" ]] && ask_expectation_update "$exit_code_expected" "$exit_code_expectation_file"
|
|
|
|
[[ $exit_code_expectation_file == "" ]] && exit 1
|
2018-08-06 16:52:49 +00:00
|
|
|
fi
|
|
|
|
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ "$(cat $stdout_path)" != "${stdout_expected}" ]]
|
|
|
|
then
|
2018-12-06 11:31:27 +00:00
|
|
|
printError "Incorrect output on stdout received. Expected:"
|
2019-04-15 21:51:31 +00:00
|
|
|
echo -e "${stdout_expected}"
|
2018-08-06 16:52:49 +00:00
|
|
|
|
|
|
|
printError "But got:"
|
2019-04-15 21:51:31 +00:00
|
|
|
echo -e "$(cat $stdout_path)"
|
2018-12-20 11:52:14 +00:00
|
|
|
|
2019-04-07 16:24:14 +00:00
|
|
|
printError "When running $solc_command"
|
|
|
|
|
2021-01-21 13:00:38 +00:00
|
|
|
[[ $stdout_expectation_file != "" ]] && ask_expectation_update "$(cat "$stdout_path")" "$stdout_expectation_file"
|
|
|
|
[[ $stdout_expectation_file == "" ]] && exit 1
|
2018-08-06 16:52:49 +00:00
|
|
|
fi
|
|
|
|
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ "$(cat $stderr_path)" != "${stderr_expected}" ]]
|
|
|
|
then
|
2018-08-06 16:52:49 +00:00
|
|
|
printError "Incorrect output on stderr received. Expected:"
|
2019-04-15 21:51:31 +00:00
|
|
|
echo -e "${stderr_expected}"
|
2018-08-06 16:52:49 +00:00
|
|
|
|
|
|
|
printError "But got:"
|
2019-04-15 21:51:31 +00:00
|
|
|
echo -e "$(cat $stderr_path)"
|
2018-12-20 11:52:14 +00:00
|
|
|
|
2019-04-07 16:24:14 +00:00
|
|
|
printError "When running $solc_command"
|
2018-08-06 16:52:49 +00:00
|
|
|
|
2021-01-21 13:00:38 +00:00
|
|
|
[[ $stderr_expectation_file != "" ]] && ask_expectation_update "$(cat "$stderr_path")" "$stderr_expectation_file"
|
|
|
|
[[ $stderr_expectation_file == "" ]] && exit 1
|
2019-04-07 16:24:14 +00:00
|
|
|
fi
|
2020-04-24 08:30:19 +00:00
|
|
|
|
|
|
|
rm -f "$stdout_path" "$stderr_path"
|
2018-08-06 16:52:49 +00:00
|
|
|
}
|
|
|
|
|
2018-12-20 11:17:33 +00:00
|
|
|
|
|
|
|
function test_solc_assembly_output()
|
|
|
|
{
|
|
|
|
local input="${1}"
|
|
|
|
local expected="${2}"
|
|
|
|
local solc_args="${3}"
|
|
|
|
|
|
|
|
local expected_object="object \"object\" { code "${expected}" }"
|
|
|
|
|
|
|
|
output=$(echo "${input}" | "$SOLC" - ${solc_args} 2>/dev/null)
|
2020-12-12 04:40:20 +00:00
|
|
|
empty=$(echo "$output" | tr '\n' ' ' | tr -s ' ' | sed -ne "/${expected_object}/p")
|
2018-12-20 11:17:33 +00:00
|
|
|
if [ -z "$empty" ]
|
|
|
|
then
|
|
|
|
printError "Incorrect assembly output. Expected: "
|
|
|
|
echo -e ${expected}
|
|
|
|
printError "with arguments ${solc_args}, but got:"
|
|
|
|
echo "${output}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
## RUN
|
|
|
|
|
|
|
|
echo "Checking that the bug list is up to date..."
|
|
|
|
"$REPO_ROOT"/scripts/update_bugs_by_version.py
|
|
|
|
|
|
|
|
printTask "Testing unknown options..."
|
|
|
|
(
|
|
|
|
set +e
|
|
|
|
output=$("$SOLC" --allow=test 2>&1)
|
|
|
|
failed=$?
|
|
|
|
set -e
|
|
|
|
|
|
|
|
if [ "$output" == "unrecognised option '--allow=test'" ] && [ $failed -ne 0 ]
|
|
|
|
then
|
|
|
|
echo "Passed"
|
|
|
|
else
|
2020-04-17 13:20:37 +00:00
|
|
|
printError "Incorrect response to unknown options: $output"
|
2018-12-20 11:17:33 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2018-08-06 16:52:49 +00:00
|
|
|
printTask "Testing passing files that are not found..."
|
2021-01-21 13:00:38 +00:00
|
|
|
test_solc_behaviour "file_not_found.sol" "" "" "" 1 "" "\"file_not_found.sol\" is not found." "" ""
|
2018-08-06 16:52:49 +00:00
|
|
|
|
|
|
|
printTask "Testing passing files that are not files..."
|
2021-01-21 13:00:38 +00:00
|
|
|
test_solc_behaviour "." "" "" "" 1 "" "\".\" is not a valid file." "" ""
|
2018-08-06 16:52:49 +00:00
|
|
|
|
2018-08-09 18:37:49 +00:00
|
|
|
printTask "Testing passing empty remappings..."
|
2021-01-21 13:00:38 +00:00
|
|
|
test_solc_behaviour "${0}" "=/some/remapping/target" "" "" 1 "" "Invalid remapping: \"=/some/remapping/target\"." "" ""
|
|
|
|
test_solc_behaviour "${0}" "ctx:=/some/remapping/target" "" "" 1 "" "Invalid remapping: \"ctx:=/some/remapping/target\"." "" ""
|
2018-12-11 14:47:19 +00:00
|
|
|
|
2018-12-06 11:31:27 +00:00
|
|
|
printTask "Running general commandline tests..."
|
2018-09-10 19:22:13 +00:00
|
|
|
(
|
2018-12-20 11:32:53 +00:00
|
|
|
cd "$REPO_ROOT"/test/cmdlineTests/
|
2018-12-20 11:28:42 +00:00
|
|
|
for tdir in */
|
2018-12-20 11:08:42 +00:00
|
|
|
do
|
2020-11-07 15:12:11 +00:00
|
|
|
printTask " - ${tdir}"
|
|
|
|
|
2020-11-10 14:59:14 +00:00
|
|
|
# Strip trailing slash from $tdir.
|
2020-11-07 15:15:04 +00:00
|
|
|
tdir=$(basename "${tdir}")
|
|
|
|
|
2020-11-10 14:59:14 +00:00
|
|
|
inputFiles="$(ls -1 ${tdir}/input.* 2> /dev/null || true)"
|
|
|
|
inputCount="$(echo ${inputFiles} | wc -w)"
|
2020-11-07 15:16:53 +00:00
|
|
|
if (( ${inputCount} > 1 ))
|
2018-12-20 11:32:53 +00:00
|
|
|
then
|
2020-11-07 15:16:53 +00:00
|
|
|
printError "Ambiguous input. Found input files in multiple formats:"
|
|
|
|
echo -e "${inputFiles}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Use printf to get rid of the trailing newline
|
|
|
|
inputFile=$(printf "%s" "${inputFiles}")
|
|
|
|
|
2020-11-10 15:55:11 +00:00
|
|
|
# If no files specified, assume input.sol as the default
|
|
|
|
if [ -z "${inputFile}" ]; then
|
|
|
|
inputFile="${tdir}/input.sol"
|
|
|
|
fi
|
|
|
|
|
2020-11-07 15:16:53 +00:00
|
|
|
if [ "${inputFile}" = "${tdir}/input.json" ]
|
|
|
|
then
|
|
|
|
stdin="${inputFile}"
|
2018-12-20 11:32:53 +00:00
|
|
|
inputFile=""
|
2019-04-07 16:24:14 +00:00
|
|
|
stdout="$(cat ${tdir}/output.json 2>/dev/null || true)"
|
2019-04-16 12:43:32 +00:00
|
|
|
stdoutExpectationFile="${tdir}/output.json"
|
2018-12-20 11:32:53 +00:00
|
|
|
args="--standard-json "$(cat ${tdir}/args 2>/dev/null || true)
|
|
|
|
else
|
|
|
|
stdin=""
|
2019-04-07 16:24:14 +00:00
|
|
|
stdout="$(cat ${tdir}/output 2>/dev/null || true)"
|
2019-04-16 12:43:32 +00:00
|
|
|
stdoutExpectationFile="${tdir}/output"
|
2018-12-20 11:32:53 +00:00
|
|
|
args=$(cat ${tdir}/args 2>/dev/null || true)
|
|
|
|
fi
|
2021-01-21 13:00:38 +00:00
|
|
|
exitCodeExpectationFile="${tdir}/exit"
|
|
|
|
exitCode=$(cat "$exitCodeExpectationFile" 2>/dev/null || true)
|
2019-04-07 16:24:14 +00:00
|
|
|
err="$(cat ${tdir}/err 2>/dev/null || true)"
|
|
|
|
stderrExpectationFile="${tdir}/err"
|
|
|
|
test_solc_behaviour "$inputFile" \
|
|
|
|
"$args" \
|
|
|
|
"$stdin" \
|
|
|
|
"$stdout" \
|
|
|
|
"$exitCode" \
|
2021-01-21 13:00:38 +00:00
|
|
|
"$exitCodeExpectationFile" \
|
2019-04-07 16:24:14 +00:00
|
|
|
"$err" \
|
|
|
|
"$stdoutExpectationFile" \
|
|
|
|
"$stderrExpectationFile"
|
2018-12-20 11:08:42 +00:00
|
|
|
done
|
2018-09-10 19:22:13 +00:00
|
|
|
)
|
|
|
|
|
2017-10-05 18:46:38 +00:00
|
|
|
printTask "Compiling various other contracts and libraries..."
|
2017-07-12 17:06:36 +00:00
|
|
|
(
|
2018-12-20 11:08:42 +00:00
|
|
|
cd "$REPO_ROOT"/test/compilationTests/
|
2018-12-20 11:12:53 +00:00
|
|
|
for dir in */
|
2018-12-20 11:08:42 +00:00
|
|
|
do
|
2018-12-20 11:12:53 +00:00
|
|
|
echo " - $dir"
|
|
|
|
cd "$dir"
|
|
|
|
compileFull -w *.sol */*.sol
|
|
|
|
cd ..
|
2018-12-20 11:08:42 +00:00
|
|
|
done
|
2017-07-12 17:06:36 +00:00
|
|
|
)
|
|
|
|
|
2017-10-05 18:46:38 +00:00
|
|
|
printTask "Compiling all examples from the documentation..."
|
2018-09-03 10:54:29 +00:00
|
|
|
SOLTMPDIR=$(mktemp -d)
|
2017-07-10 21:53:31 +00:00
|
|
|
(
|
|
|
|
set -e
|
2018-09-03 10:54:29 +00:00
|
|
|
cd "$SOLTMPDIR"
|
2017-07-10 21:53:31 +00:00
|
|
|
"$REPO_ROOT"/scripts/isolate_tests.py "$REPO_ROOT"/docs/ docs
|
2019-08-05 11:00:30 +00:00
|
|
|
|
2017-07-10 21:53:31 +00:00
|
|
|
for f in *.sol
|
|
|
|
do
|
2018-08-09 18:48:41 +00:00
|
|
|
# The contributors guide uses syntax tests, but we cannot
|
|
|
|
# really handle them here.
|
|
|
|
if grep -E 'DeclarationError:|// ----' "$f" >/dev/null
|
|
|
|
then
|
|
|
|
continue
|
|
|
|
fi
|
2017-07-12 17:06:36 +00:00
|
|
|
echo "$f"
|
2019-08-05 11:00:30 +00:00
|
|
|
|
2018-08-09 12:58:28 +00:00
|
|
|
opts=''
|
2018-08-09 18:48:41 +00:00
|
|
|
# We expect errors if explicitly stated, or if imports
|
|
|
|
# are used (in the style guide)
|
|
|
|
if grep -E "This will not compile|import \"" "$f" >/dev/null
|
2018-08-09 12:58:28 +00:00
|
|
|
then
|
|
|
|
opts="-e"
|
|
|
|
fi
|
|
|
|
if grep "This will report a warning" "$f" >/dev/null
|
|
|
|
then
|
|
|
|
opts="$opts -w"
|
|
|
|
fi
|
2020-03-10 12:21:25 +00:00
|
|
|
if grep "This may report a warning" "$f" >/dev/null
|
|
|
|
then
|
|
|
|
opts="$opts -o"
|
|
|
|
fi
|
2018-09-03 10:54:29 +00:00
|
|
|
compileFull $opts "$SOLTMPDIR/$f"
|
2017-07-10 21:53:31 +00:00
|
|
|
done
|
|
|
|
)
|
2018-09-03 10:54:29 +00:00
|
|
|
rm -rf "$SOLTMPDIR"
|
2017-07-10 21:53:31 +00:00
|
|
|
echo "Done."
|
|
|
|
|
2017-10-05 18:46:38 +00:00
|
|
|
printTask "Testing library checksum..."
|
2021-01-02 09:24:26 +00:00
|
|
|
echo '' | "$SOLC" - --link --libraries a=0x90f20564390eAe531E810af625A22f51385Cd222 >/dev/null
|
|
|
|
! echo '' | "$SOLC" - --link --libraries a=0x80f20564390eAe531E810af625A22f51385Cd222 &>/dev/null
|
2017-02-16 16:13:55 +00:00
|
|
|
|
2017-10-05 18:46:38 +00:00
|
|
|
printTask "Testing long library names..."
|
2021-01-02 09:24:26 +00:00
|
|
|
echo '' | "$SOLC" - --link --libraries aveeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeerylonglibraryname=0x90f20564390eAe531E810af625A22f51385Cd222 >/dev/null
|
2017-03-14 10:58:43 +00:00
|
|
|
|
2018-10-04 12:55:02 +00:00
|
|
|
printTask "Testing linking itself..."
|
|
|
|
SOLTMPDIR=$(mktemp -d)
|
|
|
|
(
|
|
|
|
cd "$SOLTMPDIR"
|
|
|
|
set -e
|
|
|
|
echo 'library L { function f() public pure {} } contract C { function f() public pure { L.f(); } }' > x.sol
|
|
|
|
"$SOLC" --bin -o . x.sol 2>/dev/null
|
|
|
|
# Explanation and placeholder should be there
|
|
|
|
grep -q '//' C.bin && grep -q '__' C.bin
|
|
|
|
# But not in library file.
|
|
|
|
grep -q -v '[/_]' L.bin
|
|
|
|
# Now link
|
2021-01-02 09:24:26 +00:00
|
|
|
"$SOLC" --link --libraries x.sol:L=0x90f20564390eAe531E810af625A22f51385Cd222 C.bin
|
2018-10-04 12:55:02 +00:00
|
|
|
# Now the placeholder and explanation should be gone.
|
|
|
|
grep -q -v '[/_]' C.bin
|
|
|
|
)
|
|
|
|
rm -rf "$SOLTMPDIR"
|
|
|
|
|
2018-04-24 13:18:12 +00:00
|
|
|
printTask "Testing overwriting files..."
|
2018-09-03 10:54:29 +00:00
|
|
|
SOLTMPDIR=$(mktemp -d)
|
2017-03-10 18:10:47 +00:00
|
|
|
(
|
|
|
|
set -e
|
|
|
|
# First time it works
|
2018-09-03 10:54:29 +00:00
|
|
|
echo 'contract C {} ' | "$SOLC" - --bin -o "$SOLTMPDIR/non-existing-stuff-to-create" 2>/dev/null
|
2017-03-10 18:10:47 +00:00
|
|
|
# Second time it fails
|
2018-09-03 10:54:29 +00:00
|
|
|
! echo 'contract C {} ' | "$SOLC" - --bin -o "$SOLTMPDIR/non-existing-stuff-to-create" 2>/dev/null
|
2017-03-10 18:10:47 +00:00
|
|
|
# Unless we force
|
2018-09-03 10:54:29 +00:00
|
|
|
echo 'contract C {} ' | "$SOLC" - --overwrite --bin -o "$SOLTMPDIR/non-existing-stuff-to-create" 2>/dev/null
|
2017-03-10 18:10:47 +00:00
|
|
|
)
|
2018-09-03 10:54:29 +00:00
|
|
|
rm -rf "$SOLTMPDIR"
|
2017-03-10 18:10:47 +00:00
|
|
|
|
2018-11-21 17:10:56 +00:00
|
|
|
printTask "Testing assemble, yul, strict-assembly and optimize..."
|
|
|
|
(
|
|
|
|
echo '{}' | "$SOLC" - --assemble &>/dev/null
|
|
|
|
echo '{}' | "$SOLC" - --yul &>/dev/null
|
|
|
|
echo '{}' | "$SOLC" - --strict-assembly &>/dev/null
|
|
|
|
|
|
|
|
# Test options above in conjunction with --optimize.
|
|
|
|
# Using both, --assemble and --optimize should fail.
|
|
|
|
! echo '{}' | "$SOLC" - --assemble --optimize &>/dev/null
|
2019-02-06 13:39:43 +00:00
|
|
|
! echo '{}' | "$SOLC" - --yul --optimize &>/dev/null
|
2018-11-29 14:56:51 +00:00
|
|
|
|
|
|
|
# Test yul and strict assembly output
|
|
|
|
# Non-empty code results in non-empty binary representation with optimizations turned off,
|
|
|
|
# while it results in empty binary representation with optimizations turned on.
|
2020-01-29 18:10:53 +00:00
|
|
|
test_solc_assembly_output "{ let x:u256 := 0:u256 }" "{ let x := 0 }" "--yul"
|
|
|
|
test_solc_assembly_output "{ let x:u256 := bitnot(7:u256) }" "{ let x := bitnot(7) }" "--yul"
|
|
|
|
test_solc_assembly_output "{ let t:bool := not(true) }" "{ let t:bool := not(true) }" "--yul"
|
2018-11-29 14:56:51 +00:00
|
|
|
test_solc_assembly_output "{ let x := 0 }" "{ let x := 0 }" "--strict-assembly"
|
2019-04-04 15:48:29 +00:00
|
|
|
test_solc_assembly_output "{ let x := 0 }" "{ { } }" "--strict-assembly --optimize"
|
2018-11-21 17:10:56 +00:00
|
|
|
)
|
|
|
|
|
2018-04-24 13:18:12 +00:00
|
|
|
|
|
|
|
printTask "Testing standard input..."
|
2018-09-03 10:54:29 +00:00
|
|
|
SOLTMPDIR=$(mktemp -d)
|
2018-04-24 13:18:12 +00:00
|
|
|
(
|
|
|
|
set +e
|
|
|
|
output=$("$SOLC" --bin 2>&1)
|
|
|
|
result=$?
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# This should fail
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ !("$output" =~ "No input files given") || ($result == 0) ]]
|
|
|
|
then
|
2020-04-17 13:20:37 +00:00
|
|
|
printError "Incorrect response to empty input arg list: $output"
|
2018-04-24 13:18:12 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
set +e
|
|
|
|
output=$(echo 'contract C {} ' | "$SOLC" - --bin 2>/dev/null | grep -q "<stdin>:C")
|
|
|
|
result=$?
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# The contract should be compiled
|
2018-12-20 11:08:42 +00:00
|
|
|
if [[ "$result" != 0 ]]
|
|
|
|
then
|
2020-12-12 04:49:06 +00:00
|
|
|
printError "Failed to compile a simple contract from standard input"
|
2018-04-24 13:18:12 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2018-10-15 15:54:48 +00:00
|
|
|
|
|
|
|
# This should not fail
|
|
|
|
set +e
|
2020-12-12 04:49:06 +00:00
|
|
|
output=$(echo '' | "$SOLC" --ast-json - 2>/dev/null)
|
|
|
|
result=$?
|
2018-10-15 15:54:48 +00:00
|
|
|
set -e
|
2020-12-12 04:49:06 +00:00
|
|
|
if [[ $result != 0 ]]
|
2018-12-20 11:08:42 +00:00
|
|
|
then
|
2020-12-12 04:49:06 +00:00
|
|
|
printError "Incorrect response to --ast-json option with empty stdin"
|
2018-10-15 15:54:48 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2018-04-24 13:18:12 +00:00
|
|
|
)
|
|
|
|
|
2019-09-11 19:16:35 +00:00
|
|
|
printTask "Testing AST import..."
|
|
|
|
SOLTMPDIR=$(mktemp -d)
|
|
|
|
(
|
|
|
|
cd "$SOLTMPDIR"
|
|
|
|
$REPO_ROOT/scripts/ASTImportTest.sh
|
|
|
|
if [ $? -ne 0 ]
|
|
|
|
then
|
|
|
|
rm -rf "$SOLTMPDIR"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
)
|
|
|
|
rm -rf "$SOLTMPDIR"
|
|
|
|
|
2020-07-08 20:08:50 +00:00
|
|
|
printTask "Testing AST export with stop-after=parsing..."
|
|
|
|
"$REPO_ROOT/test/stopAfterParseTests.sh"
|
|
|
|
|
2017-10-05 18:46:38 +00:00
|
|
|
printTask "Testing soljson via the fuzzer..."
|
2018-09-03 10:54:29 +00:00
|
|
|
SOLTMPDIR=$(mktemp -d)
|
2017-02-16 16:13:55 +00:00
|
|
|
(
|
2017-03-10 18:10:47 +00:00
|
|
|
set -e
|
2018-09-03 10:54:29 +00:00
|
|
|
cd "$SOLTMPDIR"
|
2017-03-22 19:19:20 +00:00
|
|
|
"$REPO_ROOT"/scripts/isolate_tests.py "$REPO_ROOT"/test/
|
2017-07-10 21:53:31 +00:00
|
|
|
"$REPO_ROOT"/scripts/isolate_tests.py "$REPO_ROOT"/docs/ docs
|
2017-08-30 23:24:25 +00:00
|
|
|
|
2020-04-17 13:02:40 +00:00
|
|
|
echo *.sol | xargs -P 4 -n 50 "${SOLIDITY_BUILD_DIR}/test/tools/solfuzzer" --quiet --input-files
|
|
|
|
echo *.sol | xargs -P 4 -n 50 "${SOLIDITY_BUILD_DIR}/test/tools/solfuzzer" --without-optimizer --quiet --input-files
|
2017-02-16 16:13:55 +00:00
|
|
|
)
|
2018-09-03 10:54:29 +00:00
|
|
|
rm -rf "$SOLTMPDIR"
|
2018-12-20 11:17:33 +00:00
|
|
|
|
2018-02-26 19:41:18 +00:00
|
|
|
echo "Commandline tests successful."
|