Use context-independent paths instead. This allows running the test from $PWD different than $rootdir. Change-Id: Id3835aab46bcd473d3852e5e1e0d6b2c1d241b37 Signed-off-by: Darek Stojaczyk <dariusz.stojaczyk@intel.com> Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/2752 Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Community-CI: Mellanox Build Bot Reviewed-by: Shuhei Matsumoto <shuhei.matsumoto.xt@hitachi.com> Reviewed-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com>
57 lines
1.4 KiB
Bash
Executable File
57 lines
1.4 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
testdir=$(readlink -f $(dirname $0))
|
|
rootdir=$(readlink -f $testdir/../..)
|
|
source $rootdir/test/common/autotest_common.sh
|
|
|
|
# simply check if rpc commands have any effect on spdk
|
|
function rpc_integrity() {
|
|
time {
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "0" ]
|
|
|
|
malloc=$($rpc bdev_malloc_create 8 512)
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "1" ]
|
|
|
|
$rpc bdev_passthru_create -b "$malloc" -p Passthru0
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "2" ]
|
|
|
|
$rpc bdev_passthru_delete Passthru0
|
|
$rpc bdev_malloc_delete $malloc
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "0" ]
|
|
}
|
|
}
|
|
|
|
function rpc_plugins() {
|
|
time {
|
|
malloc=$($rpc --plugin rpc_plugin create_malloc)
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "1" ]
|
|
|
|
$rpc --plugin rpc_plugin delete_malloc $malloc
|
|
bdevs=$($rpc bdev_get_bdevs)
|
|
[ "$(jq length <<< "$bdevs")" == "0" ]
|
|
}
|
|
}
|
|
|
|
$rootdir/app/spdk_tgt/spdk_tgt &
|
|
spdk_pid=$!
|
|
trap 'killprocess $spdk_pid; exit 1' SIGINT SIGTERM EXIT
|
|
waitforlisten $spdk_pid
|
|
|
|
export PYTHONPATH=$testdir
|
|
|
|
# basic integrity test
|
|
rpc="$rootdir/scripts/rpc.py"
|
|
run_test "rpc_integrity" rpc_integrity
|
|
run_test "rpc_plugins" rpc_plugins
|
|
# same integrity test, but with rpc_cmd() instead
|
|
rpc="rpc_cmd"
|
|
run_test "rpc_daemon_integrity" rpc_integrity
|
|
|
|
trap - SIGINT SIGTERM EXIT
|
|
killprocess $spdk_pid
|