public inbox for linux-xfs@vger.kernel.org
 help / color / mirror / Atom feed
From: Phil White <pwhite@sgi.com>
To: Dave Chinner <david@fromorbit.com>
Cc: xfs@oss.sgi.com
Subject: Re: [PATCH 15/25] xfstests: rework CLI individual test specification
Date: Sat, 23 Mar 2013 03:23:39 -0700	[thread overview]
Message-ID: <20130323102339.GS25253@caliban.engr.sgi.com> (raw)
In-Reply-To: <1363350489-22257-16-git-send-email-david@fromorbit.com>

Looks OK.

Reviewed-by: Phil White <pwhite@sgi.com>

On Fri, Mar 15, 2013 at 11:27:59PM +1100, Dave Chinner wrote:
> From: Dave Chinner <dchinner@redhat.com>
> 
> Now that tests are in separate subdirectories, they cannot be selected purely by
> test number on the command line. We need to specify the test by subdir and test
> name, so effectively we move to specifying them by regexes on the command line
> rather than by expanding a range internally. This is needed to support
> non-numeric test names as well, so the change may as well be made here.
> 
> This means the command line parsing needs to change from trying to detect tests
> by a regex match to a processing loop that simply parses the tests and checks
> for there existence. Hence the moment we find an argument that is not a switch
> (i.e no preceeding "-"), we move from the arg processing loop to the test name
> processing loop. IOWs, tests must be specified last on the command line.
> 
> Signed-off-by: Dave Chinner <dchinner@redhat.com>
> ---
>  check |   86 ++++++++++++++++++++++++++++-------------------------------------
>  1 file changed, 37 insertions(+), 49 deletions(-)
> 
> diff --git a/check b/check
> index 195c25d..620de0f 100755
> --- a/check
> +++ b/check
> @@ -71,8 +71,7 @@ check options
>  testlist options
>      -g group[,group...]	include tests from these groups
>      -x group[,group...]	exclude tests from these groups
> -    NNN			include test NNN
> -    NNN-NNN		include test range (eg. 012-021)
> +    [testlist]		include tests matching names in testlist
>  '
>  	    exit 0
>  }
> @@ -97,26 +96,6 @@ get_group_list()
>  	echo $grpl
>  }
>  
> -expand_test_numbers()
> -{
> -	# strip leading zeros, could be considered octal.
> -	start=`echo $1 | sed 's/^0*//'`
> -	end=`echo $2 | sed 's/^0*//'`
> -
> -	$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
> -			# oops
> -			echo "$id - unknown test, ignored"
> -		fi
> -	done
> -}
> -
>  _wallclock()
>  {
>      date "+%H %M %S" | $AWK_PROG '{ print $1*3600 + $2*60 + $3 }'
> @@ -146,6 +125,7 @@ then
>      exit 1
>  fi
>  
> +# Process command arguments first.
>  while [ $# -gt 0 ]; do
>  	case "$1" in
>  	-\? | -h | --help) usage ;;
> @@ -202,42 +182,50 @@ while [ $# -gt 0 ]; do
>  
>  	-T)	timestamp=true ;;
>  
> -	"$SUPPORTED_TESTS")
> -		echo "No tests?"
> -		status=1
> -		exit $status
> -		;;
> -
> -	[0-9]*-[0-9]*)
> -		eval `echo $1 | sed -e 's/^/start=/' -e 's/-/ end=/'`
> -		expand_test_numbers $start $end
> -		have_test_arg=true
> -		;;
> -
> -	[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
> -		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
> -		;;
> +	*)	# not an argument, we've got tests now.
> +		have_test_arg=true ;;
>  	esac
>  
> +	# if we've found a test specification, the break out of the processing
> +	# loop before we shift the arguments so that this is the first argument
> +	# that we process in the test arg loop below.
> +	if $have_test_arg; then
> +		break;
> +	fi
> +
>  	shift
>  done
>  
> +# Process tests from command line now.
> +if $have_test_arg; then
> +	while [ $# -gt 0 ]; do
> +		case "$1" in
> +		-*)	echo "Argments before tests, please!"
> +			status=1
> +			exit $status
> +			;;
> +		*)	test_dir=`dirname $1`
> +			test_name=`basename $1`
> +			group_file=$SRC_DIR/$test_dir/group
> +
> +			if grep "^$testname" $group_file >/dev/null ; then
> +				# in group file ... OK
> +				echo $SRC_DIR/$1 >>$tmp.list
> +			else
> +				# oops
> +				echo "$1 - unknown test, ignored"
> +			fi
> +			;;
> +		esac
> +
> +		shift
> +	done
> +fi
> +
>  if [ -s $tmp.list ]; then
>      # found some valid test numbers ... this is good
>      :
> -- 
> 1.7.10.4
> 
> _______________________________________________
> xfs mailing list
> xfs@oss.sgi.com
> http://oss.sgi.com/mailman/listinfo/xfs

_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs

  reply	other threads:[~2013-03-23 10:23 UTC|newest]

Thread overview: 59+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-03-15 12:27 [PATCH 00/25] xfstests: xfstests: move tests out of top level Dave Chinner
2013-03-15 12:27 ` [PATCH 01/25] xfstests: remove remake script Dave Chinner
2013-03-22 16:51   ` Phil White
2013-03-15 12:27 ` [PATCH 02/25] xfstests: remove bench infrastructure Dave Chinner
2013-03-15 19:36   ` Phil White
2013-03-19 22:31     ` Dave Chinner
2013-03-21 23:52       ` Phil White
2013-03-22  7:37         ` Dave Chinner
2013-03-22 16:22           ` Troy McCorkell
2013-03-26 20:26             ` Troy McCorkell
2013-03-22 16:53   ` Phil White
2013-03-15 12:27 ` [PATCH 03/25] xfstests: kill useless test owner fields Dave Chinner
2013-03-22 16:57   ` Phil White
2013-03-15 12:27 ` [PATCH 04/25] xfstests: remove stale machine configs Dave Chinner
2013-03-22 17:02   ` Phil White
2013-03-15 12:27 ` [PATCH 05/25] xfstests: fold common into check Dave Chinner
2013-03-23 10:18   ` Phil White
2013-03-15 12:27 ` [PATCH 06/25] xfstests: clean up and simply check CLI option parsing Dave Chinner
2013-03-23 10:19   ` Phil White
2013-03-15 12:27 ` [PATCH 07/25] xfstests: kill hangcheck stuff from check Dave Chinner
2013-03-23 10:19   ` Phil White
2013-03-15 12:27 ` [PATCH 08/25] xfstests: remove test expunge file support Dave Chinner
2013-03-23 10:19   ` Phil White
2013-03-15 12:27 ` [PATCH 09/25] xfstests: remove undocumented TESTS_REMAINING_LOG Dave Chinner
2013-03-23 10:20   ` Phil White
2013-03-15 12:27 ` [PATCH 10/25] xfstests: include test subdirectory support Dave Chinner
2013-03-23 10:20   ` Phil White
2013-03-15 12:27 ` [PATCH 11/25] xfstests: remove 285.full and 286.full Dave Chinner
2013-03-23 10:20   ` Phil White
2013-03-15 12:27 ` [PATCH 12/25] xfstests: move generic tests out of top level dir Dave Chinner
2013-03-23 10:22   ` Phil White
2013-03-15 12:27 ` [PATCH 13/25] xfstests: move xfs specific tests out of top directory Dave Chinner
2013-03-23 10:22   ` Phil White
2013-03-15 12:27 ` [PATCH 14/25] xfstests: move remaining tests out of top level directory Dave Chinner
2013-03-23 10:23   ` Phil White
2013-03-15 12:27 ` [PATCH 15/25] xfstests: rework CLI individual test specification Dave Chinner
2013-03-23 10:23   ` Phil White [this message]
2013-03-15 12:28 ` [PATCH 16/25] xfstests: make exclude groups aware of multiple subdirectories Dave Chinner
2013-03-23 10:23   ` Phil White
2013-03-15 12:28 ` [PATCH 17/25] xfstests: Introduce a results directory Dave Chinner
2013-03-23 10:23   ` Phil White
2013-03-15 12:28 ` [PATCH 18/25] xfstests: convert tests to use new " Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 19/25] xfstests: fix _link_out_file callers Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 20/25] xfstests: introduce a common directory Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 21/25] xfstests: Reintroduce configurable test expunging Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 22/25] xfstests: RESULTS_DIR needs to be an absolute path Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 23/25] xfstests: Decomplicate quota setup in 050 Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 24/25] xfstests: clean up test 262 output file use Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-15 12:28 ` [PATCH 25/25] xfstests: use _notrun for tape checks Dave Chinner
2013-03-23 10:24   ` Phil White
2013-03-27 10:51 ` [PATCH 00/25] xfstests: xfstests: move tests out of top level Rich Johnston
2013-03-27 10:51 ` Rich Johnston

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20130323102339.GS25253@caliban.engr.sgi.com \
    --to=pwhite@sgi.com \
    --cc=david@fromorbit.com \
    --cc=xfs@oss.sgi.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox