2018-01-03 21:34:26 +08:00
|
|
|
#!/bin/bash -e
|
|
|
|
|
|
|
|
script_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
|
|
|
|
|
|
cd $script_dir
|
|
|
|
|
|
|
|
if [[ $# -ne 2 ]]; then
|
|
|
|
echo "Invalid number of arguments"
|
|
|
|
echo "Usage: ./local_runner {test_suite} {test_name}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
test_suite=$1
|
|
|
|
test_name=$2
|
|
|
|
test_path="${test_suite}/${test_name}.py"
|
|
|
|
|
|
|
|
if [ ! -f ${test_path} ]; then
|
|
|
|
echo "Test ${test_name}.py does not exist"
|
|
|
|
echo "Usage: ./local_runner {test_suite} {test_name}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
NUM_MACHINES="$(cat $test_path | grep -m1 "NUM_MACHINES" | tail -c 2)"
|
|
|
|
|
|
|
|
# Define machine ips
|
|
|
|
for i in `seq 1 $NUM_MACHINES`;
|
|
|
|
do
|
|
|
|
export "MACHINE${i}"="127.0.0.1"
|
|
|
|
done
|
|
|
|
|
|
|
|
# Run workers
|
|
|
|
for i in `seq 2 $NUM_MACHINES`;
|
|
|
|
do
|
|
|
|
CURRENT_MACHINE="MACHINE$i" ./jail_service.py &
|
|
|
|
pids[$i]=$!
|
|
|
|
done
|
|
|
|
|
|
|
|
quit()
|
|
|
|
{
|
|
|
|
# Stop workers
|
2018-02-28 01:57:02 +08:00
|
|
|
sleep 1
|
2018-01-03 21:34:26 +08:00
|
|
|
for i in `seq 2 $NUM_MACHINES`;
|
|
|
|
do
|
2019-03-04 22:15:34 +08:00
|
|
|
kill ${pids[$i]} || true
|
2018-01-03 21:34:26 +08:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
trap 'quit' INT
|
|
|
|
|
|
|
|
# Run master with test
|
|
|
|
args="--machines-num $NUM_MACHINES --test-suite $test_suite --test $test_name"
|
|
|
|
CURRENT_MACHINE="MACHINE1" ./master.py $args || quit
|
|
|
|
|
|
|
|
quit
|