From: Dave Chinner <dchinner@xxxxxxxxxx> The option parise in a messy loop of option parsing and actions on secondary arguments. Turn it into something much neater and esay to understand rather than a mess of temporary variables and tortured logic... Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> --- check | 420 +++++++++++++++++++++++-------------------------------------- common.rc | 19 +++ 2 files changed, 174 insertions(+), 265 deletions(-) diff --git a/check b/check index 57c143a..7d563e9 100755 --- a/check +++ b/check @@ -28,47 +28,41 @@ n_bad=0 bad="" notrun="" interrupt=true +diff="diff -u" +showme=false +expunge=true +have_test_arg=false +randomize=false +here=`pwd` +FSTYP=xfs + +SUPPORTED_TESTS="[0-9][0-9][0-9] [0-9][0-9][0-9][0-9]" + +# generic initialization +iam=check export QA_CHECK_FS=${QA_CHECK_FS:=true} -# number of diff lines from a failed test, 0 for whole output -export DIFF_LENGTH=${DIFF_LENGTH:=10} # by default don't output timestamps timestamp=${TIMESTAMP:=false} -# generic initialization -iam=check - -# we need common.config -if ! . ./common.config -then - echo "$iam: failed to source common.config" - exit 1 -fi +# number of diff lines from a failed test, 0 for whole output +export DIFF_LENGTH=${DIFF_LENGTH:=10} -# argument parsing first - currently very messy, needs cleanup. -_setenvironment() -{ - MSGVERB="text:action" - export MSGVERB -} +# by default don't output timestamps +timestamp=${TIMESTAMP:=false} usage() { echo "Usage: $0 [options] [testlist]"' -common options - -v verbose - check options -xfs test XFS (default) -udf test UDF -nfs test NFS -l line mode diff - -xdiff graphical mode diff -udiff show unified diff (default) -n show me, do not run tests - -q quick [deprecated] -T output timestamps -r randomize test order --large-fs optimise scratch device for large filesystems @@ -82,258 +76,181 @@ testlist options exit 0 } -here=`pwd` -rm -f $here/$iam.out -_setenvironment - -check=${check-true} +_setenvironment() +{ + MSGVERB="text:action" + export MSGVERB +} -diff="diff -u" -verbose=false -group=false -xgroup=false -showme=false -sortme=false -expunge=true -have_test_arg=false -randomize=false -rm -f $tmp.list $tmp.tmp $tmp.sed +get_group_list() +{ + grp=$1 -# Autodetect fs type based on what's on $TEST_DEV -if [ "$HOSTOS" == "Linux" ] -then - export FSTYP=`blkid -c /dev/null -s TYPE -o value $TEST_DEV` -else - export FSTYP=xfs -fi + grpl=$(sed -n < group \ + -e 's/#.*//' \ + -e 's/$/ /' \ + -e "/^[0-9][0-9][0-9].* $grp /"'{ s/ .*//p }') + echo $grpl +} -for r -do +expand_test_numbers() +{ + # strip leading zeros, could be considered octal. + start=`echo $1 | sed 's/^0*//'` + end=`echo $2 | sed 's/^0*//'` - if $group - then - # arg after -g - group_list=$(sed -n < group \ - -e 's/#.*//' \ - -e 's/$/ /' \ - -e "/^[0-9][0-9][0-9].* $r /"'{ s/ .*//p }') - if [ -z "$group_list" ] - then - echo "Group \"$r\" is empty or not defined?" - exit 1 - fi - [ ! -s $tmp.list ] && touch $tmp.list - for t in $group_list + $AWK_PROG </dev/null ' +BEGIN { for (t='$start'; t<='$end'; t++) printf "%03d\n",t }' \ + | while read id do - if grep -s "^$t\$" $tmp.list >/dev/null - then - : - else - echo "$t" >>$tmp.list - fi + if grep -s "^$id " group >/dev/null ; then + # in group file ... OK + echo $id >>$tmp.list + elif [ -f expunged ] && $expunge && \ + egrep "^$id([ ]|\$)" expunged >/dev/null ; then + # expunged ... will be reported, but not run, later + echo $id >>$tmp.list + else + # oops + echo "$id - unknown test, ignored" + fi done - group=false - continue +} - elif $xgroup - then - # arg after -x - [ ! -s $tmp.list ] && ls [0-9][0-9][0-9] [0-9][0-9][0-9][0-9] >$tmp.list 2>/dev/null - group_list=`sed -n <group -e 's/$/ /' -e "/^[0-9][0-9][0-9].* $r /"'{ -s/ .*//p -}'` - if [ -z "$group_list" ] - then - echo "Group \"$r\" is empty or not defined?" - exit 1 - fi - numsed=0 - rm -f $tmp.sed - for t in $group_list - do - if [ $numsed -gt 100 ] - then - sed -f $tmp.sed <$tmp.list >$tmp.tmp - mv $tmp.tmp $tmp.list - numsed=0 - rm -f $tmp.sed - fi - echo "/^$t\$/d" >>$tmp.sed - numsed=`expr $numsed + 1` - done - sed -f $tmp.sed <$tmp.list >$tmp.tmp - mv $tmp.tmp $tmp.list - xgroup=false - continue - fi +_wallclock() +{ + date "+%H %M %S" | $AWK_PROG '{ print $1*3600 + $2*60 + $3 }' +} - xpand=true - case "$r" - in +_timestamp() +{ + now=`date "+%T"` + echo -n " [$now]" +} - -\? | -h | --help) # usage - usage - ;; +# start the initialisation work now +_setenvironment - -udf) # -udf ... set FSTYP to udf - FSTYP=udf - xpand=false - ;; +rm -f $tmp.list $tmp.tmp $tmp.sed $here/$iam.out - -xfs) # -xfs ... set FSTYP to xfs - FSTYP=xfs - xpand=false - ;; +# Autodetect fs type based on what's on $TEST_DEV +if [ "$HOSTOS" == "Linux" ]; then + FSTYP=`blkid -c /dev/null -s TYPE -o value $TEST_DEV` +fi +export FSTYP - -nfs) # -nfs ... set FSTYP to nfs - FSTYP=nfs - xpand=false - ;; +# we need common.config +if ! . ./common.config +then + echo "$iam: failed to source common.config" + exit 1 +fi - -g) # -g group ... pick from group file - group=true - xpand=false - ;; +while [ $# -gt 0 ]; do + case "$1" in + -\? | -h | --help) usage ;; - -l) # line mode for diff, was default before - diff="diff" - xpand=false - ;; + -udf) FSTYP=udf ;; + -xfs) FSTYP=xfs ;; + -nfs) FSTYP=nfs ;; - -xdiff) # graphical diff mode - xpand=false + -g) group=$2 ; shift ; + group_list=$(get_group_list $group) + if [ -z "$group_list" ]; then + echo "Group \"$group\" is empty or not defined?" + exit 1 + fi - if [ ! -z "$DISPLAY" ] - then - which xdiff >/dev/null 2>&1 && diff=xdiff - which gdiff >/dev/null 2>&1 && diff=gdiff - which tkdiff >/dev/null 2>&1 && diff=tkdiff - which xxdiff >/dev/null 2>&1 && diff=xxdiff - fi - ;; - - -udiff) # show a unified diff, default now, keep for backward compat - xpand=false - diff="$diff -u" - ;; - - -q) # "quick", no longer used - always quick :-) - xpand=false - ;; - - -n) # show me, don't do it - showme=true - xpand=false - ;; - -r) # randomize test order - randomize=true - xpand=false - ;; - - -T) # turn on timestamp output - timestamp=true - xpand=false - ;; - - -v) - verbose=true - xpand=false - ;; - -x) # -x group ... exclude from group file - xgroup=true - xpand=false - ;; - '[0-9][0-9][0-9] [0-9][0-9][0-9][0-9]') - echo "No tests?" - status=1 - exit $status - ;; + [ ! -s $tmp.list ] && touch $tmp.list + for t in $group_list; do + grep -s "^$t\$" $tmp.list >/dev/null || \ + echo "$t" >>$tmp.list + done - [0-9]*-[0-9]*) - eval `echo $r | sed -e 's/^/start=/' -e 's/-/ end=/'` - ;; + ;; - [0-9]*-) - eval `echo $r | sed -e 's/^/start=/' -e 's/-//'` - end=`echo [0-9][0-9][0-9] [0-9][0-9][0-9][0-9] | sed -e 's/\[0-9]//g' -e 's/ *$//' -e 's/.* //'` - if [ -z "$end" ] - then - echo "No tests in range \"$r\"?" - status=1 - exit $status - fi - ;; + -x) xgroup=$2 ; shift ; + [ ! -s $tmp.list ] && ls $SUPPORTED_TESTS >$tmp.list 2>/dev/null + group_list=$(get_group_list $xgroup) + if [ -z "$group_list" ]; then + echo "Group \"$xgroup\" is empty or not defined?" + exit 1 + fi - --large-fs) - export LARGE_SCRATCH_DEV=yes - xpand=false - ;; + rm -f $tmp.sed + numsed=0 + for t in $group_list + do + if [ $numsed -gt 100 ]; then + sed -f $tmp.sed <$tmp.list >$tmp.tmp + mv $tmp.tmp $tmp.list + numsed=0 + rm -f $tmp.sed + fi + echo "/^$t\$/d" >>$tmp.sed + numsed=`expr $numsed + 1` + done + sed -f $tmp.sed <$tmp.list >$tmp.tmp + mv $tmp.tmp $tmp.list + ;; - -*) - usage - ;; + -l) diff="diff" ;; + -udiff) diff="$diff -u" ;; - --extra-space=*) - export SCRATCH_DEV_EMPTY_SPACE=${r#*=} - xpand=false - ;; + -n) showme=true ;; + -r) randomize=true ;; - *) - start=$r - end=$r - ;; + -T) timestamp=true ;; - esac + "$SUPPORTED_TESTS") + echo "No tests?" + status=1 + exit $status + ;; - # get rid of leading 0s as can be interpreted as octal - start=`echo $start | sed 's/^0*//'` - end=`echo $end | sed 's/^0*//'` + [0-9]*-[0-9]*) + eval `echo $1 | sed -e 's/^/start=/' -e 's/-/ end=/'` + expand_test_numbers $start $end + have_test_arg=true + ;; - if $xpand - then - have_test_arg=true - $AWK_PROG </dev/null ' -BEGIN { for (t='$start'; t<='$end'; t++) printf "%03d\n",t }' \ - | while read id - do - if grep -s "^$id " group >/dev/null - then - # in group file ... OK - echo $id >>$tmp.list - else - if [ -f expunged ] && $expunge && egrep "^$id([ ]|\$)" expunged >/dev/null - then - # expunged ... will be reported, but not run, later - echo $id >>$tmp.list - else - # oops - echo "$id - unknown test, ignored" + [0-9]*-) + eval `echo $1 | sed -e 's/^/start=/' -e 's/-//'` + end=`echo $SUPPORTED_TESTS | sed -e 's/\[0-9]//g' -e 's/ *$//' -e 's/.* //'` + if [ -z "$end" ]; then + echo "No tests in range \"$1\"?" + status=1 + exit $status fi - fi - done - fi + expand_test_numbers $start $end + have_test_arg=true + ;; + + --large-fs) export LARGE_SCRATCH_DEV=yes ;; + --extra-space=*) export SCRATCH_DEV_EMPTY_SPACE=${r#*=} ;; + + -*) usage ;; + *) expand_test_numbers $1 $1 ; + have_test_arg=true + ;; + esac + shift done -if [ -s $tmp.list ] -then +if [ -s $tmp.list ]; then # found some valid test numbers ... this is good : -else - if $have_test_arg - then +elif $have_test_arg; then # had test numbers, but none in group file ... do nothing touch $tmp.list - else +else # no test numbers, do everything from group file sed -n -e '/^[0-9][0-9][0-9]*/s/[ ].*//p' <group >$tmp.list - fi fi -# should be sort -n, but this did not work for Linux when this -# was ported from IRIX -# -list=`sort $tmp.list` +# sort the list of tests into numeric order +list=`sort -n $tmp.list` rm -f $tmp.list $tmp.tmp $tmp.sed if $randomize @@ -341,24 +258,6 @@ then list=`echo $list | awk -f randomize.awk` fi -case "$FSTYP" in - xfs) - [ "$XFS_LOGPRINT_PROG" = "" ] && _fatal "xfs_logprint not found" - [ "$XFS_REPAIR_PROG" = "" ] && _fatal "xfs_repair not found" - [ "$XFS_CHECK_PROG" = "" ] && _fatal "xfs_check not found" - [ "$XFS_DB_PROG" = "" ] && _fatal "xfs_db not found" - [ "$MKFS_XFS_PROG" = "" ] && _fatal "mkfs_xfs not found" - ;; - udf) - [ "$MKFS_UDF_PROG" = "" ] && _fatal "mkfs_udf/mkudffs not found" - ;; - btrfs) - [ "$MKFS_BTRFS_PROG" = "" ] && _fatal "mkfs.btrfs not found" - ;; - nfs) - ;; -esac - # we need common.rc if ! . ./common.rc then @@ -372,16 +271,7 @@ then exit 1 fi -_wallclock() -{ - date "+%H %M %S" | $AWK_PROG '{ print $1*3600 + $2*60 + $3 }' -} - -_timestamp() -{ - now=`date "+%T"` - echo -n " [$now]" -} +# Ok, time to start running... _wrapup() { diff --git a/common.rc b/common.rc index 0972d15..0babfed 100644 --- a/common.rc +++ b/common.rc @@ -161,6 +161,25 @@ then fi fi +# check for correct setup +case "$FSTYP" in + xfs) + [ "$XFS_LOGPRINT_PROG" = "" ] && _fatal "xfs_logprint not found" + [ "$XFS_REPAIR_PROG" = "" ] && _fatal "xfs_repair not found" + [ "$XFS_CHECK_PROG" = "" ] && _fatal "xfs_check not found" + [ "$XFS_DB_PROG" = "" ] && _fatal "xfs_db not found" + [ "$MKFS_XFS_PROG" = "" ] && _fatal "mkfs_xfs not found" + ;; + udf) + [ "$MKFS_UDF_PROG" = "" ] && _fatal "mkfs_udf/mkudffs not found" + ;; + btrfs) + [ "$MKFS_BTRFS_PROG" = "" ] && _fatal "mkfs.btrfs not found" + ;; + nfs) + ;; +esac + # make sure we have a standard umask umask 022 -- 1.7.10.4 _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs