externalTests: Replace optimizer levels with named presets

This commit is contained in:
Kamil Śliwak 2021-12-09 14:37:21 +01:00
parent adfa51c01c
commit d304c84432
7 changed files with 92 additions and 76 deletions

View File

@ -211,6 +211,7 @@ function safe_kill
function circleci_select_steps function circleci_select_steps
{ {
# We expect multiple lines in $all_steps, one step per line
local all_steps="$1" local all_steps="$1"
(( $# == 1 )) || assertFail (( $# == 1 )) || assertFail
@ -222,6 +223,12 @@ function circleci_select_steps
fi fi
} }
function circleci_select_steps_multiarg
{
# We expect multiple arguments, one step per argument.
circleci_select_steps "$(printf '%s\n' "$@")"
}
function circleci_step_selected function circleci_step_selected
{ {
local selected_steps="$1" local selected_steps="$1"

View File

@ -36,20 +36,22 @@ function colony_test
local repo="https://github.com/solidity-external-tests/colonyNetwork.git" local repo="https://github.com/solidity-external-tests/colonyNetwork.git"
local branch=develop_080 local branch=develop_080
local config_file="truffle.js" local config_file="truffle.js"
# On levels 1 and 2 it compiles but tests run out of gas local settings_presets=(
local min_optimizer_level=3 #legacy-no-optimize # Compiles but tests run out of gas
local max_optimizer_level=3 #legacy-optimize-evm-only # Compiles but tests run out of gas
legacy-optimize-evm+yul
)
local selected_optimizer_levels local selected_optimizer_presets
selected_optimizer_levels=$(circleci_select_steps "$(seq "$min_optimizer_level" "$max_optimizer_level")") selected_optimizer_presets=$(circleci_select_steps_multiarg "${settings_presets[@]}")
print_optimizer_levels_or_exit "$selected_optimizer_levels" print_optimizer_presets_or_exit "$selected_optimizer_presets"
setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH" setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH"
download_project "$repo" "$branch" "$DIR" download_project "$repo" "$branch" "$DIR"
[[ $BINARY_TYPE == native ]] && replace_global_solc "$BINARY_PATH" [[ $BINARY_TYPE == native ]] && replace_global_solc "$BINARY_PATH"
neutralize_package_json_hooks neutralize_package_json_hooks
force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$min_optimizer_level" force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$(first_word "$selected_optimizer_presets")"
yarn install yarn install
git submodule update --init git submodule update --init
@ -61,8 +63,8 @@ function colony_test
replace_version_pragmas replace_version_pragmas
[[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc" [[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc"
for level in $selected_optimizer_levels; do for preset in $selected_optimizer_presets; do
truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$level" compile_fn test_fn truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$preset" compile_fn test_fn
done done
} }

View File

@ -24,13 +24,13 @@ set -e
CURRENT_EVM_VERSION=london CURRENT_EVM_VERSION=london
function print_optimizer_levels_or_exit function print_optimizer_presets_or_exit
{ {
local selected_levels="$1" local selected_presets="$1"
[[ $selected_levels != "" ]] || { printWarning "No steps to run. Exiting."; exit 0; } [[ $selected_presets != "" ]] || { printWarning "No presets to run. Exiting."; exit 0; }
printLog "Selected optimizer levels: ${selected_levels}" printLog "Selected settings presets: ${selected_presets}"
} }
function verify_input function verify_input
@ -141,7 +141,7 @@ function force_truffle_compiler_settings
local config_file="$1" local config_file="$1"
local binary_type="$2" local binary_type="$2"
local solc_path="$3" local solc_path="$3"
local level="$4" local preset="$4"
local evm_version="${5:-"$CURRENT_EVM_VERSION"}" local evm_version="${5:-"$CURRENT_EVM_VERSION"}"
[[ $binary_type == native || $binary_type == solcjs ]] || assertFail [[ $binary_type == native || $binary_type == solcjs ]] || assertFail
@ -153,14 +153,16 @@ function force_truffle_compiler_settings
echo "Config file: $config_file" echo "Config file: $config_file"
echo "Binary type: $binary_type" echo "Binary type: $binary_type"
echo "Compiler path: $solc_path" echo "Compiler path: $solc_path"
echo "Optimization level: $level" echo "Settings preset: ${preset}"
echo "Optimizer settings: $(optimizer_settings_for_level "$level")" echo "Settings: $(settings_from_preset "$preset" "$evm_version")"
echo "EVM version: $evm_version" echo "EVM version: $evm_version"
echo "Compiler version: ${SOLCVERSION_SHORT}"
echo "Compiler version (full): ${SOLCVERSION}"
echo "-------------------------------------" echo "-------------------------------------"
# Forcing the settings should always work by just overwriting the solc object. Forcing them by using a # 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. # dedicated settings objects should only be the fallback.
echo "module.exports['compilers'] = $(truffle_compiler_settings "$solc_path" "$level" "$evm_version");" >> "$config_file" echo "module.exports['compilers'] = $(truffle_compiler_settings "$solc_path" "$preset" "$evm_version");" >> "$config_file"
} }
function force_hardhat_compiler_binary function force_hardhat_compiler_binary
@ -180,14 +182,14 @@ function force_hardhat_compiler_binary
function force_hardhat_compiler_settings function force_hardhat_compiler_settings
{ {
local config_file="$1" local config_file="$1"
local level="$2" local preset="$2"
local evm_version="${3:-"$CURRENT_EVM_VERSION"}" local evm_version="${3:-"$CURRENT_EVM_VERSION"}"
printLog "Configuring Hardhat..." printLog "Configuring Hardhat..."
echo "-------------------------------------" echo "-------------------------------------"
echo "Config file: ${config_file}" echo "Config file: ${config_file}"
echo "Optimization level: ${level}" echo "Settings preset: ${preset}"
echo "Optimizer settings: $(optimizer_settings_for_level "$level")" echo "Settings: $(settings_from_preset "$preset" "$evm_version")"
echo "EVM version: ${evm_version}" echo "EVM version: ${evm_version}"
echo "Compiler version: ${SOLCVERSION_SHORT}" echo "Compiler version: ${SOLCVERSION_SHORT}"
echo "Compiler version (full): ${SOLCVERSION}" echo "Compiler version (full): ${SOLCVERSION}"
@ -195,7 +197,7 @@ function force_hardhat_compiler_settings
{ {
echo -n 'module.exports["solidity"] = ' echo -n 'module.exports["solidity"] = '
hardhat_compiler_settings "$SOLCVERSION_SHORT" "$level" "$evm_version" hardhat_compiler_settings "$SOLCVERSION_SHORT" "$preset" "$evm_version"
} >> "$config_file" } >> "$config_file"
} }
@ -242,16 +244,17 @@ function run_test
$test_fn $test_fn
} }
function optimizer_settings_for_level function settings_from_preset
{ {
local level="$1" local preset="$1"
local evm_version="$2"
case "$level" in case "$preset" in
1) echo "{enabled: false}" ;; legacy-no-optimize) echo "{evmVersion: '${evm_version}', optimizer: {enabled: false}}" ;;
2) echo "{enabled: true, details: {yul: false}}" ;; legacy-optimize-evm-only) echo "{evmVersion: '${evm_version}', optimizer: {enabled: true, details: {yul: false}}}" ;;
3) echo "{enabled: true, details: {yul: true}}" ;; legacy-optimize-evm+yul) echo "{evmVersion: '${evm_version}', optimizer: {enabled: true, details: {yul: true}}}" ;;
*) *)
fail "Optimizer level not found. Please define OPTIMIZER_LEVEL=[1, 2, 3]" fail "Unknown settings preset: '${preset}'."
;; ;;
esac esac
} }
@ -269,16 +272,13 @@ function replace_global_solc
function truffle_compiler_settings function truffle_compiler_settings
{ {
local solc_path="$1" local solc_path="$1"
local level="$2" local preset="$2"
local evm_version="$3" local evm_version="$3"
echo "{" echo "{"
echo " solc: {" echo " solc: {"
echo " version: \"${solc_path}\"," echo " version: \"${solc_path}\","
echo " settings: {" echo " settings: $(settings_from_preset "$preset" "$evm_version")"
echo " optimizer: $(optimizer_settings_for_level "$level"),"
echo " evmVersion: \"${evm_version}\""
echo " }"
echo " }" echo " }"
echo "}" echo "}"
} }
@ -310,15 +310,12 @@ function hardhat_solc_build_subtask {
function hardhat_compiler_settings { function hardhat_compiler_settings {
local solc_version="$1" local solc_version="$1"
local level="$2" local preset="$2"
local evm_version="$3" local evm_version="$3"
echo "{" echo "{"
echo " version: '${solc_version}'," echo " version: '${solc_version}',"
echo " settings: {" echo " settings: $(settings_from_preset "$preset" "$evm_version")"
echo " optimizer: $(optimizer_settings_for_level "$level"),"
echo " evmVersion: '${evm_version}'"
echo " }"
echo "}" echo "}"
} }
@ -345,24 +342,24 @@ function truffle_run_test
local config_file="$1" local config_file="$1"
local binary_type="$2" local binary_type="$2"
local solc_path="$3" local solc_path="$3"
local optimizer_level="$4" local preset="$4"
local compile_fn="$5" local compile_fn="$5"
local test_fn="$6" local test_fn="$6"
truffle_clean truffle_clean
force_truffle_compiler_settings "$config_file" "$binary_type" "$solc_path" "$optimizer_level" force_truffle_compiler_settings "$config_file" "$binary_type" "$solc_path" "$preset"
compile_and_run_test compile_fn test_fn truffle_verify_compiler_version compile_and_run_test compile_fn test_fn truffle_verify_compiler_version
} }
function hardhat_run_test function hardhat_run_test
{ {
local config_file="$1" local config_file="$1"
local optimizer_level="$2" local preset="$2"
local compile_fn="$3" local compile_fn="$3"
local test_fn="$4" local test_fn="$4"
hardhat_clean hardhat_clean
force_hardhat_compiler_settings "$config_file" "$optimizer_level" force_hardhat_compiler_settings "$config_file" "$preset"
compile_and_run_test compile_fn test_fn hardhat_verify_compiler_version compile_and_run_test compile_fn test_fn hardhat_verify_compiler_version
} }

View File

@ -36,12 +36,15 @@ function ens_test
local repo="https://github.com/ensdomains/ens.git" local repo="https://github.com/ensdomains/ens.git"
local branch=master local branch=master
local config_file="truffle.js" local config_file="truffle.js"
local min_optimizer_level=1 local settings_presets=(
local max_optimizer_level=3 legacy-no-optimize
legacy-optimize-evm-only
legacy-optimize-evm+yul
)
local selected_optimizer_levels local selected_optimizer_presets
selected_optimizer_levels=$(circleci_select_steps "$(seq "$min_optimizer_level" "$max_optimizer_level")") selected_optimizer_presets=$(circleci_select_steps_multiarg "${settings_presets[@]}")
print_optimizer_levels_or_exit "$selected_optimizer_levels" print_optimizer_presets_or_exit "$selected_optimizer_presets"
setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH" setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH"
download_project "$repo" "$branch" "$DIR" download_project "$repo" "$branch" "$DIR"
@ -52,14 +55,14 @@ function ens_test
neutralize_package_lock neutralize_package_lock
neutralize_package_json_hooks neutralize_package_json_hooks
force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$min_optimizer_level" force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$(first_word "$selected_optimizer_presets")"
npm install npm install
replace_version_pragmas replace_version_pragmas
[[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc" [[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc"
for level in $selected_optimizer_levels; do for preset in $selected_optimizer_presets; do
truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$level" compile_fn test_fn truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$preset" compile_fn test_fn
done done
} }

View File

@ -36,13 +36,15 @@ function gnosis_safe_test
local repo="https://github.com/solidity-external-tests/safe-contracts.git" local repo="https://github.com/solidity-external-tests/safe-contracts.git"
local branch=v2_080 local branch=v2_080
local config_file="truffle-config.js" local config_file="truffle-config.js"
# level 1: "Error: while migrating GnosisSafe: Returned error: base fee exceeds gas limit" local settings_presets=(
local min_optimizer_level=2 #legacy-no-optimize # "Error: while migrating GnosisSafe: Returned error: base fee exceeds gas limit"
local max_optimizer_level=3 legacy-optimize-evm-only
legacy-optimize-evm+yul
)
local selected_optimizer_levels local selected_optimizer_presets
selected_optimizer_levels=$(circleci_select_steps "$(seq "$min_optimizer_level" "$max_optimizer_level")") selected_optimizer_presets=$(circleci_select_steps_multiarg "${settings_presets[@]}")
print_optimizer_levels_or_exit "$selected_optimizer_levels" print_optimizer_presets_or_exit "$selected_optimizer_presets"
setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH" setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH"
download_project "$repo" "$branch" "$DIR" download_project "$repo" "$branch" "$DIR"
@ -53,14 +55,14 @@ function gnosis_safe_test
neutralize_package_lock neutralize_package_lock
neutralize_package_json_hooks neutralize_package_json_hooks
force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$min_optimizer_level" force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$(first_word "$selected_optimizer_presets")"
npm install --package-lock npm install --package-lock
replace_version_pragmas replace_version_pragmas
[[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc" [[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc"
for level in $selected_optimizer_levels; do for preset in $selected_optimizer_presets; do
truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$level" compile_fn test_fn truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$preset" compile_fn test_fn
done done
} }

View File

@ -36,13 +36,15 @@ function gnosis_safe_test
local repo="https://github.com/solidity-external-tests/safe-contracts.git" local repo="https://github.com/solidity-external-tests/safe-contracts.git"
local branch=development_080 local branch=development_080
local config_file="truffle-config.js" local config_file="truffle-config.js"
# levels 1 and 2: "Stack too deep" error local settings_presets=(
local min_optimizer_level=3 #legacy-no-optimize # "Stack too deep" error
local max_optimizer_level=3 #legacy-optimize-evm-only # "Stack too deep" error
legacy-optimize-evm+yul
)
local selected_optimizer_levels local selected_optimizer_presets
selected_optimizer_levels=$(circleci_select_steps "$(seq "$min_optimizer_level" "$max_optimizer_level")") selected_optimizer_presets=$(circleci_select_steps_multiarg "${settings_presets[@]}")
print_optimizer_levels_or_exit "$selected_optimizer_levels" print_optimizer_presets_or_exit "$selected_optimizer_presets"
setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH" setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH"
download_project "$repo" "$branch" "$DIR" download_project "$repo" "$branch" "$DIR"
@ -52,14 +54,14 @@ function gnosis_safe_test
neutralize_package_lock neutralize_package_lock
neutralize_package_json_hooks neutralize_package_json_hooks
force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$min_optimizer_level" force_truffle_compiler_settings "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$(first_word "$selected_optimizer_presets")"
npm install --package-lock npm install --package-lock
replace_version_pragmas replace_version_pragmas
[[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc" [[ $BINARY_TYPE == solcjs ]] && force_solc_modules "${DIR}/solc"
for level in $selected_optimizer_levels; do for preset in $selected_optimizer_presets; do
truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$level" compile_fn test_fn truffle_run_test "$config_file" "$BINARY_TYPE" "${DIR}/solc" "$preset" compile_fn test_fn
done done
} }

View File

@ -36,25 +36,28 @@ function zeppelin_test
local repo="https://github.com/OpenZeppelin/openzeppelin-contracts.git" local repo="https://github.com/OpenZeppelin/openzeppelin-contracts.git"
local branch=master local branch=master
local config_file="hardhat.config.js" local config_file="hardhat.config.js"
local min_optimizer_level=1 local settings_presets=(
local max_optimizer_level=3 legacy-no-optimize
legacy-optimize-evm-only
legacy-optimize-evm+yul
)
local selected_optimizer_levels local selected_optimizer_presets
selected_optimizer_levels=$(circleci_select_steps "$(seq "$min_optimizer_level" "$max_optimizer_level")") selected_optimizer_presets=$(circleci_select_steps_multiarg "${settings_presets[@]}")
print_optimizer_levels_or_exit "$selected_optimizer_levels" print_optimizer_presets_or_exit "$selected_optimizer_presets"
setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH" setup_solc "$DIR" "$BINARY_TYPE" "$BINARY_PATH"
download_project "$repo" "$branch" "$DIR" download_project "$repo" "$branch" "$DIR"
neutralize_package_json_hooks neutralize_package_json_hooks
force_hardhat_compiler_binary "$config_file" "$BINARY_TYPE" "$BINARY_PATH" force_hardhat_compiler_binary "$config_file" "$BINARY_TYPE" "$BINARY_PATH"
force_hardhat_compiler_settings "$config_file" "$min_optimizer_level" force_hardhat_compiler_settings "$config_file" "$(first_word "$selected_optimizer_presets")"
npm install npm install
replace_version_pragmas replace_version_pragmas
for level in $selected_optimizer_levels; do for preset in $selected_optimizer_presets; do
hardhat_run_test "$config_file" "$level" compile_fn test_fn hardhat_run_test "$config_file" "$preset" compile_fn test_fn
done done
} }