Megatest

Hex Artifact Content
Login

Artifact 3ac68c5b778c19bdb3c588c4321106918657d51c:


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 63 6f 6d 6d 61 6e   stepname comman
0110: 64 20 2e 2e 2e 2e 0a 23 20 0a 73 74 65 70 6e 61  d .....# .stepna
0120: 6d 65 3d 24 31 3b 73 68 69 66 74 0a 63 6f 6d 6d  me=$1;shift.comm
0130: 61 6e 64 3d 24 2a 0a 0a 23 20 69 66 20 61 20 6c  and=$*..# if a l
0140: 6f 67 70 72 6f 20 66 69 6c 65 20 65 78 69 73 74  ogpro file exist
0150: 73 20 74 68 65 6e 20 75 73 65 20 69 74 20 6f 74  s then use it ot
0160: 68 65 72 77 69 73 65 20 6a 75 73 74 20 72 75 6e  herwise just run
0170: 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2c 20 6e 62   the command, nb
0180: 2f 2f 20 77 61 73 20 75 73 69 6e 67 20 32 3e 26  // was using 2>&
0190: 31 0a 69 66 20 5b 20 2d 65 20 24 7b 73 74 65 70  1.if [ -e ${step
01a0: 6e 61 6d 65 7d 2e 6c 6f 67 70 72 6f 20 5d 3b 74  name}.logpro ];t
01b0: 68 65 6e 0a 20 20 20 24 63 6f 6d 6d 61 6e 64 20  hen.   $command 
01c0: 32 3e 26 31 7c 20 6c 6f 67 70 72 6f 20 24 7b 73  2>&1| logpro ${s
01d0: 74 65 70 6e 61 6d 65 7d 2e 6c 6f 67 70 72 6f 20  tepname}.logpro 
01e0: 24 7b 73 74 65 70 6e 61 6d 65 7d 2e 68 74 6d 6c  ${stepname}.html
01f0: 20 26 3e 20 24 7b 73 74 65 70 6e 61 6d 65 7d 2e   &> ${stepname}.
0200: 6c 6f 67 20 0a 20 20 20 61 6c 6c 73 74 61 74 75  log .   allstatu
0210: 73 3d 28 24 7b 50 49 50 45 53 54 41 54 55 53 5b  s=(${PIPESTATUS[
0220: 30 5d 7d 20 24 7b 50 49 50 45 53 54 41 54 55 53  0]} ${PIPESTATUS
0230: 5b 31 5d 7d 29 0a 20 20 20 72 75 6e 73 74 61 74  [1]}).   runstat
0240: 75 73 3d 24 7b 61 6c 6c 73 74 61 74 75 73 5b 30  us=${allstatus[0
0250: 5d 7d 0a 20 20 20 6c 6f 67 70 72 6f 73 74 61 74  ]}.   logprostat
0260: 75 73 3d 24 7b 61 6c 6c 73 74 61 74 75 73 5b 31  us=${allstatus[1
0270: 5d 7d 0a 65 6c 73 65 0a 20 20 20 24 63 6f 6d 6d  ]}.else.   $comm
0280: 61 6e 64 20 26 3e 20 24 7b 73 74 65 70 6e 61 6d  and &> ${stepnam
0290: 65 7d 2e 6c 6f 67 0a 20 20 20 72 75 6e 73 74 61  e}.log.   runsta
02a0: 74 75 73 3d 24 3f 0a 20 20 20 6c 6f 67 70 72 6f  tus=$?.   logpro
02b0: 73 74 61 74 75 73 3d 24 72 75 6e 73 74 61 74 75  status=$runstatu
02c0: 73 0a 66 69 0a 0a 23 20 49 66 20 74 68 65 20 74  s.fi..# If the t
02d0: 65 73 74 20 65 78 69 74 73 20 77 69 74 68 20 6e  est exits with n
02e0: 6f 6e 2d 7a 65 72 6f 2c 20 77 65 20 77 69 6c 6c  on-zero, we will
02f0: 20 72 65 63 6f 72 64 20 46 41 49 4c 20 65 76 65   record FAIL eve
0300: 6e 20 69 66 20 6c 6f 67 70 72 6f 0a 23 20 73 61  n if logpro.# sa
0310: 79 73 20 69 74 20 69 73 20 61 20 50 41 53 53 0a  ys it is a PASS.
0320: 0a 69 66 20 5b 20 24 72 75 6e 73 74 61 74 75 73  .if [ $runstatus
0330: 20 2d 6e 65 20 30 20 5d 3b 20 74 68 65 6e 0a 20   -ne 0 ]; then. 
0340: 20 20 20 65 78 69 74 73 74 61 74 75 73 3d 24 72     exitstatus=$r
0350: 75 6e 73 74 61 74 75 73 0a 65 6c 69 66 20 5b 20  unstatus.elif [ 
0360: 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d 65  $logprostatus -e
0370: 71 20 30 20 5d 3b 20 74 68 65 6e 0a 20 20 20 20  q 0 ]; then.    
0380: 65 78 69 74 73 74 61 74 75 73 3d 24 6c 6f 67 70  exitstatus=$logp
0390: 72 6f 73 74 61 74 75 73 0a 65 6c 69 66 20 5b 20  rostatus.elif [ 
03a0: 24 6c 6f 67 70 72 6f 73 74 61 74 75 73 20 2d 65  $logprostatus -e
03b0: 71 20 32 20 5d 3b 20 74 68 65 6e 0a 20 20 20 20  q 2 ]; then.    
03c0: 65 78 69 74 73 74 61 74 75 73 3d 30 0a 65 6c 73  exitstatus=0.els
03d0: 65 20 0a 20 20 20 20 65 78 69 74 73 74 61 74 75  e .    exitstatu
03e0: 73 3d 31 0a 66 69 0a 24 4d 54 5f 4d 45 47 41 54  s=1.fi.$MT_MEGAT
03f0: 45 53 54 20 2d 65 6e 76 32 66 69 6c 65 20 2e 65  EST -env2file .e
0400: 7a 73 74 65 70 73 2f 24 7b 73 74 65 70 6e 61 6d  zsteps/${stepnam
0410: 65 7d 0a 65 78 69 74 20 24 65 78 69 74 73 74 61  e}.exit $exitsta
0420: 74 75 73 0a                                      tus.