Megatest

Hex Artifact Content
Login

Artifact 07210040d05944389e77dc6bbc7511ed63687849:

Wiki page [plan] by matt 2018-02-06 05:57:55.
0000: 44 20 32 30 31 38 2d 30 32 2d 30 36 54 31 32 3a  D 2018-02-06T12:
0010: 35 37 3a 35 35 2e 31 37 34 0a 4c 20 70 6c 61 6e  57:55.174.L plan
0020: 0a 4e 20 74 65 78 74 2f 70 6c 61 69 6e 0a 50 20  .N text/plain.P 
0030: 37 35 33 61 64 38 61 64 34 32 65 30 39 65 33 31  753ad8ad42e09e31
0040: 35 39 38 61 61 66 30 31 38 63 66 38 39 66 66 62  598aaf018cf89ffb
0050: 62 38 33 36 37 36 62 66 0a 55 20 6d 61 74 74 0a  b83676bf.U matt.
0060: 57 20 37 39 32 30 0a 52 6f 61 64 20 4d 61 70 0d  W 7920.Road Map.
0070: 0a 2d 2d 2d 2d 2d 2d 2d 2d 0d 0a 0d 0a 4e 6f 74  .--------....Not
0080: 65 20 31 3a 20 54 68 69 73 20 72 6f 61 64 2d 6d  e 1: This road-m
0090: 61 70 20 69 73 20 73 74 69 6c 6c 20 65 76 6f 6c  ap is still evol
00a0: 76 69 6e 67 20 61 6e 64 20 73 75 62 6a 65 63 74  ving and subject
00b0: 20 74 6f 20 63 68 61 6e 67 65 20 77 69 74 68 6f   to change witho
00c0: 75 74 20 6e 6f 74 69 63 65 2e 0d 0a 0d 0a 52 46  ut notice.....RF
00d0: 43 20 4d 30 31 3a 20 41 64 64 20 61 62 69 6c 69  C M01: Add abili
00e0: 74 79 20 74 6f 20 6d 6f 76 65 20 72 75 6e 73 20  ty to move runs 
00f0: 74 6f 20 6f 74 68 65 72 20 41 72 65 61 73 0d 0a  to other Areas..
0100: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0110: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0120: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0130: 0d 0a 0d 0a 2a 50 75 72 70 6f 73 65 2a 3a 20 61  ....*Purpose*: a
0140: 6c 6c 6f 77 20 73 68 72 69 6e 6b 69 6e 67 20 6d  llow shrinking m
0150: 65 67 61 74 65 73 74 2e 64 62 20 64 61 74 61 20  egatest.db data 
0160: 62 79 20 6d 6f 76 69 6e 67 20 72 75 6e 73 20 74  by moving runs t
0170: 6f 20 61 6e 20 61 6c 74 65 72 6e 61 74 65 0d 0a  o an alternate..
0180: 20 4d 65 67 61 74 65 73 74 20 61 72 65 61 20 77   Megatest area w
0190: 69 74 68 20 73 61 6d 65 20 6b 65 79 73 2e 0d 0a  ith same keys...
01a0: 0d 0a 2a 4d 65 74 68 6f 64 2a 3a 20 65 78 74 65  ..*Method*: exte
01b0: 6e 64 20 64 62 20 73 79 6e 63 20 74 6f 20 74 61  nd db sync to ta
01c0: 6b 65 20 61 20 64 69 66 66 65 72 65 6e 74 20 6d  ke a different m
01d0: 65 67 61 74 65 73 74 20 61 72 65 61 20 61 73 20  egatest area as 
01e0: 61 20 64 65 73 74 69 6e 61 74 69 6f 6e 2e 0d 0a  a destination...
01f0: 0d 0a 2a 44 65 73 69 67 6e 2a 3a 0d 0a 0d 0a 2e  ..*Design*:.....
0200: 20 61 64 64 20 70 61 72 61 6d 20 2d 64 65 73 74   add param -dest
0210: 69 6e 61 74 69 6f 6e 20 5b 61 72 65 61 7c 70 61  ination [area|pa
0220: 74 68 5d 2e 20 77 68 65 6e 20 73 70 65 63 69 66  th]. when specif
0230: 69 65 64 20 72 75 6e 73 20 61 72 65 20 63 6f 70  ied runs are cop
0240: 69 65 64 20 74 6f 20 6e 65 77 0d 0a 20 20 61 72  ied to new..  ar
0250: 65 61 20 61 6e 64 20 72 65 6d 6f 76 65 64 20 66  ea and removed f
0260: 72 6f 6d 20 6c 6f 63 61 6c 20 64 62 2e 0d 0a 2e  rom local db....
0270: 20 74 68 65 20 64 61 74 61 20 6d 6f 76 65 20 77   the data move w
0280: 6f 75 6c 64 20 69 6e 76 6f 6c 76 65 20 74 68 65  ould involve the
0290: 73 65 20 73 74 65 70 73 0d 0a 2e 2e 20 63 6f 70  se steps.... cop
02a0: 79 20 74 68 65 20 72 75 6e 20 64 61 74 61 20 74  y the run data t
02b0: 6f 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 61 72  o destination ar
02c0: 65 61 20 6d 65 67 61 74 65 73 74 2e 64 62 0d 0a  ea megatest.db..
02d0: 2e 2e 20 6d 61 72 6b 20 74 68 65 20 72 75 6e 20  .. mark the run 
02e0: 72 65 63 6f 72 64 73 20 61 73 20 4d 4f 56 45 44  records as MOVED
02f0: 2c 20 64 6f 20 6e 6f 74 20 72 65 6d 6f 76 65 20  , do not remove 
0300: 74 68 65 20 72 75 6e 20 64 61 74 61 20 6f 6e 20  the run data on 
0310: 64 69 73 6b 0d 0a 2e 20 61 63 63 65 73 73 69 6e  disk... accessin
0320: 67 20 74 68 65 20 64 61 74 61 20 77 6f 75 6c 64  g the data would
0330: 20 62 65 20 62 79 20 72 75 6e 6e 69 6e 67 20 64   be by running d
0340: 61 73 68 62 6f 61 72 64 20 69 6e 20 74 68 65 20  ashboard in the 
0350: 73 61 74 65 6c 6c 69 74 65 20 61 72 65 61 0d 0a  satellite area..
0360: 2e 20 66 75 74 75 72 65 20 76 65 72 73 69 6f 6e  . future version
0370: 73 20 6f 66 20 4d 65 67 61 74 65 73 74 20 64 61  s of Megatest da
0380: 73 68 62 6f 61 72 64 20 73 68 6f 75 6c 64 20 73  shboard should s
0390: 75 70 70 6f 72 74 20 64 69 73 70 6c 61 79 69 6e  upport displayin
03a0: 67 20 61 72 65 61 73 20 69 6e 20 61 0d 0a 20 20  g areas in a..  
03b0: 6d 65 72 67 65 64 20 77 61 79 20 62 79 20 61 64  merged way by ad
03c0: 64 69 6e 67 20 74 68 65 20 61 72 65 61 20 61 73  ding the area as
03d0: 20 74 68 65 20 74 6f 70 6d 6f 73 74 20 76 61 72   the topmost var
03e0: 69 61 62 6c 65 20 28 69 2e 65 2e 20 65 66 66 65  iable (i.e. effe
03f0: 63 74 69 76 65 6c 79 0d 0a 20 20 65 78 74 65 6e  ctively..  exten
0400: 64 69 6e 67 20 74 68 65 20 74 61 72 67 65 74 2e  ding the target.
0410: 29 0d 0a 2e 20 73 6f 6d 65 20 6e 65 77 20 63 6f  )... some new co
0420: 6e 74 72 6f 6c 73 20 77 6f 75 6c 64 20 62 65 20  ntrols would be 
0430: 73 75 70 70 6f 72 74 65 64 20 69 6e 20 74 68 65  supported in the
0440: 20 63 6f 6e 66 69 67 0d 0a 2e 2e 20 5b 73 65 74   config.... [set
0450: 75 70 5d 20 3d 3e 20 61 6c 6c 6f 77 2d 72 75 6e  up] => allow-run
0460: 73 20 5b 6e 6f 7c 79 65 73 5d 20 20 3c 3d 3d 20  s [no|yes]  <== 
0470: 75 73 65 64 20 74 6f 20 64 69 73 61 6c 6c 6f 77  used to disallow
0480: 20 72 75 6e 73 0d 0a 2e 2e 20 5b 61 75 74 6f 6d   runs.... [autom
0490: 69 67 72 61 74 65 5d 20 3d 3e 20 61 72 65 61 6e  igrate] => arean
04a0: 61 6d 65 20 74 61 72 67 65 74 3d 25 2f 25 2f 25  ame target=%/%/%
04b0: 3b 20 72 75 6e 6e 61 6d 65 3d 25 3b 20 61 67 65  ; runname=%; age
04c0: 3d 33 30 64 20 3c 3d 3d 20 61 75 74 6f 6d 69 67  =30d <== automig
04d0: 72 61 74 65 0d 0a 20 20 20 62 79 20 74 68 65 73  rate..   by thes
04e0: 65 20 63 72 69 74 65 72 69 61 20 66 6f 72 20 74  e criteria for t
04f0: 68 65 20 67 69 76 65 6e 20 61 72 65 61 2e 0d 0a  he given area...
0500: 0d 0a 0d 0a 2a 42 72 61 6e 63 68 2a 3a 20 54 68  ....*Branch*: Th
0510: 69 73 20 77 6f 72 6b 20 69 73 20 74 61 6b 69 6e  is work is takin
0520: 67 20 70 6c 61 63 65 20 6f 6e 20 62 72 61 6e 63  g place on branc
0530: 68 20 76 31 2e 36 35 2d 72 65 64 75 63 65 2d 72  h v1.65-reduce-r
0540: 65 63 6f 72 64 73 0d 0a 0d 0a 52 46 43 20 4d 30  ecords....RFC M0
0550: 32 3a 20 4d 6f 76 65 20 64 61 74 61 20 69 6e 74  2: Move data int
0560: 6f 20 63 6f 6d 70 6c 65 74 65 64 2d 72 75 6e 73  o completed-runs
0570: 2e 64 62 0d 0a 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  .db..~~~~~~~~~~~
0580: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0590: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 0d 0a  ~~~~~~~~~~~~~~..
05a0: 0d 0a 2a 50 75 72 70 6f 73 65 2a 3a 20 73 68 72  ..*Purpose*: shr
05b0: 69 6e 6b 20 6d 65 67 61 74 65 73 74 2e 64 62 20  ink megatest.db 
05c0: 64 61 74 61 20 74 6f 20 65 6e 61 62 6c 65 20 6c  data to enable l
05d0: 6f 77 65 72 20 6c 6f 61 64 20 61 6e 64 20 68 69  ower load and hi
05e0: 67 68 65 72 20 70 65 72 66 6f 72 6d 61 6e 63 65  gher performance
05f0: 2e 0d 0a 0d 0a 2a 4d 65 74 68 6f 64 2a 3a 20 61  .....*Method*: a
0600: 64 64 20 61 20 63 6f 6d 70 6c 65 74 65 64 2d 72  dd a completed-r
0610: 75 6e 73 2e 64 62 20 61 6e 64 20 61 75 74 6f 6d  uns.db and autom
0620: 61 74 69 63 61 6c 6c 79 20 6d 6f 76 65 20 72 75  atically move ru
0630: 6e 73 20 64 61 74 61 20 66 72 6f 6d 20 6d 65 67  ns data from meg
0640: 61 74 65 73 74 2e 64 62 20 74 6f 20 74 68 61 74  atest.db to that
0650: 20 64 62 0d 0a 0d 0a 2a 44 65 73 69 67 6e 2a 3a   db....*Design*:
0660: 0d 0a 0d 0a 2e 20 63 6f 6d 70 6c 65 74 65 64 2d  ..... completed-
0670: 72 75 6e 73 2e 64 62 20 69 73 20 61 20 66 75 6c  runs.db is a ful
0680: 6c 20 6d 65 67 61 74 65 73 74 20 64 61 74 61 62  l megatest datab
0690: 61 73 65 20 77 69 74 68 20 63 6f 6d 70 6c 65 74  ase with complet
06a0: 65 20 73 63 68 65 6d 61 0d 0a 2e 20 74 68 65 20  e schema... the 
06b0: 64 61 74 61 20 6d 6f 76 65 20 77 6f 75 6c 64 20  data move would 
06c0: 69 6e 76 6f 6c 76 65 20 74 68 65 73 65 20 73 74  involve these st
06d0: 65 70 73 0d 0a 2e 2e 20 63 6f 70 79 20 74 68 65  eps.... copy the
06e0: 20 72 75 6e 20 64 61 74 61 20 74 6f 20 63 6f 6d   run data to com
06f0: 70 6c 65 74 65 64 2d 72 75 6e 73 2e 64 62 0d 0a  pleted-runs.db..
0700: 2e 2e 20 72 65 6d 6f 76 65 20 74 68 65 20 72 75  .. remove the ru
0710: 6e 20 64 61 74 61 2c 20 66 69 72 73 74 20 66 72  n data, first fr
0720: 6f 6d 20 2f 74 6d 70 2f e2 80 a6 2f 6d 65 67 61  om /tmp/…/mega
0730: 74 65 73 74 2e 64 62 20 61 6e 64 20 2f 74 6d 70  test.db and /tmp
0740: 2f e2 80 a6 2f 6d 65 67 61 74 65 73 74 5f 72 65  /…/megatest_re
0750: 66 2e 64 62 2c 20 66 6f 6c 6c 6f 77 65 64 20 62  f.db, followed b
0760: 79 20 6d 65 67 61 74 65 73 74 2e 64 62 0d 0a 2e  y megatest.db...
0770: 20 61 63 63 65 73 73 69 6e 67 20 74 68 65 20 64   accessing the d
0780: 61 74 61 20 77 6f 75 6c 64 20 62 65 20 75 6e 63  ata would be unc
0790: 68 61 6e 67 65 64 20 66 6f 72 20 6d 6f 73 74 20  hanged for most 
07a0: 6f 70 65 72 61 74 69 6f 6e 73 2e 0d 0a 2e 20 61  operations.... a
07b0: 20 6d 6f 64 65 20 2d 66 75 6c 6c 2d 64 62 20 77   mode -full-db w
07c0: 69 6c 6c 20 62 65 20 61 64 64 65 64 20 77 68 69  ill be added whi
07d0: 63 68 20 77 68 65 6e 20 73 70 65 63 69 66 69 65  ch when specifie
07e0: 64 20 77 6f 75 6c 64 20 61 74 74 61 63 68 20 74  d would attach t
07f0: 68 65 20 63 6f 6d 70 6c 65 74 65 64 2d 72 75 6e  he completed-run
0800: 73 2e 64 62 20 74 6f 20 6d 65 67 61 74 65 73 74  s.db to megatest
0810: 2e 64 62 20 62 65 66 6f 72 65 20 64 6f 69 6e 67  .db before doing
0820: 20 74 68 65 20 71 75 65 72 79 0d 0a 2e 20 6d 65   the query... me
0830: 63 68 61 6e 69 73 6d 73 20 66 6f 72 20 6d 6f 76  chanisms for mov
0840: 69 6e 67 20 72 75 6e 73 20 74 6f 2f 66 72 6f 6d  ing runs to/from
0850: 20 74 68 65 20 6d 65 67 61 74 65 73 74 2e 64 62   the megatest.db
0860: 20 77 6f 75 6c 64 20 62 65 20 61 64 64 65 64 0d   would be added.
0870: 0a 2e 2e 20 2d 72 65 64 75 63 65 2d 72 65 63 6f  ... -reduce-reco
0880: 72 64 73 20 3d 3e 20 6d 6f 76 65 20 72 75 6e 73  rds => move runs
0890: 20 74 6f 20 63 6f 6d 70 6c 65 74 65 64 2d 72 75   to completed-ru
08a0: 6e 73 2e 64 62 0d 0a 2e 2e 20 2d 72 65 73 74 6f  ns.db.... -resto
08b0: 72 65 2d 72 65 63 6f 72 64 73 20 3d 3e 20 6d 6f  re-records => mo
08c0: 76 65 20 72 75 6e 73 20 66 72 6f 6d 20 63 6f 6d  ve runs from com
08d0: 70 6c 65 74 65 64 2d 72 75 6e 73 2e 64 62 20 74  pleted-runs.db t
08e0: 6f 20 6d 65 67 61 74 65 73 74 2e 64 62 0d 0a 0d  o megatest.db...
08f0: 0a 2a 42 72 61 6e 63 68 2a 3a 20 54 68 69 73 20  .*Branch*: This 
0900: 77 6f 72 6b 20 69 73 20 74 61 6b 69 6e 67 20 70  work is taking p
0910: 6c 61 63 65 20 6f 6e 20 62 72 61 6e 63 68 20 76  lace on branch v
0920: 31 2e 36 35 2d 72 65 64 75 63 65 2d 72 65 63 6f  1.65-reduce-reco
0930: 72 64 73 0d 0a 0d 0a 52 46 43 20 4d 30 33 3a 20  rds....RFC M03: 
0940: 41 75 74 6f 6d 61 74 69 63 20 68 6f 6d 65 68 6f  Automatic homeho
0950: 73 74 20 6d 69 67 72 61 74 69 6f 6e 73 0d 0a 7e  st migrations..~
0960: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0970: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e  ~~~~~~~~~~~~~~~~
0980: 7e 7e 7e 7e 7e 0d 0a 0d 0a 2a 50 75 72 70 6f 73  ~~~~~....*Purpos
0990: 65 2a 3a 20 41 75 74 6f 6d 61 74 69 63 61 6c 6c  e*: Automaticall
09a0: 79 20 6d 69 67 72 61 74 65 20 68 6f 6d 65 68 6f  y migrate homeho
09b0: 73 74 2e 0d 0a 0d 0a 2a 4d 65 74 68 6f 64 2a 3a  st.....*Method*:
09c0: 20 43 68 65 63 6b 20 74 68 61 74 20 74 68 65 72   Check that ther
09d0: 65 20 61 72 65 20 6e 6f 20 74 65 73 74 73 20 72  e are no tests r
09e0: 75 6e 6e 69 6e 67 2c 20 6c 61 75 6e 63 68 65 64  unning, launched
09f0: 20 6f 72 20 72 65 6d 6f 74 65 68 6f 73 74 73 74   or remotehostst
0a00: 61 72 74 20 69 6e 20 70 61 73 74 20 c2 bd 20 68  art in past ½ h
0a10: 6f 75 72 20 74 68 65 6e 20 69 66 20 6e 6f 74 20  our then if not 
0a20: 6f 6e 20 68 6f 6d 65 68 6f 73 74 20 6d 69 67 72  on homehost migr
0a30: 61 74 65 20 74 68 65 20 64 62 20 74 6f 20 63 75  ate the db to cu
0a40: 72 72 65 6e 74 20 68 6f 73 74 0d 0a 0d 0a 2a 44  rrent host....*D
0a50: 65 73 69 67 6e 2a 3a 0d 0a 0d 0a 2e 20 43 68 65  esign*:..... Che
0a60: 63 6b 20 74 68 61 74 20 74 68 65 20 73 79 73 74  ck that the syst
0a70: 65 6d 20 69 73 20 71 75 69 65 73 63 65 6e 74 2c  em is quiescent,
0a80: 20 69 2e 65 2e 20 74 68 61 74 20 74 68 65 72 65   i.e. that there
0a90: 20 61 72 65 20 6e 6f 20 72 75 6e 73 20 69 6e 20   are no runs in 
0aa0: 66 6c 69 67 68 74 20 6f 72 20 72 65 63 65 6e 74  flight or recent
0ab0: 6c 79 20 72 75 6e 0d 0a 2e 20 43 72 65 61 74 65  ly run... Create
0ac0: 20 61 20 6c 6f 63 6b 0d 0a 2e 20 4d 69 67 72 61   a lock... Migra
0ad0: 74 65 20 74 68 65 20 2f 74 6d 70 20 63 61 63 68  te the /tmp cach
0ae0: 65 20 64 62 20 74 6f 20 74 68 65 20 63 75 72 72  e db to the curr
0af0: 65 6e 74 20 68 6f 73 74 0d 0a 2e 20 55 70 64 61  ent host... Upda
0b00: 74 65 20 74 68 65 20 2e 68 6f 6d 65 68 6f 73 74  te the .homehost
0b10: 20 66 69 6c 65 0d 0a 2e 20 52 65 6d 6f 76 65 20   file... Remove 
0b20: 74 68 65 20 6c 6f 63 6b 0d 0a 0d 0a 2a 42 72 61  the lock....*Bra
0b30: 6e 63 68 2a 3a 20 54 68 69 73 20 77 6f 72 6b 20  nch*: This work 
0b40: 6e 6f 74 20 79 65 74 20 73 74 61 72 74 65 64 0d  not yet started.
0b50: 0a 0d 0a 41 72 63 68 69 74 65 63 74 75 72 65 20  ...Architecture 
0b60: 52 65 66 61 63 74 6f 72 0d 0a 7e 7e 7e 7e 7e 7e  Refactor..~~~~~~
0b70: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 0d  ~~~~~~~~~~~~~~~.
0b80: 0a 0d 0a 47 6f 61 6c 73 0d 0a 5e 5e 5e 5e 5e 0d  ...Goals..^^^^^.
0b90: 0a 0d 0a 2e 20 52 65 64 75 63 65 20 6c 6f 61 64  .... Reduce load
0ba0: 20 6f 6e 20 74 68 65 20 66 69 6c 65 20 73 79 73   on the file sys
0bb0: 74 65 6d 2e 20 53 71 6c 69 74 65 33 20 66 69 6c  tem. Sqlite3 fil
0bc0: 65 73 20 6f 6e 20 6e 65 74 77 6f 72 6b 20 66 69  es on network fi
0bd0: 6c 65 73 79 73 74 65 6d 20 63 61 6e 20 62 65 0d  lesystem can be.
0be0: 0a 20 20 61 20 62 75 72 64 65 6e 2e 20 5b 67 72  .  a burden. [gr
0bf0: 65 65 6e 5d 23 5b 44 4f 4e 45 5d 23 0d 0a 2e 20  een]#[DONE]#... 
0c00: 52 65 64 75 63 65 20 6e 75 6d 62 65 72 20 6f 66  Reduce number of
0c10: 20 73 65 72 76 65 72 73 20 61 6e 64 20 66 72 65   servers and fre
0c20: 71 75 65 6e 63 79 20 6f 66 20 73 74 61 72 74 2f  quency of start/
0c30: 73 74 6f 70 2e 20 54 68 69 73 20 69 73 20 6d 6f  stop. This is mo
0c40: 73 74 6c 79 20 61 6e 0d 0a 20 20 69 73 73 75 65  stly an..  issue
0c50: 20 6f 66 20 63 6c 75 74 74 65 72 20 62 75 74 20   of clutter but 
0c60: 61 6c 73 6f 20 61 20 72 65 64 75 63 74 69 6f 6e  also a reduction
0c70: 20 69 6e 20 22 6d 6f 76 69 6e 67 20 70 61 72 74   in "moving part
0c80: 73 22 2e 20 5b 67 72 65 65 6e 5d 23 5b 44 4f 4e  s". [green]#[DON
0c90: 45 5d 23 0d 0a 2e 20 43 6f 61 6c 65 73 63 65 20  E]#... Coalesce 
0ca0: 61 63 74 69 76 69 74 69 65 73 20 74 6f 20 61 20  activities to a 
0cb0: 73 69 6e 67 6c 65 20 68 6f 6d 65 20 68 6f 73 74  single home host
0cc0: 20 77 68 65 72 65 20 70 6f 73 73 69 62 6c 65 2e   where possible.
0cd0: 20 47 69 76 65 20 74 68 65 20 75 73 65 72 0d 0a   Give the user..
0ce0: 20 20 66 65 65 64 62 61 63 6b 20 74 68 61 74 20    feedback that 
0cf0: 74 68 65 79 20 68 61 76 65 20 73 74 61 72 74 65  they have starte
0d00: 64 20 74 68 65 20 64 61 73 68 62 6f 61 72 64 20  d the dashboard 
0d10: 6f 6e 20 61 20 68 6f 73 74 20 6f 74 68 65 72 20  on a host other 
0d20: 74 68 61 6e 20 74 68 65 0d 0a 20 20 68 6f 6d 65  than the..  home
0d30: 20 68 6f 73 74 2e 20 5b 67 72 65 65 6e 5d 23 5b   host. [green]#[
0d40: 44 4f 4e 45 5d 23 0d 0a 2e 20 52 65 64 75 63 65  DONE]#... Reduce
0d50: 20 6e 75 6d 62 65 72 20 6f 66 20 70 72 6f 63 65   number of proce
0d60: 73 73 65 73 20 69 6e 76 6f 6c 76 65 64 20 69 6e  sses involved in
0d70: 20 6d 61 6e 61 67 69 6e 67 20 72 75 6e 6e 69 6e   managing runnin
0d80: 67 20 74 65 73 74 73 2e 0d 0a 0d 0a 43 68 61 6e  g tests.....Chan
0d90: 67 65 73 20 4e 65 65 64 65 64 0d 0a 5e 5e 5e 5e  ges Needed..^^^^
0da0: 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 0d 0a 0d 0a 2e 20  ^^^^^^^^^^..... 
0db0: 41 43 49 44 20 63 6f 6d 70 6c 69 61 6e 74 20 64  ACID compliant d
0dc0: 62 20 77 69 6c 6c 20 62 65 20 6f 6e 20 2f 74 6d  b will be on /tm
0dd0: 70 20 61 6e 64 20 73 79 6e 63 65 64 20 74 6f 20  p and synced to 
0de0: 6d 65 67 61 74 65 73 74 2e 64 62 20 77 69 74 68  megatest.db with
0df0: 20 61 20 66 69 76 65 0d 0a 20 20 73 65 63 6f 6e   a five..  secon
0e00: 64 20 6d 61 78 20 64 65 6c 61 79 2e 20 5b 67 72  d max delay. [gr
0e10: 65 65 6e 5d 23 5b 44 4f 4e 45 5d 23 0d 0a 2e 20  een]#[DONE]#... 
0e20: 52 65 61 64 2f 77 72 69 74 65 73 20 74 6f 20 64  Read/writes to d
0e30: 62 20 66 6f 72 20 70 72 6f 63 65 73 73 65 73 20  b for processes 
0e40: 6f 6e 20 68 6f 6d 65 68 6f 73 74 20 77 69 6c 6c  on homehost will
0e50: 20 67 6f 20 64 69 72 65 63 74 20 74 6f 20 2f 74   go direct to /t
0e60: 6d 70 0d 0a 20 20 6d 65 67 61 74 65 73 74 2e 64  mp..  megatest.d
0e70: 62 20 66 69 6c 65 2e 20 5b 67 72 65 65 6e 5d 23  b file. [green]#
0e80: 5b 44 4f 4e 45 5d 23 0d 0a 2e 20 52 65 61 64 2f  [DONE]#... Read/
0e90: 77 69 74 65 73 20 66 72 6f 6e 20 6e 6f 6e 2d 68  wites fron non-h
0ea0: 6f 6d 65 68 6f 73 74 20 70 72 6f 63 65 73 73 65  omehost processe
0eb0: 73 20 77 69 6c 6c 20 67 6f 20 74 68 72 6f 75 67  s will go throug
0ec0: 68 20 6f 6e 65 20 73 65 72 76 65 72 2e 20 42 75  h one server. Bu
0ed0: 6c 6b 0d 0a 20 20 72 65 61 64 73 20 28 65 2e 67  lk..  reads (e.g
0ee0: 2e 20 66 6f 72 20 64 61 73 68 62 6f 61 72 64 20  . for dashboard 
0ef0: 6f 72 20 6c 69 73 74 2d 72 75 6e 73 29 20 77 69  or list-runs) wi
0f00: 6c 6c 20 62 65 20 63 61 63 68 65 64 20 6f 6e 20  ll be cached on 
0f10: 74 68 65 20 63 75 72 72 65 6e 74 20 68 6f 73 74  the current host
0f20: 0d 0a 20 20 69 6e 20 2f 74 6d 70 20 61 6e 64 20  ..  in /tmp and 
0f30: 73 79 6e 63 65 64 20 66 72 6f 6d 20 74 68 65 20  synced from the 
0f40: 68 6f 6d 65 20 6d 65 67 61 74 65 73 74 2e 64 62  home megatest.db
0f50: 20 69 6e 20 74 68 65 20 74 65 73 74 73 75 69 74   in the testsuit
0f60: 65 20 61 72 65 61 2e 20 5b 67 72 65 65 6e 5d 23  e area. [green]#
0f70: 5b 44 4f 4e 45 5d 23 0d 0a 2e 20 44 62 20 73 79  [DONE]#... Db sy
0f80: 6e 63 73 20 72 65 6c 79 20 6f 6e 20 74 68 65 20  ncs rely on the 
0f90: 74 61 72 67 65 74 20 64 62 20 66 69 6c 65 20 74  target db file t
0fa0: 69 6d 65 73 74 61 6d 65 20 6d 69 6e 75 73 20 73  imestame minus s
0fb0: 6f 6d 65 20 6d 61 72 67 69 6e 2e 20 5b 67 72 65  ome margin. [gre
0fc0: 65 6e 5d 23 5b 44 4f 4e 45 5d 23 0d 0a 2e 20 53  en]#[DONE]#... S
0fd0: 69 6e 63 65 20 62 75 6c 6b 20 72 65 61 64 73 20  ince bulk reads 
0fe0: 64 6f 20 6e 6f 74 20 75 73 65 20 74 68 65 20 73  do not use the s
0ff0: 65 72 76 65 72 20 77 65 20 63 61 6e 20 73 77 69  erver we can swi
1000: 74 63 68 20 74 6f 20 73 69 6d 70 6c 65 20 52 50  tch to simple RP
1010: 43 20 66 6f 72 20 74 68 65 0d 0a 20 20 6e 65 74  C for the..  net
1020: 77 6f 72 6b 20 74 72 61 6e 73 70 6f 72 74 2e 20  work transport. 
1030: 5b 67 72 65 65 6e 5d 23 5b 44 4f 4e 45 5d 23 0d  [green]#[DONE]#.
1040: 0a 2e 20 54 65 73 74 20 72 75 6e 6e 69 6e 67 20  .. Test running 
1050: 6d 61 6e 61 67 65 72 20 70 72 6f 63 65 73 73 20  manager process 
1060: 65 78 74 65 6e 64 65 64 20 74 6f 20 6d 61 6e 61  extended to mana
1070: 67 65 20 6d 75 6c 74 69 70 6c 65 20 72 75 6e 6e  ge multiple runn
1080: 69 6e 67 20 74 65 73 74 73 2e 0d 0a 0d 0a 43 75  ing tests.....Cu
1090: 72 72 65 6e 74 20 49 74 65 6d 73 0d 0a 7e 7e 7e  rrent Items..~~~
10a0: 7e 7e 7e 7e 7e 7e 7e 7e 7e 7e 0d 0a 0d 0a 77 77  ~~~~~~~~~~....ww
10b0: 30 35 20 2d 20 6d 69 67 72 61 74 65 20 74 6f 20  05 - migrate to 
10c0: 69 6e 6d 65 6d 2d 64 62 0d 0a 5e 5e 5e 5e 5e 5e  inmem-db..^^^^^^
10d0: 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e 5e  ^^^^^^^^^^^^^^^^
10e0: 5e 5e 5e 5e 0d 0a 0d 0a 2e 20 53 77 69 74 63 68  ^^^^..... Switch
10f0: 20 74 6f 20 69 6e 6d 65 6d 20 64 62 20 77 69 74   to inmem db wit
1100: 68 20 66 61 73 74 20 73 79 6e 63 20 74 6f 20 6f  h fast sync to o
1110: 6e 20 64 69 73 6b 20 64 62 27 73 20 5b 67 72 65  n disk db's [gre
1120: 65 6e 5d 23 5b 44 4f 4e 45 5d 23 0d 0a 2e 20 53  en]#[DONE]#... S
1130: 65 72 76 65 72 20 70 6f 6c 6c 73 20 74 61 73 6b  erver polls task
1140: 73 20 74 61 62 6c 65 20 66 6f 72 20 6e 65 78 74  s table for next
1150: 20 61 63 74 69 6f 6e 0d 0a 2e 2e 20 54 61 73 6b   action.... Task
1160: 20 74 61 62 6c 65 20 75 73 65 64 20 66 6f 72 20   table used for 
1170: 74 72 61 63 6b 69 6e 67 20 72 75 6e 6e 65 72 20  tracking runner 
1180: 70 72 6f 63 65 73 73 20 5b 72 65 64 5d 23 5b 52  process [red]#[R
1190: 65 70 6c 61 63 65 64 20 62 79 20 6d 74 75 74 69  eplaced by mtuti
11a0: 6c 5d 23 0d 0a 2e 2e 20 54 61 73 6b 20 74 61 62  l]#.... Task tab
11b0: 6c 65 20 75 73 65 64 20 66 6f 72 20 6a 6f 62 73  le used for jobs
11c0: 20 74 6f 20 72 75 6e 20 5b 72 65 64 5d 23 5b 52   to run [red]#[R
11d0: 65 70 6c 61 63 65 64 20 62 79 20 6d 74 75 74 69  eplaced by mtuti
11e0: 6c 5d 23 0d 0a 2e 2e 20 54 61 73 6b 20 74 61 62  l]#.... Task tab
11f0: 6c 65 20 75 73 65 64 20 66 6f 72 20 71 75 65 75  le used for queu
1200: 65 69 6e 67 20 72 75 6e 6e 65 72 20 61 63 74 69  eing runner acti
1210: 6f 6e 73 20 28 72 65 6d 6f 76 65 20 72 75 6e 73  ons (remove runs
1220: 2c 0d 0a 20 20 20 63 6c 65 61 6e 52 75 6e 45 78  ,..   cleanRunEx
1230: 65 63 75 74 65 2c 20 65 74 63 29 20 20 5b 72 65  ecute, etc)  [re
1240: 64 5d 23 5b 52 65 70 6c 61 63 65 64 20 62 79 20  d]#[Replaced by 
1250: 6d 74 75 74 69 6c 23 5d 0d 0a 0d 0a 0d 0a 2f 2f  mtutil#]......//
1260: 20 77 77 33 32 0d 0a 2f 2f 20 7e 7e 7e 7e 0d 0a   ww32..// ~~~~..
1270: 2f 2f 20 0d 0a 2f 2f 20 2e 20 52 65 72 75 6e 20  // ..// . Rerun 
1280: 73 74 65 70 20 61 6e 64 20 6f 72 20 73 75 62 73  step and or subs
1290: 65 71 75 65 6e 74 20 73 74 65 70 73 20 66 72 6f  equent steps fro
12a0: 6d 20 67 75 69 0d 0a 2f 2f 20 2e 20 52 65 66 72  m gui..// . Refr
12b0: 65 73 68 20 74 65 73 74 20 61 72 65 61 20 66 69  esh test area fi
12c0: 6c 65 73 20 66 72 6f 6d 20 67 75 69 0d 0a 2f 2f  les from gui..//
12d0: 20 2e 20 43 6c 65 61 6e 20 61 6e 64 20 72 65 2d   . Clean and re-
12e0: 72 75 6e 20 62 75 74 74 6f 6e 0d 0a 2f 2f 20 2e  run button..// .
12f0: 20 43 6c 65 61 6e 20 75 70 20 53 54 41 54 45 20   Clean up STATE 
1300: 61 6e 64 20 53 54 41 54 55 53 20 68 61 6e 64 6c  and STATUS handl
1310: 69 6e 67 2e 0d 0a 2f 2f 20 2e 2e 20 44 61 73 68  ing...// .. Dash
1320: 62 6f 61 72 64 20 61 6e 64 20 54 65 73 74 20 63  board and Test c
1330: 6f 6e 74 72 6f 6c 20 70 61 6e 65 6c 20 61 72 65  ontrol panel are
1340: 20 72 65 76 65 72 73 65 20 6f 72 64 65 72 20 2d   reverse order -
1350: 20 63 68 6f 6f 73 65 20 61 6e 64 20 66 69 78 0d   choose and fix.
1360: 0a 2f 2f 20 2e 2e 20 4d 6f 76 65 20 73 65 6c 64  .// .. Move seld
1370: 6f 6d 20 75 73 65 64 20 73 74 61 74 65 73 20 61  om used states a
1380: 6e 64 20 73 74 61 74 75 73 20 74 6f 20 64 72 6f  nd status to dro
1390: 70 20 64 6f 77 6e 20 73 65 6c 65 63 74 6f 72 0d  p down selector.
13a0: 0a 2f 2f 20 2e 20 41 63 63 65 73 73 20 74 65 73  .// . Access tes
13b0: 74 20 63 6f 6e 74 72 6f 6c 20 70 61 6e 65 6c 20  t control panel 
13c0: 77 68 65 6e 20 63 6c 69 63 6b 69 6e 67 20 6f 6e  when clicking on
13d0: 20 52 75 6e 20 53 75 6d 6d 61 72 79 20 74 65 73   Run Summary tes
13e0: 74 73 0d 0a 2f 2f 20 2e 20 46 65 61 74 75 72 65  ts..// . Feature
13f0: 3a 20 2d 67 65 6e 65 72 61 74 65 2d 69 6e 64 65  : -generate-inde
1400: 78 2d 74 72 65 65 0d 0a 2f 2f 20 2e 20 43 68 61  x-tree..// . Cha
1410: 6e 67 65 20 73 70 65 63 69 66 69 6e 67 20 6f 66  nge specifing of
1420: 20 73 74 61 74 65 20 61 6e 64 20 73 74 61 74 75   state and statu
1430: 73 20 74 6f 20 75 73 65 20 53 54 41 54 45 31 2f  s to use STATE1/
1440: 53 54 41 54 55 53 31 2c 53 54 41 54 45 32 2f 53  STATUS1,STATE2/S
1450: 54 41 54 55 53 32 0d 0a 2f 2f 20 0d 0a 2f 2f 20  TATUS2..// ..// 
1460: 77 77 33 33 0d 0a 2f 2f 20 7e 7e 7e 7e 0d 0a 2f  ww33..// ~~~~../
1470: 2f 20 0d 0a 2f 2f 20 2e 20 68 74 74 70 20 61 70  / ..// . http ap
1480: 69 20 61 76 61 69 6c 61 62 6c 65 20 66 6f 72 20  i available for 
1490: 75 73 65 20 77 69 74 68 20 50 65 72 6c 2c 20 52  use with Perl, R
14a0: 75 62 79 20 65 74 63 2e 20 73 63 72 69 70 74 73  uby etc. scripts
14b0: 0d 0a 2f 2f 20 2e 20 6d 65 67 61 74 65 73 74 2e  ..// . megatest.
14c0: 63 6f 6e 66 69 67 20 73 65 74 75 70 20 65 6e 74  config setup ent
14d0: 72 69 65 73 20 66 6f 72 3a 0d 0a 2f 2f 20 2e 2e  ries for:..// ..
14e0: 20 72 75 6e 20 6c 61 75 6e 63 68 69 6e 67 20 28   run launching (
14f0: 65 2e 67 2e 20 2f 62 69 6e 2f 73 68 20 25 43 4d  e.g. /bin/sh %CM
1500: 44 25 20 3e 20 2f 64 65 76 2f 6e 75 6c 6c 29 0d  D% > /dev/null).
1510: 0a 2f 2f 20 2e 2e 20 62 72 6f 77 73 65 72 20 22  .// .. browser "
1520: 6b 6f 6e 71 75 65 72 6f 72 20 25 46 4e 41 4d 45  konqueror %FNAME
1530: 25 0d 0a 2f 2f 20 0d 0a 2f 2f 20 77 77 33 34 0d  %..// ..// ww34.
1540: 0a 2f 2f 20 7e 7e 7e 7e 0d 0a 2f 2f 20 0d 0a 2f  .// ~~~~..// ../
1550: 2f 20 2e 20 4d 61 72 6b 20 64 65 70 65 6e 64 65  / . Mark depende
1560: 6e 74 20 74 65 73 74 73 20 66 6f 72 20 63 6c 65  nt tests for cle
1570: 61 6e 2f 72 65 72 75 6e 20 2d 72 65 72 75 6e 2d  an/rerun -rerun-
1580: 64 6f 77 6e 73 74 72 65 61 6d 0d 0a 2f 2f 20 2e  downstream..// .
1590: 20 4f 6e 20 72 75 6e 20 73 74 61 72 74 20 63 68   On run start ch
15a0: 65 63 6b 20 66 6f 72 20 64 65 66 75 6e 63 74 20  eck for defunct 
15b0: 74 65 73 74 73 20 69 6e 20 52 55 4e 4e 49 4e 47  tests in RUNNING
15c0: 2c 20 4c 41 55 4e 43 48 45 44 20 6f 72 20 52 45  , LAUNCHED or RE
15d0: 4d 4f 54 45 48 4f 53 54 53 54 41 52 54 20 61 6e  MOTEHOSTSTART an
15e0: 64 20 63 6f 72 72 65 63 74 20 6f 72 20 6e 6f 74  d correct or not
15f0: 69 66 79 0d 0a 2f 2f 20 2e 20 46 69 78 3a 20 72  ify..// . Fix: r
1600: 65 66 72 65 73 68 20 6f 66 20 67 75 69 20 73 6f  efresh of gui so
1610: 6d 65 74 69 6d 65 73 20 66 61 69 6c 73 20 6f 6e  metimes fails on
1620: 20 6c 61 73 74 20 69 74 65 6d 20 28 72 61 63 65   last item (race
1630: 20 63 6f 6e 64 69 74 69 6f 6e 3f 29 0d 0a 2f 2f   condition?)..//
1640: 20 0d 0a 2f 2f 20 77 77 33 35 0d 0a 2f 2f 20 7e   ..// ww35..// ~
1650: 7e 7e 7e 0d 0a 2f 2f 20 0d 0a 2f 2f 20 2e 20 72  ~~~..// ..// . r
1660: 65 66 64 62 3a 20 41 64 64 20 65 78 70 6f 72 74  efdb: Add export
1670: 20 6f 66 20 63 73 76 2c 20 6a 73 6f 6e 20 61 6e   of csv, json an
1680: 64 20 73 65 78 70 0d 0a 2f 2f 20 2e 20 43 6f 6e  d sexp..// . Con
1690: 76 65 72 74 20 74 6f 20 75 73 69 6e 67 20 63 61  vert to using ca
16a0: 6c 6c 2d 77 69 74 68 2d 65 6e 76 69 72 6f 6e 6d  ll-with-environm
16b0: 65 6e 74 2d 76 61 72 69 61 62 6c 65 73 20 77 68  ent-variables wh
16c0: 65 72 65 20 70 6f 73 73 69 62 6c 65 2e 20 53 68  ere possible. Sh
16d0: 6f 75 6c 64 20 61 6c 6c 6f 77 20 68 61 6e 64 6c  ould allow handl
16e0: 69 6e 67 20 6f 66 20 70 61 72 61 6c 6c 65 6c 20  ing of parallel 
16f0: 72 75 6e 73 20 69 6e 20 73 61 6d 65 20 70 72 6f  runs in same pro
1700: 63 65 73 73 2e 0d 0a 2f 2f 20 2e 20 52 65 2d 77  cess...// . Re-w
1710: 6f 72 6b 20 74 65 78 74 20 69 6e 74 65 72 66 61  ork text interfa
1720: 63 65 20 77 69 7a 61 72 64 73 2e 20 53 65 76 65  ce wizards. Seve
1730: 72 61 6c 20 62 75 67 73 20 6f 6e 20 72 65 63 6f  ral bugs on reco
1740: 72 64 2e 20 50 6f 73 73 69 62 6c 79 20 63 6f 6e  rd. Possibly con
1750: 76 65 72 74 20 74 6f 20 67 75 69 20 62 61 73 65  vert to gui base
1760: 64 2e 0d 0a 2f 2f 20 2e 20 41 64 64 20 74 6f 20  d...// . Add to 
1770: 74 65 73 74 63 6f 6e 66 69 67 20 72 65 71 75 69  testconfig requi
1780: 72 65 6d 65 6e 74 73 20 73 65 63 74 69 6f 6e 3b  rements section;
1790: 20 6c 61 75 6e 63 68 6c 69 6d 69 74 65 72 20 73   launchlimiter s
17a0: 63 72 69 70 74 6e 61 6d 65 2c 20 63 61 6c 6c 73  criptname, calls
17b0: 20 73 63 72 69 70 74 6e 61 6d 65 20 74 6f 20 63   scriptname to c
17c0: 68 65 63 6b 20 69 66 20 6f 6b 20 74 6f 20 6c 61  heck if ok to la
17d0: 75 6e 63 68 20 74 65 73 74 0d 0a 2f 2f 20 2e 20  unch test..// . 
17e0: 52 65 66 61 63 74 6f 72 20 52 75 6e 20 53 75 6d  Refactor Run Sum
17f0: 6d 61 72 79 20 76 69 65 77 2c 20 63 75 72 72 65  mary view, curre
1800: 6e 74 6c 79 20 76 65 72 79 20 63 6c 75 6d 73 79  ntly very clumsy
1810: 0d 0a 2f 2f 20 2e 20 41 64 64 20 6f 70 74 69 6f  ..// . Add optio
1820: 6e 20 74 6f 20 73 68 6f 77 20 73 74 65 70 73 20  n to show steps 
1830: 69 6e 20 52 75 6e 20 53 75 6d 6d 61 72 79 20 76  in Run Summary v
1840: 69 65 77 0d 0a 2f 2f 20 0d 0a 2f 2f 20 77 77 33  iew..// ..// ww3
1850: 36 0d 0a 2f 2f 20 7e 7e 7e 7e 0d 0a 2f 2f 20 0d  6..// ~~~~..// .
1860: 0a 2f 2f 20 2e 20 52 65 66 61 63 74 6f 72 20 67  .// . Refactor g
1870: 75 69 73 20 66 6f 72 20 72 65 73 69 7a 65 61 62  uis for resizeab
1880: 6c 69 74 79 0d 0a 2f 2f 20 2e 20 41 64 64 20 66  lity..// . Add f
1890: 69 6c 74 65 72 73 20 74 6f 20 52 75 6e 20 53 75  ilters to Run Su
18a0: 6d 6d 61 72 79 20 76 69 65 77 20 61 6e 64 20 52  mmary view and R
18b0: 75 6e 20 43 6f 6e 74 72 6f 6c 20 76 69 65 77 0d  un Control view.
18c0: 0a 2f 2f 20 2e 20 41 64 64 20 74 6f 20 6d 65 67  .// . Add to meg
18d0: 61 74 65 73 74 2e 63 6f 6e 66 69 67 20 6f 72 20  atest.config or 
18e0: 74 65 73 74 63 6f 6e 66 69 67 3b 20 72 65 72 75  testconfig; reru
18f0: 6e 6f 6b 20 53 54 41 54 45 2f 53 54 41 54 55 53  nok STATE/STATUS
1900: 2c 53 54 41 54 45 2f 53 54 41 54 55 53 2e 2e 2e  ,STATE/STATUS...
1910: 0d 0a 2f 2f 20 2e 20 4c 61 75 6e 63 68 20 67 61  ..// . Launch ga
1920: 74 65 73 20 66 6f 72 20 64 69 73 6b 73 70 61 63  tes for diskspac
1930: 65 3b 20 2f 70 61 74 68 2f 6f 6e 65 3e 31 47 2c  e; /path/one>1G,
1940: 2f 70 61 74 68 2f 74 77 6f 3e 32 30 30 4d 2c 2f  /path/two>200M,/
1950: 74 6d 70 3e 35 47 2c 23 7b 73 63 68 65 6d 65 20  tmp>5G,#{scheme 
1960: 2a 74 6f 70 70 61 74 68 2a 7d 3e 31 47 0d 0a 2f  *toppath*}>1G../
1970: 2f 20 0d 0a 2f 2f 20 42 69 6e 20 4c 69 73 74 0d  / ..// Bin List.
1980: 0a 2f 2f 20 7e 7e 7e 7e 7e 7e 7e 7e 0d 0a 2f 2f  .// ~~~~~~~~..//
1990: 20 0d 0a 2f 2f 20 2e 09 51 75 61 6c 69 74 79 20   ..// ..Quality 
19a0: 69 6d 70 72 6f 76 65 6d 65 6e 74 73 0d 0a 2f 2f  improvements..//
19b0: 20 2e 2e 09 53 65 72 76 65 72 20 73 74 75 74 74   ...Server stutt
19c0: 65 72 73 20 6f 63 63 61 73 69 6f 6e 61 6c 6c 79  ers occasionally
19d0: 0d 0a 2f 2f 20 2e 2e 09 4c 61 72 67 65 20 6e 75  ..// ...Large nu
19e0: 6d 62 65 72 20 6f 66 20 69 74 65 6d 73 20 6f 72  mber of items or
19f0: 20 74 65 73 74 73 20 73 74 69 6c 6c 20 68 61 73   tests still has
1a00: 20 73 6f 6d 65 20 69 73 73 75 65 73 2e 0d 0a 2f   some issues.../
1a10: 2f 20 2e 2e 09 43 6f 64 65 20 72 65 66 61 63 74  / ...Code refact
1a20: 6f 72 69 6e 67 0d 0a 2f 2f 20 2e 2e 09 52 65 70  oring..// ...Rep
1a30: 6c 61 63 65 20 72 65 6d 6f 74 65 20 70 72 6f 63  lace remote proc
1a40: 65 73 73 20 77 69 74 68 20 74 72 75 65 20 41 50  ess with true AP
1a50: 49 20 75 73 69 6e 67 20 6a 73 6f 6e 20 28 73 75  I using json (su
1a60: 70 70 6f 72 74 73 20 57 65 62 20 61 70 70 20 61  pports Web app a
1a70: 6c 73 6f 29 0d 0a 2f 2f 20 2e 09 53 74 72 65 61  lso)..// ..Strea
1a80: 6d 6c 69 6e 65 20 74 68 65 20 67 75 69 0d 0a 2f  mline the gui../
1a90: 2f 20 2e 2e 09 45 76 65 72 79 74 68 69 6e 67 20  / ...Everything 
1aa0: 72 65 73 69 7a 61 62 6c 65 0d 0a 2f 2f 20 2e 2e  resizable..// ..
1ab0: 09 4c 65 73 73 20 63 6c 75 74 74 65 72 0d 0a 2f  .Less clutter../
1ac0: 2f 20 2e 2e 09 54 6f 6f 6c 20 74 69 70 73 0d 0a  / ...Tool tips..
1ad0: 2f 2f 20 2e 2e 09 46 69 6c 74 65 72 73 20 6f 6e  // ...Filters on
1ae0: 20 52 75 6e 20 53 75 6d 6d 61 72 79 2c 20 53 75   Run Summary, Su
1af0: 6d 6d 61 72 79 20 61 6e 64 20 52 75 6e 20 43 6f  mmary and Run Co
1b00: 6e 74 72 6f 6c 20 70 61 6e 65 6c 0d 0a 2f 2f 20  ntrol panel..// 
1b10: 2e 2e 09 42 75 69 6c 74 20 69 6e 20 6c 6f 67 20  ...Built in log 
1b20: 76 69 65 77 65 72 20 28 70 61 72 74 69 61 6c 6c  viewer (partiall
1b30: 79 20 69 6d 70 6c 65 6d 65 6e 74 65 64 29 0d 0a  y implemented)..
1b40: 2f 2f 20 2e 2e 09 52 65 66 61 63 74 6f 72 20 74  // ...Refactor t
1b50: 68 65 20 74 65 73 74 20 63 6f 6e 74 72 6f 6c 20  he test control 
1b60: 70 61 6e 65 6c 0d 0a 2f 2f 20 2e 09 48 65 6c 70  panel..// ..Help
1b70: 20 61 6e 64 20 64 6f 63 75 6d 65 6e 74 61 74 69   and documentati
1b80: 6f 6e 0d 0a 2f 2f 20 2e 2e 09 43 6f 6d 70 6c 65  on..// ...Comple
1b90: 74 65 20 74 68 65 20 75 73 65 72 20 6d 61 6e 75  te the user manu
1ba0: 61 6c 20 28 49 e2 80 99 76 65 20 62 65 65 6e 20  al (I’ve been 
1bb0: 77 6f 72 6b 69 6e 67 20 6f 6e 20 74 68 69 73 20  working on this 
1bc0: 6c 61 74 65 6c 79 29 2e 0d 0a 2f 2f 20 2e 2e 09  lately)...// ...
1bd0: 4f 6e 6c 69 6e 65 20 68 65 6c 70 20 69 6e 20 74  Online help in t
1be0: 68 65 20 67 75 69 0d 0a 2f 2f 20 2e 09 53 74 72  he gui..// ..Str
1bf0: 65 61 6d 6c 69 6e 65 64 20 69 6e 73 74 61 6c 6c  eamlined install
1c00: 0d 0a 2f 2f 20 2e 2e 09 44 65 70 6c 6f 79 65 64  ..// ...Deployed
1c10: 20 76 65 72 73 69 6f 6e 20 28 64 6f 77 6e 6c 6f   version (downlo
1c20: 61 64 20 61 20 6c 6f 63 61 74 69 6f 6e 20 69 6e  ad a location in
1c30: 64 65 70 65 6e 64 65 6e 74 20 72 65 61 64 79 20  dependent ready 
1c40: 74 6f 20 72 75 6e 20 62 69 6e 61 72 79 20 62 75  to run binary bu
1c50: 6e 64 6c 65 29 0d 0a 2f 2f 20 2e 2e 09 49 6e 73  ndle)..// ...Ins
1c60: 74 61 6c 6c 20 4d 61 6b 65 66 69 6c 65 20 28 69  tall Makefile (i
1c70: 6e 20 70 72 6f 67 72 65 73 73 2c 20 6e 65 65 64  n progress, need
1c80: 65 64 20 66 6f 72 20 4d 69 6b 65 20 74 6f 20 69  ed for Mike to i
1c90: 6e 73 74 61 6c 6c 20 6f 6e 20 56 4d 73 29 0d 0a  nstall on VMs)..
1ca0: 2f 2f 20 2e 2e 09 41 64 64 65 64 20 6f 70 74 69  // ...Added opti
1cb0: 6f 6e 20 74 6f 20 63 6f 6d 70 69 6c 65 20 49 55  on to compile IU
1cc0: 50 20 28 6e 65 65 64 65 64 20 66 6f 72 20 56 4d  P (needed for VM
1cd0: 73 29 0d 0a 2f 2f 20 2e 09 53 65 72 76 65 72 20  s)..// ..Server 
1ce0: 73 69 64 65 20 72 75 6e 20 6c 61 75 6e 63 68 69  side run launchi
1cf0: 6e 67 0d 0a 2f 2f 20 2e 09 53 75 70 70 6f 72 74  ng..// ..Support
1d00: 20 66 6f 72 20 72 65 2d 72 75 6e 6e 69 6e 67 2c   for re-running,
1d10: 20 63 6c 65 61 6e 69 6e 67 20 65 74 63 2e 20 6f   cleaning etc. o
1d20: 66 20 69 6e 64 69 76 69 64 75 61 6c 20 73 74 65  f individual ste
1d30: 70 73 20 28 65 7a 73 74 65 70 73 20 6d 61 6b 65  ps (ezsteps make
1d40: 73 20 74 68 69 73 20 76 65 72 79 20 65 61 73 79  s this very easy
1d50: 20 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 29 2e 0d   to implement)..
1d60: 0a 2f 2f 20 2e 09 4c 61 75 6e 63 68 20 70 72 6f  .// ..Launch pro
1d70: 63 65 73 73 20 6e 65 65 64 73 20 62 75 69 6c 74  cess needs built
1d80: 20 69 6e 20 64 61 65 6d 6f 6e 69 7a 69 6e 67 20   in daemonizing 
1d90: 28 65 61 73 79 20 74 6f 20 64 6f 2c 20 6a 75 73  (easy to do, jus
1da0: 74 20 6e 65 65 64 20 74 6f 20 74 65 73 74 20 69  t need to test i
1db0: 74 20 74 68 6f 72 6f 75 67 68 6c 79 29 2e 0d 0a  t thoroughly)...
1dc0: 2f 2f 20 2e 09 57 69 7a 61 72 64 73 20 66 6f 72  // ..Wizards for
1dd0: 20 63 72 65 61 74 69 6e 67 20 74 65 73 74 73 2c   creating tests,
1de0: 20 72 65 67 72 65 73 73 69 6f 6e 20 61 72 65 61   regression area
1df0: 73 20 28 63 75 72 72 65 6e 74 20 6f 6e 65 73 20  s (current ones 
1e00: 61 72 65 20 74 65 78 74 20 6f 6e 6c 79 20 61 6e  are text only an
1e10: 64 20 6c 69 6d 69 74 65 64 29 2e 0d 0a 2f 2f 20  d limited)...// 
1e20: 2e 09 46 75 6c 6c 79 20 66 75 6e 63 74 69 6f 6e  ..Fully function
1e30: 61 6c 20 62 75 69 6c 74 20 69 6e 20 77 65 62 20  al built in web 
1e40: 73 65 72 76 69 63 65 20 28 63 75 72 72 65 6e 74  service (current
1e50: 6c 79 20 79 6f 75 20 63 61 6e 20 62 72 6f 77 73  ly you can brows
1e60: 65 20 72 75 6e 73 20 62 75 74 20 69 74 20 69 73  e runs but it is
1e70: 20 76 65 72 79 20 73 69 6d 70 6c 69 73 74 69 63   very simplistic
1e80: 29 2e 0d 0a 2f 2f 20 2e 09 57 69 6c 64 63 61 72  )...// ..Wildcar
1e90: 64 73 20 69 6e 20 72 75 6e 63 6f 6e 66 69 67 73  ds in runconfigs
1ea0: 3a 20 65 2e 67 2e 20 5b 70 31 32 37 31 2f 39 2f  : e.g. [p1271/9/
1eb0: 25 2f 25 5d 0d 0a 2f 2f 20 2e 09 47 75 69 20 70  %/%]..// ..Gui p
1ec0: 61 6e 65 6c 73 20 66 6f 72 20 65 64 69 74 69 6e  anels for editin
1ed0: 67 20 6d 65 67 61 74 65 73 74 2e 63 6f 6e 66 69  g megatest.confi
1ee0: 67 20 61 6e 64 20 72 75 6e 63 6f 6e 66 69 67 73  g and runconfigs
1ef0: 2e 63 6f 6e 66 69 67 0d 0a 2f 2f 20 2e 09 46 75  .config..// ..Fu
1f00: 6c 6c 79 20 69 73 6f 6c 61 74 65 64 20 74 65 73  lly isolated tes
1f10: 74 73 20 28 6e 6f 20 75 73 65 20 6f 66 20 4e 46  ts (no use of NF
1f20: 53 20 74 6f 20 73 65 65 20 72 65 67 72 65 73 73  S to see regress
1f30: 69 6f 6e 20 61 72 65 61 20 66 69 6c 65 73 29 0d  ion area files).
1f40: 0a 2f 2f 20 2e 09 57 69 6e 64 6f 77 73 20 76 65  .// ..Windows ve
1f50: 72 73 69 6f 6e 0d 0a 0a 5a 20 33 38 33 61 32 66  rsion...Z 383a2f
1f60: 32 34 65 63 32 30 37 33 63 63 65 65 66 61 38 61  24ec2073cceefa8a
1f70: 30 37 37 66 38 65 30 64 64 33 0a                 077f8e0dd3.