Artifact
8f412827c1103e7a8cf0a48189314648001764ce :
Executable file
utils/mt_ezstep
— part of check-in
[1b0a53f5b9]
at
2011-10-09 11:36:56
on branch trunk
— Completed eztests, well, except for full validation of eztests
(user:
matt
size: 1063)
0000: 23 21 2f 62 69 6e 2f 62 61 73 68 20 2d 78 0a 0a #!/bin/bash -x..
0010: 69 66 20 5b 20 22 24 4d 54 5f 43 4d 44 49 4e 46 if [ "$MT_CMDINF
0020: 4f 22 20 3d 3d 20 22 22 20 5d 3b 74 68 65 6e 0a O" == "" ];then.
0030: 20 20 65 63 68 6f 20 22 45 52 52 4f 52 3a 20 24 echo "ERROR: $
0040: 30 20 73 68 6f 75 6c 64 20 62 65 20 72 75 6e 20 0 should be run
0050: 77 69 74 68 69 6e 20 61 20 6d 65 67 61 74 65 73 within a megates
0060: 74 20 74 65 73 74 20 65 6e 76 69 72 6f 6e 6d 65 t test environme
0070: 6e 74 22 0a 20 20 65 78 69 74 0a 66 69 0a 0a 23 nt". exit.fi..#
0080: 20 50 75 72 70 6f 73 65 3a 20 54 68 69 73 20 69 Purpose: This i
0090: 73 20 66 6f 72 20 74 68 65 20 5b 65 7a 73 74 65 s for the [ezste
00a0: 70 73 5d 20 73 65 63 74 6f 6e 20 69 6e 20 79 6f ps] secton in yo
00b0: 75 72 20 74 65 73 74 63 6f 6e 66 69 67 20 66 69 ur testconfig fi
00c0: 6c 65 2e 0a 23 20 20 20 44 4f 20 4e 4f 54 20 55 le..# DO NOT U
00d0: 53 45 20 49 4e 20 59 4f 55 52 20 53 43 52 49 50 SE IN YOUR SCRIP
00e0: 54 53 21 0a 23 0a 23 20 43 61 6c 6c 20 6c 69 6b TS!.#.# Call lik
00f0: 65 20 74 68 69 73 3a 0a 23 20 6d 74 5f 65 7a 73 e this:.# mt_ezs
0100: 74 65 70 20 73 74 65 70 6e 61 6d 65 20 63 6f 6d tep stepname com
0110: 6d 61 6e 64 20 2e 2e 2e 2e 0a 23 20 0a 73 74 65 mand .....# .ste
0120: 70 6e 61 6d 65 3d 24 31 3b 73 68 69 66 74 0a 63 pname=$1;shift.c
0130: 6f 6d 6d 61 6e 64 3d 24 2a 0a 0a 23 20 69 66 20 ommand=$*..# if
0140: 61 20 6c 6f 67 70 72 6f 20 66 69 6c 65 20 65 78 a logpro file ex
0150: 69 73 74 73 20 74 68 65 6e 20 75 73 65 20 69 74 ists then use it
0160: 20 6f 74 68 65 72 77 69 73 65 20 6a 75 73 74 20 otherwise just
0170: 72 75 6e 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2c run the command,
0180: 20 6e 62 2f 2f 20 77 61 73 20 75 73 69 6e 67 20 nb// was using
0190: 32 3e 26 31 0a 69 66 20 5b 20 2d 65 20 24 7b 73 2>&1.if [ -e ${s
01a0: 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 70 72 6f 20 tepname}.logpro
01b0: 5d 3b 74 68 65 6e 0a 20 20 20 24 63 6f 6d 6d 61 ];then. $comma
01c0: 6e 64 20 32 3e 26 31 7c 20 6c 6f 67 70 72 6f 20 nd 2>&1| logpro
01d0: 24 7b 73 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 70 ${stepname}.logp
01e0: 72 6f 20 24 7b 73 74 65 70 6e 61 6d 65 7d 2e 68 ro ${stepname}.h
01f0: 74 6d 6c 20 26 3e 20 24 7b 73 74 65 70 6e 61 6d tml &> ${stepnam
0200: 65 7d 2e 6c 6f 67 20 0a 20 20 20 61 6c 6c 73 74 e}.log . allst
0210: 61 74 75 73 3d 28 24 7b 50 49 50 45 53 54 41 54 atus=(${PIPESTAT
0220: 55 53 5b 30 5d 7d 20 24 7b 50 49 50 45 53 54 41 US[0]} ${PIPESTA
0230: 54 55 53 5b 31 5d 7d 29 0a 20 20 20 72 75 6e 73 TUS[1]}). runs
0240: 74 61 74 75 73 3d 24 7b 61 6c 6c 73 74 61 74 75 tatus=${allstatu
0250: 73 5b 30 5d 7d 0a 20 20 20 6c 6f 67 70 72 6f 73 s[0]}. logpros
0260: 74 61 74 75 73 3d 24 7b 61 6c 6c 73 74 61 74 75 tatus=${allstatu
0270: 73 5b 31 5d 7d 0a 65 6c 73 65 0a 20 20 20 24 63 s[1]}.else. $c
0280: 6f 6d 6d 61 6e 64 20 26 3e 20 24 7b 73 74 65 70 ommand &> ${step
0290: 6e 61 6d 65 7d 2e 6c 6f 67 0a 20 20 20 72 75 6e name}.log. run
02a0: 73 74 61 74 75 73 3d 24 3f 0a 20 20 20 6c 6f 67 status=$?. log
02b0: 70 72 6f 73 74 61 74 75 73 3d 24 72 75 6e 73 74 prostatus=$runst
02c0: 61 74 75 73 0a 66 69 0a 0a 23 20 49 66 20 74 68 atus.fi..# If th
02d0: 65 20 74 65 73 74 20 65 78 69 74 73 20 77 69 74 e test exits wit
02e0: 68 20 6e 6f 6e 2d 7a 65 72 6f 2c 20 77 65 20 77 h non-zero, we w
02f0: 69 6c 6c 20 72 65 63 6f 72 64 20 46 41 49 4c 20 ill record FAIL
0300: 65 76 65 6e 20 69 66 20 6c 6f 67 70 72 6f 0a 23 even if logpro.#
0310: 20 73 61 79 73 20 69 74 20 69 73 20 61 20 50 41 says it is a PA
0320: 53 53 0a 0a 69 66 20 5b 20 24 72 75 6e 73 74 61 SS..if [ $runsta
0330: 74 75 73 20 2d 6e 65 20 30 20 5d 3b 20 74 68 65 tus -ne 0 ]; the
0340: 6e 0a 20 20 20 20 65 78 69 74 73 74 61 74 75 73 n. exitstatus
0350: 3d 24 72 75 6e 73 74 61 74 75 73 0a 65 6c 69 66 =$runstatus.elif
0360: 20 5b 20 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 [ $logprostatus
0370: 20 2d 65 71 20 30 20 5d 3b 20 74 68 65 6e 0a 20 -eq 0 ]; then.
0380: 20 20 20 65 78 69 74 73 74 61 74 75 73 3d 24 6c exitstatus=$l
0390: 6f 67 70 72 6f 73 74 61 74 75 73 0a 65 6c 69 66 ogprostatus.elif
03a0: 20 5b 20 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 [ $logprostatus
03b0: 20 2d 65 71 20 32 20 5d 3b 20 74 68 65 6e 0a 20 -eq 2 ]; then.
03c0: 20 20 20 65 78 69 74 73 74 61 74 75 73 3d 30 0a exitstatus=0.
03d0: 65 6c 73 65 20 0a 20 20 20 20 65 78 69 74 73 74 else . exitst
03e0: 61 74 75 73 3d 31 0a 66 69 0a 24 4d 54 5f 4d 45 atus=1.fi.$MT_ME
03f0: 47 41 54 45 53 54 20 2d 65 6e 76 32 66 69 6c 65 GATEST -env2file
0400: 20 2e 65 7a 73 74 65 70 73 2f 24 7b 73 74 65 70 .ezsteps/${step
0410: 6e 61 6d 65 7d 0a 65 78 69 74 20 24 65 78 69 74 name}.exit $exit
0420: 73 74 61 74 75 73 0a status.