Executable file
utils/mt_ezstep
— part of check-in
[ae5dd4f3a6]
at
2012-03-25 15:15:25
on branch trunk
— Added current dir to end of path so that on systems without . in the path the script will still be found
(user:
matt
size: 1850)
0000: 23 21 2f 62 69 6e 2f 62 61 73 68 0a 0a 75 73 61 #!/bin/bash..usa
0010: 67 65 3d 22 6d 74 5f 65 7a 73 74 65 70 20 73 74 ge="mt_ezstep st
0020: 65 70 6e 61 6d 65 20 70 72 65 76 73 74 65 70 6e epname prevstepn
0030: 61 6d 65 20 63 6f 6d 6d 61 6e 64 20 5b 61 72 67 ame command [arg
0040: 73 20 2e 2e 2e 5d 22 0a 0a 69 66 20 5b 20 22 24 s ...]"..if [ "$
0050: 4d 54 5f 43 4d 44 49 4e 46 4f 22 20 3d 3d 20 22 MT_CMDINFO" == "
0060: 22 20 5d 3b 74 68 65 6e 0a 20 20 65 63 68 6f 20 " ];then. echo
0070: 22 45 52 52 4f 52 3a 20 24 30 20 73 68 6f 75 6c "ERROR: $0 shoul
0080: 64 20 62 65 20 72 75 6e 20 77 69 74 68 69 6e 20 d be run within
0090: 61 20 6d 65 67 61 74 65 73 74 20 74 65 73 74 20 a megatest test
00a0: 65 6e 76 69 72 6f 6e 6d 65 6e 74 22 0a 20 20 65 environment". e
00b0: 63 68 6f 20 22 55 73 61 67 65 3a 20 24 75 73 61 cho "Usage: $usa
00c0: 67 65 22 0a 20 20 65 78 69 74 0a 66 69 0a 0a 23 ge". exit.fi..#
00d0: 20 50 75 72 70 6f 73 65 3a 20 54 68 69 73 20 69 Purpose: This i
00e0: 73 20 66 6f 72 20 74 68 65 20 5b 65 7a 73 74 65 s for the [ezste
00f0: 70 73 5d 20 73 65 63 74 6f 6e 20 69 6e 20 79 6f ps] secton in yo
0100: 75 72 20 74 65 73 74 63 6f 6e 66 69 67 20 66 69 ur testconfig fi
0110: 6c 65 2e 0a 23 20 20 20 44 4f 20 4e 4f 54 20 55 le..# DO NOT U
0120: 53 45 20 49 4e 20 59 4f 55 52 20 53 43 52 49 50 SE IN YOUR SCRIP
0130: 54 53 21 0a 23 0a 23 20 43 61 6c 6c 20 6c 69 6b TS!.#.# Call lik
0140: 65 20 74 68 69 73 3a 0a 23 20 6d 74 5f 65 7a 73 e this:.# mt_ezs
0150: 74 65 70 20 73 74 65 70 6e 61 6d 65 20 70 72 65 tep stepname pre
0160: 76 73 74 65 70 6e 61 6d 65 20 63 6f 6d 6d 61 6e vstepname comman
0170: 64 20 2e 2e 2e 2e 0a 23 20 0a 69 66 20 5b 20 22 d .....# .if [ "
0180: 78 24 31 22 20 3d 3d 20 22 78 22 20 5d 3b 74 68 x$1" == "x" ];th
0190: 65 6e 0a 20 20 65 63 68 6f 20 22 55 73 61 67 65 en. echo "Usage
01a0: 3a 20 24 75 73 61 67 65 22 0a 20 20 65 78 69 74 : $usage". exit
01b0: 0a 66 69 0a 0a 23 20 53 69 6e 63 65 20 74 68 65 .fi..# Since the
01c0: 20 75 73 65 72 20 6d 61 79 20 6e 6f 74 20 68 61 user may not ha
01d0: 76 65 20 2e 20 6f 6e 20 74 68 65 20 70 61 74 68 ve . on the path
01e0: 20 61 6e 64 20 73 69 6e 63 65 20 77 65 20 61 72 and since we ar
01f0: 65 20 6c 69 6b 65 6c 79 20 74 6f 20 77 61 6e 74 e likely to want
0200: 20 74 6f 20 0a 23 20 72 75 6e 20 74 65 73 74 20 to .# run test
0210: 73 63 72 69 70 74 73 20 69 6e 20 74 68 65 20 63 scripts in the c
0220: 75 72 72 65 6e 74 20 64 69 72 65 63 74 6f 72 79 urrent directory
0230: 20 61 64 64 20 74 68 65 20 63 75 72 72 65 6e 74 add the current
0240: 20 64 69 72 20 74 6f 20 74 68 65 20 70 61 74 68 dir to the path
0250: 0a 65 78 70 6f 72 74 20 50 41 54 48 3d 24 50 41 .export PATH=$PA
0260: 54 48 3a 24 50 57 44 0a 0a 73 74 65 70 6e 61 6d TH:$PWD..stepnam
0270: 65 3d 24 31 3b 73 68 69 66 74 0a 70 72 65 76 73 e=$1;shift.prevs
0280: 74 65 70 6e 61 6d 65 3d 24 31 3b 73 68 69 66 74 tepname=$1;shift
0290: 0a 0a 63 6f 6d 6d 61 6e 64 3d 24 2a 0a 0a 61 6c ..command=$*..al
02a0: 6c 73 74 61 74 75 73 3d 39 39 0a 72 75 6e 73 74 lstatus=99.runst
02b0: 61 74 75 73 3d 39 39 0a 6c 6f 67 70 72 6f 70 73 atus=99.logprops
02c0: 74 61 74 75 73 3d 39 39 0a 0a 70 72 65 76 5f 65 tatus=99..prev_e
02d0: 6e 76 3d 2e 65 7a 73 74 65 70 73 2f 24 7b 70 72 nv=.ezsteps/${pr
02e0: 65 76 73 74 65 70 6e 61 6d 65 7d 2e 73 68 0a 69 evstepname}.sh.i
02f0: 66 20 5b 20 2d 65 20 24 70 72 65 76 5f 65 6e 76 f [ -e $prev_env
0300: 20 5d 3b 74 68 65 6e 0a 20 20 20 20 73 6f 75 72 ];then. sour
0310: 63 65 20 24 70 72 65 76 5f 65 6e 76 0a 66 69 0a ce $prev_env.fi.
0320: 0a 23 20 73 6f 75 72 63 65 20 74 68 65 20 65 6e .# source the en
0330: 76 69 72 6f 6e 6d 65 6e 74 20 66 72 6f 6d 20 74 vironment from t
0340: 68 65 20 70 72 65 76 69 6f 75 73 20 73 74 65 70 he previous step
0350: 20 69 66 20 69 74 20 65 78 69 73 74 73 0a 0a 23 if it exists..#
0360: 20 69 66 20 61 20 6c 6f 67 70 72 6f 20 66 69 6c if a logpro fil
0370: 65 20 65 78 69 73 74 73 20 74 68 65 6e 20 75 73 e exists then us
0380: 65 20 69 74 20 6f 74 68 65 72 77 69 73 65 20 6a e it otherwise j
0390: 75 73 74 20 72 75 6e 20 74 68 65 20 63 6f 6d 6d ust run the comm
03a0: 61 6e 64 2c 20 6e 62 2f 2f 20 77 61 73 20 75 73 and, nb// was us
03b0: 69 6e 67 20 32 3e 26 31 0a 69 66 20 5b 20 2d 65 ing 2>&1.if [ -e
03c0: 20 24 7b 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 ${stepname}.log
03d0: 70 72 6f 20 5d 3b 74 68 65 6e 0a 20 20 20 23 20 pro ];then. #
03e0: 63 6f 75 6c 64 20 64 6f 3a 0a 20 20 20 24 63 6f could do:. $co
03f0: 6d 6d 61 6e 64 20 32 3e 26 31 7c 20 74 65 65 20 mmand 2>&1| tee
0400: 24 7b 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 20 ${stepname}.log
0410: 7c 20 6c 6f 67 70 72 6f 20 24 7b 73 74 65 70 6e | logpro ${stepn
0420: 61 6d 65 7d 2e 6c 6f 67 70 72 6f 20 24 7b 73 74 ame}.logpro ${st
0430: 65 70 6e 61 6d 65 7d 2e 68 74 6d 6c 20 26 3e 20 epname}.html &>
0440: 2f 64 65 76 2f 6e 75 6c 6c 0a 20 20 20 6c 6f 67 /dev/null. log
0450: 70 72 6f 73 74 61 74 75 73 3d 24 3f 0a 20 20 20 prostatus=$?.
0460: 23 20 24 63 6f 6d 6d 61 6e 64 20 32 3e 26 31 7c # $command 2>&1|
0470: 20 6c 6f 67 70 72 6f 20 24 7b 73 74 65 70 6e 61 logpro ${stepna
0480: 6d 65 7d 2e 6c 6f 67 70 72 6f 20 24 7b 73 74 65 me}.logpro ${ste
0490: 70 6e 61 6d 65 7d 2e 68 74 6d 6c 20 26 3e 20 24 pname}.html &> $
04a0: 7b 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 20 0a {stepname}.log .
04b0: 20 20 20 23 20 61 6c 6c 73 74 61 74 75 73 3d 28 # allstatus=(
04c0: 24 7b 50 49 50 45 53 54 41 54 55 53 5b 30 5d 7d ${PIPESTATUS[0]}
04d0: 20 24 7b 50 49 50 45 53 54 41 54 55 53 5b 31 5d ${PIPESTATUS[1]
04e0: 7d 29 20 0a 20 20 20 61 6c 6c 73 74 61 74 75 73 }) . allstatus
04f0: 3d 28 24 7b 50 49 50 45 53 54 41 54 55 53 5b 30 =(${PIPESTATUS[0
0500: 5d 7d 20 24 7b 50 49 50 45 53 54 41 54 55 53 5b ]} ${PIPESTATUS[
0510: 31 5d 7d 29 0a 20 20 20 72 75 6e 73 74 61 74 75 1]}). runstatu
0520: 73 3d 24 7b 61 6c 6c 73 74 61 74 75 73 5b 30 5d s=${allstatus[0]
0530: 7d 0a 20 20 20 23 20 6c 6f 67 70 72 6f 73 74 61 }. # logprosta
0540: 74 75 73 3d 24 7b 61 6c 6c 73 74 61 74 75 73 5b tus=${allstatus[
0550: 31 5d 7d 0a 65 6c 73 65 0a 20 20 20 24 63 6f 6d 1]}.else. $com
0560: 6d 61 6e 64 20 26 3e 20 24 7b 73 74 65 70 6e 61 mand &> ${stepna
0570: 6d 65 7d 2e 6c 6f 67 0a 20 20 20 72 75 6e 73 74 me}.log. runst
0580: 61 74 75 73 3d 24 3f 0a 20 20 20 6c 6f 67 70 72 atus=$?. logpr
0590: 6f 73 74 61 74 75 73 3d 24 72 75 6e 73 74 61 74 ostatus=$runstat
05a0: 75 73 0a 66 69 0a 0a 23 20 49 66 20 74 68 65 20 us.fi..# If the
05b0: 74 65 73 74 20 65 78 69 74 73 20 77 69 74 68 20 test exits with
05c0: 6e 6f 6e 2d 7a 65 72 6f 2c 20 77 65 20 77 69 6c non-zero, we wil
05d0: 6c 20 72 65 63 6f 72 64 20 46 41 49 4c 20 65 76 l record FAIL ev
05e0: 65 6e 20 69 66 20 6c 6f 67 70 72 6f 0a 23 20 73 en if logpro.# s
05f0: 61 79 73 20 69 74 20 69 73 20 61 20 50 41 53 53 ays it is a PASS
0600: 0a 0a 69 66 20 5b 20 24 72 75 6e 73 74 61 74 75 ..if [ $runstatu
0610: 73 20 2d 6e 65 20 30 20 5d 3b 20 74 68 65 6e 0a s -ne 0 ]; then.
0620: 20 20 20 20 65 78 69 74 73 74 61 74 75 73 3d 24 exitstatus=$
0630: 72 75 6e 73 74 61 74 75 73 0a 65 6c 69 66 20 5b runstatus.elif [
0640: 20 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d $logprostatus -
0650: 65 71 20 30 20 5d 3b 20 74 68 65 6e 0a 20 20 20 eq 0 ]; then.
0660: 20 65 78 69 74 73 74 61 74 75 73 3d 24 6c 6f 67 exitstatus=$log
0670: 70 72 6f 73 74 61 74 75 73 0a 65 6c 69 66 20 5b prostatus.elif [
0680: 20 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d $logprostatus -
0690: 65 71 20 32 20 5d 3b 20 74 68 65 6e 0a 20 20 20 eq 2 ]; then.
06a0: 20 65 78 69 74 73 74 61 74 75 73 3d 32 0a 65 6c exitstatus=2.el
06b0: 69 66 20 5b 20 24 6c 6f 67 70 72 6f 73 74 61 74 if [ $logprostat
06c0: 75 73 20 2d 65 71 20 31 20 5d 3b 20 74 68 65 6e us -eq 1 ]; then
06d0: 0a 20 20 20 20 65 78 69 74 73 74 61 74 75 73 3d . exitstatus=
06e0: 31 0a 65 6c 73 65 20 0a 20 20 20 20 65 78 69 74 1.else . exit
06f0: 73 74 61 74 75 73 3d 30 0a 66 69 0a 0a 24 4d 54 status=0.fi..$MT
0700: 5f 4d 45 47 41 54 45 53 54 20 2d 65 6e 76 32 66 _MEGATEST -env2f
0710: 69 6c 65 20 2e 65 7a 73 74 65 70 73 2f 24 7b 73 ile .ezsteps/${s
0720: 74 65 70 6e 61 6d 65 7d 0a 65 78 69 74 20 24 65 tepname}.exit $e
0730: 78 69 74 73 74 61 74 75 73 0a xitstatus.