[Ocfs2-test-devel] [PATCH 1/9] single_run: Add single_run-WIP
    tristan.ye 
    tristan.ye at oracle.com
       
    Tue Sep  8 21:19:00 PDT 2009
    
    
  
Signed-off-by: Tristan Ye <tristan.ye at oracle.com>
On Tue, 2009-09-08 at 17:54 -0700, Sunil Mushran wrote:
> single_run-WIP is a work-in-progress single_run.
> 
> Signed-off-by: Sunil Mushran <sunil.mushran at oracle.com>
> ---
>  programs/python_common/Makefile          |    2 +
>  programs/python_common/single_run-WIP.sh |  561 ++++++++++++++++++++++++++++++
>  vendor/common/ocfs2-test.spec-generic.in |    1 +
>  3 files changed, 564 insertions(+), 0 deletions(-)
>  create mode 100755 programs/python_common/single_run-WIP.sh
> 
> diff --git a/programs/python_common/Makefile b/programs/python_common/Makefile
> index b95d675..289b1fd 100644
> --- a/programs/python_common/Makefile
> +++ b/programs/python_common/Makefile
> @@ -14,6 +14,7 @@ DIST_FILES = 	config_py.skel \
>  		setup.sh \
>  		o2tf.py \
>  		single_run.sh \
> +		single_run-WIP.sh \
>  		multiple_run.sh \
>  		remote_mount.py \
>  		remote_umount.py \
> @@ -24,6 +25,7 @@ BIN_EXTRA = 	config_py.skel \
>  		config_shell.skel \
>  		o2tf.py \
>  		single_run.sh \
> +		single_run-WIP.sh \
>  		remote_mount.py \
>  		remote_umount.py \
>  		command.py	\
> diff --git a/programs/python_common/single_run-WIP.sh b/programs/python_common/single_run-WIP.sh
> new file mode 100755
> index 0000000..503df3c
> --- /dev/null
> +++ b/programs/python_common/single_run-WIP.sh
> @@ -0,0 +1,561 @@
> +#!/bin/bash
> +#
> +
> +PATH=$PATH:`dirname ${0}`:/sbin
> +RUNTIME=300	# seconds
> +APP=`basename ${0}`
> +USERNAME=`/usr/bin/whoami`
> +DATE=`which date`
> +HOSTNAME=`which hostname`
> +SUDO="`which sudo` -u root"
> +DEBUGFS_BIN="`which sudo` -u root `which debugfs.ocfs2`"
> +TUNEFS_BIN="`which sudo` -u root `which tunefs.ocfs2`"
> +MKFS_BIN="`which sudo` -u root `which mkfs.ocfs2`"
> +CUT=`which cut`
> +AWK=`which awk`
> +MOUNT=`which mount`
> +UMOUNT=`which umount`
> +ECHO=`which echo`
> +MKDIR=`which mkdir`
> +CAT=`which cat`
> +MD5SUM=`which md5sum`
> +WGET=`which wget`
> +SEQ=`which seq`
> +DWNLD_PATH="http://oss.oracle.com/~smushran/ocfs2-test"
> +KERNEL_TARBALL="linux-kernel.tar.gz"
> +KERNEL_TARBALL_CHECK="${KERNEL_TARBALL}.md5sum"
> +
> +# log_message message
> +log_message()
> +{
> +	${ECHO} "`${DATE}  +\"%F %H:%M:%S\"` $@" >> ${LOGFILE}
> +}
> +
> +log_start()
> +{
> +	log_message $@
> +	START=$(date +%s)
> +}
> +
> +# log_end $?
> +log_end()
> +{
> +	if [ "$#" -lt "1" ]; then
> +      		${ECHO} "Error in log_end()"
> +		exit 1
> +	fi
> +
> +	END=$(date +%s)
> +	DIFF=$(( ${END} - ${START} ))
> +
> +	if [ ${1} -ne 0 ]; then
> +		log_message "FAILED (${DIFF} secs)"
> +	else
> +		log_message "PASSED (${DIFF} secs)"
> +	fi
> +
> +	START=0
> +}
> +
> +get_bits()
> +{
> +	if [ "$#" -lt "1" ]; then
> +      		${ECHO} "Error in get_bits()"
> +		exit 1
> +	fi
> +
> +	val=$1
> +
> +	for i in `${SEQ} 1 31`
> +	do
> +		if [ $[2 ** $i] -eq ${val} ]; then
> +			return $i
> +		fi
> +	done
> +
> +	exit 1
> +}
> +
> +# get_kernel_source $LOGDIR $DWNLD_PATH $KERNEL_TARBALL $KERNEL_TARBALL_CHECK
> +get_kernel_source()
> +{
> +	if [ "$#" -lt "4" ]; then
> +		${ECHO} "Error in get_kernel_source()"
> +		exit 1
> +	fi
> +
> +	logdir=$1
> +	dwnld_path=$2
> +	kernel_tarball=$3
> +	kernel_tarball_check=$4
> +
> +	cd ${logdir}
> +
> +	outlog=get_kernel_source.log
> +
> +	${WGET} -o ${outlog} ${dwnld_path}/${kernel_tarball_check}
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR downloading ${dwnld_path}/${kernel_tarball_check}"
> +		cd -
> +		exit 1
> +	fi
> +
> +	${WGET} -a ${outlog} ${dwnld_path}/${kernel_tarball}
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR downloading ${dwnld_path}/${kernel_tarball}"
> +		cd -
> +		exit 1
> +	fi
> +
> +	${MD5SUM} -c ${kernel_tarball_check} >>${outlog} 2>&1
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR ${kernel_tarball_check} check failed"
> +		cd -
> +		exit 1
> +	fi
> +	cd -
> +}
> +
> +# do_format() ${BLOCKSIZE} ${CLUSTERSIZE} ${FEATURES} ${DEVICE}
> +do_format() {
> +	if [ "$#" -lt "4" ]; then
> +      		${ECHO} "Error in do_format() $@"
> +		exit 1
> +	fi
> +
> +	blocksize=$1
> +	clustersize=$2
> +	features=$3
> +	device=$4
> +
> +	${MKFS_BIN} -x -b ${blocksize} -C ${clustersize} --fs-features=${features} \
> +		-N 1 -L single_run -M local ${device} >/dev/null
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR: mkfs.ocfs2 -b ${blocksize} -C ${clustersize} " \
> +			"--fs-features=${features} -N 1 -L single_run -M local ${device}"
> +		exit 1
> +	fi
> +}
> +
> +# do_mount ${DEVICE} ${MOUNTPOINT} ${MOUNTOPTS}
> +do_mount() {
> +	if [ "$#" -lt "3" ]; then
> +      		${ECHO} "Error in do_mount()"
> +		exit 1
> +	fi
> +
> +	device=$1
> +	mountpoint=$2
> +	mountopts=$3	
> +
> +	${MOUNT} -o ${mountopts} ${device} ${mountpoint} >/dev/null
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR: mount -o ${mountopts} ${device} ${mountpoint}"
> +		exit 1
> +	fi
> +}
> +
> +# do_umount ${MOUNTPOINT}
> +do_umount() {
> +	if [ "$#" -lt "1" ]; then
> +		${ECHO} "Error in do_umount()"
> +		exit 1
> +	fi
> +
> +	mountpoint=$1
> +
> +	${UMOUNT} ${mountpoint}
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR: umount ${mountpoint}"
> +		exit 1
> +	fi
> +}
> +
> +# do_mkdir DIR
> +do_mkdir() {
> +	if [ "$#" -lt "1" ]; then
> +		${ECHO} "Error in do_mkdir()"
> +		exit 1
> +	fi
> +
> +	${MKDIR} -p $1
> +	if [ $? -ne 0 ]; then
> +		${ECHO} "ERROR: mkdir $1"
> +		exit 1
> +	fi
> +}
> +
> +# run_aiostress ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +run_aiostress()
> +{
> +	log_message "run_aiostress" $@
> +        if [ "$#" -lt "3" ]; then
> +                echo "Error in run_aiostress()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +
> +	workdir=${mountpoint}/testme
> +	blocksize=4096
> +	clustersize=8192
> +	features="sparse,unwritten,inline-data"
> +
> +	for mopt in writeback ordered
> +	do
> +		mountopts="data=${mopt}"
> +
> +		log_start "aio-stress" ${mountopts}
> +
> +		do_format ${blocksize} ${clustersize} ${features} ${device}
> +		do_mount ${device} ${mountpoint} ${mountopts}
> +		do_mkdir ${workdir}
> +
> +		F1="${workdir}/aiostress1.dat"
> +		F2="${workdir}/aiostress2.dat"
> +		F3="${workdir}/aiostress3.dat"
> +		F4="${workdir}/aiostress4.dat"
> +
> +		outlog=${logdir}/aiostress_${mopt}.log
> +
> +		aio-stress -a 4k -b 32 -i 16 -O -l -L -t 8 -v ${F1} ${F2} ${F3} ${F4} >${outlog} 2>&1
> +		RC=$?
> +
> +		do_umount ${mountpoint}
> +	
> +		log_end ${RC}
> +	done
> +}
> +
> +# run_buildkernel ${LOGDIR} ${DEVICE} {MOUNTPOINT} ${KERNELSRC}
> +run_buildkernel()
> +{
> +	log_message "run_buildkernel" $@
> +        if [ "$#" -lt "4" ]; then
> +                echo "Error in run_buildkernel()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +	kernelsrc=$4
> +
> +	node=`${HOSTNAME}`
> +	workdir=${mountpoint}/testme
> +	blocksize=4096
> +	clustersize=4096
> +	features="sparse,unwritten,inline-data"
> +
> +	for mopt in writeback ordered
> +	do
> +		mountopts="data=${mopt}"
> +
> +		do_format ${blocksize} ${clustersize} ${features} ${device}
> +		do_mount ${device} ${mountpoint} ${mountopts}
> +		do_mkdir ${workdir}
> +
> +		log_start "buildkernel" ${mountopts}
> +
> +		outlog=${logdir}/buildkernel_${mopt}.log
> +
> +		buildkernel.py -e -d ${workdir} -t ${kernelsrc} -n ${node} -l ${outlog}.1
> +		RC=$?
> +		if [ ${RC} -eq 0 ]; then
> +			buildkernel.py -d ${workdir} -t ${kernelsrc} -n ${node} -l ${outlog}.2
> +			RC=$?
> +		fi
> +
> +		do_umount ${mountpoint}
> +
> +		log_end ${RC}
> +	done
> +}
> +
> +# run_filesizelimits ${LOGDIR} ${DEVICE} {MOUNTPOINT}
> +run_filesizelimits()
> +{
> +	log_message "run_filesizelimits" $@
> +        if [ "$#" -lt "3" ]; then
> +                echo "Error in run_filesizelimits()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +
> +	mountopts=defaults
> +	clustersize=4096
> +	blocksize=4096
> +
> +	get_bits $blocksize
> +	blocksize_bits=$?
> +
> +	get_bits $clustersize
> +	clustersize_bits=$?
> +
> +	workdir=${mountpoint}/testme
> +
> +	if [ `uname -m` == "i686" ]; then
> +		bitsperlong=32
> +	else
> +		bitsperlong=64
> +	fi
> +
> +	log_start "check_file_size_limits"
> +
> +	do_format ${blocksize} ${clustersize} sparse,unwritten,inline-data ${device}
> +	do_mount ${device} ${mountpoint} ${mountopts}
> +	do_mkdir ${workdir}
> +
> +	file="${workdir}/filesizelimits.dat"
> +	outlog=${logdir}/filesizelimits.log
> +
> +	check_file_size_limits -B ${bitsperlong} -b ${blocksize_bits} \
> +		-c ${clustersize_bits} ${file} >${outlog} 2>&1
> +	RC=$?
> +
> +	do_umount ${mountpoint}
> +
> +	log_end ${RC}
> +}
> +
> +# run_fillverifyholes ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +run_fillverifyholes()
> +{
> +	log_message "run_fillverifyholes" $@
> +        if [ "$#" -lt "3" ]; then
> +                echo "Error in run_fillverifyholes()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +
> +	workdir=${mountpoint}/testme
> +
> +	varfile=${logdir}/fillverifyholes.txt
> +
> +	${CAT} > ${varfile} <<EOF
> +2048	4096	nosparse,nounwritten,noinline-data	data=ordered
> +2048	65536	sparse,unwritten,inline-data		data=writeback
> +4096	4096	sparse,unwritten,inline-data		data=ordered
> +4096	8192	nosparse,nounwritten,noinline-data	data=writeback
> +4096	131072	nosparse,nounwritten,noinline-data	data=ordered
> +4096	1048576	sparse,unwritten,inline-data		data=writeback
> +EOF
> +	if [ $? != 0 ]; then
> +		${ECHO} "ERROR writing ${varfile}"
> +		exit 1
> +	fi
> +
> +	i=0
> +	${CAT} ${varfile} | while read LINE
> +	do
> +        	blocksize=`echo ${LINE} | cut -f1 -d' '`
> +        	clustersize=`echo ${LINE} | cut -f2 -d' '`
> +        	features=`echo ${LINE} | cut -f3 -d' '`
> +		mountopts=`echo ${LINE} | cut -f4 -d' '`
> +
> +		log_start "fill_verify_holes" ${blocksize} ${clustersize} ${features} ${mountopts}
> +
> +		outlog=${logdir}/fillverifyholes_${i}.log
> +		ldir=${logdir}/fillverifyholes_${i}
> +		do_mkdir ${ldir}
> +
> +		do_format ${blocksize} ${clustersize} ${features} ${device}
> +		do_mount ${device} ${mountpoint} ${mountopts}
> +		do_mkdir ${workdir}
> +
> +		burn-in.sh -b ${bindir} -l ${ldir} -c 10 -d ${workdir} -i 100 -s 5000000 >${outlog} 2>&1
> +		RC=$?
> +
> +		do_umount ${mountpoint}
> +
> +		log_end ${RC}
> +
> +		i=$[$i+1]
> +	done
> +}
> +
> +# run_mmaptruncate ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +run_mmaptruncate()
> +{
> +	log_message "run_mmaptruncate" $@
> +        if [ "$#" -lt "3" ]; then
> +                echo "Error in run_mmaptruncate()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +
> +	runtime=300
> +	workfile=${mountpoint}/mmaptruncate.txt
> +	varfile=${logdir}/mmaptruncate.conf
> +
> +	${CAT} > ${varfile} <<EOF
> +2048	4096	nosparse,nounwritten,noinline-data	data=ordered
> +2048	65536	sparse,unwritten,inline-data		data=writeback
> +4096	4096	sparse,unwritten,inline-data		data=ordered
> +4096	8192	nosparse,nounwritten,noinline-data	data=writeback
> +4096	131072	sparse,unwritten,inline-data		data=ordered
> +4096	1048576	sparse,unwritten,inline-data		data=writeback
> +EOF
> +	if [ $? != 0 ]; then
> +		${ECHO} "ERROR writing ${varfile}"
> +		exit 1
> +	fi
> +
> +	${CAT} ${varfile} | while read LINE
> +	do
> +        	blocksize=`echo ${LINE} | cut -f1 -d' '`
> +        	clustersize=`echo ${LINE} | cut -f2 -d' '`
> +        	features=`echo ${LINE} | cut -f3 -d' '`
> +		mountopts=`echo ${LINE} | cut -f4 -d' '`
> +
> +		get_bits $clustersize
> +		clustersize_bits=$?
> +
> +		log_start "mmap_truncate" ${blocksize} ${clustersize} ${features} ${mountopts}
> +
> +		do_format ${blocksize} ${clustersize} ${features} ${device}
> +		do_mount ${device} ${mountpoint} ${mountopts}
> +
> +		mmap_truncate -c ${clustersize_bits} -s ${runtime} ${workfile}
> +		RC=$?
> +
> +		sleep 10
> +		do_umount ${mountpoint}
> +
> +		log_end ${RC}
> +	done
> +}
> +
> +# run_renamewriterace ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +run_renamewriterace()
> +{
> +	log_message "run_renamewriterace" $@
> +        if [ "$#" -lt "3" ]; then
> +                echo "Error in run_renamewriterace()"
> +                exit 1
> +        fi
> +
> +	logdir=$1
> +	device=$2
> +	mountpoint=$3
> +
> +	workdir=${mountpoint}/testme
> +	blocksize=4096
> +	clustersize=4096
> +	features="sparse,unwritten,inline-data"
> +
> +	for mopt in writeback ordered
> +	do
> +		mountopts="data=${mopt}"
> +
> +		log_start "rename_write_race" ${mountopts}
> +
> +		do_format ${blocksize} ${clustersize} ${features} ${device}
> +		do_mount ${device} ${mountpoint} ${mountopts}
> +		do_mkdir ${workdir}
> +
> +                outlog=${logdir}/renamewriterace_${mopt}.log
> +
> +		rename_write_race.sh -d ${workdir} -i 10000 >${outlog} 2>&1
> +		RC=$?
> +
> +		do_umount ${mountpoint}
> +
> +		log_end ${RC}
> +	done
> +}
> +
> +#
> +#
> +# MAIN
> +#
> +#
> +
> +usage()
> +{
> +	${ECHO} "usage: ${APP} [-k kerneltarball] -m mountpoint -l logdir -d device"
> +	exit 1
> +}
> +
> +while getopts "d:m:k:l:h?" args
> +do
> +	case "$args" in
> +		d) DEVICE="$OPTARG";;
> +		m) MOUNTPOINT="$OPTARG";;
> +		k) KERNELSRC="$OPTARG";;
> +		l) OUTDIR="$OPTARG";;
> +    		h) usage;;
> +    		?) usage;;
> +  	esac
> +done
> +
> +if [ -z ${DEVICE} ] ; then
> +	${ECHO} "ERROR: No device"
> +	usage
> +elif [ ! -b ${DEVICE} ] ; then
> +	${ECHO} "ERROR: Invalid device ${DEVICE}"
> +	exit 1
> +fi
> +
> +if [ -z ${MOUNTPOINT} ] ; then
> +	${ECHO} "ERROR: No mountpoint"
> +	usage
> +elif [ ! -d ${MOUNTPOINT} ] ; then
> +	${ECHO} "ERROR: Invalid mountpoint ${MOUNTPOINT}"
> +	exit 1
> +fi
> +
> +if [ -z ${OUTDIR} ]; then
> +	${ECHO} "ERROR: No logdir"
> +	usage
> +fi
> +
> +RUNDATE=`${DATE} +%F_%H:%M`
> +LOGDIR=${OUTDIR}/${RUNDATE}
> +LOGFILE=${LOGDIR}/single_run.log
> +
> +do_mkdir ${LOGDIR}
> +
> +if [ -z ${KERNELSRC} ]; then
> +	get_kernel_source $LOGDIR $DWNLD_PATH $KERNEL_TARBALL $KERNEL_TARBALL_CHECK
> +	KERNELSRC=${LOGDIR}/${KERNEL_TARBALL}
> +fi
> +
> +if [ ! -f ${KERNELSRC} ]; then
> +	${ECHO} "No kernel source"
> +	usage
> +fi
> +
> +STARTRUN=$(date +%s)
> +log_message "*** Start Single Node test ***"
> +
> +${ECHO} "Output log is ${LOGFILE}"
> +
> +run_fillverifyholes ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +
> +run_renamewriterace ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +
> +run_aiostress ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +
> +run_filesizelimits ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +
> +run_mmaptruncate ${LOGDIR} ${DEVICE} ${MOUNTPOINT}
> +
> +run_buildkernel ${LOGDIR} ${DEVICE} ${MOUNTPOINT} ${KERNELSRC}
> +
> +ENDRUN=$(date +%s)
> +
> +DIFF=$(( ${ENDRUN} - ${STARTRUN} ))
> +log_message "Total Runtime ${DIFF} seconds"
> +log_message "*** End Single Node test ***"
> diff --git a/vendor/common/ocfs2-test.spec-generic.in b/vendor/common/ocfs2-test.spec-generic.in
> index bae26d2..b37e870 100644
> --- a/vendor/common/ocfs2-test.spec-generic.in
> +++ b/vendor/common/ocfs2-test.spec-generic.in
> @@ -113,6 +113,7 @@ rm -rf "$RPM_BUILD_ROOT"
>  %{_installdir}/bin/open_delete.py
>  %{_installdir}/bin/o2tf.py
>  %{_installdir}/bin/single_run.sh
> +%{_installdir}/bin/single_run-WIP.sh
>  %{_installdir}/bin/remote_mount.py
>  %{_installdir}/bin/remote_umount.py
>  %{_installdir}/bin/command.py
    
    
More information about the Ocfs2-test-devel
mailing list