Artifact
dc6e288c61060e14a4ff6f1209234e296dff8ac6 :
Executable file
utils/mt_ezstep
— part of check-in
[da3de938e3]
at
2012-03-04 16:47:50
on branch servermode
— Multiple small fixes made, not ready for prime time ....
(user:
matt
size: 1528)
[more...]
0000: 23 21 2f 62 69 6e 2f 62 61 73 68 0a 0a 69 66 20 #!/bin/bash..if
0010: 5b 20 22 24 4d 54 5f 43 4d 44 49 4e 46 4f 22 20 [ "$MT_CMDINFO"
0020: 3d 3d 20 22 22 20 5d 3b 74 68 65 6e 0a 20 20 65 == "" ];then. e
0030: 63 68 6f 20 22 45 52 52 4f 52 3a 20 24 30 20 73 cho "ERROR: $0 s
0040: 68 6f 75 6c 64 20 62 65 20 72 75 6e 20 77 69 74 hould be run wit
0050: 68 69 6e 20 61 20 6d 65 67 61 74 65 73 74 20 74 hin a megatest t
0060: 65 73 74 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 22 est environment"
0070: 0a 20 20 65 78 69 74 0a 66 69 0a 0a 23 20 50 75 . exit.fi..# Pu
0080: 72 70 6f 73 65 3a 20 54 68 69 73 20 69 73 20 66 rpose: This is f
0090: 6f 72 20 74 68 65 20 5b 65 7a 73 74 65 70 73 5d or the [ezsteps]
00a0: 20 73 65 63 74 6f 6e 20 69 6e 20 79 6f 75 72 20 secton in your
00b0: 74 65 73 74 63 6f 6e 66 69 67 20 66 69 6c 65 2e testconfig file.
00c0: 0a 23 20 20 20 44 4f 20 4e 4f 54 20 55 53 45 20 .# DO NOT USE
00d0: 49 4e 20 59 4f 55 52 20 53 43 52 49 50 54 53 21 IN YOUR SCRIPTS!
00e0: 0a 23 0a 23 20 43 61 6c 6c 20 6c 69 6b 65 20 74 .#.# Call like t
00f0: 68 69 73 3a 0a 23 20 6d 74 5f 65 7a 73 74 65 70 his:.# mt_ezstep
0100: 20 73 74 65 70 6e 61 6d 65 20 70 72 65 76 73 74 stepname prevst
0110: 65 70 6e 61 6d 65 20 63 6f 6d 6d 61 6e 64 20 2e epname command .
0120: 2e 2e 2e 0a 23 20 0a 73 74 65 70 6e 61 6d 65 3d ....# .stepname=
0130: 24 31 3b 73 68 69 66 74 0a 70 72 65 76 73 74 65 $1;shift.prevste
0140: 70 6e 61 6d 65 3d 24 31 3b 73 68 69 66 74 0a 0a pname=$1;shift..
0150: 63 6f 6d 6d 61 6e 64 3d 24 2a 0a 0a 61 6c 6c 73 command=$*..alls
0160: 74 61 74 75 73 3d 39 39 0a 72 75 6e 73 74 61 74 tatus=99.runstat
0170: 75 73 3d 39 39 0a 6c 6f 67 70 72 6f 70 73 74 61 us=99.logpropsta
0180: 74 75 73 3d 39 39 0a 0a 70 72 65 76 5f 65 6e 76 tus=99..prev_env
0190: 3d 2e 65 7a 73 74 65 70 73 2f 24 7b 70 72 65 76 =.ezsteps/${prev
01a0: 73 74 65 70 6e 61 6d 65 7d 2e 73 68 0a 69 66 20 stepname}.sh.if
01b0: 5b 20 2d 65 20 24 70 72 65 76 5f 65 6e 76 20 5d [ -e $prev_env ]
01c0: 3b 74 68 65 6e 0a 20 20 20 20 73 6f 75 72 63 65 ;then. source
01d0: 20 24 70 72 65 76 5f 65 6e 76 0a 66 69 0a 0a 23 $prev_env.fi..#
01e0: 20 73 6f 75 72 63 65 20 74 68 65 20 65 6e 76 69 source the envi
01f0: 72 6f 6e 6d 65 6e 74 20 66 72 6f 6d 20 74 68 65 ronment from the
0200: 20 70 72 65 76 69 6f 75 73 20 73 74 65 70 20 69 previous step i
0210: 66 20 69 74 20 65 78 69 73 74 73 0a 0a 23 20 69 f it exists..# i
0220: 66 20 61 20 6c 6f 67 70 72 6f 20 66 69 6c 65 20 f a logpro file
0230: 65 78 69 73 74 73 20 74 68 65 6e 20 75 73 65 20 exists then use
0240: 69 74 20 6f 74 68 65 72 77 69 73 65 20 6a 75 73 it otherwise jus
0250: 74 20 72 75 6e 20 74 68 65 20 63 6f 6d 6d 61 6e t run the comman
0260: 64 2c 20 6e 62 2f 2f 20 77 61 73 20 75 73 69 6e d, nb// was usin
0270: 67 20 32 3e 26 31 0a 69 66 20 5b 20 2d 65 20 24 g 2>&1.if [ -e $
0280: 7b 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 70 72 {stepname}.logpr
0290: 6f 20 5d 3b 74 68 65 6e 0a 20 20 20 23 20 63 6f o ];then. # co
02a0: 75 6c 64 20 64 6f 3a 0a 20 20 20 24 63 6f 6d 6d uld do:. $comm
02b0: 61 6e 64 20 32 3e 26 31 7c 20 74 65 65 20 24 7b and 2>&1| tee ${
02c0: 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 20 7c 20 stepname}.log |
02d0: 6c 6f 67 70 72 6f 20 24 7b 73 74 65 70 6e 61 6d logpro ${stepnam
02e0: 65 7d 2e 6c 6f 67 70 72 6f 20 24 7b 73 74 65 70 e}.logpro ${step
02f0: 6e 61 6d 65 7d 2e 68 74 6d 6c 20 26 3e 20 2f 64 name}.html &> /d
0300: 65 76 2f 6e 75 6c 6c 0a 20 20 20 6c 6f 67 70 72 ev/null. logpr
0310: 6f 73 74 61 74 75 73 3d 24 3f 0a 20 20 20 23 20 ostatus=$?. #
0320: 24 63 6f 6d 6d 61 6e 64 20 32 3e 26 31 7c 20 6c $command 2>&1| l
0330: 6f 67 70 72 6f 20 24 7b 73 74 65 70 6e 61 6d 65 ogpro ${stepname
0340: 7d 2e 6c 6f 67 70 72 6f 20 24 7b 73 74 65 70 6e }.logpro ${stepn
0350: 61 6d 65 7d 2e 68 74 6d 6c 20 26 3e 20 24 7b 73 ame}.html &> ${s
0360: 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 20 0a 20 20 tepname}.log .
0370: 20 23 20 61 6c 6c 73 74 61 74 75 73 3d 28 24 7b # allstatus=(${
0380: 50 49 50 45 53 54 41 54 55 53 5b 30 5d 7d 20 24 PIPESTATUS[0]} $
0390: 7b 50 49 50 45 53 54 41 54 55 53 5b 31 5d 7d 29 {PIPESTATUS[1]})
03a0: 20 0a 20 20 20 61 6c 6c 73 74 61 74 75 73 3d 28 . allstatus=(
03b0: 24 7b 50 49 50 45 53 54 41 54 55 53 5b 30 5d 7d ${PIPESTATUS[0]}
03c0: 20 24 7b 50 49 50 45 53 54 41 54 55 53 5b 31 5d ${PIPESTATUS[1]
03d0: 7d 29 0a 20 20 20 72 75 6e 73 74 61 74 75 73 3d }). runstatus=
03e0: 24 7b 61 6c 6c 73 74 61 74 75 73 5b 30 5d 7d 0a ${allstatus[0]}.
03f0: 20 20 20 23 20 6c 6f 67 70 72 6f 73 74 61 74 75 # logprostatu
0400: 73 3d 24 7b 61 6c 6c 73 74 61 74 75 73 5b 31 5d s=${allstatus[1]
0410: 7d 0a 65 6c 73 65 0a 20 20 20 24 63 6f 6d 6d 61 }.else. $comma
0420: 6e 64 20 26 3e 20 24 7b 73 74 65 70 6e 61 6d 65 nd &> ${stepname
0430: 7d 2e 6c 6f 67 0a 20 20 20 72 75 6e 73 74 61 74 }.log. runstat
0440: 75 73 3d 24 3f 0a 20 20 20 6c 6f 67 70 72 6f 73 us=$?. logpros
0450: 74 61 74 75 73 3d 24 72 75 6e 73 74 61 74 75 73 tatus=$runstatus
0460: 0a 66 69 0a 0a 23 20 49 66 20 74 68 65 20 74 65 .fi..# If the te
0470: 73 74 20 65 78 69 74 73 20 77 69 74 68 20 6e 6f st exits with no
0480: 6e 2d 7a 65 72 6f 2c 20 77 65 20 77 69 6c 6c 20 n-zero, we will
0490: 72 65 63 6f 72 64 20 46 41 49 4c 20 65 76 65 6e record FAIL even
04a0: 20 69 66 20 6c 6f 67 70 72 6f 0a 23 20 73 61 79 if logpro.# say
04b0: 73 20 69 74 20 69 73 20 61 20 50 41 53 53 0a 0a s it is a PASS..
04c0: 69 66 20 5b 20 24 72 75 6e 73 74 61 74 75 73 20 if [ $runstatus
04d0: 2d 6e 65 20 30 20 5d 3b 20 74 68 65 6e 0a 20 20 -ne 0 ]; then.
04e0: 20 20 65 78 69 74 73 74 61 74 75 73 3d 24 72 75 exitstatus=$ru
04f0: 6e 73 74 61 74 75 73 0a 65 6c 69 66 20 5b 20 24 nstatus.elif [ $
0500: 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d 65 71 logprostatus -eq
0510: 20 30 20 5d 3b 20 74 68 65 6e 0a 20 20 20 20 65 0 ]; then. e
0520: 78 69 74 73 74 61 74 75 73 3d 24 6c 6f 67 70 72 xitstatus=$logpr
0530: 6f 73 74 61 74 75 73 0a 65 6c 69 66 20 5b 20 24 ostatus.elif [ $
0540: 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d 65 71 logprostatus -eq
0550: 20 32 20 5d 3b 20 74 68 65 6e 0a 20 20 20 20 65 2 ]; then. e
0560: 78 69 74 73 74 61 74 75 73 3d 32 0a 65 6c 69 66 xitstatus=2.elif
0570: 20 5b 20 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 [ $logprostatus
0580: 20 2d 65 71 20 31 20 5d 3b 20 74 68 65 6e 0a 20 -eq 1 ]; then.
0590: 20 20 20 65 78 69 74 73 74 61 74 75 73 3d 31 0a exitstatus=1.
05a0: 65 6c 73 65 20 0a 20 20 20 20 65 78 69 74 73 74 else . exitst
05b0: 61 74 75 73 3d 30 0a 66 69 0a 0a 24 4d 54 5f 4d atus=0.fi..$MT_M
05c0: 45 47 41 54 45 53 54 20 2d 65 6e 76 32 66 69 6c EGATEST -env2fil
05d0: 65 20 2e 65 7a 73 74 65 70 73 2f 24 7b 73 74 65 e .ezsteps/${ste
05e0: 70 6e 61 6d 65 7d 0a 65 78 69 74 20 24 65 78 69 pname}.exit $exi
05f0: 74 73 74 61 74 75 73 0a tstatus.