xref: /spdk/autotest.sh (revision 8531656d379a9809102b4858f69950decf92a1c5)
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