Further patches in series will modify the suppression file, so this patch now creates such file in /var/tmp/. Meanwhile adding the known false positive to the list. Any known false positives or leaks in external libs/execs should be added by adding further entries to the suppression file. Change-Id: I7b78d900a86c6eca0b41240fb34dc4f7ad597079 Signed-off-by: Tomasz Zawadzki <tomasz.zawadzki@intel.com> Reviewed-on: https://review.gerrithub.io/c/spdk/spdk/+/456622 Reviewed-by: Jim Harris <james.r.harris@intel.com> Reviewed-by: Darek Stojaczyk <dariusz.stojaczyk@intel.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
		
			
				
	
	
		
			148 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| set -ex
 | |
| 
 | |
| run_step() {
 | |
| 	if [ -z "$1" ]; then
 | |
| 		echo run_step called with no parameter
 | |
| 		exit 1
 | |
| 	fi
 | |
| 
 | |
| 	echo "--spdk=$ROCKSDB_CONF" >> "$1"_flags.txt
 | |
| 	echo "--spdk_bdev=Nvme0n1" >> "$1"_flags.txt
 | |
| 	echo "--spdk_cache_size=$CACHE_SIZE" >> "$1"_flags.txt
 | |
| 
 | |
| 	echo -n Start $1 test phase...
 | |
| 	/usr/bin/time taskset 0xFF $DB_BENCH --flagfile="$1"_flags.txt &> "$1"_db_bench.txt
 | |
| 	DB_BENCH_FILE=$(grep /dev/shm "$1"_db_bench.txt | cut -f 6 -d ' ')
 | |
| 	gzip $DB_BENCH_FILE
 | |
| 	mv $DB_BENCH_FILE.gz "$1"_trace.gz
 | |
| 	chmod 644 "$1"_trace.gz
 | |
| 	echo done.
 | |
| }
 | |
| 
 | |
| run_bsdump() {
 | |
| 	$rootdir/examples/blob/cli/blobcli -c $ROCKSDB_CONF -b Nvme0n1 -D &> bsdump.txt
 | |
| }
 | |
| 
 | |
| testdir=$(readlink -f $(dirname $0))
 | |
| rootdir=$(readlink -f $testdir/../../..)
 | |
| source $rootdir/test/common/autotest_common.sh
 | |
| 
 | |
| # In the autotest job, we copy the rocksdb source to just outside the spdk directory.
 | |
| DB_BENCH_DIR="$rootdir/../rocksdb"
 | |
| DB_BENCH=$DB_BENCH_DIR/db_bench
 | |
| ROCKSDB_CONF=$testdir/rocksdb.conf
 | |
| 
 | |
| if [ ! -e $DB_BENCH_DIR ]; then
 | |
| 	echo $DB_BENCH_DIR does not exist, skipping rocksdb tests
 | |
| 	exit 0
 | |
| fi
 | |
| 
 | |
| timing_enter rocksdb
 | |
| 
 | |
| timing_enter db_bench_build
 | |
| 
 | |
| pushd $DB_BENCH_DIR
 | |
| if [ -z "$SKIP_GIT_CLEAN" ]; then
 | |
| 	git clean -x -f -d
 | |
| fi
 | |
| $MAKE db_bench $MAKEFLAGS $MAKECONFIG DEBUG_LEVEL=0 SPDK_DIR=$rootdir
 | |
| popd
 | |
| 
 | |
| timing_exit db_bench_build
 | |
| 
 | |
| $rootdir/scripts/gen_nvme.sh > $ROCKSDB_CONF
 | |
| # 0x80 is the bit mask for BlobFS tracepoints
 | |
| echo "[Global]" >> $ROCKSDB_CONF
 | |
| echo "TpointGroupMask 0x80" >> $ROCKSDB_CONF
 | |
| 
 | |
| trap 'run_bsdump; rm -f $ROCKSDB_CONF; exit 1' SIGINT SIGTERM EXIT
 | |
| 
 | |
| if [ -z "$SKIP_MKFS" ]; then
 | |
| 	timing_enter mkfs
 | |
| 	$rootdir/test/blobfs/mkfs/mkfs $ROCKSDB_CONF Nvme0n1
 | |
| 	timing_exit mkfs
 | |
| fi
 | |
| 
 | |
| mkdir -p $output_dir/rocksdb
 | |
| RESULTS_DIR=$output_dir/rocksdb
 | |
| if [ $RUN_NIGHTLY -eq 1 ]; then
 | |
| 	CACHE_SIZE=4096
 | |
| 	DURATION=60
 | |
| 	NUM_KEYS=100000000
 | |
| else
 | |
| 	CACHE_SIZE=2048
 | |
| 	DURATION=20
 | |
| 	NUM_KEYS=20000000
 | |
| fi
 | |
| 
 | |
| cd $RESULTS_DIR
 | |
| cp $testdir/common_flags.txt insert_flags.txt
 | |
| echo "--benchmarks=fillseq" >> insert_flags.txt
 | |
| echo "--threads=1" >> insert_flags.txt
 | |
| echo "--disable_wal=1" >> insert_flags.txt
 | |
| echo "--use_existing_db=0" >> insert_flags.txt
 | |
| echo "--num=$NUM_KEYS" >> insert_flags.txt
 | |
| 
 | |
| cp $testdir/common_flags.txt randread_flags.txt
 | |
| echo "--benchmarks=readrandom" >> randread_flags.txt
 | |
| echo "--threads=16" >> randread_flags.txt
 | |
| echo "--duration=$DURATION" >> randread_flags.txt
 | |
| echo "--disable_wal=1" >> randread_flags.txt
 | |
| echo "--use_existing_db=1" >> randread_flags.txt
 | |
| echo "--num=$NUM_KEYS" >> randread_flags.txt
 | |
| 
 | |
| cp $testdir/common_flags.txt overwrite_flags.txt
 | |
| echo "--benchmarks=overwrite" >> overwrite_flags.txt
 | |
| echo "--threads=1" >> overwrite_flags.txt
 | |
| echo "--duration=$DURATION" >> overwrite_flags.txt
 | |
| echo "--disable_wal=1" >> overwrite_flags.txt
 | |
| echo "--use_existing_db=1" >> overwrite_flags.txt
 | |
| echo "--num=$NUM_KEYS" >> overwrite_flags.txt
 | |
| 
 | |
| cp $testdir/common_flags.txt readwrite_flags.txt
 | |
| echo "--benchmarks=readwhilewriting" >> readwrite_flags.txt
 | |
| echo "--threads=4" >> readwrite_flags.txt
 | |
| echo "--duration=$DURATION" >> readwrite_flags.txt
 | |
| echo "--disable_wal=1" >> readwrite_flags.txt
 | |
| echo "--use_existing_db=1" >> readwrite_flags.txt
 | |
| echo "--num=$NUM_KEYS" >> readwrite_flags.txt
 | |
| 
 | |
| cp $testdir/common_flags.txt writesync_flags.txt
 | |
| echo "--benchmarks=overwrite" >> writesync_flags.txt
 | |
| echo "--threads=1" >> writesync_flags.txt
 | |
| echo "--duration=$DURATION" >> writesync_flags.txt
 | |
| echo "--disable_wal=0" >> writesync_flags.txt
 | |
| echo "--use_existing_db=1" >> writesync_flags.txt
 | |
| echo "--sync=1" >> writesync_flags.txt
 | |
| echo "--num=$NUM_KEYS" >> writesync_flags.txt
 | |
| 
 | |
| timing_enter rocksdb_insert
 | |
| run_step insert
 | |
| timing_exit rocksdb_insert
 | |
| 
 | |
| timing_enter rocksdb_overwrite
 | |
| run_step overwrite
 | |
| timing_exit rocksdb_overwrite
 | |
| 
 | |
| timing_enter rocksdb_readwrite
 | |
| run_step readwrite
 | |
| timing_exit rocksdb_readwrite
 | |
| 
 | |
| timing_enter rocksdb_writesync
 | |
| run_step writesync
 | |
| timing_exit rocksdb_writesync
 | |
| 
 | |
| timing_enter rocksdb_randread
 | |
| run_step randread
 | |
| timing_exit rocksdb_randread
 | |
| 
 | |
| trap - SIGINT SIGTERM EXIT
 | |
| 
 | |
| run_bsdump
 | |
| rm -f $ROCKSDB_CONF
 | |
| 
 | |
| report_test_completion "blobfs"
 | |
| timing_exit rocksdb
 |