mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
[scripts] ASTImportTest.sh: minor refactorings.
This commit is contained in:
parent
49a0948d92
commit
90ac362a3b
@ -508,27 +508,15 @@ function test_import_export_equivalence {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
WORKINGDIR=${PWD}
|
function test_evmjson_import_from_yul_export
|
||||||
|
{
|
||||||
command_available "${SOLC}" --version
|
local files="${*}"
|
||||||
command_available jq --version
|
for yulfile in $files
|
||||||
command_available "${EXPR}" --version
|
|
||||||
command_available "${READLINK}" --version
|
|
||||||
|
|
||||||
case "${IMPORT_TEST_TYPE}" in
|
|
||||||
ast) TEST_DIRS=("${SYNTAXTESTS_DIR}" "${ASTJSONTESTS_DIR}") ;;
|
|
||||||
evm-assembly) TEST_DIRS=("${SEMANTICTESTS_DIR}") ;;
|
|
||||||
*) assertFail "Import test type not defined. $(print_usage || true)}" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [[ "${IMPORT_TEST_TYPE}" == "evm-assembly" ]]
|
|
||||||
then
|
|
||||||
IMPORT_TEST_FILES=$(find "${YULTESTS_DIR}" -name "*.yul")
|
|
||||||
NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
|
||||||
echo "Looking at ${NSOURCES} .yul files..."
|
|
||||||
for yulfile in ${IMPORT_TEST_FILES}
|
|
||||||
do
|
do
|
||||||
|
local export_command
|
||||||
|
local import_command
|
||||||
echo -n "·"
|
echo -n "·"
|
||||||
|
|
||||||
# create a temporary sub-directory
|
# create a temporary sub-directory
|
||||||
FILETMP=$(mktemp -d)
|
FILETMP=$(mktemp -d)
|
||||||
cd "${FILETMP}"
|
cd "${FILETMP}"
|
||||||
@ -544,6 +532,7 @@ then
|
|||||||
yul_bin="$(basename "$yulfile").bin"
|
yul_bin="$(basename "$yulfile").bin"
|
||||||
yul_json="$(basename "$yulfile").asm.json"
|
yul_json="$(basename "$yulfile").asm.json"
|
||||||
echo "$output" > "${yul_bin}"
|
echo "$output" > "${yul_bin}"
|
||||||
|
# remove all lines starting with '=======' and 'Binary representation:'.
|
||||||
grep -v -e '^=======' -e '^Binary representation:' "${yul_bin}" > tmpfile && mv tmpfile "${yul_bin}"
|
grep -v -e '^=======' -e '^Binary representation:' "${yul_bin}" > tmpfile && mv tmpfile "${yul_bin}"
|
||||||
# remove all white-spaces. we only want the binary.
|
# remove all white-spaces. we only want the binary.
|
||||||
tr -d '[:space:]' < "${yul_bin}" > tmpfile && mv tmpfile "${yul_bin}"
|
tr -d '[:space:]' < "${yul_bin}" > tmpfile && mv tmpfile "${yul_bin}"
|
||||||
@ -551,11 +540,13 @@ then
|
|||||||
if [[ -s "${yul_bin}" ]]
|
if [[ -s "${yul_bin}" ]]
|
||||||
then
|
then
|
||||||
# take the yul file and export it as evm assembly json. save the result in "$yul_json".
|
# take the yul file and export it as evm assembly json. save the result in "$yul_json".
|
||||||
|
export_command=("${SOLC}" --strict-assembly "${yulfile}" --optimize --asm-json --pretty-json --json-indent 4)
|
||||||
run_solc_store_stdout "${yul_json}" --strict-assembly "${yulfile}" --optimize --asm-json --pretty-json --json-indent 4
|
run_solc_store_stdout "${yul_json}" --strict-assembly "${yulfile}" --optimize --asm-json --pretty-json --json-indent 4
|
||||||
# remove the lines containing '=======', so that we just have a nice json file.
|
# remove the lines containing '=======', so that we just have a nice json file.
|
||||||
grep -v '^=======' "${yul_json}" > tmpfile && mv tmpfile "${yul_json}"
|
grep -v '^=======' "${yul_json}" > tmpfile && mv tmpfile "${yul_json}"
|
||||||
|
|
||||||
# import the created evm assembly json file and create a combined json out of it.
|
# import the created evm assembly json file and create a combined json out of it.
|
||||||
|
import_command=("${SOLC}" --combined-json "bin" --pretty-json --json-indent 4 --import-asm-json "${yul_json}")
|
||||||
run_solc_store_stdout "${yul_json}.combined.json" --combined-json "bin" --pretty-json --json-indent 4 --import-asm-json "${yul_json}"
|
run_solc_store_stdout "${yul_json}.combined.json" --combined-json "bin" --pretty-json --json-indent 4 --import-asm-json "${yul_json}"
|
||||||
# split the combined json into different files.
|
# split the combined json into different files.
|
||||||
split_combined_json "${yul_json}.combined.json" . "compiled"
|
split_combined_json "${yul_json}.combined.json" . "compiled"
|
||||||
@ -564,13 +555,15 @@ then
|
|||||||
if ! diff_files compiled.bin "${yul_bin}" > diff_error
|
if ! diff_files compiled.bin "${yul_bin}" > diff_error
|
||||||
then
|
then
|
||||||
diff_error=$(cat diff_error)
|
diff_error=$(cat diff_error)
|
||||||
printError "ERROR: diff failed ${file} ${imported}:\n ${diff_error}"
|
printError "ERROR: diff failed ${yulfile}:\n ${diff_error}"
|
||||||
if (( EXIT_ON_ERROR == 1 ))
|
if (( EXIT_ON_ERROR == 1 ))
|
||||||
then
|
then
|
||||||
print_used_commands "${PWD}" "${export_command[*]}" "${import_command[*]}"
|
print_used_commands "${PWD}" "${export_command[*]}" "${import_command[*]}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
return 1
|
FAILED=$((FAILED + 1))
|
||||||
|
else
|
||||||
|
TESTED=$((TESTED + 1))
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -579,6 +572,28 @@ then
|
|||||||
rm -rf "${FILETMP}"
|
rm -rf "${FILETMP}"
|
||||||
done
|
done
|
||||||
echo
|
echo
|
||||||
|
}
|
||||||
|
|
||||||
|
WORKINGDIR=${PWD}
|
||||||
|
|
||||||
|
command_available "${SOLC}" --version
|
||||||
|
command_available jq --version
|
||||||
|
command_available "${EXPR}" --version
|
||||||
|
command_available "${READLINK}" --version
|
||||||
|
|
||||||
|
case "${IMPORT_TEST_TYPE}" in
|
||||||
|
ast) TEST_DIRS=("${SYNTAXTESTS_DIR}" "${ASTJSONTESTS_DIR}") ;;
|
||||||
|
evm-assembly) TEST_DIRS=("${SEMANTICTESTS_DIR}") ;;
|
||||||
|
*) assertFail "Import test type not defined. $(print_usage || true)}" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
YUL_NSOURCES=0
|
||||||
|
if [[ "${IMPORT_TEST_TYPE}" == "evm-assembly" ]]
|
||||||
|
then
|
||||||
|
IMPORT_TEST_FILES=$(find "${YULTESTS_DIR}" -name "*.yul")
|
||||||
|
YUL_NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
||||||
|
echo "Looking at ${YUL_NSOURCES} .yul files..."
|
||||||
|
test_evmjson_import_from_yul_export "${IMPORT_TEST_FILES[@]}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# boost_filesystem_bug specifically tests a local fix for a boost::filesystem
|
# boost_filesystem_bug specifically tests a local fix for a boost::filesystem
|
||||||
@ -586,8 +601,10 @@ fi
|
|||||||
# tests on it. See https://github.com/boostorg/filesystem/issues/176
|
# tests on it. See https://github.com/boostorg/filesystem/issues/176
|
||||||
IMPORT_TEST_FILES=$(find "${TEST_DIRS[@]}" -name "*.sol" -and -not -name "boost_filesystem_bug.sol" -not -path "*/experimental/*")
|
IMPORT_TEST_FILES=$(find "${TEST_DIRS[@]}" -name "*.sol" -and -not -name "boost_filesystem_bug.sol" -not -path "*/experimental/*")
|
||||||
|
|
||||||
NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
SOL_NSOURCES="$(echo "${IMPORT_TEST_FILES}" | wc -l)"
|
||||||
echo "Looking at ${NSOURCES} .sol files..."
|
echo "Looking at ${SOL_NSOURCES} .sol files..."
|
||||||
|
|
||||||
|
NSOURCES=$(( YUL_NSOURCES + SOL_NSOURCES ))
|
||||||
|
|
||||||
for solfile in ${IMPORT_TEST_FILES}
|
for solfile in ${IMPORT_TEST_FILES}
|
||||||
do
|
do
|
||||||
|
Loading…
Reference in New Issue
Block a user