mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #10585 from ethereum/fix-quoting-and-whitespace-in-shell-scripts
Fix quoting in shell scripts
This commit is contained in:
commit
d393624384
@ -36,7 +36,7 @@ set -e
|
|||||||
|
|
||||||
OPTIMIZE=${OPTIMIZE:-"0"}
|
OPTIMIZE=${OPTIMIZE:-"0"}
|
||||||
EVM=${EVM:-"invalid"}
|
EVM=${EVM:-"invalid"}
|
||||||
REPODIR="$(realpath $(dirname $0)/..)"
|
REPODIR="$(realpath "$(dirname "$0")/..")"
|
||||||
|
|
||||||
source "${REPODIR}/scripts/common.sh"
|
source "${REPODIR}/scripts/common.sh"
|
||||||
# Test result output directory (CircleCI is reading test results from here)
|
# Test result output directory (CircleCI is reading test results from here)
|
||||||
@ -60,4 +60,4 @@ test "${ABI_ENCODER_V1}" = "1" && SOLTEST_ARGS="${SOLTEST_ARGS} --abiencoderv1"
|
|||||||
|
|
||||||
echo "Running ${REPODIR}/build/test/soltest ${BOOST_TEST_ARGS} -- ${SOLTEST_ARGS}"
|
echo "Running ${REPODIR}/build/test/soltest ${BOOST_TEST_ARGS} -- ${SOLTEST_ARGS}"
|
||||||
|
|
||||||
${REPODIR}/build/test/soltest ${BOOST_TEST_ARGS} -- ${SOLTEST_ARGS}
|
"${REPODIR}/build/test/soltest" ${BOOST_TEST_ARGS} -- ${SOLTEST_ARGS}
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
# ------------------------------------------------------------------------------
|
# ------------------------------------------------------------------------------
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
REPODIR="$(realpath $(dirname $0)/..)"
|
REPODIR="$(realpath "$(dirname "$0")"/..)"
|
||||||
|
|
||||||
EVM_VALUES=(homestead byzantium constantinople petersburg istanbul)
|
EVM_VALUES=(homestead byzantium constantinople petersburg istanbul)
|
||||||
OPTIMIZE_VALUES=(0 1)
|
OPTIMIZE_VALUES=(0 1)
|
||||||
@ -65,9 +65,9 @@ STEP=$(($STEP + 1))
|
|||||||
[[ " $RUN_STEPS " =~ " $STEP " ]] && EVM=istanbul OPTIMIZE=1 ABI_ENCODER_V1=1 BOOST_TEST_ARGS="-t !smtCheckerTests" "${REPODIR}/.circleci/soltest.sh"
|
[[ " $RUN_STEPS " =~ " $STEP " ]] && EVM=istanbul OPTIMIZE=1 ABI_ENCODER_V1=1 BOOST_TEST_ARGS="-t !smtCheckerTests" "${REPODIR}/.circleci/soltest.sh"
|
||||||
STEP=$(($STEP + 1))
|
STEP=$(($STEP + 1))
|
||||||
|
|
||||||
for OPTIMIZE in ${OPTIMIZE_VALUES[@]}
|
for OPTIMIZE in "${OPTIMIZE_VALUES[@]}"
|
||||||
do
|
do
|
||||||
for EVM in ${EVM_VALUES[@]}
|
for EVM in "${EVM_VALUES[@]}"
|
||||||
do
|
do
|
||||||
# run tests against hera ewasm evmc vm, only if OPTIMIZE == 0 and evm version is byzantium
|
# run tests against hera ewasm evmc vm, only if OPTIMIZE == 0 and evm version is byzantium
|
||||||
EWASM_ARGS=""
|
EWASM_ARGS=""
|
||||||
|
@ -16,7 +16,7 @@ SPLITSOURCES=${REPO_ROOT}/scripts/splitSources.py
|
|||||||
|
|
||||||
SYNTAXTESTS_DIR="${REPO_ROOT}/test/libsolidity/syntaxTests"
|
SYNTAXTESTS_DIR="${REPO_ROOT}/test/libsolidity/syntaxTests"
|
||||||
ASTJSONTESTS_DIR="${REPO_ROOT}/test/libsolidity/ASTJSON"
|
ASTJSONTESTS_DIR="${REPO_ROOT}/test/libsolidity/ASTJSON"
|
||||||
NSOURCES="$(find $SYNTAXTESTS_DIR -type f | wc -l)"
|
NSOURCES="$(find "$SYNTAXTESTS_DIR" -type f | wc -l)"
|
||||||
|
|
||||||
# DEV_DIR="${REPO_ROOT}/../tmp/contracts/"
|
# DEV_DIR="${REPO_ROOT}/../tmp/contracts/"
|
||||||
# NSOURCES="$(find $DEV_DIR -type f | wc -l)" #TODO use find command
|
# NSOURCES="$(find $DEV_DIR -type f | wc -l)" #TODO use find command
|
||||||
@ -25,7 +25,7 @@ FAILED=0
|
|||||||
UNCOMPILABLE=0
|
UNCOMPILABLE=0
|
||||||
TESTED=0
|
TESTED=0
|
||||||
|
|
||||||
if [ $(ls | wc -l) -ne 0 ]; then
|
if [ "$(ls | wc -l)" -ne 0 ]; then
|
||||||
echo "Test directory not empty. Skipping!"
|
echo "Test directory not empty. Skipping!"
|
||||||
exit -1
|
exit -1
|
||||||
fi
|
fi
|
||||||
@ -37,10 +37,10 @@ fi
|
|||||||
# $1 name of the file to be exported and imported
|
# $1 name of the file to be exported and imported
|
||||||
# $2 any files needed to do so that might be in parent directories
|
# $2 any files needed to do so that might be in parent directories
|
||||||
function testImportExportEquivalence {
|
function testImportExportEquivalence {
|
||||||
if $SOLC $1 $2 > /dev/null 2>&1
|
if $SOLC "$1" $2 > /dev/null 2>&1
|
||||||
then
|
then
|
||||||
# save exported json as expected result (silently)
|
# save exported json as expected result (silently)
|
||||||
$SOLC --combined-json ast,compact-format --pretty-json $1 $2> expected.json 2> /dev/null
|
$SOLC --combined-json ast,compact-format --pretty-json "$1" $2 > expected.json 2> /dev/null
|
||||||
# import it, and export it again as obtained result (silently)
|
# import it, and export it again as obtained result (silently)
|
||||||
$SOLC --import-ast --combined-json ast,compact-format --pretty-json expected.json > obtained.json 2> /dev/null
|
$SOLC --import-ast --combined-json ast,compact-format --pretty-json expected.json > obtained.json 2> /dev/null
|
||||||
if [ $? -ne 0 ]
|
if [ $? -ne 0 ]
|
||||||
@ -81,15 +81,15 @@ echo "Looking at $NSOURCES .sol files..."
|
|||||||
WORKINGDIR=$PWD
|
WORKINGDIR=$PWD
|
||||||
|
|
||||||
# for solfile in $(find $DEV_DIR -name *.sol)
|
# for solfile in $(find $DEV_DIR -name *.sol)
|
||||||
for solfile in $(find $SYNTAXTESTS_DIR $ASTJSONTESTS_DIR -name *.sol)
|
for solfile in $(find "$SYNTAXTESTS_DIR" "$ASTJSONTESTS_DIR" -name *.sol)
|
||||||
do
|
do
|
||||||
echo -n "."
|
echo -n "."
|
||||||
# create a temporary sub-directory
|
# create a temporary sub-directory
|
||||||
FILETMP=$(mktemp -d)
|
FILETMP=$(mktemp -d)
|
||||||
cd $FILETMP
|
cd "$FILETMP"
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
OUTPUT=$($SPLITSOURCES $solfile)
|
OUTPUT=$("$SPLITSOURCES" "$solfile")
|
||||||
SPLITSOURCES_RC=$?
|
SPLITSOURCES_RC=$?
|
||||||
set -e
|
set -e
|
||||||
if [ ${SPLITSOURCES_RC} == 0 ]
|
if [ ${SPLITSOURCES_RC} == 0 ]
|
||||||
@ -103,29 +103,29 @@ do
|
|||||||
done
|
done
|
||||||
elif [ ${SPLITSOURCES_RC} == 1 ]
|
elif [ ${SPLITSOURCES_RC} == 1 ]
|
||||||
then
|
then
|
||||||
testImportExportEquivalence $solfile
|
testImportExportEquivalence "$solfile"
|
||||||
elif [ ${SPLITSOURCES_RC} == 2 ]
|
elif [ ${SPLITSOURCES_RC} == 2 ]
|
||||||
then
|
then
|
||||||
# The script will exit with return code 2, if an UnicodeDecodeError occurred.
|
# The script will exit with return code 2, if an UnicodeDecodeError occurred.
|
||||||
# This is the case if e.g. some tests are using invalid utf-8 sequences. We will ignore
|
# This is the case if e.g. some tests are using invalid utf-8 sequences. We will ignore
|
||||||
# these errors, but print the actual output of the script.
|
# these errors, but print the actual output of the script.
|
||||||
echo -e "\n${OUTPUT}\n"
|
echo -e "\n${OUTPUT}\n"
|
||||||
testImportExportEquivalence $solfile
|
testImportExportEquivalence "$solfile"
|
||||||
else
|
else
|
||||||
# All other return codes will be treated as critical errors. The script will exit.
|
# All other return codes will be treated as critical errors. The script will exit.
|
||||||
echo -e "\nGot unexpected return code ${SPLITSOURCES_RC} from ${SPLITSOURCES}. Aborting."
|
echo -e "\nGot unexpected return code ${SPLITSOURCES_RC} from ${SPLITSOURCES}. Aborting."
|
||||||
echo -e "\n${OUTPUT}\n"
|
echo -e "\n${OUTPUT}\n"
|
||||||
|
|
||||||
cd $WORKINGDIR
|
cd "$WORKINGDIR"
|
||||||
# Delete temporary files
|
# Delete temporary files
|
||||||
rm -rf $FILETMP
|
rm -rf "$FILETMP"
|
||||||
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd $WORKINGDIR
|
cd "$WORKINGDIR"
|
||||||
# Delete temporary files
|
# Delete temporary files
|
||||||
rm -rf $FILETMP
|
rm -rf "$FILETMP"
|
||||||
done
|
done
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
|
@ -35,6 +35,6 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# solbuildpackpusher/solidity-buildpack-deps:emscripten-4
|
# solbuildpackpusher/solidity-buildpack-deps:emscripten-4
|
||||||
docker run -v $(pwd):/root/project -w /root/project \
|
docker run -v "$(pwd):/root/project" -w /root/project \
|
||||||
solbuildpackpusher/solidity-buildpack-deps@sha256:434719d8104cab47712dd1f56f255994d04eb65b802c0d382790071c1a0c074b \
|
solbuildpackpusher/solidity-buildpack-deps@sha256:434719d8104cab47712dd1f56f255994d04eb65b802c0d382790071c1a0c074b \
|
||||||
./scripts/ci/build_emscripten.sh $BUILD_DIR
|
./scripts/ci/build_emscripten.sh "$BUILD_DIR"
|
||||||
|
@ -46,7 +46,7 @@ TMPDIR=$(mktemp -d)
|
|||||||
git clone --depth 1 https://github.com/ethereum/solc-js.git solc-js
|
git clone --depth 1 https://github.com/ethereum/solc-js.git solc-js
|
||||||
( cd solc-js; npm install )
|
( cd solc-js; npm install )
|
||||||
cp "$REPO_ROOT/emscripten_build/libsolc/soljson.js" solc-js/
|
cp "$REPO_ROOT/emscripten_build/libsolc/soljson.js" solc-js/
|
||||||
cp ""$REPO_ROOT"/scripts/bytecodecompare/prepare_report.js" .
|
cp "$REPO_ROOT/scripts/bytecodecompare/prepare_report.js" .
|
||||||
echo "Running the compiler..."
|
echo "Running the compiler..."
|
||||||
./prepare_report.js *.sol > report.txt
|
./prepare_report.js *.sol > report.txt
|
||||||
echo "Finished running the compiler."
|
echo "Finished running the compiler."
|
||||||
|
@ -1,39 +1,21 @@
|
|||||||
./test/docsCodeStyle.sh
|
|
||||||
./test/cmdlineTests.sh
|
./test/cmdlineTests.sh
|
||||||
./scripts/isoltest.sh
|
|
||||||
./scripts/get_version.sh
|
|
||||||
./scripts/soltest.sh
|
./scripts/soltest.sh
|
||||||
./scripts/test_emscripten.sh
|
|
||||||
./scripts/wasm-rebuild/docker-scripts/rebuild_tags.sh
|
./scripts/wasm-rebuild/docker-scripts/rebuild_tags.sh
|
||||||
./scripts/wasm-rebuild/docker-scripts/rebuild_current.sh
|
./scripts/wasm-rebuild/docker-scripts/rebuild_current.sh
|
||||||
./scripts/wasm-rebuild/docker-scripts/genbytecode.sh
|
./scripts/wasm-rebuild/docker-scripts/genbytecode.sh
|
||||||
./scripts/wasm-rebuild/docker-scripts/patch.sh
|
|
||||||
./scripts/wasm-rebuild/rebuild.sh
|
|
||||||
./scripts/build_emscripten.sh
|
|
||||||
./scripts/ci/build_emscripten.sh
|
./scripts/ci/build_emscripten.sh
|
||||||
./scripts/docker_build.sh
|
|
||||||
./scripts/docs_version_pragma_check.sh
|
./scripts/docs_version_pragma_check.sh
|
||||||
./scripts/uniqueErrors.sh
|
./scripts/uniqueErrors.sh
|
||||||
./scripts/tests.sh
|
./scripts/tests.sh
|
||||||
./scripts/docker_deploy.sh
|
|
||||||
./scripts/bytecodecompare/storebytecode.sh
|
./scripts/bytecodecompare/storebytecode.sh
|
||||||
./scripts/deps-ppa/static_z3.sh
|
./scripts/deps-ppa/static_z3.sh
|
||||||
./scripts/ASTImportTest.sh
|
./scripts/ASTImportTest.sh
|
||||||
./scripts/install_static_z3.sh
|
./scripts/install_static_z3.sh
|
||||||
./scripts/install_obsolete_jsoncpp_1_7_4.sh
|
|
||||||
./scripts/install_deps.sh
|
./scripts/install_deps.sh
|
||||||
./scripts/build.sh
|
|
||||||
./scripts/run_proofs.sh
|
|
||||||
./scripts/common_cmdline.sh
|
./scripts/common_cmdline.sh
|
||||||
./scripts/docker_deploy_manual.sh
|
./scripts/docker_deploy_manual.sh
|
||||||
./scripts/endToEndExtraction/create_traces.sh
|
./scripts/endToEndExtraction/create_traces.sh
|
||||||
./scripts/release.sh
|
|
||||||
./scripts/download_ossfuzz_corpus.sh
|
|
||||||
./scripts/release_ppa.sh
|
./scripts/release_ppa.sh
|
||||||
./scripts/install_cmake.sh
|
|
||||||
./scripts/release_emscripten.sh
|
|
||||||
./scripts/create_source_tarball.sh
|
./scripts/create_source_tarball.sh
|
||||||
./scripts/docs.sh
|
|
||||||
./.circleci/soltest.sh
|
./.circleci/soltest.sh
|
||||||
./.circleci/osx_install_dependencies.sh
|
|
||||||
./.circleci/soltest_all.sh
|
./.circleci/soltest_all.sh
|
||||||
|
@ -59,8 +59,8 @@ then
|
|||||||
echo -n "$CIRCLE_SHA1" >commit_hash.txt
|
echo -n "$CIRCLE_SHA1" >commit_hash.txt
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p $BUILD_DIR
|
mkdir -p "$BUILD_DIR"
|
||||||
cd $BUILD_DIR
|
cd "$BUILD_DIR"
|
||||||
emcmake cmake \
|
emcmake cmake \
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
-DBoost_USE_STATIC_LIBS=1 \
|
-DBoost_USE_STATIC_LIBS=1 \
|
||||||
@ -75,8 +75,8 @@ sed -i -e 's/addFunction(func,sig){/addFunction(func,sig){sig=sig||"viiiii";/' l
|
|||||||
|
|
||||||
cd ..
|
cd ..
|
||||||
mkdir -p upload
|
mkdir -p upload
|
||||||
cp $BUILD_DIR/libsolc/soljson.js upload/
|
cp "$BUILD_DIR/libsolc/soljson.js" upload/
|
||||||
cp $BUILD_DIR/libsolc/soljson.js ./
|
cp "$BUILD_DIR/libsolc/soljson.js" ./
|
||||||
|
|
||||||
OUTPUT_SIZE=`ls -la soljson.js`
|
OUTPUT_SIZE=`ls -la soljson.js`
|
||||||
|
|
||||||
|
@ -39,8 +39,8 @@ function compileFull()
|
|||||||
fi
|
fi
|
||||||
local args=$FULLARGS
|
local args=$FULLARGS
|
||||||
if [[ $1 = '-v' ]]; then
|
if [[ $1 = '-v' ]]; then
|
||||||
if (echo $2 | grep -Po '(?<=0.4.)\d+' >/dev/null); then
|
if (echo "$2" | grep -Po '(?<=0.4.)\d+' >/dev/null); then
|
||||||
patch=$(echo $2 | grep -Po '(?<=0.4.)\d+')
|
patch=$(echo "$2" | grep -Po '(?<=0.4.)\d+')
|
||||||
if (( patch < 22 )); then
|
if (( patch < 22 )); then
|
||||||
args=$OLDARGS
|
args=$OLDARGS
|
||||||
fi
|
fi
|
||||||
|
@ -32,9 +32,9 @@ DISTRIBUTIONS="focal groovy"
|
|||||||
for distribution in $DISTRIBUTIONS
|
for distribution in $DISTRIBUTIONS
|
||||||
do
|
do
|
||||||
cd /tmp/
|
cd /tmp/
|
||||||
rm -rf $distribution
|
rm -rf "$distribution"
|
||||||
mkdir $distribution
|
mkdir "$distribution"
|
||||||
cd $distribution
|
cd "$distribution"
|
||||||
|
|
||||||
pparepo=cpp-build-deps
|
pparepo=cpp-build-deps
|
||||||
ppafilesurl=https://launchpad.net/~ethereum/+archive/ubuntu/${pparepo}/+files
|
ppafilesurl=https://launchpad.net/~ethereum/+archive/ubuntu/${pparepo}/+files
|
||||||
@ -190,7 +190,7 @@ echo "3.0 (quilt)" > debian/source/format
|
|||||||
chmod +x debian/rules
|
chmod +x debian/rules
|
||||||
|
|
||||||
versionsuffix=1ubuntu0~${distribution}
|
versionsuffix=1ubuntu0~${distribution}
|
||||||
EMAIL="$email" dch -v 1:${debversion}-${versionsuffix} "build of ${version}"
|
EMAIL="$email" dch -v "1:${debversion}-${versionsuffix}" "build of ${version}"
|
||||||
|
|
||||||
# build source package
|
# build source package
|
||||||
# If packages is rejected because original source is already present, add
|
# If packages is rejected because original source is already present, add
|
||||||
@ -199,13 +199,13 @@ EMAIL="$email" dch -v 1:${debversion}-${versionsuffix} "build of ${version}"
|
|||||||
debuild -S -d -sa -us -uc
|
debuild -S -d -sa -us -uc
|
||||||
|
|
||||||
# prepare .changes file for Launchpad
|
# prepare .changes file for Launchpad
|
||||||
sed -i -e s/UNRELEASED/${distribution}/ -e s/urgency=medium/urgency=low/ ../*.changes
|
sed -i -e "s/UNRELEASED/${distribution}/" -e s/urgency=medium/urgency=low/ ../*.changes
|
||||||
|
|
||||||
# check if ubuntu already has the source tarball
|
# check if ubuntu already has the source tarball
|
||||||
(
|
(
|
||||||
cd ..
|
cd ..
|
||||||
orig=${packagename}_${debversion}.orig.tar.gz
|
orig="${packagename}_${debversion}.orig.tar.gz"
|
||||||
orig_size=$(ls -l $orig | cut -d ' ' -f 5)
|
orig_size=$(ls -l "$orig" | cut -d ' ' -f 5)
|
||||||
orig_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
orig_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
||||||
orig_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
orig_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
||||||
orig_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
orig_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
||||||
@ -218,15 +218,15 @@ then
|
|||||||
new_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
new_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
||||||
new_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
new_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
||||||
new_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
new_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
||||||
sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.dsc
|
sed -i -e "s,$orig_sha1,$new_sha1,g" -e "s,$orig_sha256,$new_sha256,g" -e "s,$orig_size,$new_size,g" -e "s,$orig_md5,$new_md5,g" *.dsc
|
||||||
sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.changes
|
sed -i -e "s,$orig_sha1,$new_sha1,g" -e "s,$orig_sha256,$new_sha256,g" -e "s,$orig_size,$new_size,g" -e "s,$orig_md5,$new_md5,g" *.changes
|
||||||
fi
|
fi
|
||||||
)
|
)
|
||||||
|
|
||||||
# sign the package
|
# sign the package
|
||||||
debsign --re-sign -k ${keyid} ../${packagename}_${debversion}-${versionsuffix}_source.changes
|
debsign --re-sign -k "${keyid}" "../${packagename}_${debversion}-${versionsuffix}_source.changes"
|
||||||
|
|
||||||
# upload
|
# upload
|
||||||
dput ${pparepo} ../${packagename}_${debversion}-${versionsuffix}_source.changes
|
dput "${pparepo}" "../${packagename}_${debversion}-${versionsuffix}_source.changes"
|
||||||
|
|
||||||
done
|
done
|
||||||
|
@ -20,7 +20,7 @@ git clone --depth 2 https://github.com/ethereum/solidity.git -b "$branch"
|
|||||||
cd solidity
|
cd solidity
|
||||||
commithash=$(git rev-parse --short=8 HEAD)
|
commithash=$(git rev-parse --short=8 HEAD)
|
||||||
echo -n "$commithash" > commit_hash.txt
|
echo -n "$commithash" > commit_hash.txt
|
||||||
version=$($(dirname "$0")/get_version.sh)
|
version=$("$(dirname "$0")/get_version.sh")
|
||||||
if [ "$branch" = "release" -o "$branch" = v"$version" ]
|
if [ "$branch" = "release" -o "$branch" = v"$version" ]
|
||||||
then
|
then
|
||||||
echo -n > prerelease.txt
|
echo -n > prerelease.txt
|
||||||
@ -40,7 +40,7 @@ tmp_container=$(docker create "$image":build sh)
|
|||||||
|
|
||||||
# Alpine image
|
# Alpine image
|
||||||
mkdir -p upload
|
mkdir -p upload
|
||||||
docker cp ${tmp_container}:/usr/bin/solc upload/solc-static-linux
|
docker cp "${tmp_container}":/usr/bin/solc upload/solc-static-linux
|
||||||
docker build -t "$image":build-alpine -f scripts/Dockerfile_alpine .
|
docker build -t "$image":build-alpine -f scripts/Dockerfile_alpine .
|
||||||
|
|
||||||
if [ "$branch" = "develop" ]
|
if [ "$branch" = "develop" ]
|
||||||
|
@ -27,7 +27,7 @@ set -e
|
|||||||
|
|
||||||
## GLOBAL VARIABLES
|
## GLOBAL VARIABLES
|
||||||
|
|
||||||
REPO_ROOT=$(cd $(dirname "$0")/.. && pwd)
|
REPO_ROOT=$(cd "$(dirname "$0")/.." && pwd)
|
||||||
SOLIDITY_BUILD_DIR=${SOLIDITY_BUILD_DIR:-${REPO_ROOT}/build}
|
SOLIDITY_BUILD_DIR=${SOLIDITY_BUILD_DIR:-${REPO_ROOT}/build}
|
||||||
source "${REPO_ROOT}/scripts/common.sh"
|
source "${REPO_ROOT}/scripts/common.sh"
|
||||||
source "${REPO_ROOT}/scripts/common_cmdline.sh"
|
source "${REPO_ROOT}/scripts/common_cmdline.sh"
|
||||||
@ -41,13 +41,13 @@ function versionGreater()
|
|||||||
ver1=( ${v1//./ } )
|
ver1=( ${v1//./ } )
|
||||||
ver2=( ${v2//./ } )
|
ver2=( ${v2//./ } )
|
||||||
|
|
||||||
if (( ${ver1[0]} > ${ver2[0]} ))
|
if (( "${ver1[0]}" > "${ver2[0]}" ))
|
||||||
then
|
then
|
||||||
return 0
|
return 0
|
||||||
elif (( ${ver1[0]} == ${ver2[0]} )) && (( ${ver1[1]} > ${ver2[1]} ))
|
elif (( "${ver1[0]}" == "${ver2[0]}" )) && (( "${ver1[1]}" > "${ver2[1]}" ))
|
||||||
then
|
then
|
||||||
return 0
|
return 0
|
||||||
elif (( ${ver1[0]} == ${ver2[0]} )) && (( ${ver1[1]} == ${ver2[1]} )) && (( ${ver1[2]} > ${ver2[2]} ))
|
elif (( "${ver1[0]}" == "${ver2[0]}" )) && (( "${ver1[1]}" == "${ver2[1]}" )) && (( "${ver1[2]}" > "${ver2[2]}" ))
|
||||||
then
|
then
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
@ -75,7 +75,7 @@ function getAllAvailableVersions()
|
|||||||
do
|
do
|
||||||
if versionGreater "$listed" "0.4.10"
|
if versionGreater "$listed" "0.4.10"
|
||||||
then
|
then
|
||||||
allVersions+=( $listed )
|
allVersions+=( "$listed" )
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
@ -157,7 +157,7 @@ SOLTMPDIR=$(mktemp -d)
|
|||||||
# ignore warnings in this case
|
# ignore warnings in this case
|
||||||
opts="$opts -o"
|
opts="$opts -o"
|
||||||
|
|
||||||
findMinimalVersion $f
|
findMinimalVersion "$f"
|
||||||
if [[ "$version" == "" ]]
|
if [[ "$version" == "" ]]
|
||||||
then
|
then
|
||||||
continue
|
continue
|
||||||
@ -175,9 +175,9 @@ SOLTMPDIR=$(mktemp -d)
|
|||||||
if [[ ! -f "$solc_bin" ]]
|
if [[ ! -f "$solc_bin" ]]
|
||||||
then
|
then
|
||||||
echo "Downloading release from github..."
|
echo "Downloading release from github..."
|
||||||
if wget -q https://github.com/ethereum/solidity/releases/download/v$version/solc-static-linux >/dev/null
|
if wget -q "https://github.com/ethereum/solidity/releases/download/v$version/solc-static-linux" >/dev/null
|
||||||
then
|
then
|
||||||
mv solc-static-linux $solc_bin
|
mv solc-static-linux "$solc_bin"
|
||||||
else
|
else
|
||||||
printError "No release $version was found on github!"
|
printError "No release $version was found on github!"
|
||||||
continue
|
continue
|
||||||
|
@ -6,10 +6,10 @@ cmake ../../../
|
|||||||
make soltest
|
make soltest
|
||||||
cd test/ || exit
|
cd test/ || exit
|
||||||
echo "running soltest on 'semanticTests/extracted'..."
|
echo "running soltest on 'semanticTests/extracted'..."
|
||||||
./soltest --color_output=false --log_level=test_suite -t semanticTests/extracted/ -- --testpath ${BASE_PATH}/../../test --no-smt --evmonepath /Users/alex/evmone/lib/libevmone.dylib --show-messages --show-metadata > ${BASE_PATH}/extracted-tests.trace
|
./soltest --color_output=false --log_level=test_suite -t semanticTests/extracted/ -- --testpath "${BASE_PATH}/../../test" --no-smt --evmonepath /Users/alex/evmone/lib/libevmone.dylib --show-messages --show-metadata > "${BASE_PATH}/extracted-tests.trace"
|
||||||
echo "running soltest on 'semanticTests/extracted'... done"
|
echo "running soltest on 'semanticTests/extracted'... done"
|
||||||
|
|
||||||
cd $BASE_PATH || exit
|
cd "$BASE_PATH" || exit
|
||||||
git clone git@github.com:ethereum/solidity.git solidity-develop
|
git clone git@github.com:ethereum/solidity.git solidity-develop
|
||||||
cd solidity-develop || exit
|
cd solidity-develop || exit
|
||||||
mkdir -p build
|
mkdir -p build
|
||||||
@ -18,5 +18,5 @@ cmake ..
|
|||||||
make soltest
|
make soltest
|
||||||
cd test/ || exit
|
cd test/ || exit
|
||||||
echo "running soltest on 'SolidityEndToEndTest'..."
|
echo "running soltest on 'SolidityEndToEndTest'..."
|
||||||
./soltest --color_output=false --log_level=test_suite -t SolidityEndToEndTest/ -- --testpath ${BASE_PATH}/solidity-develop/test --no-smt --evmonepath /Users/alex/evmone/lib/libevmone.dylib --show-messages --show-metadata > ${BASE_PATH}/endToEndExtraction-tests.trace
|
./soltest --color_output=false --log_level=test_suite -t SolidityEndToEndTest/ -- --testpath "${BASE_PATH}/solidity-develop/test" --no-smt --evmonepath /Users/alex/evmone/lib/libevmone.dylib --show-messages --show-metadata > "${BASE_PATH}/endToEndExtraction-tests.trace"
|
||||||
echo "running soltest on 'SolidityEndToEndTest'... done"
|
echo "running soltest on 'SolidityEndToEndTest'... done"
|
||||||
|
@ -28,4 +28,4 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
grep -oP "PROJECT_VERSION \"?\K[0-9.]+(?=\")?" $(dirname "$0")/../CMakeLists.txt
|
grep -oP "PROJECT_VERSION \"?\K[0-9.]+(?=\")?" "$(dirname "$0")/../CMakeLists.txt"
|
||||||
|
@ -27,7 +27,7 @@ if test -f $BIN/cmake && ($BIN/cmake --version | grep -q "$VERSION"); then
|
|||||||
else
|
else
|
||||||
FILE=cmake-$VERSION-$OS-x86_64.tar.gz
|
FILE=cmake-$VERSION-$OS-x86_64.tar.gz
|
||||||
URL=https://cmake.org/files/v$VERSION_MAJOR.$VERSION_MINOR/$FILE
|
URL=https://cmake.org/files/v$VERSION_MAJOR.$VERSION_MINOR/$FILE
|
||||||
TMPFILE=$(mktemp --tmpdir cmake-$VERSION-$OS-x86_64.XXXXXXXX.tar.gz)
|
TMPFILE=$(mktemp --tmpdir "cmake-$VERSION-$OS-x86_64.XXXXXXXX.tar.gz")
|
||||||
echo "Downloading CMake ($URL)..."
|
echo "Downloading CMake ($URL)..."
|
||||||
wget "$URL" -O "$TMPFILE" -nv
|
wget "$URL" -O "$TMPFILE" -nv
|
||||||
if ! (shasum -a256 "$TMPFILE" | grep -q "$SHA256"); then
|
if ! (shasum -a256 "$TMPFILE" | grep -q "$SHA256"); then
|
||||||
@ -36,5 +36,5 @@ else
|
|||||||
fi
|
fi
|
||||||
mkdir -p "$PREFIX"
|
mkdir -p "$PREFIX"
|
||||||
tar xzf "$TMPFILE" -C "$PREFIX" --strip 1
|
tar xzf "$TMPFILE" -C "$PREFIX" --strip 1
|
||||||
rm $TMPFILE
|
rm "$TMPFILE"
|
||||||
fi
|
fi
|
||||||
|
@ -51,7 +51,7 @@ uname -v > /dev/null 2>&1 || { echo >&2 "ERROR - solidity requires 'uname' to id
|
|||||||
|
|
||||||
# See http://unix.stackexchange.com/questions/92199/how-can-i-reliably-get-the-operating-systems-name
|
# See http://unix.stackexchange.com/questions/92199/how-can-i-reliably-get-the-operating-systems-name
|
||||||
detect_linux_distro() {
|
detect_linux_distro() {
|
||||||
if [ $(command -v lsb_release) ]; then
|
if [ "$(command -v lsb_release)" ]; then
|
||||||
DISTRO=$(lsb_release -is)
|
DISTRO=$(lsb_release -is)
|
||||||
elif [ -f /etc/os-release ]; then
|
elif [ -f /etc/os-release ]; then
|
||||||
# extract 'foo' from NAME=foo, only on the line with NAME=foo
|
# extract 'foo' from NAME=foo, only on the line with NAME=foo
|
||||||
@ -61,7 +61,7 @@ detect_linux_distro() {
|
|||||||
else
|
else
|
||||||
DISTRO=''
|
DISTRO=''
|
||||||
fi
|
fi
|
||||||
echo $DISTRO
|
echo "$DISTRO"
|
||||||
}
|
}
|
||||||
|
|
||||||
case $(uname -s) in
|
case $(uname -s) in
|
||||||
@ -321,7 +321,7 @@ case $(uname -s) in
|
|||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
#other Ubuntu
|
#other Ubuntu
|
||||||
echo "ERROR - Unknown or unsupported Ubuntu version (" $(lsb_release -cs) ")"
|
echo "ERROR - Unknown or unsupported Ubuntu version ($(lsb_release -cs))"
|
||||||
echo "ERROR - This might not work, but we are trying anyway."
|
echo "ERROR - This might not work, but we are trying anyway."
|
||||||
echo "Please drop us a message at https://gitter.im/ethereum/solidity-dev."
|
echo "Please drop us a message at https://gitter.im/ethereum/solidity-dev."
|
||||||
echo "We only support Trusty, Utopic, Vivid, Wily, Xenial, Yakkety, Zesty, Artful and Bionic."
|
echo "We only support Trusty, Utopic, Vivid, Wily, Xenial, Yakkety, Zesty, Artful and Bionic."
|
||||||
|
@ -3,7 +3,7 @@ set -e
|
|||||||
|
|
||||||
TEMPDIR=$(mktemp -d)
|
TEMPDIR=$(mktemp -d)
|
||||||
(
|
(
|
||||||
cd $TEMPDIR
|
cd "$TEMPDIR"
|
||||||
wget https://github.com/open-source-parsers/jsoncpp/archive/1.7.4.tar.gz
|
wget https://github.com/open-source-parsers/jsoncpp/archive/1.7.4.tar.gz
|
||||||
tar xvzf "1.7.4.tar.gz"
|
tar xvzf "1.7.4.tar.gz"
|
||||||
cd "jsoncpp-1.7.4"
|
cd "jsoncpp-1.7.4"
|
||||||
@ -13,4 +13,4 @@ TEMPDIR=$(mktemp -d)
|
|||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
)
|
)
|
||||||
rm -rf $TEMPDIR
|
rm -rf "$TEMPDIR"
|
||||||
|
@ -3,4 +3,4 @@
|
|||||||
set -e
|
set -e
|
||||||
|
|
||||||
REPO_ROOT="$(dirname "$0")"/..
|
REPO_ROOT="$(dirname "$0")"/..
|
||||||
exec ${REPO_ROOT}/build/test/tools/isoltest --testpath ${REPO_ROOT}/test
|
exec "${REPO_ROOT}/build/test/tools/isoltest" --testpath "${REPO_ROOT}/test"
|
||||||
|
@ -29,17 +29,17 @@
|
|||||||
# (c) 2016 solidity contributors.
|
# (c) 2016 solidity contributors.
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
|
|
||||||
ZIP_SUFFIX=$1
|
ZIP_SUFFIX="$1"
|
||||||
ZIP_TEMP_DIR=$(pwd)/build/zip/
|
ZIP_TEMP_DIR="$(pwd)/build/zip/"
|
||||||
|
|
||||||
# There is an implicit assumption here that we HAVE to run from root directory.
|
# There is an implicit assumption here that we HAVE to run from root directory.
|
||||||
REPO_ROOT=$(pwd)
|
REPO_ROOT=$(pwd)
|
||||||
|
|
||||||
mkdir -p $ZIP_TEMP_DIR
|
mkdir -p "$ZIP_TEMP_DIR"
|
||||||
|
|
||||||
# Copy all the solidity executables into a temporary directory prior to ZIP creation
|
# Copy all the solidity executables into a temporary directory prior to ZIP creation
|
||||||
|
|
||||||
cp $REPO_ROOT/build/solc/solc $ZIP_TEMP_DIR
|
cp "$REPO_ROOT/build/solc/solc" "$ZIP_TEMP_DIR"
|
||||||
|
|
||||||
# For macOS, we run a fix-up script which alters all of the symbolic links within
|
# For macOS, we run a fix-up script which alters all of the symbolic links within
|
||||||
# the executables and dynamic libraries such that the ZIP becomes self-contained, by
|
# the executables and dynamic libraries such that the ZIP becomes self-contained, by
|
||||||
@ -48,9 +48,9 @@ cp $REPO_ROOT/build/solc/solc $ZIP_TEMP_DIR
|
|||||||
# being for kernel-level dylibs.
|
# being for kernel-level dylibs.
|
||||||
|
|
||||||
if [[ "$OSTYPE" == "darwin"* ]]; then
|
if [[ "$OSTYPE" == "darwin"* ]]; then
|
||||||
python3 $REPO_ROOT/scripts/fix_homebrew_paths_in_standalone_zip.py $ZIP_TEMP_DIR
|
python3 "$REPO_ROOT/scripts/fix_homebrew_paths_in_standalone_zip.py" "$ZIP_TEMP_DIR"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# And ZIP it all up, with a filename suffix passed in on the command-line.
|
# And ZIP it all up, with a filename suffix passed in on the command-line.
|
||||||
mkdir -p $REPO_ROOT/upload
|
mkdir -p "$REPO_ROOT/upload"
|
||||||
zip -j $REPO_ROOT/upload/solidity-$ZIP_SUFFIX.zip $ZIP_TEMP_DIR/*
|
zip -j "$REPO_ROOT/upload/solidity-$ZIP_SUFFIX.zip" "$ZIP_TEMP_DIR/"*
|
||||||
|
@ -67,11 +67,11 @@ fi
|
|||||||
for distribution in $DISTRIBUTIONS
|
for distribution in $DISTRIBUTIONS
|
||||||
do
|
do
|
||||||
cd /tmp/
|
cd /tmp/
|
||||||
rm -rf $distribution
|
rm -rf "$distribution"
|
||||||
mkdir $distribution
|
mkdir "$distribution"
|
||||||
cd $distribution
|
cd "$distribution"
|
||||||
|
|
||||||
if [ $distribution = STATIC ]
|
if [ "$distribution" = STATIC ]
|
||||||
then
|
then
|
||||||
pparepo=ethereum-static
|
pparepo=ethereum-static
|
||||||
SMTDEPENDENCY=""
|
SMTDEPENDENCY=""
|
||||||
@ -83,12 +83,12 @@ else
|
|||||||
else
|
else
|
||||||
pparepo=ethereum-dev
|
pparepo=ethereum-dev
|
||||||
fi
|
fi
|
||||||
if [ $distribution = focal ]
|
if [ "$distribution" = focal ]
|
||||||
then
|
then
|
||||||
SMTDEPENDENCY="libz3-static-dev,
|
SMTDEPENDENCY="libz3-static-dev,
|
||||||
libcvc4-dev,
|
libcvc4-dev,
|
||||||
"
|
"
|
||||||
elif [ $distribution = disco ]
|
elif [ "$distribution" = disco ]
|
||||||
then
|
then
|
||||||
SMTDEPENDENCY="libz3-static-dev,
|
SMTDEPENDENCY="libz3-static-dev,
|
||||||
libcvc4-dev,
|
libcvc4-dev,
|
||||||
@ -112,7 +112,7 @@ wget -O ./solc/deps/downloads/range-v3-0.11.0.tar.gz https://github.com/ericnieb
|
|||||||
|
|
||||||
# Determine version
|
# Determine version
|
||||||
cd solc
|
cd solc
|
||||||
version=$($(dirname "$0")/get_version.sh)
|
version=$("$(dirname "$0")/get_version.sh")
|
||||||
commithash=$(git rev-parse --short=8 HEAD)
|
commithash=$(git rev-parse --short=8 HEAD)
|
||||||
commitdate=$(git show --format=%ci HEAD | head -n 1 | cut - -b1-10 | sed -e 's/-0?/./' | sed -e 's/-0?/./')
|
commitdate=$(git show --format=%ci HEAD | head -n 1 | cut - -b1-10 | sed -e 's/-0?/./' | sed -e 's/-0?/./')
|
||||||
|
|
||||||
@ -128,11 +128,11 @@ fi
|
|||||||
# gzip will create different tars all the time and we are not allowed
|
# gzip will create different tars all the time and we are not allowed
|
||||||
# to upload the same file twice with different contents, so we only
|
# to upload the same file twice with different contents, so we only
|
||||||
# create it once.
|
# create it once.
|
||||||
if [ ! -e /tmp/${packagename}_${debversion}.orig.tar.gz ]
|
if [ ! -e "/tmp/${packagename}_${debversion}.orig.tar.gz" ]
|
||||||
then
|
then
|
||||||
tar --exclude .git -czf /tmp/${packagename}_${debversion}.orig.tar.gz .
|
tar --exclude .git -czf "/tmp/${packagename}_${debversion}.orig.tar.gz" .
|
||||||
fi
|
fi
|
||||||
cp /tmp/${packagename}_${debversion}.orig.tar.gz ../
|
cp "/tmp/${packagename}_${debversion}.orig.tar.gz" ../
|
||||||
|
|
||||||
# Create debian package information
|
# Create debian package information
|
||||||
|
|
||||||
@ -244,7 +244,7 @@ chmod +x debian/rules
|
|||||||
|
|
||||||
versionsuffix=0ubuntu1~${distribution}
|
versionsuffix=0ubuntu1~${distribution}
|
||||||
# bump version / add entry to changelog
|
# bump version / add entry to changelog
|
||||||
EMAIL="$email" dch -v 1:${debversion}-${versionsuffix} "git build of ${commithash}"
|
EMAIL="$email" dch -v "1:${debversion}-${versionsuffix}" "git build of ${commithash}"
|
||||||
|
|
||||||
|
|
||||||
# build source package
|
# build source package
|
||||||
@ -254,39 +254,39 @@ EMAIL="$email" dch -v 1:${debversion}-${versionsuffix} "git build of ${commithas
|
|||||||
debuild -S -d -sa -us -uc
|
debuild -S -d -sa -us -uc
|
||||||
|
|
||||||
# prepare .changes file for Launchpad
|
# prepare .changes file for Launchpad
|
||||||
if [ $distribution = STATIC ]
|
if [ "$distribution" = STATIC ]
|
||||||
then
|
then
|
||||||
sed -i -e s/UNRELEASED/${static_build_distribution}/ -e s/urgency=medium/urgency=low/ ../*.changes
|
sed -i -e "s/UNRELEASED/${static_build_distribution}/" -e s/urgency=medium/urgency=low/ ../*.changes
|
||||||
else
|
else
|
||||||
sed -i -e s/UNRELEASED/${distribution}/ -e s/urgency=medium/urgency=low/ ../*.changes
|
sed -i -e "s/UNRELEASED/${distribution}/" -e s/urgency=medium/urgency=low/ ../*.changes
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# check if ubuntu already has the source tarball
|
# check if ubuntu already has the source tarball
|
||||||
(
|
(
|
||||||
cd ..
|
cd ..
|
||||||
orig=${packagename}_${debversion}.orig.tar.gz
|
orig="${packagename}_${debversion}.orig.tar.gz"
|
||||||
orig_size=$(ls -l $orig | cut -d ' ' -f 5)
|
orig_size=$(ls -l "$orig" | cut -d ' ' -f 5)
|
||||||
orig_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
orig_sha1=$(sha1sum "$orig" | cut -d ' ' -f 1)
|
||||||
orig_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
orig_sha256=$(sha256sum "$orig" | cut -d ' ' -f 1)
|
||||||
orig_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
orig_md5=$(md5sum "$orig" | cut -d ' ' -f 1)
|
||||||
|
|
||||||
if wget --quiet -O $orig-tmp "$ppafilesurl/$orig"
|
if wget --quiet -O "$orig-tmp" "$ppafilesurl/$orig"
|
||||||
then
|
then
|
||||||
echo "[WARN] Original tarball found in Ubuntu archive, using it instead"
|
echo "[WARN] Original tarball found in Ubuntu archive, using it instead"
|
||||||
mv $orig-tmp $orig
|
mv "$orig-tmp" "$orig"
|
||||||
new_size=$(ls -l *.orig.tar.gz | cut -d ' ' -f 5)
|
new_size=$(ls -l *.orig.tar.gz | cut -d ' ' -f 5)
|
||||||
new_sha1=$(sha1sum $orig | cut -d ' ' -f 1)
|
new_sha1=$(sha1sum "$orig" | cut -d ' ' -f 1)
|
||||||
new_sha256=$(sha256sum $orig | cut -d ' ' -f 1)
|
new_sha256=$(sha256sum "$orig" | cut -d ' ' -f 1)
|
||||||
new_md5=$(md5sum $orig | cut -d ' ' -f 1)
|
new_md5=$(md5sum "$orig" | cut -d ' ' -f 1)
|
||||||
sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.dsc
|
sed -i -e "s,$orig_sha1,$new_sha1,g" -e "s,$orig_sha256,$new_sha256,g" -e "s,$orig_size,$new_size,g" -e "s,$orig_md5,$new_md5,g" *.dsc
|
||||||
sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.changes
|
sed -i -e "s,$orig_sha1,$new_sha1,g" -e "s,$orig_sha256,$new_sha256,g" -e "s,$orig_size,$new_size,g" -e "s,$orig_md5,$new_md5,g" *.changes
|
||||||
fi
|
fi
|
||||||
)
|
)
|
||||||
|
|
||||||
# sign the package
|
# sign the package
|
||||||
debsign --re-sign -k ${keyid} ../${packagename}_${debversion}-${versionsuffix}_source.changes
|
debsign --re-sign -k "${keyid}" "../${packagename}_${debversion}-${versionsuffix}_source.changes"
|
||||||
|
|
||||||
# upload
|
# upload
|
||||||
dput ${pparepo} ../${packagename}_${debversion}-${versionsuffix}_source.changes
|
dput "${pparepo}" "../${packagename}_${debversion}-${versionsuffix}_source.changes"
|
||||||
|
|
||||||
done
|
done
|
||||||
|
@ -64,4 +64,4 @@ if [ "$USE_DEBUGGER" -ne "0" ]; then
|
|||||||
DEBUG_PREFIX=${DEBUGGER}
|
DEBUG_PREFIX=${DEBUGGER}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec ${DEBUG_PREFIX} ${SOLIDITY_BUILD_DIR}/test/soltest ${BOOST_OPTIONS} -- --testpath ${REPO_ROOT}/test ${SOLTEST_OPTIONS}
|
exec ${DEBUG_PREFIX} "${SOLIDITY_BUILD_DIR}/test/soltest" ${BOOST_OPTIONS} -- --testpath "${REPO_ROOT}/test" ${SOLTEST_OPTIONS}
|
||||||
|
@ -34,7 +34,7 @@ else
|
|||||||
BUILD_DIR="$1"
|
BUILD_DIR="$1"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
REPO_ROOT=$(cd $(dirname "$0")/.. && pwd)
|
REPO_ROOT=$(cd "$(dirname "$0")/.." && pwd)
|
||||||
SOLJSON="$REPO_ROOT/$BUILD_DIR/libsolc/soljson.js"
|
SOLJSON="$REPO_ROOT/$BUILD_DIR/libsolc/soljson.js"
|
||||||
VERSION=$("$REPO_ROOT"/scripts/get_version.sh)
|
VERSION=$("$REPO_ROOT"/scripts/get_version.sh)
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ cleanup() {
|
|||||||
|
|
||||||
if [[ -n "$CMDLINE_PID" ]]
|
if [[ -n "$CMDLINE_PID" ]]
|
||||||
then
|
then
|
||||||
safe_kill $CMDLINE_PID "Commandline tests"
|
safe_kill "$CMDLINE_PID" "Commandline tests"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Cleaning up working directory ${WORKDIR} ..."
|
echo "Cleaning up working directory ${WORKDIR} ..."
|
||||||
@ -72,7 +72,7 @@ then
|
|||||||
"$REPO_ROOT/test/cmdlineTests.sh" &
|
"$REPO_ROOT/test/cmdlineTests.sh" &
|
||||||
CMDLINE_PID=$!
|
CMDLINE_PID=$!
|
||||||
else
|
else
|
||||||
if ! $REPO_ROOT/test/cmdlineTests.sh
|
if ! "$REPO_ROOT/test/cmdlineTests.sh"
|
||||||
then
|
then
|
||||||
printError "Commandline tests FAILED"
|
printError "Commandline tests FAILED"
|
||||||
exit 1
|
exit 1
|
||||||
@ -105,7 +105,7 @@ do
|
|||||||
then
|
then
|
||||||
force_abiv1_flag="--abiencoderv1"
|
force_abiv1_flag="--abiencoderv1"
|
||||||
fi
|
fi
|
||||||
printTask "--> Running tests using "$optimize" --evm-version "$vm" $force_abiv1_flag..."
|
printTask "--> Running tests using $optimize --evm-version $vm $force_abiv1_flag..."
|
||||||
|
|
||||||
log=""
|
log=""
|
||||||
if [ -n "$log_directory" ]
|
if [ -n "$log_directory" ]
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
REPO=$(dirname $0)/..
|
REPO="$(dirname "$0")/.."
|
||||||
|
|
||||||
echo "Finding unique failures..."
|
echo "Finding unique failures..."
|
||||||
(
|
(
|
||||||
for x in $*
|
for x in $*
|
||||||
do
|
do
|
||||||
echo -n $x " # "
|
echo -n "$x" " # "
|
||||||
# This subshell is a workaround to prevent the shell from printing
|
# This subshell is a workaround to prevent the shell from printing
|
||||||
# "Aborted"
|
# "Aborted"
|
||||||
("$REPO"/build/test/tools/solfuzzer < "$x" || true) 2>&1 | head -n 1
|
("$REPO"/build/test/tools/solfuzzer < "$x" || true) 2>&1 | head -n 1
|
||||||
|
@ -36,7 +36,7 @@ if [ -d jsoncpp ]; then
|
|||||||
set -e
|
set -e
|
||||||
cd jsoncpp
|
cd jsoncpp
|
||||||
# Checkout the latest commit at the time of our release.
|
# Checkout the latest commit at the time of our release.
|
||||||
git checkout $(git rev-list -1 --before=$COMMIT_DATE master)
|
git checkout "$(git rev-list -1 --before="$COMMIT_DATE" master)"
|
||||||
)
|
)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ function generate_bytecode_report() {
|
|||||||
|
|
||||||
local EXIT_STATUS
|
local EXIT_STATUS
|
||||||
|
|
||||||
if semver -r "<0.4.12" $3 > /dev/null; then
|
if semver -r "<0.4.12" "$3" > /dev/null; then
|
||||||
set +e
|
set +e
|
||||||
"${SCRIPTDIR}/genbytecode.sh" "$1" >/dev/null 2>&1
|
"${SCRIPTDIR}/genbytecode.sh" "$1" >/dev/null 2>&1
|
||||||
EXIT_STATUS=$?
|
EXIT_STATUS=$?
|
||||||
@ -87,7 +87,7 @@ function process_tag() {
|
|||||||
cd /src
|
cd /src
|
||||||
# Checkout the historic commit instead of the tag directly.
|
# Checkout the historic commit instead of the tag directly.
|
||||||
local HISTORIC_COMMIT_HASH="$(grep "${TAG}+" /tmp/release_commit_list.txt | cut -d '+' -f 2 | cut -d '.' -f 2)"
|
local HISTORIC_COMMIT_HASH="$(grep "${TAG}+" /tmp/release_commit_list.txt | cut -d '+' -f 2 | cut -d '.' -f 2)"
|
||||||
if [ "$(git cat-file -t ${HISTORIC_COMMIT_HASH} 2>/dev/null)" == "commit" ]; then
|
if [ "$(git cat-file -t "${HISTORIC_COMMIT_HASH}" 2>/dev/null)" == "commit" ]; then
|
||||||
clean_git_checkout "$HISTORIC_COMMIT_HASH"
|
clean_git_checkout "$HISTORIC_COMMIT_HASH"
|
||||||
else
|
else
|
||||||
clean_git_checkout "${TAG}"
|
clean_git_checkout "${TAG}"
|
||||||
@ -138,11 +138,11 @@ function process_tag() {
|
|||||||
if [ -f "${OUTPUTDIR}/bin/soljson-${FULL_VERSION_SUFFIX}.js" ]; then
|
if [ -f "${OUTPUTDIR}/bin/soljson-${FULL_VERSION_SUFFIX}.js" ]; then
|
||||||
|
|
||||||
echo -ne "GENERATE BYTECODE REPORT FOR ${CYAN}${TAG}${RESET}... "
|
echo -ne "GENERATE BYTECODE REPORT FOR ${CYAN}${TAG}${RESET}... "
|
||||||
generate_bytecode_report "${OUTPUTDIR}/bin/soljson-${FULL_VERSION_SUFFIX}.js" "${OUTPUTDIR}"/log/reports/report-${TAG}.txt "${TAG}"
|
generate_bytecode_report "${OUTPUTDIR}/bin/soljson-${FULL_VERSION_SUFFIX}.js" "${OUTPUTDIR}/log/reports/report-${TAG}.txt" "${TAG}"
|
||||||
echo -ne "GENERATE BYTECODE REPORT FOR HISTORIC ${CYAN}${TAG}${RESET}... "
|
echo -ne "GENERATE BYTECODE REPORT FOR HISTORIC ${CYAN}${TAG}${RESET}... "
|
||||||
rm -rf /tmp/soljson.js
|
rm -rf /tmp/soljson.js
|
||||||
if wget -q "$RELEASE_URL/soljson-${HISTORIC_VERSION_SUFFIX}.js" -O /tmp/soljson.js; then
|
if wget -q "$RELEASE_URL/soljson-${HISTORIC_VERSION_SUFFIX}.js" -O /tmp/soljson.js; then
|
||||||
generate_bytecode_report /tmp/soljson.js "${OUTPUTDIR}"/log/reports/report-historic-${TAG}.txt "${TAG}"
|
generate_bytecode_report /tmp/soljson.js "${OUTPUTDIR}/log/reports/report-historic-${TAG}.txt" "${TAG}"
|
||||||
else
|
else
|
||||||
echo -e "${ORANGE}CANNOT FETCH RELEASE${RESET}"
|
echo -e "${ORANGE}CANNOT FETCH RELEASE${RESET}"
|
||||||
fi
|
fi
|
||||||
|
@ -25,4 +25,4 @@ if [ ! -d "${OUTPUTDIR}" ]; then
|
|||||||
fi
|
fi
|
||||||
OUTPUTDIR=$(realpath "${OUTPUTDIR}")
|
OUTPUTDIR=$(realpath "${OUTPUTDIR}")
|
||||||
|
|
||||||
docker run --rm -v "${OUTPUTDIR}":/tmp/output -v "${SCRIPTDIR}":/tmp/scripts:ro -it trzeci/emscripten:sdk-tag-1.39.3-64bit /tmp/scripts/docker-scripts/rebuild_tags.sh "${TAGS}" /tmp/output $@
|
docker run --rm -v "${OUTPUTDIR}":/tmp/output -v "${SCRIPTDIR}":/tmp/scripts:ro -it trzeci/emscripten:sdk-tag-1.39.3-64bit /tmp/scripts/docker-scripts/rebuild_tags.sh "${TAGS}" /tmp/output "$@"
|
||||||
|
@ -30,7 +30,7 @@ set -e
|
|||||||
|
|
||||||
## GLOBAL VARIABLES
|
## GLOBAL VARIABLES
|
||||||
|
|
||||||
REPO_ROOT=$(cd $(dirname "$0")/.. && pwd)
|
REPO_ROOT=$(cd "$(dirname "$0")/.." && pwd)
|
||||||
SOLIDITY_BUILD_DIR=${SOLIDITY_BUILD_DIR:-${REPO_ROOT}/build}
|
SOLIDITY_BUILD_DIR=${SOLIDITY_BUILD_DIR:-${REPO_ROOT}/build}
|
||||||
source "${REPO_ROOT}/scripts/common.sh"
|
source "${REPO_ROOT}/scripts/common.sh"
|
||||||
source "${REPO_ROOT}/scripts/common_cmdline.sh"
|
source "${REPO_ROOT}/scripts/common_cmdline.sh"
|
||||||
@ -185,13 +185,13 @@ function test_solc_behaviour()
|
|||||||
[[ $exit_code_expectation_file == "" ]] && exit 1
|
[[ $exit_code_expectation_file == "" ]] && exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$(cat $stdout_path)" != "${stdout_expected}" ]]
|
if [[ "$(cat "$stdout_path")" != "${stdout_expected}" ]]
|
||||||
then
|
then
|
||||||
printError "Incorrect output on stdout received. Expected:"
|
printError "Incorrect output on stdout received. Expected:"
|
||||||
echo -e "${stdout_expected}"
|
echo -e "${stdout_expected}"
|
||||||
|
|
||||||
printError "But got:"
|
printError "But got:"
|
||||||
echo -e "$(cat $stdout_path)"
|
echo -e "$(cat "$stdout_path")"
|
||||||
|
|
||||||
printError "When running $solc_command"
|
printError "When running $solc_command"
|
||||||
|
|
||||||
@ -199,13 +199,13 @@ function test_solc_behaviour()
|
|||||||
[[ $stdout_expectation_file == "" ]] && exit 1
|
[[ $stdout_expectation_file == "" ]] && exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$(cat $stderr_path)" != "${stderr_expected}" ]]
|
if [[ "$(cat "$stderr_path")" != "${stderr_expected}" ]]
|
||||||
then
|
then
|
||||||
printError "Incorrect output on stderr received. Expected:"
|
printError "Incorrect output on stderr received. Expected:"
|
||||||
echo -e "${stderr_expected}"
|
echo -e "${stderr_expected}"
|
||||||
|
|
||||||
printError "But got:"
|
printError "But got:"
|
||||||
echo -e "$(cat $stderr_path)"
|
echo -e "$(cat "$stderr_path")"
|
||||||
|
|
||||||
printError "When running $solc_command"
|
printError "When running $solc_command"
|
||||||
|
|
||||||
@ -223,14 +223,14 @@ function test_solc_assembly_output()
|
|||||||
local expected="${2}"
|
local expected="${2}"
|
||||||
local solc_args="${3}"
|
local solc_args="${3}"
|
||||||
|
|
||||||
local expected_object="object \"object\" { code "${expected}" }"
|
local expected_object="object \"object\" { code ${expected} }"
|
||||||
|
|
||||||
output=$(echo "${input}" | "$SOLC" - ${solc_args} 2>/dev/null)
|
output=$(echo "${input}" | "$SOLC" - ${solc_args} 2>/dev/null)
|
||||||
empty=$(echo "$output" | tr '\n' ' ' | tr -s ' ' | sed -ne "/${expected_object}/p")
|
empty=$(echo "$output" | tr '\n' ' ' | tr -s ' ' | sed -ne "/${expected_object}/p")
|
||||||
if [ -z "$empty" ]
|
if [ -z "$empty" ]
|
||||||
then
|
then
|
||||||
printError "Incorrect assembly output. Expected: "
|
printError "Incorrect assembly output. Expected: "
|
||||||
echo -e ${expected}
|
echo -e "${expected}"
|
||||||
printError "with arguments ${solc_args}, but got:"
|
printError "with arguments ${solc_args}, but got:"
|
||||||
echo "${output}"
|
echo "${output}"
|
||||||
exit 1
|
exit 1
|
||||||
@ -279,8 +279,8 @@ printTask "Running general commandline tests..."
|
|||||||
# Strip trailing slash from $tdir.
|
# Strip trailing slash from $tdir.
|
||||||
tdir=$(basename "${tdir}")
|
tdir=$(basename "${tdir}")
|
||||||
|
|
||||||
inputFiles="$(ls -1 ${tdir}/input.* 2> /dev/null || true)"
|
inputFiles="$(ls -1 "${tdir}/input."* 2> /dev/null || true)"
|
||||||
inputCount="$(echo ${inputFiles} | wc -w)"
|
inputCount="$(echo "${inputFiles}" | wc -w)"
|
||||||
if (( ${inputCount} > 1 ))
|
if (( ${inputCount} > 1 ))
|
||||||
then
|
then
|
||||||
printError "Ambiguous input. Found input files in multiple formats:"
|
printError "Ambiguous input. Found input files in multiple formats:"
|
||||||
@ -300,18 +300,18 @@ printTask "Running general commandline tests..."
|
|||||||
then
|
then
|
||||||
stdin="${inputFile}"
|
stdin="${inputFile}"
|
||||||
inputFile=""
|
inputFile=""
|
||||||
stdout="$(cat ${tdir}/output.json 2>/dev/null || true)"
|
stdout="$(cat "${tdir}/output.json" 2>/dev/null || true)"
|
||||||
stdoutExpectationFile="${tdir}/output.json"
|
stdoutExpectationFile="${tdir}/output.json"
|
||||||
args="--standard-json "$(cat ${tdir}/args 2>/dev/null || true)
|
args="--standard-json "$(cat "${tdir}/args" 2>/dev/null || true)
|
||||||
else
|
else
|
||||||
stdin=""
|
stdin=""
|
||||||
stdout="$(cat ${tdir}/output 2>/dev/null || true)"
|
stdout="$(cat "${tdir}/output" 2>/dev/null || true)"
|
||||||
stdoutExpectationFile="${tdir}/output"
|
stdoutExpectationFile="${tdir}/output"
|
||||||
args=$(cat ${tdir}/args 2>/dev/null || true)
|
args=$(cat "${tdir}/args" 2>/dev/null || true)
|
||||||
fi
|
fi
|
||||||
exitCodeExpectationFile="${tdir}/exit"
|
exitCodeExpectationFile="${tdir}/exit"
|
||||||
exitCode=$(cat "$exitCodeExpectationFile" 2>/dev/null || true)
|
exitCode=$(cat "$exitCodeExpectationFile" 2>/dev/null || true)
|
||||||
err="$(cat ${tdir}/err 2>/dev/null || true)"
|
err="$(cat "${tdir}/err" 2>/dev/null || true)"
|
||||||
stderrExpectationFile="${tdir}/err"
|
stderrExpectationFile="${tdir}/err"
|
||||||
test_solc_behaviour "$inputFile" \
|
test_solc_behaviour "$inputFile" \
|
||||||
"$args" \
|
"$args" \
|
||||||
@ -478,7 +478,7 @@ printTask "Testing AST import..."
|
|||||||
SOLTMPDIR=$(mktemp -d)
|
SOLTMPDIR=$(mktemp -d)
|
||||||
(
|
(
|
||||||
cd "$SOLTMPDIR"
|
cd "$SOLTMPDIR"
|
||||||
$REPO_ROOT/scripts/ASTImportTest.sh
|
"$REPO_ROOT/scripts/ASTImportTest.sh"
|
||||||
if [ $? -ne 0 ]
|
if [ $? -ne 0 ]
|
||||||
then
|
then
|
||||||
rm -rf "$SOLTMPDIR"
|
rm -rf "$SOLTMPDIR"
|
||||||
|
@ -4,7 +4,7 @@ set -e
|
|||||||
|
|
||||||
## GLOBAL VARIABLES
|
## GLOBAL VARIABLES
|
||||||
|
|
||||||
REPO_ROOT=$(cd $(dirname "$0")/.. && pwd)
|
REPO_ROOT=$(cd "$(dirname "$0")/.." && pwd)
|
||||||
|
|
||||||
## FUNCTIONS
|
## FUNCTIONS
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user