diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
commit | 19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch) | |
tree | 42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /src/spdk/test/fuzz/autofuzz_vhost.sh | |
parent | Initial commit. (diff) | |
download | ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip |
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/spdk/test/fuzz/autofuzz_vhost.sh')
-rwxr-xr-x | src/spdk/test/fuzz/autofuzz_vhost.sh | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/src/spdk/test/fuzz/autofuzz_vhost.sh b/src/spdk/test/fuzz/autofuzz_vhost.sh new file mode 100755 index 000000000..4b040ba82 --- /dev/null +++ b/src/spdk/test/fuzz/autofuzz_vhost.sh @@ -0,0 +1,75 @@ +#!/usr/bin/env bash + +rootdir=$(readlink -f $(dirname $0))/../.. +source $rootdir/test/common/autotest_common.sh +source "$rootdir/scripts/common.sh" + +TEST_TIMEOUT=1200 + +VHOST_APP+=(-p 0) +FUZZ_RPC_SOCK="/var/tmp/spdk_fuzz.sock" +VHOST_FUZZ_APP+=(-r "$FUZZ_RPC_SOCK" --wait-for-rpc) + +vhost_rpc_py="$rootdir/scripts/rpc.py" +fuzz_generic_rpc_py="$rootdir/scripts/rpc.py -s $FUZZ_RPC_SOCK" +fuzz_specific_rpc_py="$rootdir/test/app/fuzz/common/fuzz_rpc.py -s $FUZZ_RPC_SOCK" + +# This argument is used in addition to the test arguments in autotest_common.sh +for i in "$@"; do + case "$i" in + --timeout=*) + TEST_TIMEOUT="${i#*=}" + ;; + esac +done + +timing_enter vhost_fuzz_test + +#todo refactor this to use the vhosttestinit function when it becomes available. +timing_enter setup +$rootdir/scripts/setup.sh +timing_exit setup + +"${VHOST_APP[@]}" &> "$output_dir/vhost_fuzz_tgt_output.txt" & +vhostpid=$! +waitforlisten $vhostpid + +trap 'killprocess $vhostpid; exit 1' SIGINT SIGTERM exit + +"${VHOST_FUZZ_APP[@]}" -t $TEST_TIMEOUT 2> "$output_dir/vhost_autofuzz_output1.txt" & +fuzzpid=$! +waitforlisten $fuzzpid $FUZZ_RPC_SOCK + +trap 'killprocess $vhostpid; killprocess $fuzzpid; exit 1' SIGINT SIGTERM exit + +if [ "$TEST_TRANSPORT" == "bdev" ] || [ "$TEST_TRANSPORT" == "all" ]; then + $vhost_rpc_py bdev_malloc_create -b Malloc0 64 512 + $vhost_rpc_py vhost_create_blk_controller Vhost.1 Malloc0 + + # test the vhost blk controller with valid data buffers. + $fuzz_specific_rpc_py fuzz_vhost_create_dev -s $(pwd)/Vhost.1 -b -v +fi + +if [ "$TEST_TRANSPORT" == "scsi" ] || [ "$TEST_TRANSPORT" == "all" ]; then + $vhost_rpc_py bdev_malloc_create -b Malloc1 64 512 + $vhost_rpc_py vhost_create_scsi_controller naa.VhostScsi0.1 + $vhost_rpc_py vhost_scsi_controller_add_target naa.VhostScsi0.1 0 Malloc1 + + $vhost_rpc_py bdev_malloc_create -b Malloc2 64 512 + $vhost_rpc_py vhost_create_scsi_controller naa.VhostScsi0.2 + $vhost_rpc_py vhost_scsi_controller_add_target naa.VhostScsi0.2 0 Malloc2 + + # test the vhost scsi I/O queue with valid data buffers on a valid lun. + $fuzz_specific_rpc_py fuzz_vhost_create_dev -s $(pwd)/naa.VhostScsi0.1 -l -v + # test the vhost scsi management queue with valid data buffers. + $fuzz_specific_rpc_py fuzz_vhost_create_dev -s $(pwd)/naa.VhostScsi0.2 -v -m +fi + +# The test won't actually begin until this option is passed in. +$fuzz_generic_rpc_py framework_start_init + +wait $fuzzpid + +trap - SIGINT SIGTERM exit +killprocess $vhostpid +timing_exit vhost_fuzz_test |