2016-11-23 03:04:34 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
testdir=$(readlink -f $(dirname $0))
|
2017-04-04 23:20:16 +00:00
|
|
|
rootdir=$(readlink -f $testdir/../../..)
|
2018-02-27 22:14:08 +00:00
|
|
|
source $rootdir/test/common/autotest_common.sh
|
2017-05-24 23:29:24 +00:00
|
|
|
source $rootdir/test/iscsi_tgt/common.sh
|
2016-11-23 03:04:34 +00:00
|
|
|
|
|
|
|
rpc_py="python $rootdir/scripts/rpc.py"
|
|
|
|
fio_py="python $rootdir/scripts/fio.py"
|
|
|
|
|
2017-02-01 18:14:03 +00:00
|
|
|
PORT=3260
|
|
|
|
NETMASK=127.0.0.0/24
|
|
|
|
MIGRATION_ADDRESS=127.0.0.2
|
|
|
|
|
2016-11-23 03:04:34 +00:00
|
|
|
function kill_all_iscsi_target() {
|
2017-02-01 18:14:03 +00:00
|
|
|
for ((i=0; i<2; i++))
|
2016-11-23 03:04:34 +00:00
|
|
|
do
|
2017-11-20 18:01:28 +00:00
|
|
|
rpc_addr="/var/tmp/spdk${i}.sock"
|
|
|
|
$rpc_py -s $rpc_addr kill_instance SIGTERM
|
2016-11-23 03:04:34 +00:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
function rpc_config() {
|
2017-11-20 18:01:28 +00:00
|
|
|
# $1 = RPC server address
|
2016-11-23 03:04:34 +00:00
|
|
|
# $2 = Netmask
|
2017-11-29 05:51:23 +00:00
|
|
|
$rpc_py -s $1 add_initiator_group 1 ANY $2
|
2017-11-20 18:01:28 +00:00
|
|
|
$rpc_py -s $1 construct_malloc_bdev 64 512
|
2016-11-23 03:04:34 +00:00
|
|
|
}
|
|
|
|
function rpc_add_ip() {
|
2017-11-20 18:01:28 +00:00
|
|
|
$rpc_py -s $1 add_ip_address 1 $2
|
2016-11-23 03:04:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
timing_enter ip_migration
|
|
|
|
|
|
|
|
# iSCSI target configuration
|
|
|
|
|
|
|
|
echo "Running ip migration tests"
|
2017-02-01 18:14:03 +00:00
|
|
|
for ((i=0; i<2; i++))
|
2016-11-23 03:04:34 +00:00
|
|
|
do
|
2017-05-25 20:06:51 +00:00
|
|
|
timing_enter start_iscsi_tgt_$i
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
rpc_addr="/var/tmp/spdk${i}.sock"
|
|
|
|
|
2017-05-25 16:27:36 +00:00
|
|
|
# TODO: run the different iSCSI instances on non-overlapping CPU masks
|
2017-11-20 18:01:28 +00:00
|
|
|
$ISCSI_APP -r $rpc_addr -c $testdir/iscsi.conf -s 1000 -i $i -m $ISCSI_TEST_CORE_MASK &
|
2017-02-01 18:14:03 +00:00
|
|
|
pid=$!
|
|
|
|
echo "Process pid: $pid"
|
2016-11-23 03:04:34 +00:00
|
|
|
|
|
|
|
trap "kill_all_iscsi_target; exit 1" SIGINT SIGTERM EXIT
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
waitforlisten $pid $rpc_addr
|
2016-11-23 03:04:34 +00:00
|
|
|
echo "iscsi_tgt is listening. Running tests..."
|
2017-05-25 20:06:51 +00:00
|
|
|
|
|
|
|
timing_exit start_iscsi_tgt_$i
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
rpc_config $rpc_addr $NETMASK
|
2016-11-23 03:04:34 +00:00
|
|
|
trap "kill_all_iscsi_target; exit 1" \
|
|
|
|
SIGINT SIGTERM EXIT
|
|
|
|
done
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
rpc_first_addr="/var/tmp/spdk0.sock"
|
|
|
|
rpc_add_ip $rpc_first_addr $MIGRATION_ADDRESS
|
|
|
|
$rpc_py -s $rpc_first_addr add_portal_group 1 $MIGRATION_ADDRESS:$PORT
|
2018-02-21 17:51:16 +00:00
|
|
|
$rpc_py -s $rpc_first_addr construct_target_node target1 target1_alias 'Malloc0:0' '1:1' 64 -d
|
2016-11-23 03:04:34 +00:00
|
|
|
|
|
|
|
sleep 1
|
|
|
|
iscsiadm -m discovery -t sendtargets -p $MIGRATION_ADDRESS:$PORT
|
|
|
|
sleep 1
|
|
|
|
iscsiadm -m node --login -p $MIGRATION_ADDRESS:$PORT
|
|
|
|
|
|
|
|
# fio tests for multi-process
|
|
|
|
sleep 1
|
|
|
|
$fio_py 4096 32 randrw 10 &
|
|
|
|
fiopid=$!
|
|
|
|
sleep 5
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
$rpc_py -s $rpc_first_addr kill_instance SIGTERM
|
2016-11-23 03:04:34 +00:00
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
rpc_second_addr="/var/tmp/spdk1.sock"
|
|
|
|
rpc_add_ip $rpc_second_addr $MIGRATION_ADDRESS
|
|
|
|
$rpc_py -s $rpc_second_addr add_portal_group 1 $MIGRATION_ADDRESS:$PORT
|
2018-02-21 17:51:16 +00:00
|
|
|
$rpc_py -s $rpc_second_addr construct_target_node target1 target1_alias 'Malloc0:0' '1:1' 64 -d
|
2016-11-23 03:04:34 +00:00
|
|
|
|
|
|
|
wait $fiopid
|
|
|
|
|
|
|
|
trap - SIGINT SIGTERM EXIT
|
|
|
|
|
|
|
|
iscsicleanup
|
|
|
|
|
2017-11-20 18:01:28 +00:00
|
|
|
$rpc_py -s $rpc_second_addr kill_instance SIGTERM
|
2016-11-23 03:04:34 +00:00
|
|
|
timing_exit ip_migration
|