render tests/simulation/start.sh more robust to paths with spaces (#340)

This commit is contained in:
Dustin Brody 2019-08-14 10:25:39 +00:00 committed by GitHub
parent 3e587d4667
commit cba25b087c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 21 additions and 20 deletions

View File

@ -1,9 +1,9 @@
#!/bin/bash #!/bin/bash
set -eu set -euo pipefail
# Read in variables # Read in variables
. $(dirname $0)/vars.sh . "$(dirname "$0")/vars.sh"
# Set a default value for the env vars usually supplied by nimbus Makefile # Set a default value for the env vars usually supplied by nimbus Makefile
@ -22,7 +22,7 @@ mkdir -p "$SIMULATION_DIR"
mkdir -p "$VALIDATORS_DIR" mkdir -p "$VALIDATORS_DIR"
cd "$GIT_ROOT" cd "$GIT_ROOT"
mkdir -p $BUILD_OUTPUTS_DIR mkdir -p "${BUILD_OUTPUTS_DIR}"
# Run with "SHARD_COUNT=4 ./start.sh" to change these # Run with "SHARD_COUNT=4 ./start.sh" to change these
DEFS="-d:chronicles_log_level=DEBUG " DEFS="-d:chronicles_log_level=DEBUG "
@ -30,10 +30,10 @@ DEFS+="-d:SHARD_COUNT=${SHARD_COUNT:-16} " # Spec default: 1024
DEFS+="-d:SLOTS_PER_EPOCH=${SLOTS_PER_EPOCH:-16} " # Spec default: 64 DEFS+="-d:SLOTS_PER_EPOCH=${SLOTS_PER_EPOCH:-16} " # Spec default: 64
DEFS+="-d:SECONDS_PER_SLOT=${SECONDS_PER_SLOT:-18} " # Spec default: 6 DEFS+="-d:SECONDS_PER_SLOT=${SECONDS_PER_SLOT:-18} " # Spec default: 6
LAST_VALIDATOR_NUM=$(( $NUM_VALIDATORS - 1 )) LAST_VALIDATOR_NUM=$(( NUM_VALIDATORS - 1 ))
LAST_VALIDATOR="$VALIDATORS_DIR/v$(printf '%07d' $LAST_VALIDATOR_NUM).deposit.json" LAST_VALIDATOR="$VALIDATORS_DIR/v$(printf '%07d' $LAST_VALIDATOR_NUM).deposit.json"
if [ ! -f $LAST_VALIDATOR ]; then if [ ! -f "${LAST_VALIDATOR}" ]; then
if [[ -z "$SKIP_BUILDS" ]]; then if [[ -z "$SKIP_BUILDS" ]]; then
nim c -o:"$VALIDATOR_KEYGEN_BIN" $DEFS -d:release beacon_chain/validator_keygen nim c -o:"$VALIDATOR_KEYGEN_BIN" $DEFS -d:release beacon_chain/validator_keygen
nim c -o:"$DEPLOY_DEPOSIT_CONTRACT_BIN" $DEFS -d:release beacon_chain/deploy_deposit_contract nim c -o:"$DEPLOY_DEPOSIT_CONTRACT_BIN" $DEFS -d:release beacon_chain/deploy_deposit_contract
@ -41,38 +41,39 @@ if [ ! -f $LAST_VALIDATOR ]; then
fi fi
if [ "$DEPOSIT_WEB3_URL_ARG" != "" ]; then if [ "$DEPOSIT_WEB3_URL_ARG" != "" ]; then
export DEPOSIT_CONTRACT_ADDRESS=$($DEPLOY_DEPOSIT_CONTRACT_BIN $DEPOSIT_WEB3_URL_ARG) DEPOSIT_CONTRACT_ADDRESS=$($DEPLOY_DEPOSIT_CONTRACT_BIN $DEPOSIT_WEB3_URL_ARG)
export DEPOSIT_CONTRACT_ADDRESS
fi fi
$VALIDATOR_KEYGEN_BIN \ $VALIDATOR_KEYGEN_BIN \
--totalValidators=$NUM_VALIDATORS \ --totalValidators="${NUM_VALIDATORS}" \
--outputDir="$VALIDATORS_DIR" \ --outputDir="$VALIDATORS_DIR" \
--generateFakeKeys=yes \ --generateFakeKeys=yes \
$DEPOSIT_WEB3_URL_ARG \ $DEPOSIT_WEB3_URL_ARG \
--depositContractAddress=$DEPOSIT_CONTRACT_ADDRESS --depositContractAddress="${DEPOSIT_CONTRACT_ADDRESS}"
fi fi
if [[ -z "$SKIP_BUILDS" ]]; then if [[ -z "$SKIP_BUILDS" ]]; then
nim c -o:"$BEACON_NODE_BIN" $DEFS --opt:speed --debuginfo beacon_chain/beacon_node nim c -o:"$BEACON_NODE_BIN" $DEFS --opt:speed --debuginfo beacon_chain/beacon_node
fi fi
if [ ! -f $SNAPSHOT_FILE ]; then if [ ! -f "${SNAPSHOT_FILE}" ]; then
$BEACON_NODE_BIN \ $BEACON_NODE_BIN \
--dataDir=$SIMULATION_DIR/node-0 \ --dataDir="${SIMULATION_DIR}/node-0" \
createTestnet \ createTestnet \
--networkId=1000 \ --networkId=1000 \
--validatorsDir=$VALIDATORS_DIR \ --validatorsDir="${VALIDATORS_DIR}" \
--totalValidators=$NUM_VALIDATORS \ --totalValidators="${NUM_VALIDATORS}" \
--outputGenesis=$SNAPSHOT_FILE \ --outputGenesis="${SNAPSHOT_FILE}" \
--outputNetwork=$NETWORK_METADATA_FILE \ --outputNetwork="${NETWORK_METADATA_FILE}" \
--bootstrapAddress=127.0.0.1 \ --bootstrapAddress=127.0.0.1 \
--bootstrapPort=50000 \ --bootstrapPort=50000 \
--genesisOffset=5 # Delay in seconds --genesisOffset=5 # Delay in seconds
fi fi
# Delete any leftover address files from a previous session # Delete any leftover address files from a previous session
if [ -f $MASTER_NODE_ADDRESS_FILE ]; then if [ -f "${MASTER_NODE_ADDRESS_FILE}" ]; then
rm $MASTER_NODE_ADDRESS_FILE rm "${MASTER_NODE_ADDRESS_FILE}"
fi fi
# multitail support # multitail support
@ -85,18 +86,18 @@ type "$MULTITAIL" &>/dev/null || USE_MULTITAIL="no"
# Trap and ignore SIGTERM, so we don't kill this process along with its children. # Trap and ignore SIGTERM, so we don't kill this process along with its children.
if [ "$USE_MULTITAIL" = "no" ]; then if [ "$USE_MULTITAIL" = "no" ]; then
trap '' SIGTERM trap '' SIGTERM
trap "kill -- -$$" SIGINT EXIT trap 'kill -- -$$' SIGINT EXIT
fi fi
COMMANDS=() COMMANDS=()
LAST_NODE=$(( $NUM_NODES - 1 )) LAST_NODE=$(( NUM_NODES - 1 ))
for i in $(seq 0 $LAST_NODE); do for i in $(seq 0 $LAST_NODE); do
if [[ "$i" == "0" ]]; then if [[ "$i" == "0" ]]; then
sleep 0 sleep 0
elif [ "$USE_MULTITAIL" = "no" ]; then elif [ "$USE_MULTITAIL" = "no" ]; then
# Wait for the master node to write out its address file # Wait for the master node to write out its address file
while [ ! -f $MASTER_NODE_ADDRESS_FILE ]; do while [ ! -f "${MASTER_NODE_ADDRESS_FILE}" ]; do
sleep 0.1 sleep 0.1
done done
fi fi
@ -112,7 +113,7 @@ for i in $(seq 0 $LAST_NODE); do
# "multitail" closes the corresponding panel when a command exits, so let's make sure it doesn't exit # "multitail" closes the corresponding panel when a command exits, so let's make sure it doesn't exit
COMMANDS+=( " -cT ansi -t 'node #$i' -l 'sleep $SLEEP; $CMD; echo [node execution completed]; while true; do sleep 100; done'" ) COMMANDS+=( " -cT ansi -t 'node #$i' -l 'sleep $SLEEP; $CMD; echo [node execution completed]; while true; do sleep 100; done'" )
else else
eval $CMD & eval "${CMD}" &
fi fi
done done