1a65aafd0SDaniel Verkamp#!/usr/bin/env bash 2eb53c232Spaul luse# SPDX-License-Identifier: BSD-3-Clause 3eb53c232Spaul luse# Copyright (C) 2015 Intel Corporation 4eb53c232Spaul luse# All rights reserved. 5eb53c232Spaul luse# 6a65aafd0SDaniel Verkamp 7a65aafd0SDaniel Verkamprootdir=$(readlink -f $(dirname $0)) 80560976dSPawel Niedzwiecki 90560976dSPawel Niedzwiecki# In autotest_common.sh all tests are disabled by default. 100560976dSPawel Niedzwiecki# If the configuration of tests is not provided, no tests will be carried out. 11cff52180SDarek Stojaczykif [[ ! -f $1 ]]; then 12cff52180SDarek Stojaczyk echo "ERROR: SPDK test configuration not specified" 130560976dSPawel Niedzwiecki exit 1 140560976dSPawel Niedzwieckifi 150560976dSPawel Niedzwiecki 167ba67126SKarol Latecki# Autotest.sh, as part of autorun.sh, runs in a different 177ba67126SKarol Latecki# shell process than autobuild.sh. Use helper file to pass 187ba67126SKarol Latecki# over env variable containing libraries paths. 197ba67126SKarol Lateckiif [[ -e /tmp/spdk-ld-path ]]; then 207ba67126SKarol Latecki source /tmp/spdk-ld-path 217ba67126SKarol Lateckifi 227ba67126SKarol Latecki 23cff52180SDarek Stojaczyksource "$1" 24c9e5d2a6SSeth Howellsource "$rootdir/test/common/autotest_common.sh" 25c4bb610dSDaniel Verkampsource "$rootdir/test/nvmf/common.sh" 26a65aafd0SDaniel Verkamp 27a65aafd0SDaniel Verkampif [ $EUID -ne 0 ]; then 28a65aafd0SDaniel Verkamp echo "$0 must be run as root" 29a65aafd0SDaniel Verkamp exit 1 30a65aafd0SDaniel Verkampfi 31a65aafd0SDaniel Verkamp 32414e3d5fSDaniel Verkampif [ $(uname -s) = Linux ]; then 3316589c82SMichal Berger old_core_pattern=$(< /proc/sys/kernel/core_pattern) 3445c42ac2SMichal Berger mkdir -p "$output_dir/coredumps" 35a985a3aeSKarol Latecki # Set core_pattern to a known value to avoid ABRT, systemd-coredump, etc. 36a985a3aeSKarol Latecki # Dump the $output_dir path to a file so collector can pick it up while executing. 37a985a3aeSKarol Latecki # We don't set in in the core_pattern command line because of the string length limitation 38a985a3aeSKarol Latecki # of 128 bytes. See 'man core 5' for details. 399545f9acSMichal Berger echo "|$rootdir/scripts/core-collector.sh %P %s %t" > /proc/sys/kernel/core_pattern 40a985a3aeSKarol Latecki echo "$output_dir/coredumps" > "$rootdir/.coredump_path" 4150656e7aSJim Harris 4250656e7aSJim Harris # make sure nbd (network block device) driver is loaded if it is available 4350656e7aSJim Harris # this ensures that when tests need to use nbd, it will be fully initialized 4450656e7aSJim Harris modprobe nbd || true 4523040b8bSMichal Berger 4623040b8bSMichal Berger if udevadm=$(type -P udevadm); then 4723040b8bSMichal Berger "$udevadm" monitor --property &> "$output_dir/udev.log" & 4823040b8bSMichal Berger udevadm_pid=$! 4923040b8bSMichal Berger fi 503d834218SMichal Berger 51414e3d5fSDaniel Verkampfi 52414e3d5fSDaniel Verkamp 5306243cb0SMichal Bergerstart_monitor_resources 5406243cb0SMichal Berger 55cbda5664SMichal Bergertrap "autotest_cleanup || :; exit 1" SIGINT SIGTERM EXIT 5604b615bbSDaniel Verkamp 57a65aafd0SDaniel Verkamptiming_enter autotest 58a65aafd0SDaniel Verkamp 59a562812dSSeth Howellcreate_test_list 60a562812dSSeth Howell 61a65aafd0SDaniel Verkampsrc=$(readlink -f $(dirname $0)) 62dfa73e77SKarol Lateckiout=$output_dir 63a65aafd0SDaniel Verkampcd $src 64a65aafd0SDaniel Verkamp 6586ee572bSSeth Howellfreebsd_update_contigmem_mod 66a7d3e106SKarol Lateckifreebsd_set_maxsock_buf 6786ee572bSSeth Howell 6811abc273SMichal Bergerif [[ $CONFIG_COVERAGE == y ]]; then 6939fc8d8aSJim Harris # Print lcov version to log 70821bf38aSJim Harris $LCOV --version 71497d40b1SDaniel Verkamp # zero out coverage data 72125c6010SJim Harris $LCOV -q -c --no-external -i -t "Baseline" -d $src -o $out/cov_base.info 73497d40b1SDaniel Verkampfi 74497d40b1SDaniel Verkamp 750d61bf4bSDaniel Verkamp# Make sure the disks are clean (no leftover partition tables) 7606084c8bSMichal Bergertiming_enter pre_cleanup 776bef902cSJim Harris# Remove old domain socket pathname just in case 780618d6b0SDaniel Verkamprm -f /var/tmp/spdk*.sock 79a036277bSDarek Stojaczyk 800d61bf4bSDaniel Verkamp# Load the kernel driver 81de95290cSwanghailiangx$rootdir/scripts/setup.sh reset 820d61bf4bSDaniel Verkamp 830231fdc7SMichal Bergerget_zoned_devs 840231fdc7SMichal Berger 850231fdc7SMichal Bergerif ((${#zoned_devs[@]} > 0)); then 860231fdc7SMichal Berger # FIXME: For now make sure zoned devices are tested on-demand by 870231fdc7SMichal Berger # a designated tests instead of falling into any other. The main 880231fdc7SMichal Berger # concern here are fio workloads where specific configuration 890231fdc7SMichal Berger # must be in place for it to work with the zoned device. 900231fdc7SMichal Berger export PCI_BLOCKED="${zoned_devs[*]}" 91d2fe6d7dSMichal Berger export PCI_ZONED="${zoned_devs[*]}" 920231fdc7SMichal Bergerfi 930231fdc7SMichal Berger 9476f840c0SMichal Berger# Delete all leftover lvols and gpt partitions 9576f840c0SMichal Berger# Matches both /dev/nvmeXnY on Linux and /dev/nvmeXnsY on BSD 9676f840c0SMichal Berger# Filter out nvme with partitions - the "p*" suffix 97d81c3515SMichal Bergerfor dev in /dev/nvme*n!(*p*); do 980231fdc7SMichal Berger # Skip zoned devices as non-sequential IO will always fail 990231fdc7SMichal Berger [[ -z ${zoned_devs["${dev##*/}"]} ]] || continue 10076f840c0SMichal Berger if ! block_in_use "$dev"; then 10176f840c0SMichal Berger dd if=/dev/zero of="$dev" bs=1M count=1 10276f840c0SMichal Berger fi 10376f840c0SMichal Bergerdone 10476f840c0SMichal Berger 10576f840c0SMichal Bergersync 10676f840c0SMichal Berger 107575a302dSMichal Bergerif ! xtrace_disable_per_cmd reap_spdk_processes; then 108575a302dSMichal Berger echo "WARNING: Lingering SPDK processes were detected. Testing environment may be unstable" >&2 109575a302dSMichal Bergerfi 110575a302dSMichal Berger 111b4e49c37SJaroslaw Chachulskiif [[ $(uname -s) == Linux && $SPDK_TEST_SETUP -eq 1 ]]; then 112ec94874cSMichal Berger run_test "setup.sh" "$rootdir/test/setup/test-setup.sh" 113cea2c693SPawel Wodkowskifi 114cea2c693SPawel Wodkowski 115de95290cSwanghailiangx$rootdir/scripts/setup.sh status 116ec94874cSMichal Berger 117ce4d0709SMichal Bergerif [[ $(uname -s) == Linux ]]; then 1184c21ef36STomasz Zawadzki # Revert NVMe namespaces to default state 1194c21ef36STomasz Zawadzki nvme_namespace_revert 120ce4d0709SMichal Bergerfi 1214c21ef36STomasz Zawadzki 12206084c8bSMichal Bergertiming_exit pre_cleanup 1230d61bf4bSDaniel Verkamp 124a65aafd0SDaniel Verkamp# set up huge pages 125a65aafd0SDaniel Verkamptiming_enter afterboot 126de95290cSwanghailiangx$rootdir/scripts/setup.sh 127bfafdec9SDaniel Verkamptiming_exit afterboot 128a65aafd0SDaniel Verkamp 1292176f081SChunyang Hui# Revert existing OPAL to factory settings that may have been left from earlier failed tests. 1302176f081SChunyang Hui# This ensures we won't hit any unexpected failures due to NVMe SSDs being locked. 131919fdeceSChangpeng Liuopal_revert_cleanup 1322176f081SChunyang Hui 133a65aafd0SDaniel Verkamp##################### 134a65aafd0SDaniel Verkamp# Unit Tests 135a65aafd0SDaniel Verkamp##################### 136a65aafd0SDaniel Verkamp 13758ed3685SDaniel Verkampif [ $SPDK_TEST_UNITTEST -eq 1 ]; then 138de95290cSwanghailiangx run_test "unittest" $rootdir/test/unit/unittest.sh 13958ed3685SDaniel Verkampfi 140abfda721SDaniel Verkamp 1418604e568SDarek Stojaczykif [ $SPDK_RUN_FUNCTIONAL_TEST -eq 1 ]; then 14219e2dc38Spaul luse if [[ $SPDK_TEST_CRYPTO -eq 1 || $SPDK_TEST_VBDEV_COMPRESS -eq 1 ]]; then 1431aa72efaSMaciej Wawryk if [[ $SPDK_TEST_USE_IGB_UIO -eq 1 ]]; then 144de95290cSwanghailiangx $rootdir/scripts/qat_setup.sh igb_uio 1451aa72efaSMaciej Wawryk else 146de95290cSwanghailiangx $rootdir/scripts/qat_setup.sh 1471aa72efaSMaciej Wawryk fi 1481aa72efaSMaciej Wawryk fi 149a65aafd0SDaniel Verkamp timing_enter lib 150a65aafd0SDaniel Verkamp 1519f19acb5SKrzysztof Karas if [[ $SPDK_TEST_URING -eq 1 ]]; then 1529f19acb5SKrzysztof Karas export SPDK_SOCK_IMPL_DEFAULT="uring" 1539f19acb5SKrzysztof Karas fi 1549f19acb5SKrzysztof Karas 155de95290cSwanghailiangx run_test "env" $rootdir/test/env/env.sh 156de95290cSwanghailiangx run_test "rpc" $rootdir/test/rpc/rpc.sh 1572297826bSKrzysztof Karas run_test "skip_rpc" $rootdir/test/rpc/skip_rpc.sh 158de95290cSwanghailiangx run_test "rpc_client" $rootdir/test/rpc_client/rpc_client.sh 159de95290cSwanghailiangx run_test "json_config" $rootdir/test/json_config/json_config.sh 160de95290cSwanghailiangx run_test "json_config_extra_key" $rootdir/test/json_config/json_config_extra_key.sh 161de95290cSwanghailiangx run_test "alias_rpc" $rootdir/test/json_config/alias_rpc/alias_rpc.sh 162fa79ecf8SEmilia Haligowska 163fa79ecf8SEmilia Haligowska if [[ $SPDK_JSONRPC_GO_CLIENT -eq 0 ]]; then 164de95290cSwanghailiangx run_test "spdkcli_tcp" $rootdir/test/spdkcli/tcp.sh 165fa79ecf8SEmilia Haligowska fi 166fa79ecf8SEmilia Haligowska 167de95290cSwanghailiangx run_test "dpdk_mem_utility" $rootdir/test/dpdk_memory_utility/test_dpdk_mem_info.sh 168de95290cSwanghailiangx run_test "event" $rootdir/test/event/event.sh 169de95290cSwanghailiangx run_test "thread" $rootdir/test/thread/thread.sh 1708711e7e9SKamil Godzwon 1718711e7e9SKamil Godzwon if [[ $SPDK_TEST_ACCEL -eq 1 ]]; then 172de95290cSwanghailiangx run_test "accel" $rootdir/test/accel/accel.sh 173f3244a4fSKrzysztof Sprzaczkowski run_test "accel_rpc" $rootdir/test/accel/accel_rpc.sh 1748711e7e9SKamil Godzwon fi 1758711e7e9SKamil Godzwon 176de95290cSwanghailiangx run_test "app_cmdline" $rootdir/test/app/cmdline.sh 177508531e1SKonrad Sztyber run_test "version" $rootdir/test/app/version.sh 1788604e568SDarek Stojaczyk 1795681ff04SDaniel Verkamp if [ $SPDK_TEST_BLOCKDEV -eq 1 ]; then 180de95290cSwanghailiangx run_test "blockdev_general" $rootdir/test/bdev/blockdev.sh 181de95290cSwanghailiangx run_test "bdevperf_config" $rootdir/test/bdev/bdevperf/test_config.sh 18255f1698fSMichal Berger if [[ $(uname -s) == Linux ]]; then 183de95290cSwanghailiangx run_test "reactor_set_interrupt" $rootdir/test/interrupt/reactor_set_interrupt.sh 184de95290cSwanghailiangx run_test "reap_unregistered_poller" $rootdir/test/interrupt/reap_unregistered_poller.sh 18555f1698fSMichal Berger fi 1865681ff04SDaniel Verkamp fi 1875681ff04SDaniel Verkamp 188cac68eecSKamil Godzwon if [[ $SPDK_TEST_RAID -eq 1 ]]; then 189cac68eecSKamil Godzwon run_test "bdev_raid" $rootdir/test/bdev/bdev_raid.sh 190cac68eecSKamil Godzwon run_test "spdkcli_raid" $rootdir/test/spdkcli/raid.sh 191cac68eecSKamil Godzwon run_test "blockdev_raid5f" $rootdir/test/bdev/blockdev.sh "raid5f" 192cac68eecSKamil Godzwon fi 193cac68eecSKamil Godzwon 194a3a06515SMichal Berger if [[ $(uname -s) == Linux ]]; then 195a3a06515SMichal Berger if [[ $SPDK_TEST_BLOCKDEV -eq 1 || $SPDK_TEST_URING -eq 1 ]]; then 196c6db5f41SMichal Berger # The crypto job also includes the SPDK_TEST_BLOCKDEV in its configuration hence the 197c6db5f41SMichal Berger # dd tests are executed there as well. However, these tests can take a significant 198c6db5f41SMichal Berger # amount of time to complete (up to 4min) on a physical system leading to a potential 199c6db5f41SMichal Berger # job timeout. Avoid that by skipping these tests - this should not affect the coverage 200c6db5f41SMichal Berger # since dd tests are still run as part of the vg jobs. 201c6db5f41SMichal Berger if [[ $SPDK_TEST_CRYPTO -eq 0 ]]; then 202de95290cSwanghailiangx run_test "spdk_dd" $rootdir/test/dd/dd.sh 203a3a06515SMichal Berger fi 204a3a06515SMichal Berger fi 205c6db5f41SMichal Berger fi 206a3a06515SMichal Berger 2075681ff04SDaniel Verkamp if [ $SPDK_TEST_NVME -eq 1 ]; then 208de95290cSwanghailiangx run_test "blockdev_nvme" $rootdir/test/bdev/blockdev.sh "nvme" 2098419c294SMichal Berger if [[ $(uname -s) == Linux ]]; then 210de95290cSwanghailiangx run_test "blockdev_nvme_gpt" $rootdir/test/bdev/blockdev.sh "gpt" 2118419c294SMichal Berger fi 212de95290cSwanghailiangx run_test "nvme" $rootdir/test/nvme/nvme.sh 213e04da24cSKrishna Kanth Reddy if [[ $SPDK_TEST_NVME_PMR -eq 1 ]]; then 214de95290cSwanghailiangx run_test "nvme_pmr" $rootdir/test/nvme/nvme_pmr.sh 215e04da24cSKrishna Kanth Reddy fi 21681cfac61SMichal Berger 217de95290cSwanghailiangx run_test "nvme_scc" $rootdir/test/nvme/nvme_scc.sh 21881cfac61SMichal Berger 219e93e308dSKrishna Kanth Reddy if [[ $SPDK_TEST_NVME_BP -eq 1 ]]; then 220de95290cSwanghailiangx run_test "nvme_bp" $rootdir/test/nvme/nvme_bp.sh 221e93e308dSKrishna Kanth Reddy fi 222efbcd259STomasz Kulasek if [[ $SPDK_TEST_NVME_CUSE -eq 1 ]]; then 223de95290cSwanghailiangx run_test "nvme_cuse" $rootdir/test/nvme/cuse/nvme_cuse.sh 224efbcd259STomasz Kulasek fi 2250b55bf71SMichal Berger if [[ $SPDK_TEST_NVME_CMB -eq 1 ]]; then 226de95290cSwanghailiangx run_test "nvme_cmb" $rootdir/test/nvme/cmb/cmb.sh 2270b55bf71SMichal Berger fi 228c976353bSAnkit Kumar if [[ $SPDK_TEST_NVME_FDP -eq 1 ]]; then 229c976353bSAnkit Kumar run_test "nvme_fdp" test/nvme/nvme_fdp.sh 230c976353bSAnkit Kumar fi 2310231fdc7SMichal Berger 232d2fe6d7dSMichal Berger if [[ $SPDK_TEST_NVME_ZNS -eq 1 ]]; then 233de95290cSwanghailiangx run_test "nvme_zns" $rootdir/test/nvme/zns/zns.sh 234d2fe6d7dSMichal Berger fi 235d2fe6d7dSMichal Berger 236de95290cSwanghailiangx run_test "nvme_rpc" $rootdir/test/nvme/nvme_rpc.sh 237de95290cSwanghailiangx run_test "nvme_rpc_timeouts" $rootdir/test/nvme/nvme_rpc_timeouts.sh 2381826c4dcSSebastian Brzezinka 2391826c4dcSSebastian Brzezinka if [ $(uname -s) = Linux ]; then 240de95290cSwanghailiangx run_test "sw_hotplug" $rootdir/test/nvme/sw_hotplug.sh 2413e2b0689SKarol Latecki fi 24253ec23caSMichal Berger 24353ec23caSMichal Berger if [[ $SPDK_TEST_XNVME -eq 1 ]]; then 244de95290cSwanghailiangx run_test "nvme_xnvme" $rootdir/test/nvme/xnvme/xnvme.sh 245de95290cSwanghailiangx run_test "blockdev_xnvme" $rootdir/test/bdev/blockdev.sh "xnvme" 24640e8ee2aSYifan Bian # Run ublk with xnvme since they have similar kernel dependencies 247de95290cSwanghailiangx run_test "ublk" $rootdir/test/ublk/ublk.sh 248c7e4f9a0SChangpeng Liu run_test "ublk_recovery" $rootdir/test/ublk/ublk_recovery.sh 24953ec23caSMichal Berger fi 250*8531656dSAnkit Kumar 251*8531656dSAnkit Kumar if [[ $SPDK_TEST_NVME_INTERRUPT -eq 1 ]]; then 252*8531656dSAnkit Kumar run_test "nvme_interrupt" "$rootdir/test/nvme/interrupt.sh" 253*8531656dSAnkit Kumar fi 2545681ff04SDaniel Verkamp fi 2555681ff04SDaniel Verkamp 2565681ff04SDaniel Verkamp if [ $SPDK_TEST_IOAT -eq 1 ]; then 257de95290cSwanghailiangx run_test "ioat" $rootdir/test/ioat/ioat.sh 2585681ff04SDaniel Verkamp fi 259a65aafd0SDaniel Verkamp 260a65aafd0SDaniel Verkamp timing_exit lib 261a65aafd0SDaniel Verkamp 2624c438999SJim Harris if [ $SPDK_TEST_ISCSI -eq 1 ]; then 263de95290cSwanghailiangx run_test "iscsi_tgt" $rootdir/test/iscsi_tgt/iscsi_tgt.sh 264de95290cSwanghailiangx run_test "spdkcli_iscsi" $rootdir/test/spdkcli/iscsi.sh 2651e92d78aSBen Walker fi 2661e92d78aSBen Walker 2671edd9bf3SJim Harris if [ $SPDK_TEST_BLOBFS -eq 1 ]; then 268de95290cSwanghailiangx run_test "rocksdb" $rootdir/test/blobfs/rocksdb/rocksdb.sh 269de95290cSwanghailiangx run_test "blobstore" $rootdir/test/blobstore/blobstore.sh 270de95290cSwanghailiangx run_test "blobstore_grow" $rootdir/test/blobstore/blobstore_grow/blobstore_grow.sh 271de95290cSwanghailiangx run_test "blobfs" $rootdir/test/blobfs/blobfs.sh 27285bdd43bSBen Walker run_test "hello_blob" $SPDK_EXAMPLE_DIR/hello_blob \ 273a1c00096SWANGHAILIANG examples/blob/hello_world/hello_blob.json 2741edd9bf3SJim Harris fi 2751edd9bf3SJim Harris 2765681ff04SDaniel Verkamp if [ $SPDK_TEST_NVMF -eq 1 ]; then 277cbda5664SMichal Berger export NET_TYPE 27864569ea5SSeth Howell # The NVMe-oF run test cases are split out like this so that the parser that compiles the 27964569ea5SSeth Howell # list of all tests can properly differentiate them. Please do not merge them into one line. 28064569ea5SSeth Howell if [ "$SPDK_TEST_NVMF_TRANSPORT" = "rdma" ]; then 281de95290cSwanghailiangx run_test "nvmf_rdma" $rootdir/test/nvmf/nvmf.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 282de95290cSwanghailiangx run_test "spdkcli_nvmf_rdma" $rootdir/test/spdkcli/nvmf.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 28364569ea5SSeth Howell elif [ "$SPDK_TEST_NVMF_TRANSPORT" = "tcp" ]; then 284de95290cSwanghailiangx run_test "nvmf_tcp" $rootdir/test/nvmf/nvmf.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 2851b5d4b52SMichal Berger if [[ $SPDK_TEST_URING -eq 0 ]]; then 286de95290cSwanghailiangx run_test "spdkcli_nvmf_tcp" $rootdir/test/spdkcli/nvmf.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 287de95290cSwanghailiangx run_test "nvmf_identify_passthru" $rootdir/test/nvmf/target/identify_passthru.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 2881b5d4b52SMichal Berger fi 289de95290cSwanghailiangx run_test "nvmf_dif" $rootdir/test/nvmf/target/dif.sh 290de95290cSwanghailiangx run_test "nvmf_abort_qd_sizes" $rootdir/test/nvmf/target/abort_qd_sizes.sh 291af952d78SKonrad Sztyber # The keyring tests utilize NVMe/TLS 292af952d78SKonrad Sztyber run_test "keyring_file" "$rootdir/test/keyring/file.sh" 2935420e499SKonrad Sztyber if [[ "$CONFIG_HAVE_KEYUTILS" == y ]]; then 29404d51ba0SKonrad Sztyber run_test "keyring_linux" "$rootdir/scripts/keyctl-session-wrapper" \ 29504d51ba0SKonrad Sztyber "$rootdir/test/keyring/linux.sh" 2965420e499SKonrad Sztyber fi 29764569ea5SSeth Howell elif [ "$SPDK_TEST_NVMF_TRANSPORT" = "fc" ]; then 298de95290cSwanghailiangx run_test "nvmf_fc" $rootdir/test/nvmf/nvmf.sh --transport=$SPDK_TEST_NVMF_TRANSPORT 299de95290cSwanghailiangx run_test "spdkcli_nvmf_fc" $rootdir/test/spdkcli/nvmf.sh 30064569ea5SSeth Howell else 30164569ea5SSeth Howell echo "unknown NVMe transport, please specify rdma, tcp, or fc." 30264569ea5SSeth Howell exit 1 30364569ea5SSeth Howell fi 3045681ff04SDaniel Verkamp fi 30591330eb5SDaniel Verkamp 306e0001c6eSMichal Berger # For vfio_user and vhost tests We need to make sure entire HUGEMEM default 307e0001c6eSMichal Berger # goes to a single node as we share hugepages with qemu instance(s) and we 308e0001c6eSMichal Berger # cannot split it across all numa nodes without making sure there's enough 309e0001c6eSMichal Berger # memory available. 310e0001c6eSMichal Berger 3115681ff04SDaniel Verkamp if [ $SPDK_TEST_VHOST -eq 1 ]; then 312e0001c6eSMichal Berger HUGENODE=0 run_test "vhost" $rootdir/test/vhost/vhost.sh --iso 3135681ff04SDaniel Verkamp fi 3141dbf53eeSPiotr Pelplinski 315a0d255acSMao Jiang if [ $SPDK_TEST_VFIOUSER_QEMU -eq 1 ]; then 316e0001c6eSMichal Berger HUGENODE=0 run_test "vfio_user_qemu" $rootdir/test/vfio_user/vfio_user.sh --iso 317a0d255acSMao Jiang fi 318a0d255acSMao Jiang 3193a6f8dc8SLukasz Galka if [ $SPDK_TEST_LVOL -eq 1 ]; then 320de95290cSwanghailiangx run_test "lvol" $rootdir/test/lvol/lvol.sh 321de95290cSwanghailiangx run_test "blob_io_wait" $rootdir/test/blobstore/blob_io_wait/blob_io_wait.sh 3223a6f8dc8SLukasz Galka fi 3233a6f8dc8SLukasz Galka 32496bd1909SPawel Kaminski if [ $SPDK_TEST_VHOST_INIT -eq 1 ]; then 3259c3b481bSSeth Howell timing_enter vhost_initiator 326de95290cSwanghailiangx run_test "vhost_blockdev" $rootdir/test/vhost/initiator/blockdev.sh 327de95290cSwanghailiangx run_test "spdkcli_virtio" $rootdir/test/spdkcli/virtio.sh 328de95290cSwanghailiangx run_test "vhost_shared" $rootdir/test/vhost/shared/shared.sh 329de95290cSwanghailiangx run_test "vhost_fuzz" $rootdir/test/vhost/fuzz/fuzz.sh 3309c3b481bSSeth Howell timing_exit vhost_initiator 33196bd1909SPawel Kaminski fi 33296bd1909SPawel Kaminski 33357bce795SPawel Kaminski if [ $SPDK_TEST_RBD -eq 1 ]; then 334de95290cSwanghailiangx run_test "blockdev_rbd" $rootdir/test/bdev/blockdev.sh "rbd" 335de95290cSwanghailiangx run_test "spdkcli_rbd" $rootdir/test/spdkcli/rbd.sh 33657bce795SPawel Kaminski fi 33757bce795SPawel Kaminski 3382fde729fSVitaliy Mysak if [ $SPDK_TEST_OCF -eq 1 ]; then 339de95290cSwanghailiangx run_test "ocf" $rootdir/test/ocf/ocf.sh 3402fde729fSVitaliy Mysak fi 3412fde729fSVitaliy Mysak 3420291b284SArtur Paszkiewicz if [ $SPDK_TEST_FTL -eq 1 ]; then 343de95290cSwanghailiangx run_test "ftl" $rootdir/test/ftl/ftl.sh 3440291b284SArtur Paszkiewicz fi 3450291b284SArtur Paszkiewicz 3461d717c7cSWojciech Malikowski if [ $SPDK_TEST_VMD -eq 1 ]; then 347de95290cSwanghailiangx run_test "vmd" $rootdir/test/vmd/vmd.sh 3481d717c7cSWojciech Malikowski fi 34932e5d083SDarek Stojaczyk 35019e2dc38Spaul luse if [ $SPDK_TEST_VBDEV_COMPRESS -eq 1 ]; then 351de95290cSwanghailiangx run_test "compress_compdev" $rootdir/test/compress/compress.sh "compdev" 352de95290cSwanghailiangx run_test "compress_isal" $rootdir/test/compress/compress.sh "isal" 35332e5d083SDarek Stojaczyk fi 3542176f081SChunyang Hui 3552176f081SChunyang Hui if [ $SPDK_TEST_OPAL -eq 1 ]; then 356de95290cSwanghailiangx run_test "nvme_opal" $rootdir/test/nvme/nvme_opal.sh 3572176f081SChunyang Hui fi 358de303275SSeth Howell 359de303275SSeth Howell if [ $SPDK_TEST_CRYPTO -eq 1 ]; then 360de95290cSwanghailiangx run_test "blockdev_crypto_aesni" $rootdir/test/bdev/blockdev.sh "crypto_aesni" 361de95290cSwanghailiangx run_test "blockdev_crypto_sw" $rootdir/test/bdev/blockdev.sh "crypto_sw" 362de95290cSwanghailiangx run_test "blockdev_crypto_qat" $rootdir/test/bdev/blockdev.sh "crypto_qat" 3636060669eSKonrad Sztyber run_test "chaining" $rootdir/test/bdev/chaining.sh 364102731bdSMichal Berger fi 365c313f1b2SMichal Berger 366c313f1b2SMichal Berger if [[ $SPDK_TEST_SCHEDULER -eq 1 ]]; then 367de95290cSwanghailiangx run_test "scheduler" $rootdir/test/scheduler/scheduler.sh 368c313f1b2SMichal Berger fi 369cfbab2dcSJaroslaw Chachulski 370cfbab2dcSJaroslaw Chachulski if [[ $SPDK_TEST_SMA -eq 1 ]]; then 371de95290cSwanghailiangx run_test "sma" $rootdir/test/sma/sma.sh 372cfbab2dcSJaroslaw Chachulski fi 373c7385758SMichal Berger 374c7385758SMichal Berger if [[ $SPDK_TEST_FUZZER -eq 1 ]]; then 375de95290cSwanghailiangx run_test "llvm_fuzz" $rootdir/test/fuzz/llvm.sh 3768604e568SDarek Stojaczyk fi 37718384adcSAlexey Marchuk 37818384adcSAlexey Marchuk if [[ $SPDK_TEST_ACCEL_MLX5 -eq 1 ]]; then 37918384adcSAlexey Marchuk run_test "accel_mlx5_crypto" $rootdir/test/accel/mlx5/accel_mlx5_crypto.sh 380d987d777SAlexey Marchuk run_test "accel_mlx5_copy" $rootdir/test/accel/mlx5/accel_mlx5_copy.sh 38164627ae7SAlexey Marchuk run_test "accel_mlx5_crc32c" $rootdir/test/accel/mlx5/accel_mlx5_crc32c.sh 38218384adcSAlexey Marchuk fi 38366e8a091SSebastian Brzezinkafi 384651d9158SPawel Wodkowski 385405d338fSMichal Bergertrap - SIGINT SIGTERM EXIT 386405d338fSMichal Berger 38706084c8bSMichal Bergertiming_enter post_cleanup 388d1f9da82SSeth Howellautotest_cleanup 38906084c8bSMichal Bergertiming_exit post_cleanup 390a65aafd0SDaniel Verkamp 391a65aafd0SDaniel Verkamptiming_exit autotest 392a65aafd0SDaniel Verkampchmod a+r $output_dir/timing.txt 393a65aafd0SDaniel Verkamp 3948106e207SKarol Latecki[[ -f "$output_dir/udev.log" ]] && rm -f "$output_dir/udev.log" 3958106e207SKarol Latecki 39611abc273SMichal Bergerif [[ $CONFIG_COVERAGE == y ]]; then 397497d40b1SDaniel Verkamp # generate coverage data and combine with baseline 398125c6010SJim Harris $LCOV -q -c --no-external -d $src -t "$(hostname)" -o $out/cov_test.info 399dfa73e77SKarol Latecki $LCOV -q -a $out/cov_base.info -a $out/cov_test.info -o $out/cov_total.info 400978bc57aSDaniel Verkamp $LCOV -q -r $out/cov_total.info '*/dpdk/*' -o $out/cov_total.info 401125c6010SJim Harris # C++ headers in /usr can sometimes generate data even when specifying 402125c6010SJim Harris # --no-external, so remove them. But we need to add an ignore-errors 403125c6010SJim Harris # flag to squash warnings on systems where they don't generate data. 404125c6010SJim Harris $LCOV -q -r $out/cov_total.info --ignore-errors unused,unused '/usr/*' -o $out/cov_total.info 405888ea520SKarol Latecki $LCOV -q -r $out/cov_total.info '*/examples/vmd/*' -o $out/cov_total.info 406bf1deaffSKarol Latecki $LCOV -q -r $out/cov_total.info '*/app/spdk_lspci/*' -o $out/cov_total.info 407bdf1bf40SKarol Latecki $LCOV -q -r $out/cov_total.info '*/app/spdk_top/*' -o $out/cov_total.info 40827becf40SSeth Howell rm -f cov_base.info cov_test.info OLD_STDOUT OLD_STDERR 409497d40b1SDaniel Verkampfi 410