System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact ead88808834cf4a04d557d76b09f61e1d0a6da93:


0000: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0010: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0020: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0040: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
0050: 0a 23 0d 0a 23 20 73 74 72 65 73 73 2e 65 61 67  .#..# stress.eag
0060: 6c 65 20 2d 2d 0d 0a 23 0d 0a 23 20 57 72 69 74  le --..#..# Writ
0070: 74 65 6e 20 62 79 20 4a 6f 65 20 4d 69 73 74 61  ten by Joe Mista
0080: 63 68 6b 69 6e 2e 0d 0a 23 20 52 65 6c 65 61 73  chkin...# Releas
0090: 65 64 20 74 6f 20 74 68 65 20 70 75 62 6c 69 63  ed to the public
00a0: 20 64 6f 6d 61 69 6e 2c 20 75 73 65 20 61 74 20   domain, use at 
00b0: 79 6f 75 72 20 6f 77 6e 20 72 69 73 6b 21 0d 0a  your own risk!..
00c0: 23 0d 0a 23 23 23 23 23 23 23 23 23 23 23 23 23  #..#############
00d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
00e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
00f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0100: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0110: 23 23 0d 0a 0d 0a 70 61 63 6b 61 67 65 20 72 65  ##....package re
0120: 71 75 69 72 65 20 45 61 67 6c 65 0d 0a 70 61 63  quire Eagle..pac
0130: 6b 61 67 65 20 72 65 71 75 69 72 65 20 45 61 67  kage require Eag
0140: 6c 65 2e 4c 69 62 72 61 72 79 0d 0a 70 61 63 6b  le.Library..pack
0150: 61 67 65 20 72 65 71 75 69 72 65 20 45 61 67 6c  age require Eagl
0160: 65 2e 54 65 73 74 0d 0a 0d 0a 72 75 6e 54 65 73  e.Test....runTes
0170: 74 50 72 6f 6c 6f 67 75 65 0d 0a 0d 0a 23 23 23  tPrologue....###
0180: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0190: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
01c0: 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a  ############....
01d0: 70 61 63 6b 61 67 65 20 72 65 71 75 69 72 65 20  package require 
01e0: 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69  System.Data.SQLi
01f0: 74 65 2e 54 65 73 74 0d 0a 72 75 6e 53 51 4c 69  te.Test..runSQLi
0200: 74 65 54 65 73 74 50 72 6f 6c 6f 67 75 65 0d 0a  teTestPrologue..
0210: 0d 0a 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ..##############
0220: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0230: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0240: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0250: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0260: 23 0d 0a 0d 0a 23 0d 0a 23 20 4e 4f 54 45 3a 20  #....#..# NOTE: 
0270: 4d 61 6b 65 20 73 75 72 65 20 74 68 61 74 20 53  Make sure that S
0280: 51 4c 69 74 65 20 63 6f 72 65 20 6c 69 62 72 61  QLite core libra
0290: 72 79 20 69 73 20 63 6f 6d 70 6c 65 74 65 6c 79  ry is completely
02a0: 20 73 68 75 74 64 6f 77 6e 20 70 72 69 6f 72 20   shutdown prior 
02b0: 74 6f 0d 0a 23 20 20 20 20 20 20 20 73 74 61 72  to..#       star
02c0: 74 69 6e 67 20 61 6e 79 20 6f 66 20 74 68 65 20  ting any of the 
02d0: 74 65 73 74 73 20 69 6e 20 74 68 69 73 20 66 69  tests in this fi
02e0: 6c 65 2e 0d 0a 23 0d 0a 73 68 75 74 64 6f 77 6e  le...#..shutdown
02f0: 53 51 4c 69 74 65 20 24 74 65 73 74 5f 63 68 61  SQLite $test_cha
0300: 6e 6e 65 6c 0d 0a 0d 0a 23 23 23 23 23 23 23 23  nnel....########
0310: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0320: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0330: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0340: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0350: 23 23 23 23 23 23 23 0d 0a 0d 0a 72 75 6e 54 65  #######....runTe
0360: 73 74 20 7b 74 65 73 74 20 73 74 72 65 73 73 2d  st {test stress-
0370: 31 2e 31 20 7b 6d 75 6c 74 69 74 68 72 65 61 64  1.1 {multithread
0380: 65 64 20 73 74 72 65 73 73 20 74 65 73 74 69 6e  ed stress testin
0390: 67 7d 20 2d 73 65 74 75 70 20 7b 0d 0a 20 20 75  g} -setup {..  u
03a0: 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e  nset -nocomplain
03b0: 20 72 65 73 75 6c 74 20 74 68 72 65 61 64 20 69   result thread i
03c0: 6e 64 65 78 20 77 6f 72 6b 6c 6f 61 64 20 70 72  ndex workload pr
03d0: 69 6f 72 69 74 79 20 6e 6f 57 6f 72 6b 6c 6f 61  iority noWorkloa
03e0: 64 20 5c 0d 0a 20 20 20 20 20 20 70 72 69 6f 72  d \..      prior
03f0: 69 74 69 65 73 20 73 72 63 44 62 20 64 62 20 66  ities srcDb db f
0400: 69 6c 65 4e 61 6d 65 20 63 6f 6d 70 69 6c 65 64  ileName compiled
0410: 20 6f 70 74 69 6f 6e 73 20 63 6f 75 6e 74 20 74   options count t
0420: 69 6d 65 73 20 6c 6f 67 46 69 6c 65 4e 61 6d 65  imes logFileName
0430: 20 5c 0d 0a 20 20 20 20 20 20 6c 6f 67 4c 69 73   \..      logLis
0440: 74 65 6e 65 72 20 63 6f 6e 6e 65 63 74 69 6f 6e  tener connection
0450: 20 69 6e 64 69 63 61 74 6f 72 73 20 69 74 65 72   indicators iter
0460: 61 74 69 6f 6e 73 20 65 78 69 74 4f 6e 46 61 69  ations exitOnFai
0470: 6c 20 63 6f 54 61 73 6b 4d 65 6d 20 5c 0d 0a 20  l coTaskMem \.. 
0480: 20 20 20 20 20 6e 6f 54 72 61 63 65 20 66 61 69       noTrace fai
0490: 6c 75 72 65 73 0d 0a 0d 0a 20 20 23 23 23 23 23  lures....  #####
04a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
04b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
04c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
04d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
04e0: 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72  ########....  pr
04f0: 6f 63 20 66 6f 72 6d 61 74 57 6f 72 6b 6c 6f 61  oc formatWorkloa
0500: 64 52 65 73 75 6c 74 20 7b 20 69 6e 64 65 78 20  dResult { index 
0510: 7d 20 7b 0d 0a 20 20 20 20 73 65 74 20 72 65 73  } {..    set res
0520: 75 6c 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20  ult [appendArgs 
0530: 22 2d 2d 2d 2d 20 69 74 65 72 61 74 69 6f 6e 73  "---- iterations
0540: 20 66 6f 72 20 77 6f 72 6b 6c 6f 61 64 20 28 22   for workload ("
0550: 20 24 69 6e 64 65 78 20 22 29 3a 20 22 5d 0d 0a   $index "): "]..
0560: 0d 0a 20 20 20 20 61 70 70 65 6e 64 20 72 65 73  ..    append res
0570: 75 6c 74 20 5b 65 78 70 72 20 7b 5b 69 6e 66 6f  ult [expr {[info
0580: 20 65 78 69 73 74 73 20 3a 3a 69 74 65 72 61 74   exists ::iterat
0590: 69 6f 6e 73 28 24 69 6e 64 65 78 2c 6f 6b 29 5d  ions($index,ok)]
05a0: 20 3f 20 5c 0d 0a 20 20 20 20 20 20 20 20 24 3a   ? \..        $:
05b0: 3a 69 74 65 72 61 74 69 6f 6e 73 28 24 69 6e 64  :iterations($ind
05c0: 65 78 2c 6f 6b 29 20 3a 20 30 7d 5d 20 22 20 6f  ex,ok) : 0}] " o
05d0: 6b 2c 20 22 0d 0a 0d 0a 20 20 20 20 61 70 70 65  k, "....    appe
05e0: 6e 64 20 72 65 73 75 6c 74 20 5b 65 78 70 72 20  nd result [expr 
05f0: 7b 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 3a 3a  {[info exists ::
0600: 69 74 65 72 61 74 69 6f 6e 73 28 24 69 6e 64 65  iterations($inde
0610: 78 2c 65 72 72 6f 72 29 5d 20 3f 20 5c 0d 0a 20  x,error)] ? \.. 
0620: 20 20 20 20 20 20 20 24 3a 3a 69 74 65 72 61 74         $::iterat
0630: 69 6f 6e 73 28 24 69 6e 64 65 78 2c 65 72 72 6f  ions($index,erro
0640: 72 29 20 3a 20 30 7d 5d 20 22 20 65 72 72 6f 72  r) : 0}] " error
0650: 2c 20 22 0d 0a 0d 0a 20 20 20 20 23 0d 0a 20 20  , "....    #..  
0660: 20 20 23 20 4e 4f 54 45 3a 20 54 72 61 6e 73 6c    # NOTE: Transl
0670: 61 74 65 20 74 68 65 20 77 6f 72 6b 6c 6f 61 64  ate the workload
0680: 20 69 6e 64 65 78 20 74 6f 20 74 68 65 20 63 6f   index to the co
0690: 72 72 65 73 70 6f 6e 64 69 6e 67 20 69 74 65 72  rresponding iter
06a0: 61 74 69 6f 6e 0d 0a 20 20 20 20 23 20 20 20 20  ation..    #    
06b0: 20 20 20 65 72 72 6f 72 20 69 6e 64 69 63 61 74     error indicat
06c0: 6f 72 20 73 6f 20 74 68 61 74 20 77 65 20 63 61  or so that we ca
06d0: 6e 20 65 61 73 69 6c 79 20 6c 6f 6f 6b 75 70 20  n easily lookup 
06e0: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 0d 0a 20  the number of.. 
06f0: 20 20 20 23 20 20 20 20 20 20 20 66 61 69 6c 75     #       failu
0700: 72 65 73 20 28 69 2e 65 2e 20 22 75 6e 65 78 70  res (i.e. "unexp
0710: 65 63 74 65 64 20 65 72 72 6f 72 73 22 29 20 66  ected errors") f
0720: 6f 72 20 74 68 65 20 77 6f 72 6b 6c 6f 61 64 2e  or the workload.
0730: 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 73 65 74  ..    #..    set
0740: 20 69 6e 64 69 63 61 74 6f 72 20 5b 73 74 72 69   indicator [stri
0750: 6e 67 20 63 68 61 72 61 63 74 65 72 20 5b 65 78  ng character [ex
0760: 70 72 20 7b 5b 73 74 72 69 6e 67 20 6f 72 64 69  pr {[string ordi
0770: 6e 61 6c 20 61 20 30 5d 20 2b 20 24 69 6e 64 65  nal a 0] + $inde
0780: 78 20 2d 20 31 7d 5d 5d 0d 0a 0d 0a 20 20 20 20  x - 1}]]....    
0790: 61 70 70 65 6e 64 20 72 65 73 75 6c 74 20 5b 65  append result [e
07a0: 78 70 72 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74  xpr {[info exist
07b0: 73 20 3a 3a 66 61 69 6c 75 72 65 73 28 24 69 6e  s ::failures($in
07c0: 64 69 63 61 74 6f 72 29 5d 20 3f 20 5c 0d 0a 20  dicator)] ? \.. 
07d0: 20 20 20 20 20 20 20 24 3a 3a 66 61 69 6c 75 72         $::failur
07e0: 65 73 28 24 69 6e 64 69 63 61 74 6f 72 29 20 3a  es($indicator) :
07f0: 20 30 7d 5d 20 22 20 66 61 69 6c 65 64 5c 6e 22   0}] " failed\n"
0800: 0d 0a 0d 0a 20 20 20 20 72 65 74 75 72 6e 20 24  ....    return $
0810: 72 65 73 75 6c 74 0d 0a 20 20 7d 0d 0a 0d 0a 20  result..  }.... 
0820: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
0830: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0840: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0850: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0860: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
0870: 0d 0a 20 20 70 72 6f 63 20 69 73 45 78 70 65 63  ..  proc isExpec
0880: 74 65 64 45 72 72 6f 72 20 7b 20 65 72 72 6f 72  tedError { error
0890: 20 7d 20 7b 0d 0a 20 20 20 20 72 65 74 75 72 6e   } {..    return
08a0: 20 5b 65 78 70 72 20 7b 5b 72 65 67 65 78 70 20   [expr {[regexp 
08b0: 2d 2d 20 7b 5c 73 6e 6f 20 73 75 63 68 20 74 61  -- {\sno such ta
08c0: 62 6c 65 3a 20 74 31 5c 73 7d 20 24 65 72 72 6f  ble: t1\s} $erro
08d0: 72 5d 20 7c 7c 20 5c 0d 0a 20 20 20 20 20 20 20  r] || \..       
08e0: 20 5b 72 65 67 65 78 70 20 2d 2d 20 7b 5c 73 64   [regexp -- {\sd
08f0: 61 74 61 62 61 73 65 20 69 73 20 6c 6f 63 6b 65  atabase is locke
0900: 64 5c 73 7d 20 24 65 72 72 6f 72 5d 20 7c 7c 20  d\s} $error] || 
0910: 5c 0d 0a 20 20 20 20 20 20 20 20 5b 72 65 67 65  \..        [rege
0920: 78 70 20 2d 2d 20 7b 5c 73 64 61 74 61 62 61 73  xp -- {\sdatabas
0930: 65 20 74 61 62 6c 65 20 69 73 20 6c 6f 63 6b 65  e table is locke
0940: 64 5c 73 7d 20 24 65 72 72 6f 72 5d 7d 5d 0d 0a  d\s} $error]}]..
0950: 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23    }....  #######
0960: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0970: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0980: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0990: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
09a0: 23 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72 6f 63  ######....  proc
09b0: 20 77 61 69 74 46 6f 72 54 65 73 74 20 7b 20 7b   waitForTest { {
09c0: 65 78 74 72 61 20 30 7d 20 7d 20 7b 0d 0a 20 20  extra 0} } {..  
09d0: 20 20 61 66 74 65 72 20 5b 65 78 70 72 20 7b 69    after [expr {i
09e0: 6e 74 28 28 72 61 6e 64 28 29 20 2a 20 31 30 30  nt((rand() * 100
09f0: 30 29 20 2b 20 24 65 78 74 72 61 29 7d 5d 0d 0a  0) + $extra)}]..
0a00: 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23    }....  #######
0a10: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0a20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0a30: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0a40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0a50: 23 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72 6f 63  ######....  proc
0a60: 20 73 68 6f 77 54 65 73 74 20 7b 20 69 6e 64 69   showTest { indi
0a70: 63 61 74 6f 72 20 7d 20 7b 0d 0a 20 20 20 20 74  cator } {..    t
0a80: 70 75 74 73 20 24 3a 3a 74 65 73 74 5f 63 68 61  puts $::test_cha
0a90: 6e 6e 65 6c 20 24 69 6e 64 69 63 61 74 6f 72 0d  nnel $indicator.
0aa0: 0a 20 20 20 20 61 70 70 65 6e 64 20 3a 3a 69 6e  .    append ::in
0ab0: 64 69 63 61 74 6f 72 73 20 24 69 6e 64 69 63 61  dicators $indica
0ac0: 74 6f 72 0d 0a 20 20 20 20 77 61 69 74 46 6f 72  tor..    waitFor
0ad0: 54 65 73 74 20 24 3a 3a 63 6f 75 6e 74 28 32 29  Test $::count(2)
0ae0: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23  ..  }....  #####
0af0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0b00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0b10: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0b20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0b30: 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72  ########....  pr
0b40: 6f 63 20 66 61 69 6c 54 65 73 74 20 7b 20 69 6e  oc failTest { in
0b50: 64 69 63 61 74 6f 72 20 65 72 72 6f 72 20 7d 20  dicator error } 
0b60: 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20  {..    #..    # 
0b70: 4e 4f 54 45 3a 20 48 61 6c 74 20 61 6c 6c 20 74  NOTE: Halt all t
0b80: 65 73 74 69 6e 67 20 61 6e 64 20 65 78 69 74 20  esting and exit 
0b90: 74 68 65 20 70 72 6f 63 65 73 73 20 6e 6f 77 0d  the process now.
0ba0: 0a 20 20 20 20 23 20 20 20 20 20 20 20 2d 4f 52  .    #       -OR
0bb0: 2d 20 6a 75 73 74 20 72 65 63 6f 72 64 20 74 68  - just record th
0bc0: 65 20 66 61 69 6c 75 72 65 20 61 6e 64 20 63 6f  e failure and co
0bd0: 6e 74 69 6e 75 65 3f 0d 0a 20 20 20 20 23 0d 0a  ntinue?..    #..
0be0: 20 20 20 20 69 66 20 7b 24 3a 3a 65 78 69 74 4f      if {$::exitO
0bf0: 6e 46 61 69 6c 7d 20 74 68 65 6e 20 7b 0d 0a 20  nFail} then {.. 
0c00: 20 20 20 20 20 73 65 74 20 6c 65 76 65 6c 20 5b       set level [
0c10: 65 78 70 72 20 7b 5b 69 6e 66 6f 20 6c 65 76 65  expr {[info leve
0c20: 6c 5d 20 2d 20 31 7d 5d 0d 0a 0d 0a 20 20 20 20  l] - 1}]....    
0c30: 20 20 74 70 75 74 73 20 24 3a 3a 74 65 73 74 5f    tputs $::test_
0c40: 63 68 61 6e 6e 65 6c 20 5b 61 70 70 65 6e 64 41  channel [appendA
0c50: 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  rgs \..         
0c60: 20 5c 6e 20 5b 69 6e 66 6f 20 6c 65 76 65 6c 20   \n [info level 
0c70: 24 6c 65 76 65 6c 5d 20 22 3a 20 22 20 5c 6e 5c  $level] ": " \n\
0c80: 74 20 24 65 72 72 6f 72 20 5c 6e 5d 0d 0a 0d 0a  t $error \n]....
0c90: 20 20 20 20 20 20 65 78 69 74 20 46 61 69 6c 75        exit Failu
0ca0: 72 65 0d 0a 20 20 20 20 7d 20 65 6c 73 65 20 7b  re..    } else {
0cb0: 0d 0a 20 20 20 20 20 20 74 70 75 74 73 20 24 3a  ..      tputs $:
0cc0: 3a 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20 24 69  :test_channel $i
0cd0: 6e 64 69 63 61 74 6f 72 0d 0a 0d 0a 20 20 20 20  ndicator....    
0ce0: 20 20 69 66 20 7b 21 5b 69 6e 66 6f 20 65 78 69    if {![info exi
0cf0: 73 74 73 20 3a 3a 66 61 69 6c 75 72 65 73 28 24  sts ::failures($
0d00: 69 6e 64 69 63 61 74 6f 72 29 5d 7d 20 74 68 65  indicator)]} the
0d10: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 73 65 74  n {..        set
0d20: 20 3a 3a 66 61 69 6c 75 72 65 73 28 24 69 6e 64   ::failures($ind
0d30: 69 63 61 74 6f 72 29 20 30 0d 0a 20 20 20 20 20  icator) 0..     
0d40: 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 69 6e 63 72   }....      incr
0d50: 20 3a 3a 66 61 69 6c 75 72 65 73 28 24 69 6e 64   ::failures($ind
0d60: 69 63 61 74 6f 72 29 0d 0a 20 20 20 20 20 20 77  icator)..      w
0d70: 61 69 74 46 6f 72 54 65 73 74 20 24 3a 3a 63 6f  aitForTest $::co
0d80: 75 6e 74 28 32 29 0d 0a 20 20 20 20 7d 0d 0a 20  unt(2)..    }.. 
0d90: 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23   }....  ########
0da0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0db0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0dc0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0dd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0de0: 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72 6f 63 20  #####....  proc 
0df0: 61 6c 6c 6f 63 4d 65 6d 20 7b 20 73 69 7a 65 20  allocMem { size 
0e00: 7d 20 7b 0d 0a 20 20 20 20 69 66 20 7b 24 3a 3a  } {..    if {$::
0e10: 63 6f 54 61 73 6b 4d 65 6d 7d 20 74 68 65 6e 20  coTaskMem} then 
0e20: 7b 0d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  {..      return 
0e30: 5b 6f 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20 2d  [object invoke -
0e40: 63 72 65 61 74 65 20 5c 0d 0a 20 20 20 20 20 20  create \..      
0e50: 20 20 20 20 53 79 73 74 65 6d 2e 52 75 6e 74 69      System.Runti
0e60: 6d 65 2e 49 6e 74 65 72 6f 70 53 65 72 76 69 63  me.InteropServic
0e70: 65 73 2e 4d 61 72 73 68 61 6c 20 5c 0d 0a 20 20  es.Marshal \..  
0e80: 20 20 20 20 20 20 20 20 41 6c 6c 6f 63 43 6f 54          AllocCoT
0e90: 61 73 6b 4d 65 6d 20 24 73 69 7a 65 5d 3b 20 23  askMem $size]; #
0ea0: 20 74 68 72 6f 77 0d 0a 20 20 20 20 7d 20 65 6c   throw..    } el
0eb0: 73 65 20 7b 0d 0a 20 20 20 20 20 20 73 65 74 20  se {..      set 
0ec0: 70 74 72 20 5b 6f 62 6a 65 63 74 20 69 6e 76 6f  ptr [object invo
0ed0: 6b 65 20 2d 63 72 65 61 74 65 20 2d 66 6c 61 67  ke -create -flag
0ee0: 73 20 2b 4e 6f 6e 50 75 62 6c 69 63 20 5c 0d 0a  s +NonPublic \..
0ef0: 20 20 20 20 20 20 20 20 20 20 53 79 73 74 65 6d            System
0f00: 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e 55 6e 73  .Data.SQLite.Uns
0f10: 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f 64 73  afeNativeMethods
0f20: 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 73 71   \..          sq
0f30: 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 20 24 73 69  lite3_malloc $si
0f40: 7a 65 5d 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  ze]....      if 
0f50: 7b 5b 6f 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20  {[object invoke 
0f60: 24 70 74 72 20 54 6f 49 6e 74 36 34 5d 20 21 3d  $ptr ToInt64] !=
0f70: 20 30 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20   0} then {..    
0f80: 20 20 20 20 72 65 74 75 72 6e 20 24 70 74 72 0d      return $ptr.
0f90: 0a 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d  .      } else {.
0fa0: 0a 20 20 20 20 20 20 20 20 65 72 72 6f 72 20 5b  .        error [
0fb0: 61 70 70 65 6e 64 41 72 67 73 20 22 73 71 6c 69  appendArgs "sqli
0fc0: 74 65 33 5f 6d 61 6c 6c 6f 63 28 22 20 24 73 69  te3_malloc(" $si
0fd0: 7a 65 20 22 29 20 66 61 69 6c 65 64 22 5d 0d 0a  ze ") failed"]..
0fe0: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a        }..    }..
0ff0: 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23    }....  #######
1000: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1010: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1020: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1040: 23 23 23 23 23 23 0d 0a 0d 0a 20 20 70 72 6f 63  ######....  proc
1050: 20 75 73 65 4d 65 6d 20 7b 20 70 74 72 20 73 69   useMem { ptr si
1060: 7a 65 20 7d 20 7b 0d 0a 20 20 20 20 69 66 20 7b  ze } {..    if {
1070: 21 5b 69 73 4d 6f 6e 6f 5d 7d 20 74 68 65 6e 20  ![isMono]} then 
1080: 7b 0d 0a 20 20 20 20 20 20 6f 62 6a 65 63 74 20  {..      object 
1090: 69 6e 76 6f 6b 65 20 2d 66 6c 61 67 73 20 2b 4e  invoke -flags +N
10a0: 6f 6e 50 75 62 6c 69 63 20 5c 0d 0a 20 20 20 20  onPublic \..    
10b0: 20 20 20 20 20 20 4d 69 63 72 6f 73 6f 66 74 2e        Microsoft.
10c0: 57 69 6e 33 32 2e 57 69 6e 33 32 4e 61 74 69 76  Win32.Win32Nativ
10d0: 65 20 5a 65 72 6f 4d 65 6d 6f 72 79 20 5c 0d 0a  e ZeroMemory \..
10e0: 20 20 20 20 20 20 20 20 20 20 24 70 74 72 20 24            $ptr $
10f0: 73 69 7a 65 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d  size..    }..  }
1100: 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23  ....  ##########
1110: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1120: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1130: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1140: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1150: 23 23 23 0d 0a 0d 0a 20 20 70 72 6f 63 20 66 72  ###....  proc fr
1160: 65 65 4d 65 6d 20 7b 20 70 74 72 20 7d 20 7b 0d  eeMem { ptr } {.
1170: 0a 20 20 20 20 69 66 20 7b 24 3a 3a 63 6f 54 61  .    if {$::coTa
1180: 73 6b 4d 65 6d 7d 20 74 68 65 6e 20 7b 0d 0a 20  skMem} then {.. 
1190: 20 20 20 20 20 6f 62 6a 65 63 74 20 69 6e 76 6f       object invo
11a0: 6b 65 20 53 79 73 74 65 6d 2e 52 75 6e 74 69 6d  ke System.Runtim
11b0: 65 2e 49 6e 74 65 72 6f 70 53 65 72 76 69 63 65  e.InteropService
11c0: 73 2e 4d 61 72 73 68 61 6c 20 5c 0d 0a 20 20 20  s.Marshal \..   
11d0: 20 20 20 20 20 20 20 46 72 65 65 43 6f 54 61 73         FreeCoTas
11e0: 6b 4d 65 6d 20 24 70 74 72 0d 0a 20 20 20 20 7d  kMem $ptr..    }
11f0: 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20 6f   else {..      o
1200: 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20 2d 66 6c  bject invoke -fl
1210: 61 67 73 20 2b 4e 6f 6e 50 75 62 6c 69 63 20 5c  ags +NonPublic \
1220: 0d 0a 20 20 20 20 20 20 20 20 20 20 53 79 73 74  ..          Syst
1230: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e 55  em.Data.SQLite.U
1240: 6e 73 61 66 65 4e 61 74 69 76 65 4d 65 74 68 6f  nsafeNativeMetho
1250: 64 73 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20  ds \..          
1260: 73 71 6c 69 74 65 33 5f 66 72 65 65 20 24 70 74  sqlite3_free $pt
1270: 72 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 0d  r..    }..  }...
1280: 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23  .  #############
1290: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
12a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
12b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
12c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
12d0: 0d 0a 0d 0a 20 20 70 72 6f 63 20 73 65 74 75 70  ....  proc setup
12e0: 4c 6f 67 67 69 6e 67 20 7b 20 66 69 6c 65 4e 61  Logging { fileNa
12f0: 6d 65 20 7d 20 7b 0d 0a 20 20 20 20 69 66 20 7b  me } {..    if {
1300: 21 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 3a 3a  ![info exists ::
1310: 6c 6f 67 4c 69 73 74 65 6e 65 72 5d 7d 20 74 68  logListener]} th
1320: 65 6e 20 7b 0d 0a 20 20 20 20 20 20 73 65 74 20  en {..      set 
1330: 3a 3a 6c 6f 67 4c 69 73 74 65 6e 65 72 20 5b 6f  ::logListener [o
1340: 62 6a 65 63 74 20 63 72 65 61 74 65 20 2d 61 6c  bject create -al
1350: 69 61 73 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  ias \..         
1360: 20 53 79 73 74 65 6d 2e 44 69 61 67 6e 6f 73 74   System.Diagnost
1370: 69 63 73 2e 54 65 78 74 57 72 69 74 65 72 54 72  ics.TextWriterTr
1380: 61 63 65 4c 69 73 74 65 6e 65 72 20 24 66 69 6c  aceListener $fil
1390: 65 4e 61 6d 65 5d 0d 0a 20 20 20 20 7d 0d 0a 0d  eName]..    }...
13a0: 0a 20 20 20 20 6f 62 6a 65 63 74 20 69 6e 76 6f  .    object invo
13b0: 6b 65 20 53 79 73 74 65 6d 2e 44 69 61 67 6e 6f  ke System.Diagno
13c0: 73 74 69 63 73 2e 54 72 61 63 65 2e 4c 69 73 74  stics.Trace.List
13d0: 65 6e 65 72 73 20 41 64 64 20 24 3a 3a 6c 6f 67  eners Add $::log
13e0: 4c 69 73 74 65 6e 65 72 0d 0a 20 20 20 20 6f 62  Listener..    ob
13f0: 6a 65 63 74 20 69 6e 76 6f 6b 65 20 53 79 73 74  ject invoke Syst
1400: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e 53  em.Data.SQLite.S
1410: 51 4c 69 74 65 4c 6f 67 20 49 6e 69 74 69 61 6c  QLiteLog Initial
1420: 69 7a 65 0d 0a 0d 0a 20 20 20 20 74 70 75 74 73  ize....    tputs
1430: 20 24 3a 3a 74 65 73 74 5f 63 68 61 6e 6e 65 6c   $::test_channel
1440: 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a   [appendArgs \..
1450: 20 20 20 20 20 20 20 20 22 2d 2d 2d 2d 20 65 6e          "---- en
1460: 61 62 6c 65 64 20 53 51 4c 69 74 65 20 74 72 61  abled SQLite tra
1470: 63 65 20 6c 6f 67 67 69 6e 67 20 74 6f 20 66 69  ce logging to fi
1480: 6c 65 20 5c 22 22 20 24 66 69 6c 65 4e 61 6d 65  le \"" $fileName
1490: 20 5c 22 5c 6e 5d 0d 0a 20 20 7d 0d 0a 0d 0a 20   \"\n]..  }.... 
14a0: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
14b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
14c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
14d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
14e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
14f0: 0d 0a 20 20 70 72 6f 63 20 63 6c 65 61 6e 75 70  ..  proc cleanup
1500: 4c 6f 67 67 69 6e 67 20 7b 20 66 69 6c 65 4e 61  Logging { fileNa
1510: 6d 65 20 7d 20 7b 0d 0a 20 20 20 20 69 66 20 7b  me } {..    if {
1520: 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 3a 3a 6c  [info exists ::l
1530: 6f 67 4c 69 73 74 65 6e 65 72 5d 7d 20 74 68 65  ogListener]} the
1540: 6e 20 7b 0d 0a 20 20 20 20 20 20 6f 62 6a 65 63  n {..      objec
1550: 74 20 69 6e 76 6f 6b 65 20 53 79 73 74 65 6d 2e  t invoke System.
1560: 44 69 61 67 6e 6f 73 74 69 63 73 2e 54 72 61 63  Diagnostics.Trac
1570: 65 2e 4c 69 73 74 65 6e 65 72 73 20 52 65 6d 6f  e.Listeners Remo
1580: 76 65 20 24 3a 3a 6c 6f 67 4c 69 73 74 65 6e 65  ve $::logListene
1590: 72 0d 0a 20 20 20 20 20 20 24 3a 3a 6c 6f 67 4c  r..      $::logL
15a0: 69 73 74 65 6e 65 72 20 43 6c 6f 73 65 0d 0a 20  istener Close.. 
15b0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 23 0d 0a 20     }....    #.. 
15c0: 20 20 20 23 20 4e 4f 54 45 3a 20 43 6f 70 79 20     # NOTE: Copy 
15d0: 74 68 65 20 74 72 61 63 65 20 6c 69 73 74 65 6e  the trace listen
15e0: 65 72 20 6c 6f 67 20 66 69 6c 65 20 74 6f 20 74  er log file to t
15f0: 68 65 20 6d 61 69 6e 20 74 65 73 74 20 6c 6f 67  he main test log
1600: 20 66 69 6c 65 2e 0d 0a 20 20 20 20 23 0d 0a 20   file...    #.. 
1610: 20 20 20 74 6c 6f 67 20 22 2d 2d 2d 2d 20 42 45     tlog "---- BE
1620: 47 49 4e 20 54 52 41 43 45 20 4c 49 53 54 45 4e  GIN TRACE LISTEN
1630: 45 52 20 4f 55 54 50 55 54 5c 6e 22 0d 0a 20 20  ER OUTPUT\n"..  
1640: 20 20 74 6c 6f 67 20 5b 72 65 61 64 46 69 6c 65    tlog [readFile
1650: 20 24 66 69 6c 65 4e 61 6d 65 5d 0d 0a 20 20 20   $fileName]..   
1660: 20 74 6c 6f 67 20 22 5c 6e 2d 2d 2d 2d 20 45 4e   tlog "\n---- EN
1670: 44 20 54 52 41 43 45 20 4c 49 53 54 45 4e 45 52  D TRACE LISTENER
1680: 20 4f 55 54 50 55 54 5c 6e 22 0d 0a 0d 0a 20 20   OUTPUT\n"....  
1690: 20 20 23 0d 0a 20 20 20 20 23 20 4e 4f 54 45 3a    #..    # NOTE:
16a0: 20 44 65 6c 65 74 65 20 74 68 65 20 74 72 61 63   Delete the trac
16b0: 65 20 6c 69 73 74 65 6e 65 72 20 6c 6f 67 20 66  e listener log f
16c0: 69 6c 65 20 62 65 63 61 75 73 65 20 69 74 73 20  ile because its 
16d0: 63 6f 6e 74 65 6e 74 73 20 68 61 76 65 0d 0a 20  contents have.. 
16e0: 20 20 20 23 20 20 20 20 20 20 20 62 65 65 6e 20     #       been 
16f0: 63 6f 70 69 65 64 20 74 6f 20 74 68 65 20 6d 61  copied to the ma
1700: 69 6e 20 74 65 73 74 20 6c 6f 67 20 66 69 6c 65  in test log file
1710: 2e 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 63 6c  ...    #..    cl
1720: 65 61 6e 75 70 46 69 6c 65 20 24 66 69 6c 65 4e  eanupFile $fileN
1730: 61 6d 65 0d 0a 0d 0a 20 20 20 20 74 70 75 74 73  ame....    tputs
1740: 20 24 3a 3a 74 65 73 74 5f 63 68 61 6e 6e 65 6c   $::test_channel
1750: 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a   [appendArgs \..
1760: 20 20 20 20 20 20 20 20 22 2d 2d 2d 2d 20 64 69          "---- di
1770: 73 61 62 6c 65 64 20 53 51 4c 69 74 65 20 74 72  sabled SQLite tr
1780: 61 63 65 20 6c 6f 67 67 69 6e 67 20 74 6f 20 66  ace logging to f
1790: 69 6c 65 20 5c 22 22 20 24 66 69 6c 65 4e 61 6d  ile \"" $fileNam
17a0: 65 20 5c 22 5c 6e 5d 0d 0a 20 20 7d 0d 0a 0d 0a  e \"\n]..  }....
17b0: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
17c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
17d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
17e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
17f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
1800: 0a 0d 0a 20 20 23 0d 0a 20 20 23 20 4e 4f 54 45  ...  #..  # NOTE
1810: 3a 20 53 65 74 75 70 20 74 68 65 20 64 65 66 61  : Setup the defa
1820: 75 6c 74 20 76 61 6c 75 65 73 20 66 6f 72 20 74  ult values for t
1830: 68 65 20 74 75 6e 61 62 6c 65 20 77 6f 72 6b 6c  he tunable workl
1840: 6f 61 64 20 70 61 72 61 6d 65 74 65 72 73 2e 20  oad parameters. 
1850: 20 41 6e 79 2c 0d 0a 20 20 23 20 20 20 20 20 20   Any,..  #      
1860: 20 61 6c 6c 2c 20 6f 72 20 6e 6f 6e 65 20 6f 66   all, or none of
1870: 20 74 68 65 73 65 20 6d 61 79 20 62 65 20 6f 76   these may be ov
1880: 65 72 72 69 64 65 6e 20 76 69 61 20 74 68 65 20  erriden via the 
1890: 63 6f 6d 6d 61 6e 64 20 6c 69 6e 65 2e 0d 0a 20  command line... 
18a0: 20 23 0d 0a 20 20 73 65 74 20 63 6f 75 6e 74 28   #..  set count(
18b0: 30 29 20 31 3b 20 20 20 20 20 20 20 20 20 23 20  0) 1;         # 
18c0: 57 6f 72 6b 6c 6f 61 64 20 72 65 70 65 61 74 20  Workload repeat 
18d0: 63 6f 75 6e 74 20 28 69 2e 65 2e 20 74 6f 74 61  count (i.e. tota
18e0: 6c 20 66 75 6c 6c 20 72 75 6e 73 29 2e 0d 0a 20  l full runs)... 
18f0: 20 73 65 74 20 63 6f 75 6e 74 28 31 29 20 32 30   set count(1) 20
1900: 3b 20 20 20 20 20 20 20 20 23 20 57 6f 72 6b 6c  ;        # Workl
1910: 6f 61 64 20 69 74 65 72 61 74 69 6f 6e 20 63 6f  oad iteration co
1920: 75 6e 74 20 28 69 2e 65 2e 20 77 69 74 68 69 6e  unt (i.e. within
1930: 20 61 20 72 75 6e 29 2e 0d 0a 20 20 73 65 74 20   a run)...  set 
1940: 63 6f 75 6e 74 28 32 29 20 35 30 30 3b 20 20 20  count(2) 500;   
1950: 20 20 20 20 23 20 57 6f 72 6b 6c 6f 61 64 20 69      # Workload i
1960: 74 65 72 61 74 69 6f 6e 20 64 65 6c 61 79 2c 20  teration delay, 
1970: 69 6e 20 6d 69 6c 6c 69 73 65 63 6f 6e 64 73 2e  in milliseconds.
1980: 0d 0a 20 20 73 65 74 20 63 6f 75 6e 74 28 33 29  ..  set count(3)
1990: 20 32 30 30 30 3b 20 20 20 20 20 20 23 20 57 6f   2000;      # Wo
19a0: 72 6b 6c 6f 61 64 20 22 73 6d 61 6c 6c 22 20 64  rkload "small" d
19b0: 61 74 61 20 63 68 75 6e 6b 20 73 69 7a 65 2c 20  ata chunk size, 
19c0: 69 6e 20 62 79 74 65 73 2e 0d 0a 20 20 73 65 74  in bytes...  set
19d0: 20 63 6f 75 6e 74 28 34 29 20 31 30 30 30 30 30   count(4) 100000
19e0: 30 30 3b 20 20 23 20 57 6f 72 6b 6c 6f 61 64 20  00;  # Workload 
19f0: 22 62 69 67 22 20 64 61 74 61 20 63 68 75 6e 6b  "big" data chunk
1a00: 20 73 69 7a 65 2c 20 69 6e 20 62 79 74 65 73 2e   size, in bytes.
1a10: 0d 0a 20 20 73 65 74 20 63 6f 75 6e 74 28 35 29  ..  set count(5)
1a20: 20 33 31 34 35 37 32 38 30 30 3b 20 23 20 4d 61   314572800; # Ma
1a30: 78 69 6d 75 6d 20 68 65 61 70 20 6d 65 6d 6f 72  ximum heap memor
1a40: 79 20 74 6f 20 65 78 63 6c 75 64 65 20 61 74 20  y to exclude at 
1a50: 6f 6e 65 20 74 69 6d 65 2e 0d 0a 20 20 73 65 74  one time...  set
1a60: 20 6e 6f 57 6f 72 6b 6c 6f 61 64 20 5b 6c 69 73   noWorkload [lis
1a70: 74 5d 3b 20 20 23 20 57 6f 72 6b 6c 6f 61 64 73  t];  # Workloads
1a80: 20 74 6f 20 62 65 20 6f 6d 69 74 74 65 64 20 66   to be omitted f
1a90: 72 6f 6d 20 74 68 65 20 72 75 6e 2c 20 62 79 20  rom the run, by 
1aa0: 69 6e 64 65 78 2e 0d 0a 20 20 73 65 74 20 70 72  index...  set pr
1ab0: 69 6f 72 69 74 69 65 73 20 5b 6c 69 73 74 5d 3b  iorities [list];
1ac0: 20 20 23 20 44 69 63 74 69 6f 6e 61 72 79 20 6f    # Dictionary o
1ad0: 66 20 77 6f 72 6b 6c 6f 61 64 20 74 68 72 65 61  f workload threa
1ae0: 64 20 70 72 69 6f 72 69 74 69 65 73 2e 0d 0a 20  d priorities... 
1af0: 20 73 65 74 20 65 78 69 74 4f 6e 46 61 69 6c 20   set exitOnFail 
1b00: 74 72 75 65 3b 20 20 20 20 23 20 48 61 6c 74 20  true;    # Halt 
1b10: 74 65 73 74 69 6e 67 20 61 6e 64 20 65 78 69 74  testing and exit
1b20: 20 70 72 6f 63 65 73 73 20 6f 6e 20 74 65 73 74   process on test
1b30: 20 66 61 69 6c 75 72 65 3f 0d 0a 20 20 73 65 74   failure?..  set
1b40: 20 63 6f 54 61 73 6b 4d 65 6d 20 74 72 75 65 3b   coTaskMem true;
1b50: 20 20 20 20 20 23 20 55 73 65 20 41 6c 6c 6f 63       # Use Alloc
1b60: 43 6f 54 61 73 6b 4d 65 6d 2f 46 72 65 65 43 6f  CoTaskMem/FreeCo
1b70: 54 61 73 6b 4d 65 6d 20 66 6f 72 20 6d 65 6d 6f  TaskMem for memo
1b80: 72 79 3f 0d 0a 20 20 73 65 74 20 6e 6f 54 72 61  ry?..  set noTra
1b90: 63 65 20 66 61 6c 73 65 3b 20 20 20 20 20 20 23  ce false;      #
1ba0: 20 44 69 73 61 62 6c 65 20 53 51 4c 69 74 65 20   Disable SQLite 
1bb0: 74 72 61 63 65 20 6c 6f 67 67 69 6e 67 20 74 6f  trace logging to
1bc0: 20 61 20 66 69 6c 65 3f 0d 0a 0d 0a 20 20 23 23   a file?....  ##
1bd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1be0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1bf0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1c00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1c10: 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20  ###########.... 
1c20: 20 23 0d 0a 20 20 23 20 4e 4f 54 45 3a 20 49 66   #..  # NOTE: If
1c30: 20 63 6f 6d 6d 61 6e 64 20 6c 69 6e 65 20 61 72   command line ar
1c40: 67 75 6d 65 6e 74 73 20 74 6f 20 74 68 65 20 74  guments to the t
1c50: 65 73 74 20 73 75 69 74 65 20 61 72 65 20 61 76  est suite are av
1c60: 61 69 6c 61 62 6c 65 2c 20 70 72 6f 63 65 73 73  ailable, process
1c70: 0d 0a 20 20 23 20 20 20 20 20 20 20 74 68 65 6d  ..  #       them
1c80: 20 66 6f 72 20 61 6e 79 20 6f 70 74 69 6f 6e 73   for any options
1c90: 20 74 68 61 74 20 61 72 65 20 61 70 70 6c 69 63   that are applic
1ca0: 61 62 6c 65 20 74 6f 20 74 68 69 73 20 74 65 73  able to this tes
1cb0: 74 20 28 69 2e 65 2e 20 61 6e 79 20 6f 66 0d 0a  t (i.e. any of..
1cc0: 20 20 23 20 20 20 20 20 20 20 74 68 65 20 74 75    #       the tu
1cd0: 6e 61 62 6c 65 20 77 6f 72 6b 6c 6f 61 64 20 70  nable workload p
1ce0: 61 72 61 6d 65 74 65 72 73 20 6c 69 73 74 65 64  arameters listed
1cf0: 20 61 62 6f 76 65 29 2e 0d 0a 20 20 23 0d 0a 20   above)...  #.. 
1d00: 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74   if {[info exist
1d10: 73 20 61 72 67 76 5d 20 26 26 20 5b 6c 6c 65 6e  s argv] && [llen
1d20: 67 74 68 20 24 61 72 67 76 5d 20 3e 20 30 7d 20  gth $argv] > 0} 
1d30: 74 68 65 6e 20 7b 0d 0a 20 20 20 20 70 61 72 73  then {..    pars
1d40: 65 20 6f 70 74 69 6f 6e 73 20 2d 66 6c 61 67 73  e options -flags
1d50: 20 5c 0d 0a 20 20 20 20 20 20 20 20 7b 2d 53 74   \..        {-St
1d60: 6f 70 4f 6e 55 6e 6b 6e 6f 77 6e 4f 70 74 69 6f  opOnUnknownOptio
1d70: 6e 20 2b 49 67 6e 6f 72 65 4f 6e 55 6e 6b 6e 6f  n +IgnoreOnUnkno
1d80: 77 6e 4f 70 74 69 6f 6e 20 53 6b 69 70 4f 6e 55  wnOption SkipOnU
1d90: 6e 6b 6e 6f 77 6e 4f 70 74 69 6f 6e 7d 20 2d 2d  nknownOption} --
1da0: 20 5c 0d 0a 20 20 20 20 20 20 20 20 5b 6c 69 73   \..        [lis
1db0: 74 20 5b 6c 69 73 74 20 6e 75 6c 6c 20 4d 75 73  t [list null Mus
1dc0: 74 48 61 76 65 49 6e 74 65 67 65 72 56 61 6c 75  tHaveIntegerValu
1dd0: 65 20 2d 31 20 2d 31 20 2d 63 6f 75 6e 74 30 20  e -1 -1 -count0 
1de0: 24 63 6f 75 6e 74 28 30 29 5d 20 5c 0d 0a 20 20  $count(0)] \..  
1df0: 20 20 20 20 20 20 5b 6c 69 73 74 20 6e 75 6c 6c        [list null
1e00: 20 4d 75 73 74 48 61 76 65 49 6e 74 65 67 65 72   MustHaveInteger
1e10: 56 61 6c 75 65 20 2d 31 20 2d 31 20 2d 63 6f 75  Value -1 -1 -cou
1e20: 6e 74 31 20 24 63 6f 75 6e 74 28 31 29 5d 20 5c  nt1 $count(1)] \
1e30: 0d 0a 20 20 20 20 20 20 20 20 5b 6c 69 73 74 20  ..        [list 
1e40: 6e 75 6c 6c 20 4d 75 73 74 48 61 76 65 49 6e 74  null MustHaveInt
1e50: 65 67 65 72 56 61 6c 75 65 20 2d 31 20 2d 31 20  egerValue -1 -1 
1e60: 2d 63 6f 75 6e 74 32 20 24 63 6f 75 6e 74 28 32  -count2 $count(2
1e70: 29 5d 20 5c 0d 0a 20 20 20 20 20 20 20 20 5b 6c  )] \..        [l
1e80: 69 73 74 20 6e 75 6c 6c 20 4d 75 73 74 48 61 76  ist null MustHav
1e90: 65 49 6e 74 65 67 65 72 56 61 6c 75 65 20 2d 31  eIntegerValue -1
1ea0: 20 2d 31 20 2d 63 6f 75 6e 74 33 20 24 63 6f 75   -1 -count3 $cou
1eb0: 6e 74 28 33 29 5d 20 5c 0d 0a 20 20 20 20 20 20  nt(3)] \..      
1ec0: 20 20 5b 6c 69 73 74 20 6e 75 6c 6c 20 4d 75 73    [list null Mus
1ed0: 74 48 61 76 65 49 6e 74 65 67 65 72 56 61 6c 75  tHaveIntegerValu
1ee0: 65 20 2d 31 20 2d 31 20 2d 63 6f 75 6e 74 34 20  e -1 -1 -count4 
1ef0: 24 63 6f 75 6e 74 28 34 29 5d 20 5c 0d 0a 20 20  $count(4)] \..  
1f00: 20 20 20 20 20 20 5b 6c 69 73 74 20 6e 75 6c 6c        [list null
1f10: 20 4d 75 73 74 48 61 76 65 49 6e 74 65 67 65 72   MustHaveInteger
1f20: 56 61 6c 75 65 20 2d 31 20 2d 31 20 2d 63 6f 75  Value -1 -1 -cou
1f30: 6e 74 35 20 24 63 6f 75 6e 74 28 35 29 5d 20 5c  nt5 $count(5)] \
1f40: 0d 0a 20 20 20 20 20 20 20 20 5b 6c 69 73 74 20  ..        [list 
1f50: 6e 75 6c 6c 20 4d 75 73 74 48 61 76 65 4c 69 73  null MustHaveLis
1f60: 74 56 61 6c 75 65 20 2d 31 20 2d 31 20 2d 6e 6f  tValue -1 -1 -no
1f70: 57 6f 72 6b 6c 6f 61 64 20 24 6e 6f 57 6f 72 6b  Workload $noWork
1f80: 6c 6f 61 64 5d 20 5c 0d 0a 20 20 20 20 20 20 20  load] \..       
1f90: 20 5b 6c 69 73 74 20 6e 75 6c 6c 20 4d 75 73 74   [list null Must
1fa0: 48 61 76 65 4c 69 73 74 56 61 6c 75 65 20 2d 31  HaveListValue -1
1fb0: 20 2d 31 20 2d 70 72 69 6f 72 69 74 69 65 73 20   -1 -priorities 
1fc0: 24 70 72 69 6f 72 69 74 69 65 73 5d 20 5c 0d 0a  $priorities] \..
1fd0: 20 20 20 20 20 20 20 20 5b 6c 69 73 74 20 6e 75          [list nu
1fe0: 6c 6c 20 4d 75 73 74 48 61 76 65 42 6f 6f 6c 65  ll MustHaveBoole
1ff0: 61 6e 56 61 6c 75 65 20 2d 31 20 2d 31 20 2d 65  anValue -1 -1 -e
2000: 78 69 74 4f 6e 46 61 69 6c 20 24 65 78 69 74 4f  xitOnFail $exitO
2010: 6e 46 61 69 6c 5d 20 5c 0d 0a 20 20 20 20 20 20  nFail] \..      
2020: 20 20 5b 6c 69 73 74 20 6e 75 6c 6c 20 4d 75 73    [list null Mus
2030: 74 48 61 76 65 42 6f 6f 6c 65 61 6e 56 61 6c 75  tHaveBooleanValu
2040: 65 20 2d 31 20 2d 31 20 2d 63 6f 54 61 73 6b 4d  e -1 -1 -coTaskM
2050: 65 6d 20 24 63 6f 54 61 73 6b 4d 65 6d 5d 20 5c  em $coTaskMem] \
2060: 0d 0a 20 20 20 20 20 20 20 20 5b 6c 69 73 74 20  ..        [list 
2070: 6e 75 6c 6c 20 4d 75 73 74 48 61 76 65 42 6f 6f  null MustHaveBoo
2080: 6c 65 61 6e 56 61 6c 75 65 20 2d 31 20 2d 31 20  leanValue -1 -1 
2090: 2d 6e 6f 54 72 61 63 65 20 24 6e 6f 54 72 61 63  -noTrace $noTrac
20a0: 65 5d 5d 20 24 61 72 67 76 0d 0a 0d 0a 20 20 20  e]] $argv....   
20b0: 20 73 65 74 20 63 6f 75 6e 74 28 30 29 20 24 6f   set count(0) $o
20c0: 70 74 69 6f 6e 73 28 2d 63 6f 75 6e 74 30 2c 76  ptions(-count0,v
20d0: 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74 20 63  alue)..    set c
20e0: 6f 75 6e 74 28 31 29 20 24 6f 70 74 69 6f 6e 73  ount(1) $options
20f0: 28 2d 63 6f 75 6e 74 31 2c 76 61 6c 75 65 29 0d  (-count1,value).
2100: 0a 20 20 20 20 73 65 74 20 63 6f 75 6e 74 28 32  .    set count(2
2110: 29 20 24 6f 70 74 69 6f 6e 73 28 2d 63 6f 75 6e  ) $options(-coun
2120: 74 32 2c 76 61 6c 75 65 29 0d 0a 20 20 20 20 73  t2,value)..    s
2130: 65 74 20 63 6f 75 6e 74 28 33 29 20 24 6f 70 74  et count(3) $opt
2140: 69 6f 6e 73 28 2d 63 6f 75 6e 74 33 2c 76 61 6c  ions(-count3,val
2150: 75 65 29 0d 0a 20 20 20 20 73 65 74 20 63 6f 75  ue)..    set cou
2160: 6e 74 28 34 29 20 24 6f 70 74 69 6f 6e 73 28 2d  nt(4) $options(-
2170: 63 6f 75 6e 74 34 2c 76 61 6c 75 65 29 0d 0a 20  count4,value).. 
2180: 20 20 20 73 65 74 20 63 6f 75 6e 74 28 35 29 20     set count(5) 
2190: 24 6f 70 74 69 6f 6e 73 28 2d 63 6f 75 6e 74 35  $options(-count5
21a0: 2c 76 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74  ,value)..    set
21b0: 20 6e 6f 57 6f 72 6b 6c 6f 61 64 20 24 6f 70 74   noWorkload $opt
21c0: 69 6f 6e 73 28 2d 6e 6f 57 6f 72 6b 6c 6f 61 64  ions(-noWorkload
21d0: 2c 76 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74  ,value)..    set
21e0: 20 70 72 69 6f 72 69 74 69 65 73 20 24 6f 70 74   priorities $opt
21f0: 69 6f 6e 73 28 2d 70 72 69 6f 72 69 74 69 65 73  ions(-priorities
2200: 2c 76 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74  ,value)..    set
2210: 20 65 78 69 74 4f 6e 46 61 69 6c 20 24 6f 70 74   exitOnFail $opt
2220: 69 6f 6e 73 28 2d 65 78 69 74 4f 6e 46 61 69 6c  ions(-exitOnFail
2230: 2c 76 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74  ,value)..    set
2240: 20 63 6f 54 61 73 6b 4d 65 6d 20 24 6f 70 74 69   coTaskMem $opti
2250: 6f 6e 73 28 2d 63 6f 54 61 73 6b 4d 65 6d 2c 76  ons(-coTaskMem,v
2260: 61 6c 75 65 29 0d 0a 20 20 20 20 73 65 74 20 6e  alue)..    set n
2270: 6f 54 72 61 63 65 20 24 6f 70 74 69 6f 6e 73 28  oTrace $options(
2280: 2d 6e 6f 54 72 61 63 65 2c 76 61 6c 75 65 29 0d  -noTrace,value).
2290: 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23  .  }....  ######
22a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
22b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
22c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
22d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
22e0: 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 23 0d 0a  #######....  #..
22f0: 20 20 23 20 4e 4f 54 45 3a 20 4c 6f 61 64 20 63    # NOTE: Load c
2300: 75 73 74 6f 6d 20 70 65 72 2d 75 73 65 72 20 61  ustom per-user a
2310: 6e 64 2f 6f 72 20 70 65 72 2d 68 6f 73 74 20 74  nd/or per-host t
2320: 65 73 74 20 73 65 74 74 69 6e 67 73 2e 20 20 43  est settings.  C
2330: 75 72 72 65 6e 74 6c 79 2c 20 74 68 69 73 0d 0a  urrently, this..
2340: 20 20 23 20 20 20 20 20 20 20 69 73 20 64 6f 6e    #       is don
2350: 65 20 61 66 74 65 72 20 70 72 6f 63 65 73 73 69  e after processi
2360: 6e 67 20 74 68 65 20 63 6f 6d 6d 61 6e 64 20 6c  ng the command l
2370: 69 6e 65 20 6f 70 74 69 6f 6e 73 2e 20 20 54 68  ine options.  Th
2380: 65 20 73 65 74 74 69 6e 67 73 20 66 69 6c 65 0d  e settings file.
2390: 0a 20 20 23 20 20 20 20 20 20 20 73 68 6f 75 6c  .  #       shoul
23a0: 64 20 74 61 6b 65 20 69 6e 74 6f 20 61 63 63 6f  d take into acco
23b0: 75 6e 74 20 74 68 65 20 65 78 69 73 74 69 6e 67  unt the existing
23c0: 20 77 6f 72 6b 6c 6f 61 64 20 70 61 72 61 6d 65   workload parame
23d0: 74 65 72 73 20 61 6e 64 20 61 76 6f 69 64 0d 0a  ters and avoid..
23e0: 20 20 23 20 20 20 20 20 20 20 63 68 61 6e 67 69    #       changi
23f0: 6e 67 20 61 6e 79 20 74 68 61 74 20 6d 61 79 20  ng any that may 
2400: 68 61 76 65 20 61 6c 72 65 61 64 79 20 62 65 65  have already bee
2410: 6e 20 6f 76 65 72 72 69 64 64 65 6e 2e 0d 0a 20  n overridden... 
2420: 20 23 0d 0a 20 20 6c 6f 61 64 53 51 4c 69 74 65   #..  loadSQLite
2430: 54 65 73 74 53 65 74 74 69 6e 67 73 20 24 74 65  TestSettings $te
2440: 73 74 5f 63 68 61 6e 6e 65 6c 0d 0a 0d 0a 20 20  st_channel....  
2450: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2460: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2470: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2480: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2490: 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d  #############...
24a0: 0a 20 20 23 0d 0a 20 20 23 20 4e 4f 54 45 3a 20  .  #..  # NOTE: 
24b0: 54 68 65 20 74 72 61 63 65 20 6c 69 73 74 65 6e  The trace listen
24c0: 65 72 20 75 73 65 64 20 77 69 74 68 20 74 68 65  er used with the
24d0: 20 53 51 4c 69 74 65 4c 6f 67 20 63 6c 61 73 73   SQLiteLog class
24e0: 20 74 6f 20 63 61 70 74 75 72 65 20 6f 75 74 70   to capture outp
24f0: 75 74 0d 0a 20 20 23 20 20 20 20 20 20 20 66 72  ut..  #       fr
2500: 6f 6d 20 74 68 65 20 63 6f 72 65 20 53 51 4c 69  om the core SQLi
2510: 74 65 20 6c 69 62 72 61 72 79 20 72 65 71 75 69  te library requi
2520: 72 65 73 20 69 74 73 20 6f 77 6e 20 6c 6f 67 20  res its own log 
2530: 66 69 6c 65 20 62 65 63 61 75 73 65 20 74 68 65  file because the
2540: 0d 0a 20 20 23 20 20 20 20 20 20 20 54 65 78 74  ..  #       Text
2550: 57 72 69 74 65 72 54 72 61 63 65 4c 69 73 74 65  WriterTraceListe
2560: 6e 65 72 20 63 6c 61 73 73 20 6f 70 65 6e 73 20  ner class opens 
2570: 61 6e 64 20 6c 6f 63 6b 73 20 74 68 65 20 6c 6f  and locks the lo
2580: 67 20 66 69 6c 65 20 69 74 20 75 73 65 73 0d 0a  g file it uses..
2590: 20 20 23 20 20 20 20 20 20 20 61 73 20 74 68 65    #       as the
25a0: 20 62 61 73 69 73 20 6f 66 20 74 68 65 20 6f 75   basis of the ou
25b0: 74 70 75 74 20 73 74 72 65 61 6d 2e 20 20 42 65  tput stream.  Be
25c0: 66 6f 72 65 20 74 68 69 73 20 74 65 73 74 20 69  fore this test i
25d0: 73 20 63 6f 6d 70 6c 65 74 65 2c 0d 0a 20 20 23  s complete,..  #
25e0: 20 20 20 20 20 20 20 74 68 65 20 65 6e 74 69 72         the entir
25f0: 65 20 63 6f 6e 74 65 6e 74 73 20 6f 66 20 74 68  e contents of th
2600: 69 73 20 74 72 61 63 65 20 6c 6f 67 20 66 69 6c  is trace log fil
2610: 65 20 77 69 6c 6c 20 62 65 20 63 6f 70 69 65 64  e will be copied
2620: 20 69 6e 74 6f 20 74 68 65 0d 0a 20 20 23 20 20   into the..  #  
2630: 20 20 20 20 20 6d 61 69 6e 20 74 65 73 74 20 6c       main test l
2640: 6f 67 20 66 69 6c 65 20 61 6e 64 20 74 68 65 6e  og file and then
2650: 20 64 65 6c 65 74 65 64 2e 0d 0a 20 20 23 0d 0a   deleted...  #..
2660: 20 20 69 66 20 7b 21 24 6e 6f 54 72 61 63 65 7d    if {!$noTrace}
2670: 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 73 65 74   then {..    set
2680: 20 6c 6f 67 46 69 6c 65 4e 61 6d 65 20 5b 61 70   logFileName [ap
2690: 70 65 6e 64 41 72 67 73 20 5b 66 69 6c 65 20 72  pendArgs [file r
26a0: 6f 6f 74 6e 61 6d 65 20 24 74 65 73 74 5f 6c 6f  ootname $test_lo
26b0: 67 5d 20 2e 74 72 61 63 65 2e 6c 6f 67 5d 0d 0a  g] .trace.log]..
26c0: 20 20 20 20 73 65 74 75 70 4c 6f 67 67 69 6e 67      setupLogging
26d0: 20 24 6c 6f 67 46 69 6c 65 4e 61 6d 65 0d 0a 20   $logFileName.. 
26e0: 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23   }....  ########
26f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2700: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2710: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2720: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2730: 23 23 23 23 23 0d 0a 0d 0a 20 20 74 70 75 74 73  #####....  tputs
2740: 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b   $test_channel [
2750: 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20  appendArgs \..  
2760: 20 20 20 20 22 2d 2d 2d 2d 20 77 6f 72 6b 6c 6f      "---- worklo
2770: 61 64 73 20 77 69 6c 6c 20 72 65 70 65 61 74 20  ads will repeat 
2780: 22 20 24 63 6f 75 6e 74 28 30 29 20 22 20 74 69  " $count(0) " ti
2790: 6d 65 28 73 29 5c 6e 22 5d 0d 0a 0d 0a 20 20 74  me(s)\n"]....  t
27a0: 70 75 74 73 20 24 74 65 73 74 5f 63 68 61 6e 6e  puts $test_chann
27b0: 65 6c 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c  el [appendArgs \
27c0: 0d 0a 20 20 20 20 20 20 22 2d 2d 2d 2d 20 77 6f  ..      "---- wo
27d0: 72 6b 6c 6f 61 64 73 20 77 69 6c 6c 20 68 61 76  rkloads will hav
27e0: 65 20 22 20 24 63 6f 75 6e 74 28 31 29 20 22 20  e " $count(1) " 
27f0: 69 74 65 72 61 74 69 6f 6e 28 73 29 5c 6e 22 5d  iteration(s)\n"]
2800: 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74 65 73  ....  tputs $tes
2810: 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70 65 6e  t_channel [appen
2820: 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 22  dArgs \..      "
2830: 2d 2d 2d 2d 20 77 6f 72 6b 6c 6f 61 64 73 20 77  ---- workloads w
2840: 69 6c 6c 20 77 61 69 74 20 61 74 20 6c 65 61 73  ill wait at leas
2850: 74 20 22 20 24 63 6f 75 6e 74 28 32 29 20 5c 0d  t " $count(2) \.
2860: 0a 20 20 20 20 20 20 22 20 6d 69 6c 6c 69 73 65  .      " millise
2870: 63 6f 6e 64 28 73 29 20 61 66 74 65 72 20 65 61  cond(s) after ea
2880: 63 68 20 69 74 65 72 61 74 69 6f 6e 5c 6e 22 5d  ch iteration\n"]
2890: 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74 65 73  ....  tputs $tes
28a0: 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70 65 6e  t_channel [appen
28b0: 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 22  dArgs \..      "
28c0: 2d 2d 2d 2d 20 73 6d 61 6c 6c 20 63 68 75 6e 6b  ---- small chunk
28d0: 20 73 69 7a 65 20 69 73 20 22 20 24 63 6f 75 6e   size is " $coun
28e0: 74 28 33 29 20 22 20 62 79 74 65 28 73 29 5c 6e  t(3) " byte(s)\n
28f0: 22 5d 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74  "]....  tputs $t
2900: 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70  est_channel [app
2910: 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20  endArgs \..     
2920: 20 22 2d 2d 2d 2d 20 62 69 67 20 63 68 75 6e 6b   "---- big chunk
2930: 20 73 69 7a 65 20 69 73 20 22 20 24 63 6f 75 6e   size is " $coun
2940: 74 28 34 29 20 22 20 62 79 74 65 28 73 29 5c 6e  t(4) " byte(s)\n
2950: 22 5d 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74  "]....  tputs $t
2960: 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70  est_channel [app
2970: 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20  endArgs \..     
2980: 20 22 2d 2d 2d 2d 20 6d 61 78 69 6d 75 6d 20 65   "---- maximum e
2990: 78 63 6c 75 64 65 64 20 68 65 61 70 20 6d 65 6d  xcluded heap mem
29a0: 6f 72 79 20 69 73 20 22 20 24 63 6f 75 6e 74 28  ory is " $count(
29b0: 35 29 20 22 20 62 79 74 65 28 73 29 5c 6e 22 5d  5) " byte(s)\n"]
29c0: 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74 65 73  ....  tputs $tes
29d0: 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70 65 6e  t_channel [appen
29e0: 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 22  dArgs \..      "
29f0: 2d 2d 2d 2d 20 77 6f 72 6b 6c 6f 61 64 73 20 74  ---- workloads t
2a00: 6f 20 62 65 20 73 6b 69 70 70 65 64 2e 2e 2e 20  o be skipped... 
2a10: 22 20 5c 0d 0a 20 20 20 20 20 20 5b 65 78 70 72  " \..      [expr
2a20: 20 7b 5b 6c 6c 65 6e 67 74 68 20 24 6e 6f 57 6f   {[llength $noWo
2a30: 72 6b 6c 6f 61 64 5d 20 3e 20 30 20 3f 20 24 6e  rkload] > 0 ? $n
2a40: 6f 57 6f 72 6b 6c 6f 61 64 20 3a 20 22 6e 6f 6e  oWorkload : "non
2a50: 65 22 7d 5d 20 5c 6e 5d 0d 0a 0d 0a 20 20 74 70  e"}] \n]....  tp
2a60: 75 74 73 20 24 74 65 73 74 5f 63 68 61 6e 6e 65  uts $test_channe
2a70: 6c 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c 0d  l [appendArgs \.
2a80: 0a 20 20 20 20 20 20 22 2d 2d 2d 2d 20 77 6f 72  .      "---- wor
2a90: 6b 6c 6f 61 64 73 20 70 72 69 6f 72 69 74 79 20  kloads priority 
2aa0: 6f 76 65 72 72 69 64 65 73 2e 2e 2e 20 22 20 5c  overrides... " \
2ab0: 0d 0a 20 20 20 20 20 20 5b 65 78 70 72 20 7b 5b  ..      [expr {[
2ac0: 6c 6c 65 6e 67 74 68 20 24 70 72 69 6f 72 69 74  llength $priorit
2ad0: 69 65 73 5d 20 3e 20 30 20 3f 20 24 70 72 69 6f  ies] > 0 ? $prio
2ae0: 72 69 74 69 65 73 20 3a 20 22 6e 6f 6e 65 22 7d  rities : "none"}
2af0: 5d 20 5c 6e 5d 0d 0a 0d 0a 20 20 74 70 75 74 73  ] \n]....  tputs
2b00: 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b   $test_channel [
2b10: 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20  appendArgs \..  
2b20: 20 20 20 20 22 2d 2d 2d 2d 20 75 6e 65 78 70 65      "---- unexpe
2b30: 63 74 65 64 20 65 72 72 6f 72 73 20 22 20 5c 0d  cted errors " \.
2b40: 0a 20 20 20 20 20 20 5b 65 78 70 72 20 7b 24 65  .      [expr {$e
2b50: 78 69 74 4f 6e 46 61 69 6c 20 3f 20 22 77 69 6c  xitOnFail ? "wil
2b60: 6c 22 20 3a 20 22 77 69 6c 6c 20 6e 6f 74 22 7d  l" : "will not"}
2b70: 5d 20 5c 0d 0a 20 20 20 20 20 20 22 20 68 61 6c  ] \..      " hal
2b80: 74 20 74 65 73 74 69 6e 67 20 61 6e 64 20 65 78  t testing and ex
2b90: 69 74 20 74 68 65 20 70 72 6f 63 65 73 73 5c 6e  it the process\n
2ba0: 22 5d 0d 0a 0d 0a 20 20 74 70 75 74 73 20 24 74  "]....  tputs $t
2bb0: 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b 61 70 70  est_channel [app
2bc0: 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20  endArgs \..     
2bd0: 20 22 2d 2d 2d 2d 20 74 68 65 20 22 20 5b 65 78   "---- the " [ex
2be0: 70 72 20 7b 24 63 6f 54 61 73 6b 4d 65 6d 20 3f  pr {$coTaskMem ?
2bf0: 20 22 43 6f 54 61 73 6b 4d 65 6d 22 20 3a 20 22   "CoTaskMem" : "
2c00: 53 51 4c 69 74 65 22 7d 5d 20 5c 0d 0a 20 20 20  SQLite"}] \..   
2c10: 20 20 20 22 20 61 6c 6c 6f 63 61 74 6f 72 20 77     " allocator w
2c20: 69 6c 6c 20 62 65 20 75 73 65 64 20 74 6f 20 65  ill be used to e
2c30: 78 63 6c 75 64 65 20 68 65 61 70 20 6d 65 6d 6f  xclude heap memo
2c40: 72 79 5c 6e 22 5d 0d 0a 0d 0a 20 20 74 70 75 74  ry\n"]....  tput
2c50: 73 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20  s $test_channel 
2c60: 5b 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20  [appendArgs \.. 
2c70: 20 20 20 20 20 22 2d 2d 2d 2d 20 74 72 61 63 65       "---- trace
2c80: 20 6c 6f 67 67 69 6e 67 20 74 6f 20 61 20 66 69   logging to a fi
2c90: 6c 65 20 69 73 20 22 20 5c 0d 0a 20 20 20 20 20  le is " \..     
2ca0: 20 5b 65 78 70 72 20 7b 24 6e 6f 54 72 61 63 65   [expr {$noTrace
2cb0: 20 3f 20 22 64 69 73 61 62 6c 65 64 22 20 3a 20   ? "disabled" : 
2cc0: 22 65 6e 61 62 6c 65 64 22 7d 5d 20 5c 6e 5d 0d  "enabled"}] \n].
2cd0: 0a 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23  ...  ###########
2ce0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2cf0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2d00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2d10: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2d20: 23 23 0d 0a 0d 0a 20 20 23 0d 0a 20 20 23 20 4e  ##....  #..  # N
2d30: 4f 54 45 3a 20 43 72 65 61 74 65 20 74 68 65 20  OTE: Create the 
2d40: 77 6f 72 6b 6c 6f 61 64 20 70 72 69 6f 72 69 74  workload priorit
2d50: 79 20 61 72 72 61 79 20 62 61 73 65 64 20 6f 6e  y array based on
2d60: 20 74 68 65 20 70 72 69 6f 72 69 74 79 20 6c 69   the priority li
2d70: 73 74 20 73 65 65 6e 0d 0a 20 20 23 20 20 20 20  st seen..  #    
2d80: 20 20 20 6f 6e 20 74 68 65 20 63 6f 6d 6d 61 6e     on the comman
2d90: 64 20 6c 69 6e 65 2c 20 69 66 20 61 6e 79 2e 0d  d line, if any..
2da0: 0a 20 20 23 0d 0a 20 20 61 72 72 61 79 20 73 65  .  #..  array se
2db0: 74 20 70 72 69 6f 72 69 74 79 20 24 70 72 69 6f  t priority $prio
2dc0: 72 69 74 69 65 73 0d 0a 0d 0a 20 20 23 23 23 23  rities....  ####
2dd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2de0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2df0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2e00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
2e10: 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 23  #########....  #
2e20: 0d 0a 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b  ..  # NOTE: Work
2e30: 6c 6f 61 64 73 20 23 31 32 20 61 6e 64 20 23 31  loads #12 and #1
2e40: 33 20 63 6f 6e 74 61 69 6e 20 43 23 20 63 6f 64  3 contain C# cod
2e50: 65 20 74 68 61 74 20 73 68 6f 75 6c 64 20 62 65  e that should be
2e60: 20 63 6f 6d 70 69 6c 65 64 2c 20 62 75 74 0d 0a   compiled, but..
2e70: 20 20 23 20 20 20 20 20 20 20 6f 6e 6c 79 20 6f    #       only o
2e80: 6e 63 65 2e 20 20 54 68 65 73 65 20 76 61 72 69  nce.  These vari
2e90: 61 62 6c 65 73 20 6b 65 65 70 20 74 72 61 63 6b  ables keep track
2ea0: 20 6f 66 20 74 68 61 74 20 73 74 61 74 65 20 69   of that state i
2eb0: 6e 66 6f 72 6d 61 74 69 6f 6e 2e 0d 0a 20 20 23  nformation...  #
2ec0: 20 20 20 20 20 20 20 41 6e 20 69 6e 74 65 67 65         An intege
2ed0: 72 20 76 61 6c 75 65 20 69 6e 20 6f 6e 65 20 6f  r value in one o
2ee0: 66 20 74 68 65 73 65 20 76 61 72 69 61 62 6c 65  f these variable
2ef0: 73 20 6d 65 61 6e 73 20 74 68 65 20 63 6f 6d 70  s means the comp
2f00: 69 6c 61 74 69 6f 6e 20 77 61 73 0d 0a 20 20 23  ilation was..  #
2f10: 20 20 20 20 20 20 20 63 6f 6d 70 6c 65 74 65 64         completed
2f20: 20 61 6e 64 20 74 68 65 20 72 65 73 75 6c 74 69   and the resulti
2f30: 6e 67 20 63 6f 6d 70 69 6c 65 64 20 6d 65 74 68  ng compiled meth
2f40: 6f 64 20 6d 61 79 20 62 65 20 69 6e 76 6f 6b 65  od may be invoke
2f50: 64 20 75 73 69 6e 67 20 74 68 65 0d 0a 20 20 23  d using the..  #
2f60: 20 20 20 20 20 20 20 66 6f 6c 6c 6f 77 69 6e 67         following
2f70: 20 63 6f 6d 6d 61 6e 64 20 28 77 68 65 72 65 20   command (where 
2f80: 24 7b 69 64 7d 20 69 73 20 74 68 65 20 76 61 6c  ${id} is the val
2f90: 75 65 20 6f 66 20 74 68 65 20 76 61 72 69 61 62  ue of the variab
2fa0: 6c 65 29 3a 0d 0a 20 20 23 0d 0a 20 20 23 20 20  le):..  #..  #  
2fb0: 20 20 20 20 20 20 20 20 20 6f 62 6a 65 63 74 20           object 
2fc0: 69 6e 76 6f 6b 65 20 5f 44 79 6e 61 6d 69 63 24  invoke _Dynamic$
2fd0: 7b 69 64 7d 2e 54 65 73 74 24 7b 69 64 7d 20 42  {id}.Test${id} B
2fe0: 61 63 6b 75 70 41 6e 64 47 65 74 44 61 74 61 0d  ackupAndGetData.
2ff0: 0a 20 20 23 0d 0a 20 20 73 65 74 20 63 6f 6d 70  .  #..  set comp
3000: 69 6c 65 64 28 31 32 29 20 22 22 0d 0a 20 20 73  iled(12) ""..  s
3010: 65 74 20 63 6f 6d 70 69 6c 65 64 28 31 33 29 20  et compiled(13) 
3020: 22 22 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23  ""....  ########
3030: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3040: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3050: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3060: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3070: 23 23 23 23 23 0d 0a 0d 0a 20 20 23 0d 0a 20 20  #####....  #..  
3080: 23 20 4e 4f 54 45 3a 20 54 68 69 73 20 69 73 20  # NOTE: This is 
3090: 61 6e 20 69 6e 2d 6d 65 6d 6f 72 79 20 64 61 74  an in-memory dat
30a0: 61 62 61 73 65 20 77 69 74 68 20 73 68 61 72 65  abase with share
30b0: 64 20 63 61 63 68 65 20 65 6e 61 62 6c 65 64 2e  d cache enabled.
30c0: 0d 0a 20 20 23 0d 0a 20 20 73 65 74 20 66 69 6c  ..  #..  set fil
30d0: 65 4e 61 6d 65 28 31 29 20 66 69 6c 65 3a 3a 6d  eName(1) file::m
30e0: 65 6d 6f 72 79 3a 3f 63 61 63 68 65 3d 73 68 61  emory:?cache=sha
30f0: 72 65 64 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23  red....  #######
3100: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3110: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3120: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3130: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3140: 23 23 23 23 23 23 0d 0a 0d 0a 20 20 23 0d 0a 20  ######....  #.. 
3150: 20 23 20 4e 4f 54 45 3a 20 54 68 69 73 20 69 73   # NOTE: This is
3160: 20 61 20 6e 6f 72 6d 61 6c 20 6f 6e 2d 64 69 73   a normal on-dis
3170: 6b 20 64 61 74 61 62 61 73 65 2e 0d 0a 20 20 23  k database...  #
3180: 0d 0a 20 20 73 65 74 20 66 69 6c 65 4e 61 6d 65  ..  set fileName
3190: 28 32 29 20 5b 66 69 6c 65 20 6a 6f 69 6e 20 5b  (2) [file join [
31a0: 67 65 74 44 61 74 61 62 61 73 65 44 69 72 65 63  getDatabaseDirec
31b0: 74 6f 72 79 5d 20 5b 61 70 70 65 6e 64 41 72 67  tory] [appendArg
31c0: 73 20 5c 0d 0a 20 20 20 20 20 20 73 74 72 65 73  s \..      stres
31d0: 73 2d 20 5b 70 69 64 5d 20 2d 20 5b 73 74 72 69  s- [pid] - [stri
31e0: 6e 67 20 74 72 69 6d 20 5b 63 6c 6f 63 6b 20 73  ng trim [clock s
31f0: 65 63 6f 6e 64 73 5d 20 2d 5d 20 2e 64 62 5d 5d  econds] -] .db]]
3200: 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23  ....  ##########
3210: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3220: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3230: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3240: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3250: 23 23 23 0d 0a 0d 0a 20 20 73 65 74 75 70 44 62  ###....  setupDb
3260: 20 24 66 69 6c 65 4e 61 6d 65 28 31 29 20 22 22   $fileName(1) ""
3270: 20 22 22 20 22 22 20 22 22 20 22 22 20 66 61 6c   "" "" "" "" fal
3280: 73 65 20 66 61 6c 73 65 20 74 72 75 65 20 74 72  se false true tr
3290: 75 65 20 73 72 63 44 62 0d 0a 20 20 73 65 74 75  ue srcDb..  setu
32a0: 70 44 62 20 24 66 69 6c 65 4e 61 6d 65 28 32 29  pDb $fileName(2)
32b0: 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23  ....  ##########
32c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
32d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
32e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
32f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3300: 23 23 23 0d 0a 0d 0a 20 20 23 0d 0a 20 20 23 20  ###....  #..  # 
3310: 4e 4f 54 45 3a 20 54 68 69 73 20 73 65 72 76 65  NOTE: This serve
3320: 73 20 74 77 6f 20 70 75 72 70 6f 73 65 73 2e 20  s two purposes. 
3330: 20 46 69 72 73 74 2c 20 69 74 20 61 6c 6c 6f 77   First, it allow
3340: 73 20 75 73 20 74 6f 20 76 65 72 69 66 79 20 74  s us to verify t
3350: 68 65 20 74 72 61 63 65 0d 0a 20 20 23 20 20 20  he trace..  #   
3360: 20 20 20 20 6c 6f 67 67 69 6e 67 20 73 75 62 73      logging subs
3370: 79 73 74 65 6d 20 69 73 20 77 6f 72 6b 69 6e 67  ystem is working
3380: 20 70 72 6f 70 65 72 6c 79 2e 20 20 53 65 63 6f   properly.  Seco
3390: 6e 64 2c 20 69 74 20 70 6c 61 63 65 73 20 74 68  nd, it places th
33a0: 65 20 66 69 6c 65 0d 0a 20 20 23 20 20 20 20 20  e file..  #     
33b0: 20 20 6e 61 6d 65 20 66 6f 72 20 74 68 65 20 61    name for the a
33c0: 73 73 6f 63 69 61 74 65 64 20 64 61 74 61 62 61  ssociated databa
33d0: 73 65 20 66 69 6c 65 20 69 6e 74 6f 20 74 68 65  se file into the
33e0: 20 74 72 61 63 65 20 6c 6f 67 20 66 69 6c 65 2e   trace log file.
33f0: 0d 0a 20 20 23 0d 0a 20 20 73 65 74 20 63 6f 6e  ..  #..  set con
3400: 6e 65 63 74 69 6f 6e 20 5b 67 65 74 44 62 43 6f  nection [getDbCo
3410: 6e 6e 65 63 74 69 6f 6e 5d 0d 0a 0d 0a 20 20 24  nnection]....  $
3420: 63 6f 6e 6e 65 63 74 69 6f 6e 20 4c 6f 67 4d 65  connection LogMe
3430: 73 73 61 67 65 20 30 20 5b 61 70 70 65 6e 64 41  ssage 0 [appendA
3440: 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 22 73 74  rgs \..      "st
3450: 61 72 74 69 6e 67 20 73 74 72 65 73 73 20 74 65  arting stress te
3460: 73 74 20 75 73 69 6e 67 20 64 61 74 61 62 61 73  st using databas
3470: 65 20 5c 22 22 20 24 66 69 6c 65 4e 61 6d 65 28  e \"" $fileName(
3480: 32 29 20 5c 22 2e 2e 2e 5d 0d 0a 0d 0a 20 20 23  2) \"...]....  #
3490: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
34a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
34b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
34c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
34d0: 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 20 20  ############..  
34e0: 23 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  #               
34f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 57                 W
3500: 4f 52 4b 4c 4f 41 44 20 23 31 20 28 41 29 20 20  ORKLOAD #1 (A)  
3510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3520: 20 20 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20              #.. 
3530: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
3540: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3550: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3560: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3570: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
3580: 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c 6f 61 64  ..  set workload
3590: 28 31 29 20 5b 6c 69 73 74 20 5c 0d 0a 20 20 20  (1) [list \..   
35a0: 20 20 20 5b 6c 69 73 74 20 73 72 63 46 69 6c 65     [list srcFile
35b0: 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e 61 6d 65  Name dstFileName
35c0: 20 74 61 62 6c 65 20 63 6f 75 6e 74 31 20 63 6f   table count1 co
35d0: 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20 7b 0d 0a  unt2 count3] {..
35e0: 20 20 20 20 23 0d 0a 20 20 20 20 23 20 4e 4f 54      #..    # NOT
35f0: 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 31 2c 20  E: Workload #1, 
3600: 43 52 45 41 54 45 20 54 41 42 4c 45 20 73 74 61  CREATE TABLE sta
3610: 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20 20 23 0d  tements...    #.
3620: 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74  .    lappend ::t
3630: 69 6d 65 73 28 31 29 20 5b 6c 69 6e 64 65 78 20  imes(1) [lindex 
3640: 5b 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 73  [time {..      s
3650: 65 74 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e  etupDb $dstFileN
3660: 61 6d 65 20 22 22 20 22 22 20 22 22 20 22 22 20  ame "" "" "" "" 
3670: 22 22 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20  "" true false.. 
3680: 20 20 20 20 20 66 6f 72 20 7b 73 65 74 20 69 6e       for {set in
3690: 64 65 78 20 32 7d 20 7b 24 69 6e 64 65 78 20 3c  dex 2} {$index <
36a0: 3d 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e 63 72  = $count1} {incr
36b0: 20 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20 20 20   index} {..     
36c0: 20 20 20 69 66 20 7b 5b 63 61 74 63 68 20 7b 0d     if {[catch {.
36d0: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 20 65  .          sql e
36e0: 78 65 63 75 74 65 20 24 64 62 20 5b 61 70 70 65  xecute $db [appe
36f0: 6e 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20 20  ndArgs \..      
3700: 20 20 20 20 20 20 20 20 22 43 52 45 41 54 45 20          "CREATE 
3710: 54 41 42 4c 45 20 49 46 20 4e 4f 54 20 45 58 49  TABLE IF NOT EXI
3720: 53 54 53 20 74 22 20 5c 0d 0a 20 20 20 20 20 20  STS t" \..      
3730: 20 20 20 20 20 20 20 20 24 69 6e 64 65 78 20 22          $index "
3740: 28 78 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20  (x PRIMARY KEY, 
3750: 79 2c 20 7a 29 3b 22 5d 0d 0a 20 20 20 20 20 20  y, z);"]..      
3760: 20 20 20 20 73 68 6f 77 54 65 73 74 20 41 0d 0a      showTest A..
3770: 20 20 20 20 20 20 20 20 7d 20 65 72 72 6f 72 5d          } error]
3780: 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20  } then {..      
3790: 20 20 20 20 69 66 20 7b 5b 69 73 45 78 70 65 63      if {[isExpec
37a0: 74 65 64 45 72 72 6f 72 20 24 65 72 72 6f 72 5d  tedError $error]
37b0: 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20  } then {..      
37c0: 20 20 20 20 20 20 73 68 6f 77 54 65 73 74 20 61        showTest a
37d0: 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 20 65 6c  ..          } el
37e0: 73 65 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  se {..          
37f0: 20 20 66 61 69 6c 54 65 73 74 20 61 20 24 65 72    failTest a $er
3800: 72 6f 72 0d 0a 20 20 20 20 20 20 20 20 20 20 7d  ror..          }
3810: 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20  ..        }..   
3820: 20 20 20 7d 0d 0a 20 20 20 20 20 20 63 6c 65 61     }..      clea
3830: 6e 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e 61  nupDb $dstFileNa
3840: 6d 65 20 64 62 20 66 61 6c 73 65 20 74 72 75 65  me db false true
3850: 20 66 61 6c 73 65 0d 0a 20 20 20 20 7d 5d 20 30   false..    }] 0
3860: 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20 20 23 23 23  ]..  }]....  ###
3870: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3880: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3890: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
38a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
38b0: 23 23 23 23 23 23 23 23 23 23 0d 0a 20 20 23 20  ##########..  # 
38c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
38d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 57 4f 52               WOR
38e0: 4b 4c 4f 41 44 20 23 32 20 28 42 29 20 20 20 20  KLOAD #2 (B)    
38f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3900: 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20 23            #..  #
3910: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3920: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3930: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3940: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3950: 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a  ############....
3960: 20 20 73 65 74 20 77 6f 72 6b 6c 6f 61 64 28 32    set workload(2
3970: 29 20 5b 6c 69 73 74 20 5c 0d 0a 20 20 20 20 20  ) [list \..     
3980: 20 5b 6c 69 73 74 20 73 72 63 46 69 6c 65 4e 61   [list srcFileNa
3990: 6d 65 20 64 73 74 46 69 6c 65 4e 61 6d 65 20 74  me dstFileName t
39a0: 61 62 6c 65 20 63 6f 75 6e 74 31 20 63 6f 75 6e  able count1 coun
39b0: 74 32 20 63 6f 75 6e 74 33 5d 20 7b 0d 0a 20 20  t2 count3] {..  
39c0: 20 20 23 0d 0a 20 20 20 20 23 20 4e 4f 54 45 3a    #..    # NOTE:
39d0: 20 57 6f 72 6b 6c 6f 61 64 20 23 32 2c 20 44 52   Workload #2, DR
39e0: 4f 50 20 54 41 42 4c 45 20 73 74 61 74 65 6d 65  OP TABLE stateme
39f0: 6e 74 73 2e 0d 0a 20 20 20 20 23 0d 0a 20 20 20  nts...    #..   
3a00: 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69 6d 65 73   lappend ::times
3a10: 28 32 29 20 5b 6c 69 6e 64 65 78 20 5b 74 69 6d  (2) [lindex [tim
3a20: 65 20 7b 0d 0a 20 20 20 20 20 20 73 65 74 75 70  e {..      setup
3a30: 44 62 20 24 64 73 74 46 69 6c 65 4e 61 6d 65 20  Db $dstFileName 
3a40: 22 22 20 22 22 20 22 22 20 22 22 20 22 22 20 74  "" "" "" "" "" t
3a50: 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20 20 20  rue false..     
3a60: 20 66 6f 72 20 7b 73 65 74 20 69 6e 64 65 78 20   for {set index 
3a70: 32 7d 20 7b 24 69 6e 64 65 78 20 3c 3d 20 24 63  2} {$index <= $c
3a80: 6f 75 6e 74 31 7d 20 7b 69 6e 63 72 20 69 6e 64  ount1} {incr ind
3a90: 65 78 7d 20 7b 0d 0a 20 20 20 20 20 20 20 20 69  ex} {..        i
3aa0: 66 20 7b 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20  f {[catch {..   
3ab0: 20 20 20 20 20 20 20 73 71 6c 20 65 78 65 63 75         sql execu
3ac0: 74 65 20 24 64 62 20 5b 61 70 70 65 6e 64 41 72  te $db [appendAr
3ad0: 67 73 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20  gs \..          
3ae0: 20 20 20 20 22 44 52 4f 50 20 54 41 42 4c 45 20      "DROP TABLE 
3af0: 49 46 20 45 58 49 53 54 53 20 74 22 20 24 69 6e  IF EXISTS t" $in
3b00: 64 65 78 20 5c 3b 5d 0d 0a 20 20 20 20 20 20 20  dex \;]..       
3b10: 20 20 20 73 68 6f 77 54 65 73 74 20 42 0d 0a 20     showTest B.. 
3b20: 20 20 20 20 20 20 20 7d 20 65 72 72 6f 72 5d 7d         } error]}
3b30: 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20   then {..       
3b40: 20 20 20 69 66 20 7b 5b 69 73 45 78 70 65 63 74     if {[isExpect
3b50: 65 64 45 72 72 6f 72 20 24 65 72 72 6f 72 5d 7d  edError $error]}
3b60: 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20   then {..       
3b70: 20 20 20 20 20 73 68 6f 77 54 65 73 74 20 62 0d       showTest b.
3b80: 0a 20 20 20 20 20 20 20 20 20 20 7d 20 65 6c 73  .          } els
3b90: 65 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e {..           
3ba0: 20 66 61 69 6c 54 65 73 74 20 62 20 24 65 72 72   failTest b $err
3bb0: 6f 72 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d  or..          }.
3bc0: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
3bd0: 20 20 7d 0d 0a 20 20 20 20 20 20 63 6c 65 61 6e    }..      clean
3be0: 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e 61 6d  upDb $dstFileNam
3bf0: 65 20 64 62 20 66 61 6c 73 65 20 74 72 75 65 20  e db false true 
3c00: 66 61 6c 73 65 0d 0a 20 20 20 20 7d 5d 20 30 5d  false..    }] 0]
3c10: 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20 20 23 23 23 23  ..  }]....  ####
3c20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3c30: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3c40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3c50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3c60: 23 23 23 23 23 23 23 23 23 0d 0a 20 20 23 20 20  #########..  #  
3c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c80: 20 20 20 20 20 20 20 20 20 20 20 20 57 4f 52 4b              WORK
3c90: 4c 4f 41 44 20 23 33 20 28 43 29 20 20 20 20 20  LOAD #3 (C)     
3ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3cb0: 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20 23 23           #..  ##
3cc0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3cd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3ce0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3cf0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
3d00: 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20  ###########.... 
3d10: 20 73 65 74 20 77 6f 72 6b 6c 6f 61 64 28 33 29   set workload(3)
3d20: 20 5b 6c 69 73 74 20 5c 0d 0a 20 20 20 20 20 20   [list \..      
3d30: 5b 6c 69 73 74 20 73 72 63 46 69 6c 65 4e 61 6d  [list srcFileNam
3d40: 65 20 64 73 74 46 69 6c 65 4e 61 6d 65 20 74 61  e dstFileName ta
3d50: 62 6c 65 20 63 6f 75 6e 74 31 20 63 6f 75 6e 74  ble count1 count
3d60: 32 20 63 6f 75 6e 74 33 5d 20 7b 0d 0a 20 20 20  2 count3] {..   
3d70: 20 23 0d 0a 20 20 20 20 23 20 4e 4f 54 45 3a 20   #..    # NOTE: 
3d80: 57 6f 72 6b 6c 6f 61 64 20 23 33 2c 20 22 73 6d  Workload #3, "sm
3d90: 61 6c 6c 22 20 53 45 4c 45 43 54 20 73 74 61 74  all" SELECT stat
3da0: 65 6d 65 6e 74 73 2e 0d 0a 20 20 20 20 23 0d 0a  ements...    #..
3db0: 20 20 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69      lappend ::ti
3dc0: 6d 65 73 28 33 29 20 5b 6c 69 6e 64 65 78 20 5b  mes(3) [lindex [
3dd0: 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 73 65  time {..      se
3de0: 74 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e 61  tupDb $dstFileNa
3df0: 6d 65 20 22 22 20 22 22 20 22 22 20 22 22 20 22  me "" "" "" "" "
3e00: 22 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20  " true false..  
3e10: 20 20 20 20 66 6f 72 20 7b 73 65 74 20 69 6e 64      for {set ind
3e20: 65 78 20 31 7d 20 7b 24 69 6e 64 65 78 20 3c 3d  ex 1} {$index <=
3e30: 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e 63 72 20   $count1} {incr 
3e40: 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20 20 20 20  index} {..      
3e50: 20 20 69 66 20 7b 5b 63 61 74 63 68 20 7b 0d 0a    if {[catch {..
3e60: 20 20 20 20 20 20 20 20 20 20 73 65 74 20 72 65            set re
3e70: 61 64 65 72 20 5b 73 71 6c 20 65 78 65 63 75 74  ader [sql execut
3e80: 65 20 2d 65 78 65 63 75 74 65 20 72 65 61 64 65  e -execute reade
3e90: 72 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  r \..           
3ea0: 20 20 20 2d 66 6f 72 6d 61 74 20 64 61 74 61 52     -format dataR
3eb0: 65 61 64 65 72 20 2d 61 6c 69 61 73 20 24 64 62  eader -alias $db
3ec0: 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a   [appendArgs \..
3ed0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 53                "S
3ee0: 45 4c 45 43 54 20 78 2c 20 79 20 46 52 4f 4d 20  ELECT x, y FROM 
3ef0: 22 20 24 74 61 62 6c 65 20 22 20 57 48 45 52 45  " $table " WHERE
3f00: 20 7a 20 3d 20 27 73 6d 61 6c 6c 27 3b 22 5d 5d   z = 'small';"]]
3f10: 0d 0a 20 20 20 20 20 20 20 20 20 20 77 68 69 6c  ..          whil
3f20: 65 20 7b 5b 24 72 65 61 64 65 72 20 52 65 61 64  e {[$reader Read
3f30: 5d 7d 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  ]} {..          
3f40: 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20 20 20    #..           
3f50: 20 23 20 4e 4f 54 45 3a 20 44 6f 20 6e 6f 74 68   # NOTE: Do noth
3f60: 69 6e 67 2e 0d 0a 20 20 20 20 20 20 20 20 20 20  ing...          
3f70: 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20 20 7d    #..          }
3f80: 0d 0a 20 20 20 20 20 20 20 20 20 20 75 6e 73 65  ..          unse
3f90: 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20 72 65  t -nocomplain re
3fa0: 61 64 65 72 0d 0a 20 20 20 20 20 20 20 20 20 20  ader..          
3fb0: 73 68 6f 77 54 65 73 74 20 43 0d 0a 20 20 20 20  showTest C..    
3fc0: 20 20 20 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68      } error]} th
3fd0: 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  en {..          
3fe0: 69 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45  if {[isExpectedE
3ff0: 72 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68  rror $error]} th
4000: 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  en {..          
4010: 20 20 73 68 6f 77 54 65 73 74 20 63 0d 0a 20 20    showTest c..  
4020: 20 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b          } else {
4030: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61  ..            fa
4040: 69 6c 54 65 73 74 20 63 20 24 65 72 72 6f 72 0d  ilTest c $error.
4050: 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20  .          }..  
4060: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d        }..      }
4070: 0d 0a 20 20 20 20 20 20 63 6c 65 61 6e 75 70 44  ..      cleanupD
4080: 62 20 24 64 73 74 46 69 6c 65 4e 61 6d 65 20 64  b $dstFileName d
4090: 62 20 66 61 6c 73 65 20 74 72 75 65 20 66 61 6c  b false true fal
40a0: 73 65 0d 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a 20  se..    }] 0].. 
40b0: 20 7d 5d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23   }]....  #######
40c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
40d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
40e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
40f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4100: 23 23 23 23 23 23 0d 0a 20 20 23 20 20 20 20 20  ######..  #     
4110: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4120: 20 20 20 20 20 20 20 20 20 57 4f 52 4b 4c 4f 41           WORKLOA
4130: 44 20 23 34 20 28 44 29 20 20 20 20 20 20 20 20  D #4 (D)        
4140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4150: 20 20 20 20 20 20 23 0d 0a 20 20 23 23 23 23 23        #..  #####
4160: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4170: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4180: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4190: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
41a0: 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 73 65  ########....  se
41b0: 74 20 77 6f 72 6b 6c 6f 61 64 28 34 29 20 5b 6c  t workload(4) [l
41c0: 69 73 74 20 5c 0d 0a 20 20 20 20 20 20 5b 6c 69  ist \..      [li
41d0: 73 74 20 73 72 63 46 69 6c 65 4e 61 6d 65 20 64  st srcFileName d
41e0: 73 74 46 69 6c 65 4e 61 6d 65 20 74 61 62 6c 65  stFileName table
41f0: 20 63 6f 75 6e 74 31 20 63 6f 75 6e 74 32 20 63   count1 count2 c
4200: 6f 75 6e 74 33 5d 20 7b 0d 0a 20 20 20 20 23 0d  ount3] {..    #.
4210: 0a 20 20 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72  .    # NOTE: Wor
4220: 6b 6c 6f 61 64 20 23 34 2c 20 22 62 69 67 22 20  kload #4, "big" 
4230: 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74  SELECT statement
4240: 73 2e 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 6c  s...    #..    l
4250: 61 70 70 65 6e 64 20 3a 3a 74 69 6d 65 73 28 34  append ::times(4
4260: 29 20 5b 6c 69 6e 64 65 78 20 5b 74 69 6d 65 20  ) [lindex [time 
4270: 7b 0d 0a 20 20 20 20 20 20 73 65 74 75 70 44 62  {..      setupDb
4280: 20 24 64 73 74 46 69 6c 65 4e 61 6d 65 20 22 22   $dstFileName ""
4290: 20 22 22 20 22 22 20 22 22 20 22 22 20 74 72 75   "" "" "" "" tru
42a0: 65 20 66 61 6c 73 65 0d 0a 20 20 20 20 20 20 66  e false..      f
42b0: 6f 72 20 7b 73 65 74 20 69 6e 64 65 78 20 31 7d  or {set index 1}
42c0: 20 7b 24 69 6e 64 65 78 20 3c 3d 20 24 63 6f 75   {$index <= $cou
42d0: 6e 74 31 7d 20 7b 69 6e 63 72 20 69 6e 64 65 78  nt1} {incr index
42e0: 7d 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20  } {..        if 
42f0: 7b 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20 20 20  {[catch {..     
4300: 20 20 20 20 20 73 65 74 20 72 65 61 64 65 72 20       set reader 
4310: 5b 73 71 6c 20 65 78 65 63 75 74 65 20 2d 65 78  [sql execute -ex
4320: 65 63 75 74 65 20 72 65 61 64 65 72 20 5c 0d 0a  ecute reader \..
4330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2d 66                -f
4340: 6f 72 6d 61 74 20 64 61 74 61 52 65 61 64 65 72  ormat dataReader
4350: 20 2d 61 6c 69 61 73 20 24 64 62 20 5b 61 70 70   -alias $db [app
4360: 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20 20 20 20  endArgs \..     
4370: 20 20 20 20 20 20 20 20 20 22 53 45 4c 45 43 54           "SELECT
4380: 20 78 2c 20 79 20 46 52 4f 4d 20 22 20 24 74 61   x, y FROM " $ta
4390: 62 6c 65 20 22 20 57 48 45 52 45 20 7a 20 3d 20  ble " WHERE z = 
43a0: 27 62 69 67 27 3b 22 5d 5d 0d 0a 20 20 20 20 20  'big';"]]..     
43b0: 20 20 20 20 20 77 68 69 6c 65 20 7b 5b 24 72 65       while {[$re
43c0: 61 64 65 72 20 52 65 61 64 5d 7d 20 7b 0d 0a 20  ader Read]} {.. 
43d0: 20 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20             #..  
43e0: 20 20 20 20 20 20 20 20 20 20 23 20 4e 4f 54 45            # NOTE
43f0: 3a 20 44 6f 20 6e 6f 74 68 69 6e 67 2e 0d 0a 20  : Do nothing... 
4400: 20 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20             #..  
4410: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
4420: 20 20 20 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f       unset -noco
4430: 6d 70 6c 61 69 6e 20 72 65 61 64 65 72 0d 0a 20  mplain reader.. 
4440: 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73           showTes
4450: 74 20 44 0d 0a 20 20 20 20 20 20 20 20 7d 20 65  t D..        } e
4460: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
4470: 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73           if {[is
4480: 45 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65  ExpectedError $e
4490: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
44a0: 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54             showT
44b0: 65 73 74 20 64 0d 0a 20 20 20 20 20 20 20 20 20  est d..         
44c0: 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20   } else {..     
44d0: 20 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20         failTest 
44e0: 64 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20  d $error..      
44f0: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
4500: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
4510: 20 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46   cleanupDb $dstF
4520: 69 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65  ileName db false
4530: 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20   true false..   
4540: 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a   }] 0]..  }]....
4550: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
4560: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4570: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4580: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4590: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
45a0: 0a 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20  .  #            
45b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
45c0: 20 20 57 4f 52 4b 4c 4f 41 44 20 23 35 20 28 45    WORKLOAD #5 (E
45d0: 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )               
45e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23                 #
45f0: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
4600: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4610: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4620: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4630: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4640: 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c  #....  set workl
4650: 6f 61 64 28 35 29 20 5b 6c 69 73 74 20 5c 0d 0a  oad(5) [list \..
4660: 20 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63 46        [list srcF
4670: 69 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e  ileName dstFileN
4680: 61 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74 31  ame table count1
4690: 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20   count2 count3] 
46a0: 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20  {..    #..    # 
46b0: 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23  NOTE: Workload #
46c0: 35 2c 20 22 73 6d 61 6c 6c 22 20 49 4e 53 45 52  5, "small" INSER
46d0: 54 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20  T statements... 
46e0: 20 20 20 23 0d 0a 20 20 20 20 6c 61 70 70 65 6e     #..    lappen
46f0: 64 20 3a 3a 74 69 6d 65 73 28 35 29 20 5b 6c 69  d ::times(5) [li
4700: 6e 64 65 78 20 5b 74 69 6d 65 20 7b 0d 0a 20 20  ndex [time {..  
4710: 20 20 20 20 73 65 74 75 70 44 62 20 24 64 73 74      setupDb $dst
4720: 46 69 6c 65 4e 61 6d 65 20 22 22 20 22 22 20 22  FileName "" "" "
4730: 22 20 22 22 20 22 22 20 74 72 75 65 20 66 61 6c  " "" "" true fal
4740: 73 65 0d 0a 20 20 20 20 20 20 66 6f 72 20 7b 73  se..      for {s
4750: 65 74 20 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e  et index 1} {$in
4760: 64 65 78 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20  dex <= $count1} 
4770: 7b 69 6e 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a  {incr index} {..
4780: 20 20 20 20 20 20 20 20 69 66 20 7b 5b 63 61 74          if {[cat
4790: 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  ch {..          
47a0: 73 71 6c 20 65 78 65 63 75 74 65 20 24 64 62 20  sql execute $db 
47b0: 5b 61 70 70 65 6e 64 41 72 67 73 20 22 49 4e 53  [appendArgs "INS
47c0: 45 52 54 20 49 4e 54 4f 20 22 20 24 74 61 62 6c  ERT INTO " $tabl
47d0: 65 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e \..           
47e0: 20 20 20 22 28 78 2c 20 79 2c 20 7a 29 20 56 41     "(x, y, z) VA
47f0: 4c 55 45 53 28 27 22 20 5b 66 6f 72 6d 61 74 20  LUES('" [format 
4800: 25 6c 58 20 5b 65 78 70 72 20 7b 72 61 6e 64 6f  %lX [expr {rando
4810: 6d 28 29 7d 5d 5d 20 5c 0d 0a 20 20 20 20 20 20  m()}]] \..      
4820: 20 20 20 20 20 20 20 20 22 27 2c 20 27 22 20 5b          "', '" [
4830: 62 61 73 65 36 34 20 65 6e 63 6f 64 65 20 2d 2d  base64 encode --
4840: 20 5b 65 78 70 72 20 7b 72 61 6e 64 73 74 72 28   [expr {randstr(
4850: 24 63 6f 75 6e 74 32 29 7d 5d 5d 20 5c 0d 0a 20  $count2)}]] \.. 
4860: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 27 2c               "',
4870: 20 27 73 6d 61 6c 6c 27 29 3b 22 5d 0d 0a 20 20   'small');"]..  
4880: 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73 74          showTest
4890: 20 45 0d 0a 20 20 20 20 20 20 20 20 7d 20 65 72   E..        } er
48a0: 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  ror]} then {..  
48b0: 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73 45          if {[isE
48c0: 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65 72  xpectedError $er
48d0: 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  ror]} then {..  
48e0: 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65            showTe
48f0: 73 74 20 65 0d 0a 20 20 20 20 20 20 20 20 20 20  st e..          
4900: 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20  } else {..      
4910: 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20 65        failTest e
4920: 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20 20   $error..       
4930: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
4940: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20  .      }..      
4950: 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46 69  cleanupDb $dstFi
4960: 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65 20  leName db false 
4970: 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20 20  true false..    
4980: 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20  }] 0]..  }].... 
4990: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
49a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
49b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
49c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
49d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
49e0: 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20 20    #             
49f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4a00: 20 57 4f 52 4b 4c 4f 41 44 20 23 36 20 28 46 29   WORKLOAD #6 (F)
4a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 0d                #.
4a30: 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23  .  #############
4a40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4a50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4a60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4a70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4a80: 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c 6f  ....  set worklo
4a90: 61 64 28 36 29 20 5b 6c 69 73 74 20 5c 0d 0a 20  ad(6) [list \.. 
4aa0: 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63 46 69       [list srcFi
4ab0: 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e 61  leName dstFileNa
4ac0: 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74 31 20  me table count1 
4ad0: 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20 7b  count2 count3] {
4ae0: 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20 4e  ..    #..    # N
4af0: 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 36  OTE: Workload #6
4b00: 2c 20 22 62 69 67 22 20 49 4e 53 45 52 54 20 73  , "big" INSERT s
4b10: 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20 20  tatements...    
4b20: 23 0d 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 3a  #..    lappend :
4b30: 3a 74 69 6d 65 73 28 36 29 20 5b 6c 69 6e 64 65  :times(6) [linde
4b40: 78 20 5b 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20  x [time {..     
4b50: 20 73 65 74 75 70 44 62 20 24 64 73 74 46 69 6c   setupDb $dstFil
4b60: 65 4e 61 6d 65 20 22 22 20 22 22 20 22 22 20 22  eName "" "" "" "
4b70: 22 20 22 22 20 74 72 75 65 20 66 61 6c 73 65 0d  " "" true false.
4b80: 0a 20 20 20 20 20 20 66 6f 72 20 7b 73 65 74 20  .      for {set 
4b90: 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e 64 65 78  index 1} {$index
4ba0: 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e   <= $count1} {in
4bb0: 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20  cr index} {..   
4bc0: 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63 68 20       if {[catch 
4bd0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  {..          sql
4be0: 20 65 78 65 63 75 74 65 20 24 64 62 20 5b 61 70   execute $db [ap
4bf0: 70 65 6e 64 41 72 67 73 20 22 49 4e 53 45 52 54  pendArgs "INSERT
4c00: 20 49 4e 54 4f 20 22 20 24 74 61 62 6c 65 20 5c   INTO " $table \
4c10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
4c20: 22 28 78 2c 20 79 2c 20 7a 29 20 56 41 4c 55 45  "(x, y, z) VALUE
4c30: 53 28 27 22 20 5b 66 6f 72 6d 61 74 20 25 6c 58  S('" [format %lX
4c40: 20 5b 65 78 70 72 20 7b 72 61 6e 64 6f 6d 28 29   [expr {random()
4c50: 7d 5d 5d 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  }]] \..         
4c60: 20 20 20 20 20 22 27 2c 20 52 41 4e 44 4f 4d 42       "', RANDOMB
4c70: 4c 4f 42 28 22 20 24 63 6f 75 6e 74 33 20 22 29  LOB(" $count3 ")
4c80: 2c 20 27 62 69 67 27 29 3b 22 5d 0d 0a 20 20 20  , 'big');"]..   
4c90: 20 20 20 20 20 20 20 73 68 6f 77 54 65 73 74 20         showTest 
4ca0: 46 0d 0a 20 20 20 20 20 20 20 20 7d 20 65 72 72  F..        } err
4cb0: 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20  or]} then {..   
4cc0: 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73 45 78         if {[isEx
4cd0: 70 65 63 74 65 64 45 72 72 6f 72 20 24 65 72 72  pectedError $err
4ce0: 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20  or]} then {..   
4cf0: 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73           showTes
4d00: 74 20 66 0d 0a 20 20 20 20 20 20 20 20 20 20 7d  t f..          }
4d10: 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20 20   else {..       
4d20: 20 20 20 20 20 66 61 69 6c 54 65 73 74 20 66 20       failTest f 
4d30: 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20 20 20  $error..        
4d40: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d 0a    }..        }..
4d50: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 63        }..      c
4d60: 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46 69 6c  leanupDb $dstFil
4d70: 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65 20 74  eName db false t
4d80: 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20 20 7d  rue false..    }
4d90: 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20 20  ] 0]..  }]....  
4da0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4db0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4dc0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4dd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4de0: 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 20  #############.. 
4df0: 20 23 20 20 20 20 20 20 20 20 20 20 20 20 20 20   #              
4e00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4e10: 57 4f 52 4b 4c 4f 41 44 20 23 37 20 28 47 29 20  WORKLOAD #7 (G) 
4e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 23 0d 0a               #..
4e40: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
4e50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4e60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4e70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
4e80: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
4e90: 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c 6f 61  ...  set workloa
4ea0: 64 28 37 29 20 5b 6c 69 73 74 20 5c 0d 0a 20 20  d(7) [list \..  
4eb0: 20 20 20 20 5b 6c 69 73 74 20 73 72 63 46 69 6c      [list srcFil
4ec0: 65 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e 61 6d  eName dstFileNam
4ed0: 65 20 74 61 62 6c 65 20 63 6f 75 6e 74 31 20 63  e table count1 c
4ee0: 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20 7b 0d  ount2 count3] {.
4ef0: 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20 4e 4f  .    #..    # NO
4f00: 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 37 2c  TE: Workload #7,
4f10: 20 22 73 6d 61 6c 6c 22 20 55 50 44 41 54 45 20   "small" UPDATE 
4f20: 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20  statements...   
4f30: 20 23 0d 0a 20 20 20 20 6c 61 70 70 65 6e 64 20   #..    lappend 
4f40: 3a 3a 74 69 6d 65 73 28 37 29 20 5b 6c 69 6e 64  ::times(7) [lind
4f50: 65 78 20 5b 74 69 6d 65 20 7b 0d 0a 20 20 20 20  ex [time {..    
4f60: 20 20 73 65 74 75 70 44 62 20 24 64 73 74 46 69    setupDb $dstFi
4f70: 6c 65 4e 61 6d 65 20 22 22 20 22 22 20 22 22 20  leName "" "" "" 
4f80: 22 22 20 22 22 20 74 72 75 65 20 66 61 6c 73 65  "" "" true false
4f90: 0d 0a 20 20 20 20 20 20 66 6f 72 20 7b 73 65 74  ..      for {set
4fa0: 20 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e 64 65   index 1} {$inde
4fb0: 78 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20 7b 69  x <= $count1} {i
4fc0: 6e 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a 20 20  ncr index} {..  
4fd0: 20 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63 68        if {[catch
4fe0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73 71   {..          sq
4ff0: 6c 20 65 78 65 63 75 74 65 20 24 64 62 20 5b 61  l execute $db [a
5000: 70 70 65 6e 64 41 72 67 73 20 22 55 50 44 41 54  ppendArgs "UPDAT
5010: 45 20 22 20 24 74 61 62 6c 65 20 5c 0d 0a 20 20  E " $table \..  
5020: 20 20 20 20 20 20 20 20 20 20 20 20 22 20 53 45              " SE
5030: 54 20 79 20 3d 20 27 22 20 5b 62 61 73 65 36 34  T y = '" [base64
5040: 20 65 6e 63 6f 64 65 20 2d 2d 20 5b 65 78 70 72   encode -- [expr
5050: 20 7b 72 61 6e 64 73 74 72 28 24 63 6f 75 6e 74   {randstr($count
5060: 32 29 7d 5d 5d 20 5c 0d 0a 20 20 20 20 20 20 20  2)}]] \..       
5070: 20 20 20 20 20 20 20 22 27 20 57 48 45 52 45 20         "' WHERE 
5080: 78 20 4c 49 4b 45 20 27 22 20 5b 66 6f 72 6d 61  x LIKE '" [forma
5090: 74 20 25 58 20 24 69 6e 64 65 78 5d 20 22 25 27  t %X $index] "%'
50a0: 20 41 4e 44 20 7a 20 3d 20 27 73 6d 61 6c 6c 27   AND z = 'small'
50b0: 3b 22 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 73  ;"]..          s
50c0: 68 6f 77 54 65 73 74 20 47 0d 0a 20 20 20 20 20  howTest G..     
50d0: 20 20 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68 65     } error]} the
50e0: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 69  n {..          i
50f0: 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45 72  f {[isExpectedEr
5100: 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68 65  ror $error]} the
5110: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n {..           
5120: 20 73 68 6f 77 54 65 73 74 20 67 0d 0a 20 20 20   showTest g..   
5130: 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d         } else {.
5140: 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61 69  .            fai
5150: 6c 54 65 73 74 20 67 20 24 65 72 72 6f 72 0d 0a  lTest g $error..
5160: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
5170: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d       }..      }.
5180: 0a 20 20 20 20 20 20 63 6c 65 61 6e 75 70 44 62  .      cleanupDb
5190: 20 24 64 73 74 46 69 6c 65 4e 61 6d 65 20 64 62   $dstFileName db
51a0: 20 66 61 6c 73 65 20 74 72 75 65 20 66 61 6c 73   false true fals
51b0: 65 0d 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a 20 20  e..    }] 0]..  
51c0: 7d 5d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23  }]....  ########
51d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
51e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
51f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5200: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5210: 23 23 23 23 23 0d 0a 20 20 23 20 20 20 20 20 20  #####..  #      
5220: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5230: 20 20 20 20 20 20 20 20 57 4f 52 4b 4c 4f 41 44          WORKLOAD
5240: 20 23 38 20 28 48 29 20 20 20 20 20 20 20 20 20   #8 (H)         
5250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5260: 20 20 20 20 20 23 0d 0a 20 20 23 23 23 23 23 23       #..  ######
5270: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5280: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5290: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
52a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
52b0: 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 73 65 74  #######....  set
52c0: 20 77 6f 72 6b 6c 6f 61 64 28 38 29 20 5b 6c 69   workload(8) [li
52d0: 73 74 20 5c 0d 0a 20 20 20 20 20 20 5b 6c 69 73  st \..      [lis
52e0: 74 20 73 72 63 46 69 6c 65 4e 61 6d 65 20 64 73  t srcFileName ds
52f0: 74 46 69 6c 65 4e 61 6d 65 20 74 61 62 6c 65 20  tFileName table 
5300: 63 6f 75 6e 74 31 20 63 6f 75 6e 74 32 20 63 6f  count1 count2 co
5310: 75 6e 74 33 5d 20 7b 0d 0a 20 20 20 20 23 0d 0a  unt3] {..    #..
5320: 20 20 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b      # NOTE: Work
5330: 6c 6f 61 64 20 23 38 2c 20 22 62 69 67 22 20 55  load #8, "big" U
5340: 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 73  PDATE statements
5350: 2e 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 6c 61  ...    #..    la
5360: 70 70 65 6e 64 20 3a 3a 74 69 6d 65 73 28 38 29  ppend ::times(8)
5370: 20 5b 6c 69 6e 64 65 78 20 5b 74 69 6d 65 20 7b   [lindex [time {
5380: 0d 0a 20 20 20 20 20 20 73 65 74 75 70 44 62 20  ..      setupDb 
5390: 24 64 73 74 46 69 6c 65 4e 61 6d 65 20 22 22 20  $dstFileName "" 
53a0: 22 22 20 22 22 20 22 22 20 22 22 20 74 72 75 65  "" "" "" "" true
53b0: 20 66 61 6c 73 65 0d 0a 20 20 20 20 20 20 66 6f   false..      fo
53c0: 72 20 7b 73 65 74 20 69 6e 64 65 78 20 31 7d 20  r {set index 1} 
53d0: 7b 24 69 6e 64 65 78 20 3c 3d 20 24 63 6f 75 6e  {$index <= $coun
53e0: 74 31 7d 20 7b 69 6e 63 72 20 69 6e 64 65 78 7d  t1} {incr index}
53f0: 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 7b   {..        if {
5400: 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20 20 20 20  [catch {..      
5410: 20 20 20 20 73 71 6c 20 65 78 65 63 75 74 65 20      sql execute 
5420: 24 64 62 20 5b 61 70 70 65 6e 64 41 72 67 73 20  $db [appendArgs 
5430: 22 55 50 44 41 54 45 20 22 20 24 74 61 62 6c 65  "UPDATE " $table
5440: 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   \..            
5450: 20 20 22 20 53 45 54 20 79 20 3d 20 52 41 4e 44    " SET y = RAND
5460: 4f 4d 42 4c 4f 42 28 22 20 24 63 6f 75 6e 74 33  OMBLOB(" $count3
5470: 20 22 29 20 57 48 45 52 45 20 78 20 4c 49 4b 45   ") WHERE x LIKE
5480: 20 27 22 20 5c 0d 0a 20 20 20 20 20 20 20 20 20   '" \..         
5490: 20 20 20 20 20 5b 66 6f 72 6d 61 74 20 25 58 20       [format %X 
54a0: 24 69 6e 64 65 78 5d 20 22 25 27 20 41 4e 44 20  $index] "%' AND 
54b0: 7a 20 3d 20 27 62 69 67 27 3b 22 5d 0d 0a 20 20  z = 'big';"]..  
54c0: 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73 74          showTest
54d0: 20 48 0d 0a 20 20 20 20 20 20 20 20 7d 20 65 72   H..        } er
54e0: 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  ror]} then {..  
54f0: 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73 45          if {[isE
5500: 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65 72  xpectedError $er
5510: 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  ror]} then {..  
5520: 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65            showTe
5530: 73 74 20 68 0d 0a 20 20 20 20 20 20 20 20 20 20  st h..          
5540: 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20  } else {..      
5550: 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20 68        failTest h
5560: 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20 20   $error..       
5570: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 0d     }..        }.
5580: 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20  .      }..      
5590: 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46 69  cleanupDb $dstFi
55a0: 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65 20  leName db false 
55b0: 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20 20  true false..    
55c0: 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20  }] 0]..  }].... 
55d0: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
55e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
55f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5600: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5610: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
5620: 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20 20    #             
5630: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5640: 20 57 4f 52 4b 4c 4f 41 44 20 23 39 20 28 49 29   WORKLOAD #9 (I)
5650: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5660: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 0d                #.
5670: 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23  .  #############
5680: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5690: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
56a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
56b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
56c0: 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c 6f  ....  set worklo
56d0: 61 64 28 39 29 20 5b 6c 69 73 74 20 5c 0d 0a 20  ad(9) [list \.. 
56e0: 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63 46 69       [list srcFi
56f0: 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e 61  leName dstFileNa
5700: 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74 31 20  me table count1 
5710: 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20 7b  count2 count3] {
5720: 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20 4e  ..    #..    # N
5730: 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 39  OTE: Workload #9
5740: 2c 20 22 73 6d 61 6c 6c 22 20 44 45 4c 45 54 45  , "small" DELETE
5750: 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20   statements...  
5760: 20 20 23 0d 0a 20 20 20 20 6c 61 70 70 65 6e 64    #..    lappend
5770: 20 3a 3a 74 69 6d 65 73 28 39 29 20 5b 6c 69 6e   ::times(9) [lin
5780: 64 65 78 20 5b 74 69 6d 65 20 7b 0d 0a 20 20 20  dex [time {..   
5790: 20 20 20 73 65 74 75 70 44 62 20 24 64 73 74 46     setupDb $dstF
57a0: 69 6c 65 4e 61 6d 65 20 22 22 20 22 22 20 22 22  ileName "" "" ""
57b0: 20 22 22 20 22 22 20 74 72 75 65 20 66 61 6c 73   "" "" true fals
57c0: 65 0d 0a 20 20 20 20 20 20 66 6f 72 20 7b 73 65  e..      for {se
57d0: 74 20 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e 64  t index 1} {$ind
57e0: 65 78 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20 7b  ex <= $count1} {
57f0: 69 6e 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a 20  incr index} {.. 
5800: 20 20 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63         if {[catc
5810: 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73  h {..          s
5820: 71 6c 20 65 78 65 63 75 74 65 20 24 64 62 20 5b  ql execute $db [
5830: 61 70 70 65 6e 64 41 72 67 73 20 22 44 45 4c 45  appendArgs "DELE
5840: 54 45 20 46 52 4f 4d 20 22 20 24 74 61 62 6c 65  TE FROM " $table
5850: 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   \..            
5860: 20 20 22 20 57 48 45 52 45 20 78 20 4c 49 4b 45    " WHERE x LIKE
5870: 20 27 22 20 5b 66 6f 72 6d 61 74 20 25 58 20 24   '" [format %X $
5880: 69 6e 64 65 78 5d 20 22 25 27 20 41 4e 44 20 7a  index] "%' AND z
5890: 20 3d 20 27 73 6d 61 6c 6c 27 3b 22 5d 0d 0a 20   = 'small';"].. 
58a0: 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73           showTes
58b0: 74 20 49 0d 0a 20 20 20 20 20 20 20 20 7d 20 65  t I..        } e
58c0: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
58d0: 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73           if {[is
58e0: 45 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65  ExpectedError $e
58f0: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
5900: 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54             showT
5910: 65 73 74 20 69 0d 0a 20 20 20 20 20 20 20 20 20  est i..         
5920: 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20   } else {..     
5930: 20 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20         failTest 
5940: 69 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20  i $error..      
5950: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
5960: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
5970: 20 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46   cleanupDb $dstF
5980: 69 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65  ileName db false
5990: 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20   true false..   
59a0: 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a   }] 0]..  }]....
59b0: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
59c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
59d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
59e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
59f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
5a00: 0a 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20  .  #            
5a10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a20: 20 20 57 4f 52 4b 4c 4f 41 44 20 23 31 30 20 28    WORKLOAD #10 (
5a30: 4a 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20  J)              
5a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23                 #
5a50: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
5a60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5a70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5a80: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5a90: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5aa0: 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c  #....  set workl
5ab0: 6f 61 64 28 31 30 29 20 5b 6c 69 73 74 20 5c 0d  oad(10) [list \.
5ac0: 0a 20 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63  .      [list src
5ad0: 46 69 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65  FileName dstFile
5ae0: 4e 61 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74  Name table count
5af0: 31 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d  1 count2 count3]
5b00: 20 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23   {..    #..    #
5b10: 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20   NOTE: Workload 
5b20: 23 31 30 2c 20 22 62 69 67 22 20 44 45 4c 45 54  #10, "big" DELET
5b30: 45 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20  E statements... 
5b40: 20 20 20 23 0d 0a 20 20 20 20 6c 61 70 70 65 6e     #..    lappen
5b50: 64 20 3a 3a 74 69 6d 65 73 28 31 30 29 20 5b 6c  d ::times(10) [l
5b60: 69 6e 64 65 78 20 5b 74 69 6d 65 20 7b 0d 0a 20  index [time {.. 
5b70: 20 20 20 20 20 73 65 74 75 70 44 62 20 24 64 73       setupDb $ds
5b80: 74 46 69 6c 65 4e 61 6d 65 20 22 22 20 22 22 20  tFileName "" "" 
5b90: 22 22 20 22 22 20 22 22 20 74 72 75 65 20 66 61  "" "" "" true fa
5ba0: 6c 73 65 0d 0a 20 20 20 20 20 20 66 6f 72 20 7b  lse..      for {
5bb0: 73 65 74 20 69 6e 64 65 78 20 31 7d 20 7b 24 69  set index 1} {$i
5bc0: 6e 64 65 78 20 3c 3d 20 24 63 6f 75 6e 74 31 7d  ndex <= $count1}
5bd0: 20 7b 69 6e 63 72 20 69 6e 64 65 78 7d 20 7b 0d   {incr index} {.
5be0: 0a 20 20 20 20 20 20 20 20 69 66 20 7b 5b 63 61  .        if {[ca
5bf0: 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 20  tch {..         
5c00: 20 73 71 6c 20 65 78 65 63 75 74 65 20 24 64 62   sql execute $db
5c10: 20 5b 61 70 70 65 6e 64 41 72 67 73 20 22 44 45   [appendArgs "DE
5c20: 4c 45 54 45 20 46 52 4f 4d 20 22 20 24 74 61 62  LETE FROM " $tab
5c30: 6c 65 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20  le \..          
5c40: 20 20 20 20 22 20 57 48 45 52 45 20 78 20 4c 49      " WHERE x LI
5c50: 4b 45 20 27 22 20 5b 66 6f 72 6d 61 74 20 25 58  KE '" [format %X
5c60: 20 24 69 6e 64 65 78 5d 20 22 25 27 20 41 4e 44   $index] "%' AND
5c70: 20 7a 20 3d 20 27 62 69 67 27 3b 22 5d 0d 0a 20   z = 'big';"].. 
5c80: 20 20 20 20 20 20 20 20 20 73 68 6f 77 54 65 73           showTes
5c90: 74 20 4a 0d 0a 20 20 20 20 20 20 20 20 7d 20 65  t J..        } e
5ca0: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
5cb0: 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73           if {[is
5cc0: 45 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65  ExpectedError $e
5cd0: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
5ce0: 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54             showT
5cf0: 65 73 74 20 6a 0d 0a 20 20 20 20 20 20 20 20 20  est j..         
5d00: 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20   } else {..     
5d10: 20 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20         failTest 
5d20: 6a 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20  j $error..      
5d30: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
5d40: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
5d50: 20 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46   cleanupDb $dstF
5d60: 69 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65  ileName db false
5d70: 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20   true false..   
5d80: 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a   }] 0]..  }]....
5d90: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
5da0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5db0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5dc0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5dd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
5de0: 0a 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20  .  #            
5df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e00: 20 20 57 4f 52 4b 4c 4f 41 44 20 23 31 31 20 28    WORKLOAD #11 (
5e10: 4b 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20  K)              
5e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23                 #
5e30: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
5e40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5e50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5e60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5e70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5e80: 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c  #....  set workl
5e90: 6f 61 64 28 31 31 29 20 5b 6c 69 73 74 20 5c 0d  oad(11) [list \.
5ea0: 0a 20 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63  .      [list src
5eb0: 46 69 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65  FileName dstFile
5ec0: 4e 61 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74  Name table count
5ed0: 31 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d  1 count2 count3]
5ee0: 20 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23   {..    #..    #
5ef0: 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20   NOTE: Workload 
5f00: 23 31 31 2c 20 56 41 43 55 55 4d 20 73 74 61 74  #11, VACUUM stat
5f10: 65 6d 65 6e 74 2e 0d 0a 20 20 20 20 23 0d 0a 20  ement...    #.. 
5f20: 20 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69 6d     lappend ::tim
5f30: 65 73 28 31 31 29 20 5b 6c 69 6e 64 65 78 20 5b  es(11) [lindex [
5f40: 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 73 65  time {..      se
5f50: 74 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e 61  tupDb $dstFileNa
5f60: 6d 65 20 22 22 20 22 22 20 22 22 20 22 22 20 22  me "" "" "" "" "
5f70: 22 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20  " true false..  
5f80: 20 20 20 20 66 6f 72 20 7b 73 65 74 20 69 6e 64      for {set ind
5f90: 65 78 20 31 7d 20 7b 24 69 6e 64 65 78 20 3c 3d  ex 1} {$index <=
5fa0: 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e 63 72 20   $count1} {incr 
5fb0: 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20 20 20 20  index} {..      
5fc0: 20 20 69 66 20 7b 5b 63 61 74 63 68 20 7b 0d 0a    if {[catch {..
5fd0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 20 65 78            sql ex
5fe0: 65 63 75 74 65 20 24 64 62 20 22 56 41 43 55 55  ecute $db "VACUU
5ff0: 4d 3b 22 0d 0a 20 20 20 20 20 20 20 20 20 20 73  M;"..          s
6000: 68 6f 77 54 65 73 74 20 4b 0d 0a 20 20 20 20 20  howTest K..     
6010: 20 20 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68 65     } error]} the
6020: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 69  n {..          i
6030: 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45 72  f {[isExpectedEr
6040: 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68 65  ror $error]} the
6050: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n {..           
6060: 20 73 68 6f 77 54 65 73 74 20 6b 0d 0a 20 20 20   showTest k..   
6070: 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d         } else {.
6080: 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61 69  .            fai
6090: 6c 54 65 73 74 20 6b 20 24 65 72 72 6f 72 0d 0a  lTest k $error..
60a0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
60b0: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d       }..      }.
60c0: 0a 20 20 20 20 20 20 63 6c 65 61 6e 75 70 44 62  .      cleanupDb
60d0: 20 24 64 73 74 46 69 6c 65 4e 61 6d 65 20 64 62   $dstFileName db
60e0: 20 66 61 6c 73 65 20 74 72 75 65 20 66 61 6c 73   false true fals
60f0: 65 0d 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a 20 20  e..    }] 0]..  
6100: 7d 5d 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23  }]....  ########
6110: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6120: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6130: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6140: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6150: 23 23 23 23 23 0d 0a 20 20 23 20 20 20 20 20 20  #####..  #      
6160: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6170: 20 20 20 20 20 20 20 20 57 4f 52 4b 4c 4f 41 44          WORKLOAD
6180: 20 23 31 32 20 28 4c 29 20 20 20 20 20 20 20 20   #12 (L)        
6190: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
61a0: 20 20 20 20 20 23 0d 0a 20 20 23 23 23 23 23 23       #..  ######
61b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
61c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
61d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
61e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
61f0: 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 73 65 74  #######....  set
6200: 20 77 6f 72 6b 6c 6f 61 64 28 31 32 29 20 5b 6c   workload(12) [l
6210: 69 73 74 20 5c 0d 0a 20 20 20 20 20 20 5b 6c 69  ist \..      [li
6220: 73 74 20 73 72 63 46 69 6c 65 4e 61 6d 65 20 64  st srcFileName d
6230: 73 74 46 69 6c 65 4e 61 6d 65 20 74 61 62 6c 65  stFileName table
6240: 20 63 6f 75 6e 74 31 20 63 6f 75 6e 74 32 20 63   count1 count2 c
6250: 6f 75 6e 74 33 5d 20 7b 0d 0a 20 20 20 20 23 0d  ount3] {..    #.
6260: 0a 20 20 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72  .    # NOTE: Wor
6270: 6b 6c 6f 61 64 20 23 31 32 2c 20 62 61 63 6b 75  kload #12, backu
6280: 70 20 74 6f 20 69 6e 2d 6d 65 6d 6f 72 79 20 64  p to in-memory d
6290: 61 74 61 62 61 73 65 2e 0d 0a 20 20 20 20 23 0d  atabase...    #.
62a0: 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74  .    lappend ::t
62b0: 69 6d 65 73 28 31 32 29 20 5b 6c 69 6e 64 65 78  imes(12) [lindex
62c0: 20 5b 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20   [time {..      
62d0: 66 6f 72 20 7b 73 65 74 20 69 6e 64 65 78 20 31  for {set index 1
62e0: 7d 20 7b 24 69 6e 64 65 78 20 3c 3d 20 24 63 6f  } {$index <= $co
62f0: 75 6e 74 31 7d 20 7b 69 6e 63 72 20 69 6e 64 65  unt1} {incr inde
6300: 78 7d 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66  x} {..        if
6310: 20 7b 5b 73 74 72 69 6e 67 20 69 73 20 69 6e 74   {[string is int
6320: 65 67 65 72 20 2d 73 74 72 69 63 74 20 24 3a 3a  eger -strict $::
6330: 63 6f 6d 70 69 6c 65 64 28 31 32 29 5d 7d 20 74  compiled(12)]} t
6340: 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20  hen {..         
6350: 20 73 65 74 20 69 64 20 24 3a 3a 63 6f 6d 70 69   set id $::compi
6360: 6c 65 64 28 31 32 29 3b 20 23 20 4e 4f 54 45 3a  led(12); # NOTE:
6370: 20 41 6c 72 65 61 64 79 20 63 6f 6d 70 69 6c 65   Already compile
6380: 64 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66  d...          if
6390: 20 7b 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20 20   {[catch {..    
63a0: 20 20 20 20 20 20 20 20 6f 62 6a 65 63 74 20 69          object i
63b0: 6e 76 6f 6b 65 20 5f 44 79 6e 61 6d 69 63 24 7b  nvoke _Dynamic${
63c0: 69 64 7d 2e 54 65 73 74 24 7b 69 64 7d 20 42 61  id}.Test${id} Ba
63d0: 63 6b 75 70 41 6e 64 47 65 74 44 61 74 61 0d 0a  ckupAndGetData..
63e0: 20 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77              show
63f0: 54 65 73 74 20 4c 0d 0a 20 20 20 20 20 20 20 20  Test L..        
6400: 20 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68 65 6e    } error]} then
6410: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
6420: 69 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45  if {[isExpectedE
6430: 72 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68  rror $error]} th
6440: 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  en {..          
6450: 20 20 20 20 73 68 6f 77 54 65 73 74 20 6c 0d 0a      showTest l..
6460: 20 20 20 20 20 20 20 20 20 20 20 20 7d 20 65 6c              } el
6470: 73 65 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20  se {..          
6480: 20 20 20 20 66 61 69 6c 54 65 73 74 20 6c 20 24      failTest l $
6490: 65 72 72 6f 72 0d 0a 20 20 20 20 20 20 20 20 20  error..         
64a0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
64b0: 7d 0d 0a 20 20 20 20 20 20 20 20 7d 20 65 6c 73  }..        } els
64c0: 65 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73  e {..          s
64d0: 65 74 20 69 64 20 5b 6f 62 6a 65 63 74 20 69 6e  et id [object in
64e0: 76 6f 6b 65 20 49 6e 74 65 72 70 72 65 74 65 72  voke Interpreter
64f0: 2e 47 65 74 41 63 74 69 76 65 20 4e 65 78 74 49  .GetActive NextI
6500: 64 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 73 65  d]..          se
6510: 74 20 63 6f 64 65 20 5b 63 6f 6d 70 69 6c 65 43  t code [compileC
6520: 53 68 61 72 70 57 69 74 68 20 5b 73 75 62 73 74  SharpWith [subst
6530: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
6540: 75 73 69 6e 67 20 53 79 73 74 65 6d 3b 0d 0a 20  using System;.. 
6550: 20 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67             using
6560: 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c   System.Data.SQL
6570: 69 74 65 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  ite;..          
6580: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 54    using System.T
6590: 65 78 74 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ext;....        
65a0: 20 20 20 20 6e 61 6d 65 73 70 61 63 65 20 5f 44      namespace _D
65b0: 79 6e 61 6d 69 63 24 7b 69 64 7d 0d 0a 20 20 20  ynamic${id}..   
65c0: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
65d0: 20 20 20 20 20 20 20 20 20 20 70 75 62 6c 69 63            public
65e0: 20 73 74 61 74 69 63 20 63 6c 61 73 73 20 54 65   static class Te
65f0: 73 74 24 7b 69 64 7d 0d 0a 20 20 20 20 20 20 20  st${id}..       
6600: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
6610: 20 20 20 20 20 20 20 20 20 20 70 75 62 6c 69 63            public
6620: 20 73 74 61 74 69 63 20 76 6f 69 64 20 42 61 63   static void Bac
6630: 6b 75 70 41 6e 64 47 65 74 44 61 74 61 28 29 0d  kupAndGetData().
6640: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6650: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
6660: 20 20 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c        using (SQL
6670: 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 73 6f  iteConnection so
6680: 75 72 63 65 20 3d 20 6e 65 77 20 53 51 4c 69 74  urce = new SQLit
6690: 65 43 6f 6e 6e 65 63 74 69 6f 6e 28 0d 0a 20 20  eConnection(..  
66a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
66b0: 20 20 20 20 22 46 75 6c 6c 55 72 69 3d 24 7b 64      "FullUri=${d
66c0: 73 74 46 69 6c 65 4e 61 6d 65 7d 3b 22 29 29 0d  stFileName};")).
66d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
66e0: 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20     {..          
66f0: 20 20 20 20 20 20 20 20 20 20 73 6f 75 72 63 65            source
6700: 2e 4f 70 65 6e 28 29 3b 0d 0a 20 20 20 20 20 20  .Open();..      
6710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 75 73                us
6720: 69 6e 67 20 28 53 51 4c 69 74 65 43 6f 6e 6e 65  ing (SQLiteConne
6730: 63 74 69 6f 6e 20 64 65 73 74 69 6e 61 74 69 6f  ction destinatio
6740: 6e 20 3d 20 6e 65 77 20 53 51 4c 69 74 65 43 6f  n = new SQLiteCo
6750: 6e 6e 65 63 74 69 6f 6e 28 0d 0a 20 20 20 20 20  nnection(..     
6760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6770: 20 20 20 22 46 75 6c 6c 55 72 69 3d 24 7b 73 72     "FullUri=${sr
6780: 63 46 69 6c 65 4e 61 6d 65 7d 3b 22 29 29 0d 0a  cFileName};"))..
6790: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
67a0: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
67b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 64 65 73               des
67c0: 74 69 6e 61 74 69 6f 6e 2e 4f 70 65 6e 28 29 3b  tination.Open();
67d0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  ....            
67e0: 20 20 20 20 20 20 20 20 20 20 73 6f 75 72 63 65            source
67f0: 2e 42 61 63 6b 75 70 44 61 74 61 62 61 73 65 28  .BackupDatabase(
6800: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6810: 20 20 20 20 20 20 20 20 20 20 20 20 64 65 73 74              dest
6820: 69 6e 61 74 69 6f 6e 2c 20 22 6d 61 69 6e 22 2c  ination, "main",
6830: 20 22 6d 61 69 6e 22 2c 20 2d 31 2c 20 6e 75 6c   "main", -1, nul
6840: 6c 2c 20 30 29 3b 0d 0a 20 20 20 20 20 20 20 20  l, 0);..        
6850: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
6860: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6870: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
6880: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20      }....       
6890: 20 20 20 20 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f           ///////
68a0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
68b0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
68c0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
68d0: 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a 20 20 20 20  ////////....    
68e0: 20 20 20 20 20 20 20 20 20 20 20 20 70 75 62 6c              publ
68f0: 69 63 20 73 74 61 74 69 63 20 76 6f 69 64 20 4d  ic static void M
6900: 61 69 6e 28 29 0d 0a 20 20 20 20 20 20 20 20 20  ain()..         
6910: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
6920: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 64              // d
6930: 6f 20 6e 6f 74 68 69 6e 67 2e 0d 0a 20 20 20 20  o nothing...    
6940: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
6950: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a               }..
6960: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20              }.. 
6970: 20 20 20 20 20 20 20 20 20 7d 5d 20 74 72 75 65           }] true
6980: 20 74 72 75 65 20 74 72 75 65 20 72 65 73 75 6c   true true resul
6990: 74 73 20 65 72 72 6f 72 73 20 53 79 73 74 65 6d  ts errors System
69a0: 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e 64 6c 6c  .Data.SQLite.dll
69b0: 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20  ]..          if 
69c0: 7b 24 63 6f 64 65 20 65 71 20 22 4f 6b 22 7d 20  {$code eq "Ok"} 
69d0: 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20  then {..        
69e0: 20 20 20 20 73 65 74 20 3a 3a 63 6f 6d 70 69 6c      set ::compil
69f0: 65 64 28 31 32 29 20 24 69 64 3b 20 23 20 4e 4f  ed(12) $id; # NO
6a00: 54 45 3a 20 43 6f 6d 70 69 6c 65 64 20 4f 4b 2e  TE: Compiled OK.
6a10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66  ..            if
6a20: 20 7b 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20 20   {[catch {..    
6a30: 20 20 20 20 20 20 20 20 20 20 6f 62 6a 65 63 74            object
6a40: 20 69 6e 76 6f 6b 65 20 5f 44 79 6e 61 6d 69 63   invoke _Dynamic
6a50: 24 7b 69 64 7d 2e 54 65 73 74 24 7b 69 64 7d 20  ${id}.Test${id} 
6a60: 42 61 63 6b 75 70 41 6e 64 47 65 74 44 61 74 61  BackupAndGetData
6a70: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6a80: 73 68 6f 77 54 65 73 74 20 4c 0d 0a 20 20 20 20  showTest L..    
6a90: 20 20 20 20 20 20 20 20 7d 20 65 72 72 6f 72 5d          } error]
6aa0: 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20  } then {..      
6ab0: 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73 45          if {[isE
6ac0: 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65 72  xpectedError $er
6ad0: 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  ror]} then {..  
6ae0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73 68                sh
6af0: 6f 77 54 65 73 74 20 6c 0d 0a 20 20 20 20 20 20  owTest l..      
6b00: 20 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b          } else {
6b10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
6b20: 20 20 66 61 69 6c 54 65 73 74 20 6c 20 24 65 72    failTest l $er
6b30: 72 6f 72 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ror..           
6b40: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
6b50: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 7d    }..          }
6b60: 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20 20   else {..       
6b70: 20 20 20 20 20 65 72 72 6f 72 20 24 65 72 72 6f       error $erro
6b80: 72 73 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d  rs..          }.
6b90: 0a 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  .        }..    
6ba0: 20 20 7d 0d 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a    }..    }] 0]..
6bb0: 20 20 7d 5d 0d 0a 0d 0a 20 20 23 23 23 23 23 23    }]....  ######
6bc0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6bd0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6be0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6bf0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6c00: 23 23 23 23 23 23 23 0d 0a 20 20 23 20 20 20 20  #######..  #    
6c10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6c20: 20 20 20 20 20 20 20 20 20 20 57 4f 52 4b 4c 4f            WORKLO
6c30: 41 44 20 23 31 33 20 28 4d 29 20 20 20 20 20 20  AD #13 (M)      
6c40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6c50: 20 20 20 20 20 20 20 23 0d 0a 20 20 23 23 23 23         #..  ####
6c60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6c70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6c80: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6c90: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
6ca0: 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 73  #########....  s
6cb0: 65 74 20 77 6f 72 6b 6c 6f 61 64 28 31 33 29 20  et workload(13) 
6cc0: 5b 6c 69 73 74 20 5c 0d 0a 20 20 20 20 20 20 5b  [list \..      [
6cd0: 6c 69 73 74 20 73 72 63 46 69 6c 65 4e 61 6d 65  list srcFileName
6ce0: 20 64 73 74 46 69 6c 65 4e 61 6d 65 20 74 61 62   dstFileName tab
6cf0: 6c 65 20 63 6f 75 6e 74 31 20 63 6f 75 6e 74 32  le count1 count2
6d00: 20 63 6f 75 6e 74 33 5d 20 7b 0d 0a 20 20 20 20   count3] {..    
6d10: 23 0d 0a 20 20 20 20 23 20 4e 4f 54 45 3a 20 57  #..    # NOTE: W
6d20: 6f 72 6b 6c 6f 61 64 20 23 31 33 2c 20 62 61 63  orkload #13, bac
6d30: 6b 75 70 20 66 72 6f 6d 20 61 6e 20 69 6e 2d 6d  kup from an in-m
6d40: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 2e 0d  emory database..
6d50: 0a 20 20 20 20 23 0d 0a 20 20 20 20 6c 61 70 70  .    #..    lapp
6d60: 65 6e 64 20 3a 3a 74 69 6d 65 73 28 31 33 29 20  end ::times(13) 
6d70: 5b 6c 69 6e 64 65 78 20 5b 74 69 6d 65 20 7b 0d  [lindex [time {.
6d80: 0a 20 20 20 20 20 20 66 6f 72 20 7b 73 65 74 20  .      for {set 
6d90: 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e 64 65 78  index 1} {$index
6da0: 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e   <= $count1} {in
6db0: 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20  cr index} {..   
6dc0: 20 20 20 20 20 69 66 20 7b 5b 73 74 72 69 6e 67       if {[string
6dd0: 20 69 73 20 69 6e 74 65 67 65 72 20 2d 73 74 72   is integer -str
6de0: 69 63 74 20 24 3a 3a 63 6f 6d 70 69 6c 65 64 28  ict $::compiled(
6df0: 31 33 29 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  13)]} then {..  
6e00: 20 20 20 20 20 20 20 20 73 65 74 20 69 64 20 24          set id $
6e10: 3a 3a 63 6f 6d 70 69 6c 65 64 28 31 33 29 3b 20  ::compiled(13); 
6e20: 23 20 4e 4f 54 45 3a 20 41 6c 72 65 61 64 79 20  # NOTE: Already 
6e30: 63 6f 6d 70 69 6c 65 64 2e 0d 0a 20 20 20 20 20  compiled...     
6e40: 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63 68 20       if {[catch 
6e50: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 6f  {..            o
6e60: 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20 5f 44 79  bject invoke _Dy
6e70: 6e 61 6d 69 63 24 7b 69 64 7d 2e 54 65 73 74 24  namic${id}.Test$
6e80: 7b 69 64 7d 20 42 61 63 6b 75 70 41 6e 64 47 65  {id} BackupAndGe
6e90: 74 44 61 74 61 0d 0a 20 20 20 20 20 20 20 20 20  tData..         
6ea0: 20 20 20 73 68 6f 77 54 65 73 74 20 4d 0d 0a 20     showTest M.. 
6eb0: 20 20 20 20 20 20 20 20 20 7d 20 65 72 72 6f 72           } error
6ec0: 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20  ]} then {..     
6ed0: 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73 45 78         if {[isEx
6ee0: 70 65 63 74 65 64 45 72 72 6f 72 20 24 65 72 72  pectedError $err
6ef0: 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20  or]} then {..   
6f00: 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54             showT
6f10: 65 73 74 20 6d 0d 0a 20 20 20 20 20 20 20 20 20  est m..         
6f20: 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20     } else {..   
6f30: 20 20 20 20 20 20 20 20 20 20 20 66 61 69 6c 54             failT
6f40: 65 73 74 20 6d 20 24 65 72 72 6f 72 0d 0a 20 20  est m $error..  
6f50: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
6f60: 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20         }..      
6f70: 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20    } else {..    
6f80: 20 20 20 20 20 20 73 65 74 20 69 64 20 5b 6f 62        set id [ob
6f90: 6a 65 63 74 20 69 6e 76 6f 6b 65 20 49 6e 74 65  ject invoke Inte
6fa0: 72 70 72 65 74 65 72 2e 47 65 74 41 63 74 69 76  rpreter.GetActiv
6fb0: 65 20 4e 65 78 74 49 64 5d 0d 0a 20 20 20 20 20  e NextId]..     
6fc0: 20 20 20 20 20 73 65 74 20 63 6f 64 65 20 5b 63       set code [c
6fd0: 6f 6d 70 69 6c 65 43 53 68 61 72 70 57 69 74 68  ompileCSharpWith
6fe0: 20 5b 73 75 62 73 74 20 7b 0d 0a 20 20 20 20 20   [subst {..     
6ff0: 20 20 20 20 20 20 20 75 73 69 6e 67 20 53 79 73         using Sys
7000: 74 65 6d 3b 0d 0a 20 20 20 20 20 20 20 20 20 20  tem;..          
7010: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44    using System.D
7020: 61 74 61 2e 53 51 4c 69 74 65 3b 0d 0a 20 20 20  ata.SQLite;..   
7030: 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 53           using S
7040: 79 73 74 65 6d 2e 54 65 78 74 3b 0d 0a 0d 0a 20  ystem.Text;.... 
7050: 20 20 20 20 20 20 20 20 20 20 20 6e 61 6d 65 73             names
7060: 70 61 63 65 20 5f 44 79 6e 61 6d 69 63 24 7b 69  pace _Dynamic${i
7070: 64 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  d}..            
7080: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
7090: 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20 63   public static c
70a0: 6c 61 73 73 20 54 65 73 74 24 7b 69 64 7d 0d 0a  lass Test${id}..
70b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
70c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
70d0: 20 70 75 62 6c 69 63 20 73 74 61 74 69 63 20 76   public static v
70e0: 6f 69 64 20 42 61 63 6b 75 70 41 6e 64 47 65 74  oid BackupAndGet
70f0: 44 61 74 61 28 29 0d 0a 20 20 20 20 20 20 20 20  Data()..        
7100: 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20          {..     
7110: 20 20 20 20 20 20 20 20 20 20 20 20 20 75 73 69               usi
7120: 6e 67 20 28 53 51 4c 69 74 65 43 6f 6e 6e 65 63  ng (SQLiteConnec
7130: 74 69 6f 6e 20 73 6f 75 72 63 65 20 3d 20 6e 65  tion source = ne
7140: 77 20 53 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69  w SQLiteConnecti
7150: 6f 6e 28 0d 0a 20 20 20 20 20 20 20 20 20 20 20  on(..           
7160: 20 20 20 20 20 20 20 20 20 20 20 22 46 75 6c 6c             "Full
7170: 55 72 69 3d 24 7b 73 72 63 46 69 6c 65 4e 61 6d  Uri=${srcFileNam
7180: 65 7d 3b 22 29 29 0d 0a 20 20 20 20 20 20 20 20  e};"))..        
7190: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
71a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
71b0: 20 73 6f 75 72 63 65 2e 4f 70 65 6e 28 29 3b 0d   source.Open();.
71c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
71d0: 20 20 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69       using (SQLi
71e0: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 20 64 65 73  teConnection des
71f0: 74 69 6e 61 74 69 6f 6e 20 3d 20 6e 65 77 20 53  tination = new S
7200: 51 4c 69 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 28  QLiteConnection(
7210: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
7220: 20 20 20 20 20 20 20 20 20 20 22 46 75 6c 6c 55            "FullU
7230: 72 69 3d 24 7b 64 73 74 46 69 6c 65 4e 61 6d 65  ri=${dstFileName
7240: 7d 3b 22 29 29 0d 0a 20 20 20 20 20 20 20 20 20  };"))..         
7250: 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20             {..  
7260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7270: 20 20 20 20 64 65 73 74 69 6e 61 74 69 6f 6e 2e      destination.
7280: 4f 70 65 6e 28 29 3b 0d 0a 0d 0a 20 20 20 20 20  Open();....     
7290: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
72a0: 20 73 6f 75 72 63 65 2e 42 61 63 6b 75 70 44 61   source.BackupDa
72b0: 74 61 62 61 73 65 28 0d 0a 20 20 20 20 20 20 20  tabase(..       
72c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
72d0: 20 20 20 64 65 73 74 69 6e 61 74 69 6f 6e 2c 20     destination, 
72e0: 22 6d 61 69 6e 22 2c 20 22 6d 61 69 6e 22 2c 20  "main", "main", 
72f0: 2d 31 2c 20 6e 75 6c 6c 2c 20 30 29 3b 0d 0a 20  -1, null, 0);.. 
7300: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7310: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
7320: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
7330: 20 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a             }....
7340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7350: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7360: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7370: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
7380: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d  ///////////////.
7390: 0a 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
73a0: 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69 63     public static
73b0: 20 76 6f 69 64 20 4d 61 69 6e 28 29 0d 0a 20 20   void Main()..  
73c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d                {.
73d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
73e0: 20 20 20 2f 2f 20 64 6f 20 6e 6f 74 68 69 6e 67     // do nothing
73f0: 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ...             
7400: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
7410: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20      }..         
7420: 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20     }..          
7430: 7d 5d 20 74 72 75 65 20 74 72 75 65 20 74 72 75  }] true true tru
7440: 65 20 72 65 73 75 6c 74 73 20 65 72 72 6f 72 73  e results errors
7450: 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c   System.Data.SQL
7460: 69 74 65 2e 64 6c 6c 5d 0d 0a 20 20 20 20 20 20  ite.dll]..      
7470: 20 20 20 20 69 66 20 7b 24 63 6f 64 65 20 65 71      if {$code eq
7480: 20 22 4f 6b 22 7d 20 74 68 65 6e 20 7b 0d 0a 20   "Ok"} then {.. 
7490: 20 20 20 20 20 20 20 20 20 20 20 73 65 74 20 3a             set :
74a0: 3a 63 6f 6d 70 69 6c 65 64 28 31 33 29 20 24 69  :compiled(13) $i
74b0: 64 3b 20 23 20 4e 4f 54 45 3a 20 43 6f 6d 70 69  d; # NOTE: Compi
74c0: 6c 65 64 20 4f 4b 2e 0d 0a 20 20 20 20 20 20 20  led OK...       
74d0: 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63 68 20       if {[catch 
74e0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
74f0: 20 6f 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20 5f   object invoke _
7500: 44 79 6e 61 6d 69 63 24 7b 69 64 7d 2e 54 65 73  Dynamic${id}.Tes
7510: 74 24 7b 69 64 7d 20 42 61 63 6b 75 70 41 6e 64  t${id} BackupAnd
7520: 47 65 74 44 61 74 61 0d 0a 20 20 20 20 20 20 20  GetData..       
7530: 20 20 20 20 20 20 20 73 68 6f 77 54 65 73 74 20         showTest 
7540: 4d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  M..            }
7550: 20 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d   error]} then {.
7560: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69  .              i
7570: 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45 72  f {[isExpectedEr
7580: 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68 65  ror $error]} the
7590: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n {..           
75a0: 20 20 20 20 20 73 68 6f 77 54 65 73 74 20 6d 0d       showTest m.
75b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d  .              }
75c0: 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20 20   else {..       
75d0: 20 20 20 20 20 20 20 20 20 66 61 69 6c 54 65 73           failTes
75e0: 74 20 6d 20 24 65 72 72 6f 72 0d 0a 20 20 20 20  t m $error..    
75f0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
7600: 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20           }..    
7610: 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a        } else {..
7620: 20 20 20 20 20 20 20 20 20 20 20 20 65 72 72 6f              erro
7630: 72 20 24 65 72 72 6f 72 73 0d 0a 20 20 20 20 20  r $errors..     
7640: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20       }..        
7650: 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  }..      }..    
7660: 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a 20  }] 0]..  }].... 
7670: 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23   ###############
7680: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7690: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
76a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
76b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a  ##############..
76c0: 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20 20    #             
76d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
76e0: 20 57 4f 52 4b 4c 4f 41 44 20 23 31 34 20 28 4e   WORKLOAD #14 (N
76f0: 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  )               
7700: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23 0d                #.
7710: 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23  .  #############
7720: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7730: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7740: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7750: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7760: 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c 6f  ....  set worklo
7770: 61 64 28 31 34 29 20 5b 6c 69 73 74 20 5c 0d 0a  ad(14) [list \..
7780: 20 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63 46        [list srcF
7790: 69 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65 4e  ileName dstFileN
77a0: 61 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74 31  ame table count1
77b0: 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d 20   count2 count3] 
77c0: 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23 20  {..    #..    # 
77d0: 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23  NOTE: Workload #
77e0: 31 34 2c 20 50 52 41 47 4d 41 20 69 6e 74 65 67  14, PRAGMA integ
77f0: 72 69 74 79 20 63 68 65 63 6b 20 73 74 61 74 65  rity check state
7800: 6d 65 6e 74 2e 0d 0a 20 20 20 20 23 0d 0a 20 20  ment...    #..  
7810: 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69 6d 65    lappend ::time
7820: 73 28 31 34 29 20 5b 6c 69 6e 64 65 78 20 5b 74  s(14) [lindex [t
7830: 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 73 65 74  ime {..      set
7840: 75 70 44 62 20 24 64 73 74 46 69 6c 65 4e 61 6d  upDb $dstFileNam
7850: 65 20 22 22 20 22 22 20 22 22 20 22 22 20 22 22  e "" "" "" "" ""
7860: 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20   true false..   
7870: 20 20 20 66 6f 72 20 7b 73 65 74 20 69 6e 64 65     for {set inde
7880: 78 20 31 7d 20 7b 24 69 6e 64 65 78 20 3c 3d 20  x 1} {$index <= 
7890: 24 63 6f 75 6e 74 31 7d 20 7b 69 6e 63 72 20 69  $count1} {incr i
78a0: 6e 64 65 78 7d 20 7b 0d 0a 20 20 20 20 20 20 20  ndex} {..       
78b0: 20 69 66 20 7b 5b 63 61 74 63 68 20 7b 0d 0a 20   if {[catch {.. 
78c0: 20 20 20 20 20 20 20 20 20 73 65 74 20 72 65 73           set res
78d0: 75 6c 74 20 5b 73 71 6c 20 65 78 65 63 75 74 65  ult [sql execute
78e0: 20 2d 65 78 65 63 75 74 65 20 73 63 61 6c 61 72   -execute scalar
78f0: 20 24 64 62 20 5c 0d 0a 20 20 20 20 20 20 20 20   $db \..        
7900: 20 20 20 20 20 20 22 50 52 41 47 4d 41 20 69 6e        "PRAGMA in
7910: 74 65 67 72 69 74 79 5f 63 68 65 63 6b 3b 22 5d  tegrity_check;"]
7920: 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 7b  ..          if {
7930: 24 72 65 73 75 6c 74 20 65 71 20 22 6f 6b 22 7d  $result eq "ok"}
7940: 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20 20 20   then {..       
7950: 20 20 20 20 20 73 68 6f 77 54 65 73 74 20 4e 0d       showTest N.
7960: 0a 20 20 20 20 20 20 20 20 20 20 7d 20 65 6c 73  .          } els
7970: 65 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  e {..           
7980: 20 65 72 72 6f 72 20 5b 61 70 70 65 6e 64 41 72   error [appendAr
7990: 67 73 20 22 69 6e 74 65 67 72 69 74 79 20 63 68  gs "integrity ch
79a0: 65 63 6b 20 66 61 69 6c 65 64 3a 20 22 20 24 72  eck failed: " $r
79b0: 65 73 75 6c 74 5d 0d 0a 20 20 20 20 20 20 20 20  esult]..        
79c0: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d 20 65    }..        } e
79d0: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
79e0: 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b 69 73           if {[is
79f0: 45 78 70 65 63 74 65 64 45 72 72 6f 72 20 24 65  ExpectedError $e
7a00: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
7a10: 20 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54             showT
7a20: 65 73 74 20 6e 0d 0a 20 20 20 20 20 20 20 20 20  est n..         
7a30: 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20   } else {..     
7a40: 20 20 20 20 20 20 20 66 61 69 6c 54 65 73 74 20         failTest 
7a50: 6e 20 24 65 72 72 6f 72 0d 0a 20 20 20 20 20 20  n $error..      
7a60: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 7d      }..        }
7a70: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20  ..      }..     
7a80: 20 63 6c 65 61 6e 75 70 44 62 20 24 64 73 74 46   cleanupDb $dstF
7a90: 69 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c 73 65  ileName db false
7aa0: 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20 20 20   true false..   
7ab0: 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a 0d 0a   }] 0]..  }]....
7ac0: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
7ad0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7ae0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7af0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7b00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
7b10: 0a 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20  .  #            
7b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7b30: 20 20 57 4f 52 4b 4c 4f 41 44 20 23 31 35 20 28    WORKLOAD #15 (
7b40: 4f 29 20 20 20 20 20 20 20 20 20 20 20 20 20 20  O)              
7b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 23                 #
7b60: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
7b70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7b80: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7b90: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7ba0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7bb0: 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72 6b 6c  #....  set workl
7bc0: 6f 61 64 28 31 35 29 20 5b 6c 69 73 74 20 5c 0d  oad(15) [list \.
7bd0: 0a 20 20 20 20 20 20 5b 6c 69 73 74 20 73 72 63  .      [list src
7be0: 46 69 6c 65 4e 61 6d 65 20 64 73 74 46 69 6c 65  FileName dstFile
7bf0: 4e 61 6d 65 20 74 61 62 6c 65 20 63 6f 75 6e 74  Name table count
7c00: 31 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74 33 5d  1 count2 count3]
7c10: 20 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 23   {..    #..    #
7c20: 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20   NOTE: Workload 
7c30: 23 31 35 2c 20 66 6f 72 63 65 20 6d 61 6e 61 67  #15, force manag
7c40: 65 64 20 67 61 72 62 61 67 65 20 63 6f 6c 6c 65  ed garbage colle
7c50: 63 74 69 6f 6e 0d 0a 20 20 20 20 23 0d 0a 20 20  ction..    #..  
7c60: 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69 6d 65    lappend ::time
7c70: 73 28 31 35 29 20 5b 6c 69 6e 64 65 78 20 5b 74  s(15) [lindex [t
7c80: 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 66 6f 72  ime {..      for
7c90: 20 7b 73 65 74 20 69 6e 64 65 78 20 31 7d 20 7b   {set index 1} {
7ca0: 24 69 6e 64 65 78 20 3c 3d 20 24 63 6f 75 6e 74  $index <= $count
7cb0: 31 7d 20 7b 69 6e 63 72 20 69 6e 64 65 78 7d 20  1} {incr index} 
7cc0: 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 7b 5b  {..        if {[
7cd0: 63 61 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 20  catch {..       
7ce0: 20 20 20 63 6f 6c 6c 65 63 74 47 61 72 62 61 67     collectGarbag
7cf0: 65 20 24 3a 3a 74 65 73 74 5f 63 68 61 6e 6e 65  e $::test_channe
7d00: 6c 0d 0a 20 20 20 20 20 20 20 20 20 20 73 68 6f  l..          sho
7d10: 77 54 65 73 74 20 4f 0d 0a 20 20 20 20 20 20 20  wTest O..       
7d20: 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20   } error]} then 
7d30: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 69 66 20  {..          if 
7d40: 7b 5b 69 73 45 78 70 65 63 74 65 64 45 72 72 6f  {[isExpectedErro
7d50: 72 20 24 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20  r $error]} then 
7d60: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 73  {..            s
7d70: 68 6f 77 54 65 73 74 20 6f 0d 0a 20 20 20 20 20  howTest o..     
7d80: 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20       } else {.. 
7d90: 20 20 20 20 20 20 20 20 20 20 20 66 61 69 6c 54             failT
7da0: 65 73 74 20 6f 20 24 65 72 72 6f 72 0d 0a 20 20  est o $error..  
7db0: 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20          }..     
7dc0: 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20     }..      }.. 
7dd0: 20 20 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a     }] 0]..  }]..
7de0: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
7df0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7e00: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7e10: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7e20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7e30: 23 0d 0a 20 20 23 20 20 20 20 20 20 20 20 20 20  #..  #          
7e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7e50: 20 20 20 20 57 4f 52 4b 4c 4f 41 44 20 23 31 36      WORKLOAD #16
7e60: 20 28 50 29 20 20 20 20 20 20 20 20 20 20 20 20   (P)            
7e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7e80: 20 23 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23   #..  ##########
7e90: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7ea0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7eb0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7ec0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
7ed0: 23 23 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72  ###....  set wor
7ee0: 6b 6c 6f 61 64 28 31 36 29 20 5b 6c 69 73 74 20  kload(16) [list 
7ef0: 5c 0d 0a 20 20 20 20 20 20 5b 6c 69 73 74 20 73  \..      [list s
7f00: 72 63 46 69 6c 65 4e 61 6d 65 20 64 73 74 46 69  rcFileName dstFi
7f10: 6c 65 4e 61 6d 65 20 74 61 62 6c 65 20 63 6f 75  leName table cou
7f20: 6e 74 31 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74  nt1 count2 count
7f30: 33 5d 20 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20  3] {..    #..   
7f40: 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61   # NOTE: Workloa
7f50: 64 20 23 31 36 2c 20 61 6c 6c 6f 63 61 74 65 20  d #16, allocate 
7f60: 28 65 78 63 6c 75 64 65 29 20 73 6f 6d 65 20 6e  (exclude) some n
7f70: 61 74 69 76 65 20 68 65 61 70 20 6d 65 6d 6f 72  ative heap memor
7f80: 79 0d 0a 20 20 20 20 23 0d 0a 20 20 20 20 6c 61  y..    #..    la
7f90: 70 70 65 6e 64 20 3a 3a 74 69 6d 65 73 28 31 36  ppend ::times(16
7fa0: 29 20 5b 6c 69 6e 64 65 78 20 5b 74 69 6d 65 20  ) [lindex [time 
7fb0: 7b 0d 0a 20 20 20 20 20 20 73 65 74 20 6d 61 78  {..      set max
7fc0: 53 69 7a 65 20 24 3a 3a 63 6f 75 6e 74 28 35 29  Size $::count(5)
7fd0: 0d 0a 20 20 20 20 20 20 6f 62 6a 65 63 74 20 69  ..      object i
7fe0: 6e 76 6f 6b 65 20 47 43 20 41 64 64 4d 65 6d 6f  nvoke GC AddMemo
7ff0: 72 79 50 72 65 73 73 75 72 65 20 24 6d 61 78 53  ryPressure $maxS
8000: 69 7a 65 0d 0a 20 20 20 20 20 20 74 72 79 20 7b  ize..      try {
8010: 0d 0a 20 20 20 20 20 20 20 20 66 6f 72 20 7b 73  ..        for {s
8020: 65 74 20 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e  et index 1} {$in
8030: 64 65 78 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20  dex <= $count1} 
8040: 7b 69 6e 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a  {incr index} {..
8050: 20 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b 63            if {[c
8060: 61 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20  atch {..        
8070: 20 20 20 20 73 65 74 20 73 69 7a 65 20 5b 65 78      set size [ex
8080: 70 72 20 7b 69 6e 74 28 6d 69 6e 28 24 6d 61 78  pr {int(min($max
8090: 53 69 7a 65 2c 20 61 62 73 28 24 63 6f 75 6e 74  Size, abs($count
80a0: 33 20 2a 20 24 69 6e 64 65 78 20 2a 20 35 2e 30  3 * $index * 5.0
80b0: 29 29 29 7d 5d 0d 0a 20 20 20 20 20 20 20 20 20  )))}]..         
80c0: 20 20 20 73 65 74 20 70 74 72 20 5b 61 6c 6c 6f     set ptr [allo
80d0: 63 4d 65 6d 20 24 73 69 7a 65 5d 3b 20 23 20 74  cMem $size]; # t
80e0: 68 72 6f 77 0d 0a 20 20 20 20 20 20 20 20 20 20  hrow..          
80f0: 20 20 75 73 65 4d 65 6d 20 24 70 74 72 20 24 73    useMem $ptr $s
8100: 69 7a 65 3b 20 77 61 69 74 46 6f 72 54 65 73 74  ize; waitForTest
8110: 20 24 63 6f 75 6e 74 32 0d 0a 20 20 20 20 20 20   $count2..      
8120: 20 20 20 20 20 20 66 72 65 65 4d 65 6d 20 24 70        freeMem $p
8130: 74 72 3b 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d  tr; unset -nocom
8140: 70 6c 61 69 6e 20 70 74 72 0d 0a 20 20 20 20 20  plain ptr..     
8150: 20 20 20 20 20 20 20 73 68 6f 77 54 65 73 74 20         showTest 
8160: 50 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 20 65  P..          } e
8170: 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  rror]} then {.. 
8180: 20 20 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b             if {[
8190: 69 73 45 78 70 65 63 74 65 64 45 72 72 6f 72 20  isExpectedError 
81a0: 24 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d  $error]} then {.
81b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73  .              s
81c0: 68 6f 77 54 65 73 74 20 70 0d 0a 20 20 20 20 20  howTest p..     
81d0: 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d         } else {.
81e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 66  .              f
81f0: 61 69 6c 54 65 73 74 20 70 20 24 65 72 72 6f 72  ailTest p $error
8200: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d 0d  ..            }.
8210: 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20  .          }..  
8220: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d        }..      }
8230: 20 66 69 6e 61 6c 6c 79 20 7b 0d 0a 20 20 20 20   finally {..    
8240: 20 20 20 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78      if {[info ex
8250: 69 73 74 73 20 70 74 72 5d 7d 20 74 68 65 6e 20  ists ptr]} then 
8260: 7b 66 72 65 65 4d 65 6d 20 24 70 74 72 7d 0d 0a  {freeMem $ptr}..
8270: 20 20 20 20 20 20 20 20 6f 62 6a 65 63 74 20 69          object i
8280: 6e 76 6f 6b 65 20 47 43 20 52 65 6d 6f 76 65 4d  nvoke GC RemoveM
8290: 65 6d 6f 72 79 50 72 65 73 73 75 72 65 20 24 6d  emoryPressure $m
82a0: 61 78 53 69 7a 65 0d 0a 20 20 20 20 20 20 7d 0d  axSize..      }.
82b0: 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d  .    }] 0]..  }]
82c0: 0d 0a 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23  ....  ##########
82d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
82e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
82f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8300: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8310: 23 23 23 0d 0a 20 20 23 20 20 20 20 20 20 20 20  ###..  #        
8320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8330: 20 20 20 20 20 20 57 4f 52 4b 4c 4f 41 44 20 23        WORKLOAD #
8340: 31 37 20 28 51 29 20 20 20 20 20 20 20 20 20 20  17 (Q)          
8350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8360: 20 20 20 23 0d 0a 20 20 23 23 23 23 23 23 23 23     #..  ########
8370: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8380: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8390: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
83a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
83b0: 23 23 23 23 23 0d 0a 0d 0a 20 20 73 65 74 20 77  #####....  set w
83c0: 6f 72 6b 6c 6f 61 64 28 31 37 29 20 5b 6c 69 73  orkload(17) [lis
83d0: 74 20 5c 0d 0a 20 20 20 20 20 20 5b 6c 69 73 74  t \..      [list
83e0: 20 73 72 63 46 69 6c 65 4e 61 6d 65 20 64 73 74   srcFileName dst
83f0: 46 69 6c 65 4e 61 6d 65 20 74 61 62 6c 65 20 63  FileName table c
8400: 6f 75 6e 74 31 20 63 6f 75 6e 74 32 20 63 6f 75  ount1 count2 cou
8410: 6e 74 33 5d 20 7b 0d 0a 20 20 20 20 23 0d 0a 20  nt3] {..    #.. 
8420: 20 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c     # NOTE: Workl
8430: 6f 61 64 20 23 31 37 2c 20 63 68 61 6e 67 65 20  oad #17, change 
8440: 74 68 65 20 64 61 74 61 62 61 73 65 20 6a 6f 75  the database jou
8450: 72 6e 61 6c 20 6d 6f 64 65 0d 0a 20 20 20 20 23  rnal mode..    #
8460: 0d 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 3a 3a  ..    lappend ::
8470: 74 69 6d 65 73 28 31 37 29 20 5b 6c 69 6e 64 65  times(17) [linde
8480: 78 20 5b 74 69 6d 65 20 7b 0d 0a 20 20 20 20 20  x [time {..     
8490: 20 73 65 74 75 70 44 62 20 24 64 73 74 46 69 6c   setupDb $dstFil
84a0: 65 4e 61 6d 65 20 22 22 20 22 22 20 22 22 20 22  eName "" "" "" "
84b0: 22 20 22 22 20 74 72 75 65 20 66 61 6c 73 65 0d  " "" true false.
84c0: 0a 20 20 20 20 20 20 66 6f 72 20 7b 73 65 74 20  .      for {set 
84d0: 69 6e 64 65 78 20 31 7d 20 7b 24 69 6e 64 65 78  index 1} {$index
84e0: 20 3c 3d 20 24 63 6f 75 6e 74 31 7d 20 7b 69 6e   <= $count1} {in
84f0: 63 72 20 69 6e 64 65 78 7d 20 7b 0d 0a 20 20 20  cr index} {..   
8500: 20 20 20 20 20 69 66 20 7b 5b 63 61 74 63 68 20       if {[catch 
8510: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 73 65 74  {..          set
8520: 20 6d 6f 64 65 20 5b 65 78 70 72 20 7b 24 69 6e   mode [expr {$in
8530: 64 65 78 20 25 20 32 20 3d 3d 20 30 20 3f 20 22  dex % 2 == 0 ? "
8540: 64 65 6c 65 74 65 22 20 3a 20 22 77 61 6c 22 7d  delete" : "wal"}
8550: 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  ]..          sql
8560: 20 65 78 65 63 75 74 65 20 24 64 62 20 5b 61 70   execute $db [ap
8570: 70 65 6e 64 41 72 67 73 20 22 50 52 41 47 4d 41  pendArgs "PRAGMA
8580: 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 20 3d 20   journal_mode = 
8590: 5c 22 22 20 24 6d 6f 64 65 20 5c 22 5c 3b 5d 0d  \"" $mode \"\;].
85a0: 0a 20 20 20 20 20 20 20 20 20 20 73 68 6f 77 54  .          showT
85b0: 65 73 74 20 51 0d 0a 20 20 20 20 20 20 20 20 7d  est Q..        }
85c0: 20 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d   error]} then {.
85d0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 7b 5b  .          if {[
85e0: 69 73 45 78 70 65 63 74 65 64 45 72 72 6f 72 20  isExpectedError 
85f0: 24 65 72 72 6f 72 5d 7d 20 74 68 65 6e 20 7b 0d  $error]} then {.
8600: 0a 20 20 20 20 20 20 20 20 20 20 20 20 73 68 6f  .            sho
8610: 77 54 65 73 74 20 71 0d 0a 20 20 20 20 20 20 20  wTest q..       
8620: 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20     } else {..   
8630: 20 20 20 20 20 20 20 20 20 66 61 69 6c 54 65 73           failTes
8640: 74 20 71 20 24 65 72 72 6f 72 0d 0a 20 20 20 20  t q $error..    
8650: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20        }..       
8660: 20 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20   }..      }..   
8670: 20 20 20 63 6c 65 61 6e 75 70 44 62 20 24 64 73     cleanupDb $ds
8680: 74 46 69 6c 65 4e 61 6d 65 20 64 62 20 66 61 6c  tFileName db fal
8690: 73 65 20 74 72 75 65 20 66 61 6c 73 65 0d 0a 20  se true false.. 
86a0: 20 20 20 7d 5d 20 30 5d 0d 0a 20 20 7d 5d 0d 0a     }] 0]..  }]..
86b0: 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23 23 23  ..  ############
86c0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
86d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
86e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
86f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8700: 23 0d 0a 20 20 23 20 20 20 20 20 20 20 20 20 20  #..  #          
8710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8720: 20 20 20 20 57 4f 52 4b 4c 4f 41 44 20 23 31 38      WORKLOAD #18
8730: 20 28 52 29 20 20 20 20 20 20 20 20 20 20 20 20   (R)            
8740: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8750: 20 23 0d 0a 20 20 23 23 23 23 23 23 23 23 23 23   #..  ##########
8760: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8770: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8780: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
8790: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
87a0: 23 23 23 0d 0a 0d 0a 20 20 73 65 74 20 77 6f 72  ###....  set wor
87b0: 6b 6c 6f 61 64 28 31 38 29 20 5b 6c 69 73 74 20  kload(18) [list 
87c0: 5c 0d 0a 20 20 20 20 20 20 5b 6c 69 73 74 20 73  \..      [list s
87d0: 72 63 46 69 6c 65 4e 61 6d 65 20 64 73 74 46 69  rcFileName dstFi
87e0: 6c 65 4e 61 6d 65 20 74 61 62 6c 65 20 63 6f 75  leName table cou
87f0: 6e 74 31 20 63 6f 75 6e 74 32 20 63 6f 75 6e 74  nt1 count2 count
8800: 33 5d 20 7b 0d 0a 20 20 20 20 23 0d 0a 20 20 20  3] {..    #..   
8810: 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61   # NOTE: Workloa
8820: 64 20 23 31 38 2c 20 65 78 65 63 75 74 65 20 71  d #18, execute q
8830: 75 65 72 69 65 73 20 61 67 61 69 6e 73 74 20 74  ueries against t
8840: 68 65 20 69 6e 2d 6d 65 6d 6f 72 79 20 64 61 74  he in-memory dat
8850: 61 62 61 73 65 0d 0a 20 20 20 20 23 0d 0a 20 20  abase..    #..  
8860: 20 20 6c 61 70 70 65 6e 64 20 3a 3a 74 69 6d 65    lappend ::time
8870: 73 28 31 38 29 20 5b 6c 69 6e 64 65 78 20 5b 74  s(18) [lindex [t
8880: 69 6d 65 20 7b 0d 0a 20 20 20 20 20 20 73 65 74  ime {..      set
8890: 75 70 44 62 20 24 73 72 63 46 69 6c 65 4e 61 6d  upDb $srcFileNam
88a0: 65 20 22 22 20 22 22 20 22 22 20 22 22 20 22 22  e "" "" "" "" ""
88b0: 20 66 61 6c 73 65 20 66 61 6c 73 65 20 74 72 75   false false tru
88c0: 65 20 74 72 75 65 0d 0a 20 20 20 20 20 20 66 6f  e true..      fo
88d0: 72 20 7b 73 65 74 20 69 6e 64 65 78 20 31 7d 20  r {set index 1} 
88e0: 7b 24 69 6e 64 65 78 20 3c 3d 20 24 63 6f 75 6e  {$index <= $coun
88f0: 74 31 7d 20 7b 69 6e 63 72 20 69 6e 64 65 78 7d  t1} {incr index}
8900: 20 7b 0d 0a 20 20 20 20 20 20 20 20 69 66 20 7b   {..        if {
8910: 5b 63 61 74 63 68 20 7b 0d 0a 20 20 20 20 20 20  [catch {..      
8920: 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20      #..         
8930: 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61   # NOTE: Workloa
8940: 64 20 23 31 38 2e 33 2c 20 22 73 6d 61 6c 6c 22  d #18.3, "small"
8950: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
8960: 74 73 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 23  ts...          #
8970: 0d 0a 20 20 20 20 20 20 20 20 20 20 73 65 74 20  ..          set 
8980: 72 65 61 64 65 72 20 5b 73 71 6c 20 65 78 65 63  reader [sql exec
8990: 75 74 65 20 2d 65 78 65 63 75 74 65 20 72 65 61  ute -execute rea
89a0: 64 65 72 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  der \..         
89b0: 20 20 20 20 20 2d 66 6f 72 6d 61 74 20 64 61 74       -format dat
89c0: 61 52 65 61 64 65 72 20 2d 61 6c 69 61 73 20 24  aReader -alias $
89d0: 64 62 20 5b 61 70 70 65 6e 64 41 72 67 73 20 5c  db [appendArgs \
89e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
89f0: 22 53 45 4c 45 43 54 20 78 2c 20 79 20 46 52 4f  "SELECT x, y FRO
8a00: 4d 20 22 20 24 74 61 62 6c 65 20 22 20 57 48 45  M " $table " WHE
8a10: 52 45 20 7a 20 3d 20 27 73 6d 61 6c 6c 27 3b 22  RE z = 'small';"
8a20: 5d 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 77 68  ]]..          wh
8a30: 69 6c 65 20 7b 5b 24 72 65 61 64 65 72 20 52 65  ile {[$reader Re
8a40: 61 64 5d 7d 20 7b 0d 0a 20 20 20 20 20 20 20 20  ad]} {..        
8a50: 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20      #..         
8a60: 20 20 20 23 20 4e 4f 54 45 3a 20 44 6f 20 6e 6f     # NOTE: Do no
8a70: 74 68 69 6e 67 2e 0d 0a 20 20 20 20 20 20 20 20  thing...        
8a80: 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20      #..         
8a90: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 75 6e   }..          un
8aa0: 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20  set -nocomplain 
8ab0: 72 65 61 64 65 72 0d 0a 20 20 20 20 20 20 20 20  reader..        
8ac0: 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20 20 23    #..          #
8ad0: 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20   NOTE: Workload 
8ae0: 23 31 38 2e 34 2c 20 22 62 69 67 22 20 53 45 4c  #18.4, "big" SEL
8af0: 45 43 54 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d  ECT statements..
8b00: 0a 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20  .          #..  
8b10: 20 20 20 20 20 20 20 20 73 65 74 20 72 65 61 64          set read
8b20: 65 72 20 5b 73 71 6c 20 65 78 65 63 75 74 65 20  er [sql execute 
8b30: 2d 65 78 65 63 75 74 65 20 72 65 61 64 65 72 20  -execute reader 
8b40: 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  \..             
8b50: 20 2d 66 6f 72 6d 61 74 20 64 61 74 61 52 65 61   -format dataRea
8b60: 64 65 72 20 2d 61 6c 69 61 73 20 24 64 62 20 5b  der -alias $db [
8b70: 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20  appendArgs \..  
8b80: 20 20 20 20 20 20 20 20 20 20 20 20 22 53 45 4c              "SEL
8b90: 45 43 54 20 78 2c 20 79 20 46 52 4f 4d 20 22 20  ECT x, y FROM " 
8ba0: 24 74 61 62 6c 65 20 22 20 57 48 45 52 45 20 7a  $table " WHERE z
8bb0: 20 3d 20 27 62 69 67 27 3b 22 5d 5d 0d 0a 20 20   = 'big';"]]..  
8bc0: 20 20 20 20 20 20 20 20 77 68 69 6c 65 20 7b 5b          while {[
8bd0: 24 72 65 61 64 65 72 20 52 65 61 64 5d 7d 20 7b  $reader Read]} {
8be0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 23 0d  ..            #.
8bf0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 23 20 4e  .            # N
8c00: 4f 54 45 3a 20 44 6f 20 6e 6f 74 68 69 6e 67 2e  OTE: Do nothing.
8c10: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 23 0d  ..            #.
8c20: 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20  .          }..  
8c30: 20 20 20 20 20 20 20 20 75 6e 73 65 74 20 2d 6e          unset -n
8c40: 6f 63 6f 6d 70 6c 61 69 6e 20 72 65 61 64 65 72  ocomplain reader
8c50: 0d 0a 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20  ..          #.. 
8c60: 20 20 20 20 20 20 20 20 20 23 20 4e 4f 54 45 3a           # NOTE:
8c70: 20 57 6f 72 6b 6c 6f 61 64 20 23 31 38 2e 35 2c   Workload #18.5,
8c80: 20 22 73 6d 61 6c 6c 22 20 49 4e 53 45 52 54 20   "small" INSERT 
8c90: 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20  statements...   
8ca0: 20 20 20 20 20 20 20 23 0d 0a 20 20 20 20 20 20         #..      
8cb0: 20 20 20 20 73 71 6c 20 65 78 65 63 75 74 65 20      sql execute 
8cc0: 24 64 62 20 5b 61 70 70 65 6e 64 41 72 67 73 20  $db [appendArgs 
8cd0: 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 22 20 24  "INSERT INTO " $
8ce0: 74 61 62 6c 65 20 5c 0d 0a 20 20 20 20 20 20 20  table \..       
8cf0: 20 20 20 20 20 20 20 22 28 78 2c 20 79 2c 20 7a         "(x, y, z
8d00: 29 20 56 41 4c 55 45 53 28 27 22 20 5b 66 6f 72  ) VALUES('" [for
8d10: 6d 61 74 20 25 6c 58 20 5b 65 78 70 72 20 7b 72  mat %lX [expr {r
8d20: 61 6e 64 6f 6d 28 29 7d 5d 5d 20 5c 0d 0a 20 20  andom()}]] \..  
8d30: 20 20 20 20 20 20 20 20 20 20 20 20 22 27 2c 20              "', 
8d40: 27 22 20 5b 62 61 73 65 36 34 20 65 6e 63 6f 64  '" [base64 encod
8d50: 65 20 2d 2d 20 5b 65 78 70 72 20 7b 72 61 6e 64  e -- [expr {rand
8d60: 73 74 72 28 24 63 6f 75 6e 74 32 29 7d 5d 5d 20  str($count2)}]] 
8d70: 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  \..             
8d80: 20 22 27 2c 20 27 73 6d 61 6c 6c 27 29 3b 22 5d   "', 'small');"]
8d90: 0d 0a 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20  ..          #.. 
8da0: 20 20 20 20 20 20 20 20 20 23 20 4e 4f 54 45 3a           # NOTE:
8db0: 20 57 6f 72 6b 6c 6f 61 64 20 23 31 38 2e 36 2c   Workload #18.6,
8dc0: 20 22 62 69 67 22 20 49 4e 53 45 52 54 20 73 74   "big" INSERT st
8dd0: 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20 20 20  atements...     
8de0: 20 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20       #..        
8df0: 20 20 73 71 6c 20 65 78 65 63 75 74 65 20 24 64    sql execute $d
8e00: 62 20 5b 61 70 70 65 6e 64 41 72 67 73 20 22 49  b [appendArgs "I
8e10: 4e 53 45 52 54 20 49 4e 54 4f 20 22 20 24 74 61  NSERT INTO " $ta
8e20: 62 6c 65 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  ble \..         
8e30: 20 20 20 20 20 22 28 78 2c 20 79 2c 20 7a 29 20       "(x, y, z) 
8e40: 56 41 4c 55 45 53 28 27 22 20 5b 66 6f 72 6d 61  VALUES('" [forma
8e50: 74 20 25 6c 58 20 5b 65 78 70 72 20 7b 72 61 6e  t %lX [expr {ran
8e60: 64 6f 6d 28 29 7d 5d 5d 20 5c 0d 0a 20 20 20 20  dom()}]] \..    
8e70: 20 20 20 20 20 20 20 20 20 20 22 27 2c 20 52 41            "', RA
8e80: 4e 44 4f 4d 42 4c 4f 42 28 22 20 24 63 6f 75 6e  NDOMBLOB(" $coun
8e90: 74 33 20 22 29 2c 20 27 62 69 67 27 29 3b 22 5d  t3 "), 'big');"]
8ea0: 0d 0a 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20  ..          #.. 
8eb0: 20 20 20 20 20 20 20 20 20 23 20 4e 4f 54 45 3a           # NOTE:
8ec0: 20 57 6f 72 6b 6c 6f 61 64 20 23 31 38 2e 37 2c   Workload #18.7,
8ed0: 20 22 73 6d 61 6c 6c 22 20 55 50 44 41 54 45 20   "small" UPDATE 
8ee0: 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a 20 20 20  statements...   
8ef0: 20 20 20 20 20 20 20 23 0d 0a 20 20 20 20 20 20         #..      
8f00: 20 20 20 20 73 71 6c 20 65 78 65 63 75 74 65 20      sql execute 
8f10: 24 64 62 20 5b 61 70 70 65 6e 64 41 72 67 73 20  $db [appendArgs 
8f20: 22 55 50 44 41 54 45 20 22 20 24 74 61 62 6c 65  "UPDATE " $table
8f30: 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   \..            
8f40: 20 20 22 20 53 45 54 20 79 20 3d 20 27 22 20 5b    " SET y = '" [
8f50: 62 61 73 65 36 34 20 65 6e 63 6f 64 65 20 2d 2d  base64 encode --
8f60: 20 5b 65 78 70 72 20 7b 72 61 6e 64 73 74 72 28   [expr {randstr(
8f70: 24 63 6f 75 6e 74 32 29 7d 5d 5d 20 5c 0d 0a 20  $count2)}]] \.. 
8f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 27 20               "' 
8f90: 57 48 45 52 45 20 78 20 4c 49 4b 45 20 27 22 20  WHERE x LIKE '" 
8fa0: 5b 66 6f 72 6d 61 74 20 25 58 20 24 69 6e 64 65  [format %X $inde
8fb0: 78 5d 20 22 25 27 20 41 4e 44 20 7a 20 3d 20 27  x] "%' AND z = '
8fc0: 73 6d 61 6c 6c 27 3b 22 5d 0d 0a 20 20 20 20 20  small';"]..     
8fd0: 20 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20       #..        
8fe0: 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f    # NOTE: Worklo
8ff0: 61 64 20 23 31 38 2e 38 2c 20 22 62 69 67 22 20  ad #18.8, "big" 
9000: 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74  UPDATE statement
9010: 73 2e 0d 0a 20 20 20 20 20 20 20 20 20 20 23 0d  s...          #.
9020: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 20 65  .          sql e
9030: 78 65 63 75 74 65 20 24 64 62 20 5b 61 70 70 65  xecute $db [appe
9040: 6e 64 41 72 67 73 20 22 55 50 44 41 54 45 20 22  ndArgs "UPDATE "
9050: 20 24 74 61 62 6c 65 20 5c 0d 0a 20 20 20 20 20   $table \..     
9060: 20 20 20 20 20 20 20 20 20 22 20 53 45 54 20 79           " SET y
9070: 20 3d 20 52 41 4e 44 4f 4d 42 4c 4f 42 28 22 20   = RANDOMBLOB(" 
9080: 24 63 6f 75 6e 74 33 20 22 29 20 57 48 45 52 45  $count3 ") WHERE
9090: 20 78 20 4c 49 4b 45 20 27 22 20 5c 0d 0a 20 20   x LIKE '" \..  
90a0: 20 20 20 20 20 20 20 20 20 20 20 20 5b 66 6f 72              [for
90b0: 6d 61 74 20 25 58 20 24 69 6e 64 65 78 5d 20 22  mat %X $index] "
90c0: 25 27 20 41 4e 44 20 7a 20 3d 20 27 62 69 67 27  %' AND z = 'big'
90d0: 3b 22 5d 0d 0a 20 20 20 20 20 20 20 20 20 20 23  ;"]..          #
90e0: 0d 0a 20 20 20 20 20 20 20 20 20 20 23 20 4e 4f  ..          # NO
90f0: 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 31 38  TE: Workload #18
9100: 2e 39 2c 20 22 73 6d 61 6c 6c 22 20 44 45 4c 45  .9, "small" DELE
9110: 54 45 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d 0a  TE statements...
9120: 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20 20            #..   
9130: 20 20 20 20 20 20 20 73 71 6c 20 65 78 65 63 75         sql execu
9140: 74 65 20 24 64 62 20 5b 61 70 70 65 6e 64 41 72  te $db [appendAr
9150: 67 73 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20  gs "DELETE FROM 
9160: 22 20 24 74 61 62 6c 65 20 5c 0d 0a 20 20 20 20  " $table \..    
9170: 20 20 20 20 20 20 20 20 20 20 22 20 57 48 45 52            " WHER
9180: 45 20 78 20 4c 49 4b 45 20 27 22 20 5b 66 6f 72  E x LIKE '" [for
9190: 6d 61 74 20 25 58 20 24 69 6e 64 65 78 5d 20 22  mat %X $index] "
91a0: 25 27 20 41 4e 44 20 7a 20 3d 20 27 73 6d 61 6c  %' AND z = 'smal
91b0: 6c 27 3b 22 5d 0d 0a 20 20 20 20 20 20 20 20 20  l';"]..         
91c0: 20 23 0d 0a 20 20 20 20 20 20 20 20 20 20 23 20   #..          # 
91d0: 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23  NOTE: Workload #
91e0: 31 38 2e 31 30 2c 20 22 62 69 67 22 20 44 45 4c  18.10, "big" DEL
91f0: 45 54 45 20 73 74 61 74 65 6d 65 6e 74 73 2e 0d  ETE statements..
9200: 0a 20 20 20 20 20 20 20 20 20 20 23 0d 0a 20 20  .          #..  
9210: 20 20 20 20 20 20 20 20 73 71 6c 20 65 78 65 63          sql exec
9220: 75 74 65 20 24 64 62 20 5b 61 70 70 65 6e 64 41  ute $db [appendA
9230: 72 67 73 20 22 44 45 4c 45 54 45 20 46 52 4f 4d  rgs "DELETE FROM
9240: 20 22 20 24 74 61 62 6c 65 20 5c 0d 0a 20 20 20   " $table \..   
9250: 20 20 20 20 20 20 20 20 20 20 20 22 20 57 48 45             " WHE
9260: 52 45 20 78 20 4c 49 4b 45 20 27 22 20 5b 66 6f  RE x LIKE '" [fo
9270: 72 6d 61 74 20 25 58 20 24 69 6e 64 65 78 5d 20  rmat %X $index] 
9280: 22 25 27 20 41 4e 44 20 7a 20 3d 20 27 62 69 67  "%' AND z = 'big
9290: 27 3b 22 5d 0d 0a 20 20 20 20 20 20 20 20 20 20  ';"]..          
92a0: 23 0d 0a 20 20 20 20 20 20 20 20 20 20 23 20 4e  #..          # N
92b0: 4f 54 45 3a 20 57 6f 72 6b 6c 6f 61 64 20 23 31  OTE: Workload #1
92c0: 38 2e 31 31 2c 20 56 41 43 55 55 4d 20 73 74 61  8.11, VACUUM sta
92d0: 74 65 6d 65 6e 74 2e 0d 0a 20 20 20 20 20 20 20  tement...       
92e0: 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20 20 20     #..          
92f0: 73 71 6c 20 65 78 65 63 75 74 65 20 24 64 62 20  sql execute $db 
9300: 22 56 41 43 55 55 4d 3b 22 0d 0a 20 20 20 20 20  "VACUUM;"..     
9310: 20 20 20 20 20 23 0d 0a 20 20 20 20 20 20 20 20       #..        
9320: 20 20 23 20 4e 4f 54 45 3a 20 57 6f 72 6b 6c 6f    # NOTE: Worklo
9330: 61 64 20 23 31 38 2e 31 34 2c 20 50 52 41 47 4d  ad #18.14, PRAGM
9340: 41 20 69 6e 74 65 67 72 69 74 79 20 63 68 65 63  A integrity chec
9350: 6b 20 73 74 61 74 65 6d 65 6e 74 2e 0d 0a 20 20  k statement...  
9360: 20 20 20 20 20 20 20 20 23 0d 0a 20 20 20 20 20          #..     
9370: 20 20 20 20 20 73 65 74 20 72 65 73 75 6c 74 20       set result 
9380: 5b 73 71 6c 20 65 78 65 63 75 74 65 20 2d 65 78  [sql execute -ex
9390: 65 63 75 74 65 20 73 63 61 6c 61 72 20 24 64 62  ecute scalar $db
93a0: 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   \..            
93b0: 20 20 22 50 52 41 47 4d 41 20 69 6e 74 65 67 72    "PRAGMA integr
93c0: 69 74 79 5f 63 68 65 63 6b 3b 22 5d 0d 0a 20 20  ity_check;"]..  
93d0: 20 20 20 20 20 20 20 20 69 66 20 7b 24 72 65 73          if {$res
93e0: 75 6c 74 20 6e 65 20 22 6f 6b 22 7d 20 74 68 65  ult ne "ok"} the
93f0: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n {..           
9400: 20 65 72 72 6f 72 20 5b 61 70 70 65 6e 64 41 72   error [appendAr
9410: 67 73 20 22 69 6e 74 65 67 72 69 74 79 20 63 68  gs "integrity ch
9420: 65 63 6b 20 66 61 69 6c 65 64 3a 20 22 20 24 72  eck failed: " $r
9430: 65 73 75 6c 74 5d 0d 0a 20 20 20 20 20 20 20 20  esult]..        
9440: 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 73    }..          s
9450: 68 6f 77 54 65 73 74 20 52 0d 0a 20 20 20 20 20  howTest R..     
9460: 20 20 20 7d 20 65 72 72 6f 72 5d 7d 20 74 68 65     } error]} the
9470: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 69  n {..          i
9480: 66 20 7b 5b 69 73 45 78 70 65 63 74 65 64 45 72  f {[isExpectedEr
9490: 72 6f 72 20 24 65 72 72 6f 72 5d 7d 20 74 68 65  ror $error]} the
94a0: 6e 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20  n {..           
94b0: 20 73 68 6f 77 54 65 73 74 20 72 0d 0a 20 20 20   showTest r..   
94c0: 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d         } else {.
94d0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 66 61 69  .            fai
94e0: 6c 54 65 73 74 20 72 20 24 65 72 72 6f 72 0d 0a  lTest r $error..
94f0: 20 20 20 20 20 20 20 20 20 20 7d 0d 0a 20 20 20            }..   
9500: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 7d 0d       }..      }.
9510: 0a 20 20 20 20 20 20 63 6c 65 61 6e 75 70 44 62  .      cleanupDb
9520: 20 24 73 72 63 46 69 6c 65 4e 61 6d 65 20 64 62   $srcFileName db
9530: 20 66 61 6c 73 65 20 74 72 75 65 20 66 61 6c 73   false true fals
9540: 65 0d 0a 20 20 20 20 7d 5d 20 30 5d 0d 0a 20 20  e..    }] 0]..  
9550: 7d 5d 0d 0a 7d 20 2d 62 6f 64 79 20 7b 0d 0a 20  }]..} -body {.. 
9560: 20 66 6f 72 20 7b 73 65 74 20 69 6e 64 65 78 28   for {set index(
9570: 30 29 20 30 7d 20 7b 24 69 6e 64 65 78 28 30 29  0) 0} {$index(0)
9580: 20 3c 20 24 63 6f 75 6e 74 28 30 29 7d 20 7b 69   < $count(0)} {i
9590: 6e 63 72 20 69 6e 64 65 78 28 30 29 7d 20 7b 0d  ncr index(0)} {.
95a0: 0a 20 20 20 20 73 71 6c 20 65 78 65 63 75 74 65  .    sql execute
95b0: 20 24 73 72 63 44 62 20 22 43 52 45 41 54 45 20   $srcDb "CREATE 
95c0: 54 41 42 4c 45 20 49 46 20 4e 4f 54 20 45 58 49  TABLE IF NOT EXI
95d0: 53 54 53 20 74 31 28 78 20 50 52 49 4d 41 52 59  STS t1(x PRIMARY
95e0: 20 4b 45 59 2c 20 79 2c 20 7a 29 3b 22 0d 0a 20   KEY, y, z);".. 
95f0: 20 20 20 73 71 6c 20 65 78 65 63 75 74 65 20 24     sql execute $
9600: 64 62 20 22 43 52 45 41 54 45 20 54 41 42 4c 45  db "CREATE TABLE
9610: 20 49 46 20 4e 4f 54 20 45 58 49 53 54 53 20 74   IF NOT EXISTS t
9620: 31 28 78 20 50 52 49 4d 41 52 59 20 4b 45 59 2c  1(x PRIMARY KEY,
9630: 20 79 2c 20 7a 29 3b 22 0d 0a 0d 0a 20 20 20 20   y, z);"....    
9640: 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69  unset -nocomplai
9650: 6e 20 74 68 72 65 61 64 0d 0a 0d 0a 20 20 20 20  n thread....    
9660: 66 6f 72 65 61 63 68 20 69 6e 64 65 78 28 31 29  foreach index(1)
9670: 20 5b 6c 73 6f 72 74 20 2d 69 6e 74 65 67 65 72   [lsort -integer
9680: 20 5b 61 72 72 61 79 20 6e 61 6d 65 73 20 77 6f   [array names wo
9690: 72 6b 6c 6f 61 64 5d 5d 20 7b 0d 0a 20 20 20 20  rkload]] {..    
96a0: 20 20 69 66 20 7b 5b 6c 73 65 61 72 63 68 20 2d    if {[lsearch -
96b0: 65 78 61 63 74 20 24 6e 6f 57 6f 72 6b 6c 6f 61  exact $noWorkloa
96c0: 64 20 24 69 6e 64 65 78 28 31 29 5d 20 3d 3d 20  d $index(1)] == 
96d0: 2d 31 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20  -1} then {..    
96e0: 20 20 20 20 73 65 74 20 74 68 72 65 61 64 28 24      set thread($
96f0: 69 6e 64 65 78 28 31 29 29 20 5b 6f 62 6a 65 63  index(1)) [objec
9700: 74 20 63 72 65 61 74 65 20 2d 61 6c 69 61 73 20  t create -alias 
9710: 53 79 73 74 65 6d 2e 54 68 72 65 61 64 69 6e 67  System.Threading
9720: 2e 54 68 72 65 61 64 20 5c 0d 0a 20 20 20 20 20  .Thread \..     
9730: 20 20 20 20 20 20 20 5b 6c 69 73 74 20 61 70 70         [list app
9740: 6c 79 20 24 77 6f 72 6b 6c 6f 61 64 28 24 69 6e  ly $workload($in
9750: 64 65 78 28 31 29 29 20 24 66 69 6c 65 4e 61 6d  dex(1)) $fileNam
9760: 65 28 31 29 20 24 66 69 6c 65 4e 61 6d 65 28 32  e(1) $fileName(2
9770: 29 20 74 31 20 5c 0d 0a 20 20 20 20 20 20 20 20  ) t1 \..        
9780: 20 20 20 20 24 63 6f 75 6e 74 28 31 29 20 24 63      $count(1) $c
9790: 6f 75 6e 74 28 33 29 20 24 63 6f 75 6e 74 28 34  ount(3) $count(4
97a0: 29 5d 20 31 30 34 38 35 37 36 5d 0d 0a 0d 0a 20  )] 1048576].... 
97b0: 20 20 20 20 20 20 20 24 74 68 72 65 61 64 28 24         $thread($
97c0: 69 6e 64 65 78 28 31 29 29 20 4e 61 6d 65 20 5b  index(1)) Name [
97d0: 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20  appendArgs \..  
97e0: 20 20 20 20 20 20 20 20 5b 66 69 6c 65 20 72 6f          [file ro
97f0: 6f 74 6e 61 6d 65 20 5b 66 69 6c 65 20 74 61 69  otname [file tai
9800: 6c 20 24 66 69 6c 65 4e 61 6d 65 28 32 29 5d 5d  l $fileName(2)]]
9810: 20 22 20 23 22 20 24 69 6e 64 65 78 28 31 29 5d   " #" $index(1)]
9820: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 7b  ....        if {
9830: 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 70 72 69  [info exists pri
9840: 6f 72 69 74 79 28 24 69 6e 64 65 78 28 31 29 29  ority($index(1))
9850: 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 20  ]} then {..     
9860: 20 20 20 20 20 24 74 68 72 65 61 64 28 24 69 6e       $thread($in
9870: 64 65 78 28 31 29 29 20 50 72 69 6f 72 69 74 79  dex(1)) Priority
9880: 20 24 70 72 69 6f 72 69 74 79 28 24 69 6e 64 65   $priority($inde
9890: 78 28 31 29 29 0d 0a 20 20 20 20 20 20 20 20 7d  x(1))..        }
98a0: 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d  ..      }..    }
98b0: 0d 0a 0d 0a 20 20 20 20 66 6f 72 65 61 63 68 20  ....    foreach 
98c0: 69 6e 64 65 78 28 31 29 20 5b 6c 69 73 74 20 53  index(1) [list S
98d0: 74 61 72 74 20 4a 6f 69 6e 5d 20 7b 0d 0a 20 20  tart Join] {..  
98e0: 20 20 20 20 66 6f 72 65 61 63 68 20 69 6e 64 65      foreach inde
98f0: 78 28 32 29 20 5b 61 72 72 61 79 20 6e 61 6d 65  x(2) [array name
9900: 73 20 74 68 72 65 61 64 5d 20 7b 0d 0a 20 20 20  s thread] {..   
9910: 20 20 20 20 20 24 74 68 72 65 61 64 28 24 69 6e       $thread($in
9920: 64 65 78 28 32 29 29 20 24 69 6e 64 65 78 28 31  dex(2)) $index(1
9930: 29 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  )..      }..    
9940: 7d 0d 0a 0d 0a 20 20 20 20 75 6e 73 65 74 20 2d  }....    unset -
9950: 6e 6f 63 6f 6d 70 6c 61 69 6e 20 74 68 72 65 61  nocomplain threa
9960: 64 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23  d..  }....  ####
9970: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9980: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9990: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
99a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
99b0: 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 66  #########....  f
99c0: 6f 72 65 61 63 68 20 69 6e 64 65 78 28 30 29 20  oreach index(0) 
99d0: 5b 73 70 6c 69 74 20 24 69 6e 64 69 63 61 74 6f  [split $indicato
99e0: 72 73 20 22 22 5d 20 7b 0d 0a 20 20 20 20 23 0d  rs ""] {..    #.
99f0: 0a 20 20 20 20 23 20 4e 4f 54 45 3a 20 53 65 65  .    # NOTE: See
9a00: 20 69 66 20 74 68 69 73 20 77 6f 72 6b 6c 6f 61   if this workloa
9a10: 64 20 69 74 65 72 61 74 69 6f 6e 20 72 61 69 73  d iteration rais
9a20: 65 64 20 61 6e 20 65 72 72 6f 72 2e 20 20 49 66  ed an error.  If
9a30: 20 73 6f 2c 20 74 68 65 0d 0a 20 20 20 20 23 20   so, the..    # 
9a40: 20 20 20 20 20 20 69 6e 64 69 63 61 74 6f 72 20        indicator 
9a50: 6c 65 74 74 65 72 20 77 69 6c 6c 20 62 65 20 69  letter will be i
9a60: 6e 20 6c 6f 77 65 72 20 63 61 73 65 3b 20 6f 74  n lower case; ot
9a70: 68 65 72 77 69 73 65 2c 20 69 74 20 77 69 6c 6c  herwise, it will
9a80: 0d 0a 20 20 20 20 23 20 20 20 20 20 20 20 62 65  ..    #       be
9a90: 20 69 6e 20 75 70 70 65 72 20 63 61 73 65 2e 0d   in upper case..
9aa0: 0a 20 20 20 20 23 0d 0a 20 20 20 20 73 65 74 20  .    #..    set 
9ab0: 69 6e 64 65 78 28 31 29 20 5b 73 74 72 69 6e 67  index(1) [string
9ac0: 20 69 73 20 75 70 70 65 72 20 2d 73 74 72 69 63   is upper -stric
9ad0: 74 20 24 69 6e 64 65 78 28 30 29 5d 0d 0a 0d 0a  t $index(0)]....
9ae0: 20 20 20 20 73 65 74 20 69 6e 64 65 78 28 32 29      set index(2)
9af0: 20 5b 65 78 70 72 20 7b 5b 73 74 72 69 6e 67 20   [expr {[string 
9b00: 6f 72 64 69 6e 61 6c 20 24 69 6e 64 65 78 28 30  ordinal $index(0
9b10: 29 20 30 5d 20 2d 20 5c 0d 0a 20 20 20 20 20 20  ) 0] - \..      
9b20: 20 20 5b 73 74 72 69 6e 67 20 6f 72 64 69 6e 61    [string ordina
9b30: 6c 20 5b 65 78 70 72 20 7b 24 69 6e 64 65 78 28  l [expr {$index(
9b40: 31 29 20 3f 20 22 41 22 20 3a 20 22 61 22 7d 5d  1) ? "A" : "a"}]
9b50: 20 30 5d 20 2b 20 31 7d 5d 0d 0a 0d 0a 20 20 20   0] + 1}]....   
9b60: 20 73 65 74 20 69 6e 64 65 78 28 33 29 20 5b 65   set index(3) [e
9b70: 78 70 72 20 7b 24 69 6e 64 65 78 28 31 29 20 3f  xpr {$index(1) ?
9b80: 20 22 6f 6b 22 20 3a 20 22 65 72 72 6f 72 22 7d   "ok" : "error"}
9b90: 5d 0d 0a 0d 0a 20 20 20 20 69 66 20 7b 21 5b 69  ]....    if {![i
9ba0: 6e 66 6f 20 65 78 69 73 74 73 20 69 74 65 72 61  nfo exists itera
9bb0: 74 69 6f 6e 73 28 24 69 6e 64 65 78 28 32 29 2c  tions($index(2),
9bc0: 24 69 6e 64 65 78 28 33 29 29 5d 7d 20 74 68 65  $index(3))]} the
9bd0: 6e 20 7b 0d 0a 20 20 20 20 20 20 73 65 74 20 69  n {..      set i
9be0: 74 65 72 61 74 69 6f 6e 73 28 24 69 6e 64 65 78  terations($index
9bf0: 28 32 29 2c 24 69 6e 64 65 78 28 33 29 29 20 30  (2),$index(3)) 0
9c00: 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 69  ..    }....    i
9c10: 6e 63 72 20 69 74 65 72 61 74 69 6f 6e 73 28 24  ncr iterations($
9c20: 69 6e 64 65 78 28 32 29 2c 24 69 6e 64 65 78 28  index(2),$index(
9c30: 33 29 29 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23  3))..  }....  ##
9c40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9c50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9c60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9c70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9c80: 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20  ###########.... 
9c90: 20 23 0d 0a 20 20 23 20 4e 4f 54 45 3a 20 41 64   #..  # NOTE: Ad
9ca0: 76 61 6e 63 65 20 6f 75 74 70 75 74 20 74 6f 20  vance output to 
9cb0: 74 68 65 20 6e 65 78 74 20 6c 69 6e 65 20 64 75  the next line du
9cc0: 65 20 74 6f 20 74 68 65 20 77 6f 72 6b 6c 6f 61  e to the workloa
9cd0: 64 20 69 74 65 72 61 74 69 6f 6e 0d 0a 20 20 23  d iteration..  #
9ce0: 20 20 20 20 20 20 20 70 72 6f 67 72 65 73 73 20         progress 
9cf0: 69 6e 64 69 63 61 74 6f 72 73 2e 0d 0a 20 20 23  indicators...  #
9d00: 0d 0a 20 20 74 70 75 74 73 20 24 74 65 73 74 5f  ..  tputs $test_
9d10: 63 68 61 6e 6e 65 6c 20 5c 6e 0d 0a 0d 0a 20 20  channel \n....  
9d20: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9d30: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9d40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9d50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9d60: 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d  #############...
9d70: 0a 20 20 66 6f 72 65 61 63 68 20 69 6e 64 65 78  .  foreach index
9d80: 28 30 29 20 5b 6c 73 6f 72 74 20 2d 69 6e 74 65  (0) [lsort -inte
9d90: 67 65 72 20 5b 61 72 72 61 79 20 6e 61 6d 65 73  ger [array names
9da0: 20 74 69 6d 65 73 5d 5d 20 7b 0d 0a 20 20 20 20   times]] {..    
9db0: 73 65 74 20 74 69 6d 65 73 28 6c 65 6e 67 74 68  set times(length
9dc0: 29 20 5b 6c 6c 65 6e 67 74 68 20 24 74 69 6d 65  ) [llength $time
9dd0: 73 28 24 69 6e 64 65 78 28 30 29 29 5d 0d 0a 0d  s($index(0))]...
9de0: 0a 20 20 20 20 69 66 20 7b 24 74 69 6d 65 73 28  .    if {$times(
9df0: 6c 65 6e 67 74 68 29 20 3e 20 30 7d 20 74 68 65  length) > 0} the
9e00: 6e 20 7b 0d 0a 20 20 20 20 20 20 74 70 75 74 73  n {..      tputs
9e10: 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20 5b   $test_channel [
9e20: 61 70 70 65 6e 64 41 72 67 73 20 5c 0d 0a 20 20  appendArgs \..  
9e30: 20 20 20 20 20 20 20 20 22 2d 2d 2d 2d 20 61 76          "---- av
9e40: 65 72 61 67 65 20 74 69 6d 65 20 66 6f 72 20 77  erage time for w
9e50: 6f 72 6b 6c 6f 61 64 20 28 22 20 24 69 6e 64 65  orkload (" $inde
9e60: 78 28 30 29 20 22 29 20 69 73 20 61 62 6f 75 74  x(0) ") is about
9e70: 20 22 20 5c 0d 0a 20 20 20 20 20 20 20 20 20 20   " \..          
9e80: 5b 65 78 70 72 20 69 6e 74 28 28 5b 6a 6f 69 6e  [expr int(([join
9e90: 20 24 74 69 6d 65 73 28 24 69 6e 64 65 78 28 30   $times($index(0
9ea0: 29 29 20 2b 5d 29 2f 24 74 69 6d 65 73 28 6c 65  )) +])/$times(le
9eb0: 6e 67 74 68 29 2f 31 30 30 30 2e 30 29 5d 20 5c  ngth)/1000.0)] \
9ec0: 0d 0a 20 20 20 20 20 20 20 20 20 20 22 20 6d 69  ..          " mi
9ed0: 6c 6c 69 73 65 63 6f 6e 64 73 5c 6e 22 5d 0d 0a  lliseconds\n"]..
9ee0: 20 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20      } else {..  
9ef0: 20 20 20 20 74 70 75 74 73 20 24 74 65 73 74 5f      tputs $test_
9f00: 63 68 61 6e 6e 65 6c 20 5b 61 70 70 65 6e 64 41  channel [appendA
9f10: 72 67 73 20 5c 0d 0a 20 20 20 20 20 20 20 20 20  rgs \..         
9f20: 20 22 2d 2d 2d 2d 20 6e 6f 20 74 69 6d 65 73 20   "---- no times 
9f30: 66 6f 72 20 77 6f 72 6b 6c 6f 61 64 20 28 22 20  for workload (" 
9f40: 24 69 6e 64 65 78 28 30 29 20 22 29 5c 6e 22 5d  $index(0) ")\n"]
9f50: 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 0d 0a  ..    }..  }....
9f60: 20 20 23 23 23 23 23 23 23 23 23 23 23 23 23 23    ##############
9f70: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9f80: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9f90: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
9fa0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
9fb0: 0a 0d 0a 20 20 66 6f 72 65 61 63 68 20 69 6e 64  ...  foreach ind
9fc0: 65 78 28 30 29 20 5b 6c 73 6f 72 74 20 2d 69 6e  ex(0) [lsort -in
9fd0: 74 65 67 65 72 20 5b 61 72 72 61 79 20 6e 61 6d  teger [array nam
9fe0: 65 73 20 77 6f 72 6b 6c 6f 61 64 5d 5d 20 7b 0d  es workload]] {.
9ff0: 0a 20 20 20 20 69 66 20 7b 5b 6c 73 65 61 72 63  .    if {[lsearc
a000: 68 20 2d 65 78 61 63 74 20 24 6e 6f 57 6f 72 6b  h -exact $noWork
a010: 6c 6f 61 64 20 24 69 6e 64 65 78 28 30 29 5d 20  load $index(0)] 
a020: 3d 3d 20 2d 31 7d 20 74 68 65 6e 20 7b 0d 0a 20  == -1} then {.. 
a030: 20 20 20 20 20 74 70 75 74 73 20 24 74 65 73 74       tputs $test
a040: 5f 63 68 61 6e 6e 65 6c 20 5b 66 6f 72 6d 61 74  _channel [format
a050: 57 6f 72 6b 6c 6f 61 64 52 65 73 75 6c 74 20 24  WorkloadResult $
a060: 69 6e 64 65 78 28 30 29 5d 0d 0a 20 20 20 20 7d  index(0)]..    }
a070: 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23  ..  }....  #####
a080: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a090: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a0a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a0b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a0c0: 23 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 73 65  ########....  se
a0d0: 74 20 72 65 73 75 6c 74 20 5b 73 71 6c 20 65 78  t result [sql ex
a0e0: 65 63 75 74 65 20 2d 65 78 65 63 75 74 65 20 73  ecute -execute s
a0f0: 63 61 6c 61 72 20 24 73 72 63 44 62 20 22 50 52  calar $srcDb "PR
a100: 41 47 4d 41 20 69 6e 74 65 67 72 69 74 79 5f 63  AGMA integrity_c
a110: 68 65 63 6b 3b 22 5d 0d 0a 0d 0a 20 20 69 66 20  heck;"]....  if 
a120: 7b 24 72 65 73 75 6c 74 20 65 71 20 22 6f 6b 22  {$result eq "ok"
a130: 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 74 70  } then {..    tp
a140: 75 74 73 20 24 74 65 73 74 5f 63 68 61 6e 6e 65  uts $test_channe
a150: 6c 20 22 2d 2d 2d 2d 20 69 6e 74 65 67 72 69 74  l "---- integrit
a160: 79 20 63 68 65 63 6b 20 6f 6b 20 28 73 72 63 44  y check ok (srcD
a170: 62 29 5c 6e 22 0d 0a 20 20 7d 20 65 6c 73 65 20  b)\n"..  } else 
a180: 7b 0d 0a 20 20 20 20 65 72 72 6f 72 20 5b 61 70  {..    error [ap
a190: 70 65 6e 64 41 72 67 73 20 22 69 6e 74 65 67 72  pendArgs "integr
a1a0: 69 74 79 20 63 68 65 63 6b 20 66 61 69 6c 65 64  ity check failed
a1b0: 20 28 73 72 63 44 62 29 3a 20 22 20 24 72 65 73   (srcDb): " $res
a1c0: 75 6c 74 5d 0d 0a 20 20 7d 0d 0a 0d 0a 20 20 23  ult]..  }....  #
a1d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a1e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a1f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a200: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a210: 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a  ############....
a220: 20 20 73 65 74 20 72 65 73 75 6c 74 20 5b 73 71    set result [sq
a230: 6c 20 65 78 65 63 75 74 65 20 2d 65 78 65 63 75  l execute -execu
a240: 74 65 20 73 63 61 6c 61 72 20 24 64 62 20 22 50  te scalar $db "P
a250: 52 41 47 4d 41 20 69 6e 74 65 67 72 69 74 79 5f  RAGMA integrity_
a260: 63 68 65 63 6b 3b 22 5d 0d 0a 0d 0a 20 20 69 66  check;"]....  if
a270: 20 7b 24 72 65 73 75 6c 74 20 65 71 20 22 6f 6b   {$result eq "ok
a280: 22 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 20 20 74  "} then {..    t
a290: 70 75 74 73 20 24 74 65 73 74 5f 63 68 61 6e 6e  puts $test_chann
a2a0: 65 6c 20 22 2d 2d 2d 2d 20 69 6e 74 65 67 72 69  el "---- integri
a2b0: 74 79 20 63 68 65 63 6b 20 6f 6b 20 28 64 62 29  ty check ok (db)
a2c0: 5c 6e 22 0d 0a 20 20 7d 20 65 6c 73 65 20 7b 0d  \n"..  } else {.
a2d0: 0a 20 20 20 20 65 72 72 6f 72 20 5b 61 70 70 65  .    error [appe
a2e0: 6e 64 41 72 67 73 20 22 69 6e 74 65 67 72 69 74  ndArgs "integrit
a2f0: 79 20 63 68 65 63 6b 20 66 61 69 6c 65 64 20 28  y check failed (
a300: 64 62 29 3a 20 22 20 24 72 65 73 75 6c 74 5d 0d  db): " $result].
a310: 0a 20 20 7d 0d 0a 0d 0a 20 20 23 23 23 23 23 23  .  }....  ######
a320: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a330: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a340: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a350: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a360: 23 23 23 23 23 23 23 0d 0a 0d 0a 20 20 23 0d 0a  #######....  #..
a370: 20 20 23 20 4e 4f 54 45 3a 20 54 68 65 20 6f 76    # NOTE: The ov
a380: 65 72 61 6c 6c 20 74 65 73 74 20 72 65 73 75 6c  erall test resul
a390: 74 20 69 73 20 74 68 65 20 74 6f 74 61 6c 20 6e  t is the total n
a3a0: 75 6d 62 65 72 20 6f 66 20 66 61 69 6c 75 72 65  umber of failure
a3b0: 73 20 28 69 2e 65 2e 0d 0a 20 20 23 20 20 20 20  s (i.e...  #    
a3c0: 20 20 20 22 75 6e 65 78 70 65 63 74 65 64 20 65     "unexpected e
a3d0: 72 72 6f 72 73 22 29 20 65 6e 63 6f 75 6e 74 65  rrors") encounte
a3e0: 72 65 64 20 64 75 72 69 6e 67 20 61 20 77 6f 72  red during a wor
a3f0: 6b 6c 6f 61 64 20 69 74 65 72 61 74 69 6f 6e 2e  kload iteration.
a400: 0d 0a 20 20 23 0d 0a 20 20 65 78 70 72 20 7b 5b  ..  #..  expr {[
a410: 61 72 72 61 79 20 73 69 7a 65 20 66 61 69 6c 75  array size failu
a420: 72 65 73 5d 20 3e 20 30 20 3f 20 5c 0d 0a 20 20  res] > 0 ? \..  
a430: 20 20 20 20 5b 65 78 70 72 20 5b 6a 6f 69 6e 20      [expr [join 
a440: 5b 61 72 72 61 79 20 76 61 6c 75 65 73 20 66 61  [array values fa
a450: 69 6c 75 72 65 73 5d 20 2b 5d 5d 20 3a 20 30 7d  ilures] +]] : 0}
a460: 0d 0a 7d 20 2d 63 6c 65 61 6e 75 70 20 7b 0d 0a  ..} -cleanup {..
a470: 20 20 72 65 6e 61 6d 65 20 66 72 65 65 4d 65 6d    rename freeMem
a480: 20 22 22 0d 0a 20 20 72 65 6e 61 6d 65 20 75 73   ""..  rename us
a490: 65 4d 65 6d 20 22 22 0d 0a 20 20 72 65 6e 61 6d  eMem ""..  renam
a4a0: 65 20 61 6c 6c 6f 63 4d 65 6d 20 22 22 0d 0a 20  e allocMem "".. 
a4b0: 20 72 65 6e 61 6d 65 20 66 61 69 6c 54 65 73 74   rename failTest
a4c0: 20 22 22 0d 0a 20 20 72 65 6e 61 6d 65 20 73 68   ""..  rename sh
a4d0: 6f 77 54 65 73 74 20 22 22 0d 0a 20 20 72 65 6e  owTest ""..  ren
a4e0: 61 6d 65 20 77 61 69 74 46 6f 72 54 65 73 74 20  ame waitForTest 
a4f0: 22 22 0d 0a 20 20 72 65 6e 61 6d 65 20 69 73 45  ""..  rename isE
a500: 78 70 65 63 74 65 64 45 72 72 6f 72 20 22 22 0d  xpectedError "".
a510: 0a 20 20 72 65 6e 61 6d 65 20 66 6f 72 6d 61 74  .  rename format
a520: 57 6f 72 6b 6c 6f 61 64 52 65 73 75 6c 74 20 22  WorkloadResult "
a530: 22 0d 0a 0d 0a 20 20 63 6c 65 61 6e 75 70 44 62  "....  cleanupDb
a540: 20 24 66 69 6c 65 4e 61 6d 65 28 32 29 0d 0a 20   $fileName(2).. 
a550: 20 63 6c 65 61 6e 75 70 44 62 20 24 66 69 6c 65   cleanupDb $file
a560: 4e 61 6d 65 28 31 29 20 73 72 63 44 62 0d 0a 0d  Name(1) srcDb...
a570: 0a 20 20 66 6f 72 65 61 63 68 20 69 6e 64 65 78  .  foreach index
a580: 28 30 29 20 5b 61 72 72 61 79 20 6e 61 6d 65 73  (0) [array names
a590: 20 77 6f 72 6b 6c 6f 61 64 5d 20 7b 0d 0a 20 20   workload] {..  
a5a0: 20 20 63 61 74 63 68 20 7b 0d 0a 20 20 20 20 20    catch {..     
a5b0: 20 6f 62 6a 65 63 74 20 72 65 6d 6f 76 65 63 61   object removeca
a5c0: 6c 6c 62 61 63 6b 20 5b 6c 69 73 74 20 61 70 70  llback [list app
a5d0: 6c 79 20 24 77 6f 72 6b 6c 6f 61 64 28 24 69 6e  ly $workload($in
a5e0: 64 65 78 28 30 29 29 20 24 66 69 6c 65 4e 61 6d  dex(0)) $fileNam
a5f0: 65 28 31 29 20 5c 0d 0a 20 20 20 20 20 20 20 20  e(1) \..        
a600: 20 20 24 66 69 6c 65 4e 61 6d 65 28 32 29 20 74    $fileName(2) t
a610: 31 20 24 63 6f 75 6e 74 28 31 29 20 24 63 6f 75  1 $count(1) $cou
a620: 6e 74 28 33 29 20 24 63 6f 75 6e 74 28 34 29 5d  nt(3) $count(4)]
a630: 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 0d 0a  ..    }..  }....
a640: 20 20 66 72 65 65 44 62 43 6f 6e 6e 65 63 74 69    freeDbConnecti
a650: 6f 6e 0d 0a 0d 0a 20 20 69 66 20 7b 21 24 6e 6f  on....  if {!$no
a660: 54 72 61 63 65 7d 20 74 68 65 6e 20 7b 0d 0a 20  Trace} then {.. 
a670: 20 20 20 63 6c 65 61 6e 75 70 4c 6f 67 67 69 6e     cleanupLoggin
a680: 67 20 24 6c 6f 67 46 69 6c 65 4e 61 6d 65 0d 0a  g $logFileName..
a690: 20 20 7d 0d 0a 0d 0a 20 20 72 65 6e 61 6d 65 20    }....  rename 
a6a0: 63 6c 65 61 6e 75 70 4c 6f 67 67 69 6e 67 20 22  cleanupLogging "
a6b0: 22 0d 0a 20 20 72 65 6e 61 6d 65 20 73 65 74 75  "..  rename setu
a6c0: 70 4c 6f 67 67 69 6e 67 20 22 22 0d 0a 0d 0a 20  pLogging "".... 
a6d0: 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61   unset -nocompla
a6e0: 69 6e 20 72 65 73 75 6c 74 20 74 68 72 65 61 64  in result thread
a6f0: 20 69 6e 64 65 78 20 77 6f 72 6b 6c 6f 61 64 20   index workload 
a700: 70 72 69 6f 72 69 74 79 20 6e 6f 57 6f 72 6b 6c  priority noWorkl
a710: 6f 61 64 20 5c 0d 0a 20 20 20 20 20 20 70 72 69  oad \..      pri
a720: 6f 72 69 74 69 65 73 20 73 72 63 44 62 20 64 62  orities srcDb db
a730: 20 66 69 6c 65 4e 61 6d 65 20 63 6f 6d 70 69 6c   fileName compil
a740: 65 64 20 6f 70 74 69 6f 6e 73 20 63 6f 75 6e 74  ed options count
a750: 20 74 69 6d 65 73 20 6c 6f 67 46 69 6c 65 4e 61   times logFileNa
a760: 6d 65 20 5c 0d 0a 20 20 20 20 20 20 6c 6f 67 4c  me \..      logL
a770: 69 73 74 65 6e 65 72 20 63 6f 6e 6e 65 63 74 69  istener connecti
a780: 6f 6e 20 69 6e 64 69 63 61 74 6f 72 73 20 69 74  on indicators it
a790: 65 72 61 74 69 6f 6e 73 20 65 78 69 74 4f 6e 46  erations exitOnF
a7a0: 61 69 6c 20 63 6f 54 61 73 6b 4d 65 6d 20 5c 0d  ail coTaskMem \.
a7b0: 0a 20 20 20 20 20 20 6e 6f 54 72 61 63 65 20 66  .      noTrace f
a7c0: 61 69 6c 75 72 65 73 0d 0a 7d 20 2d 63 6f 6e 73  ailures..} -cons
a7d0: 74 72 61 69 6e 74 73 20 5c 0d 0a 7b 65 61 67 6c  traints \..{eagl
a7e0: 65 20 6d 6f 6e 6f 42 75 67 32 38 20 63 6f 6d 6d  e monoBug28 comm
a7f0: 61 6e 64 2e 73 71 6c 20 63 6f 6d 70 69 6c 65 2e  and.sql compile.
a800: 44 41 54 41 20 53 51 4c 69 74 65 20 53 79 73 74  DATA SQLite Syst
a810: 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 7d 20  em.Data.SQLite} 
a820: 5c 0d 0a 2d 72 65 73 75 6c 74 20 7b 30 7d 7d 0d  \..-result {0}}.
a830: 0a 0d 0a 23 23 23 23 23 23 23 23 23 23 23 23 23  ...#############
a840: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a850: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a860: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a870: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
a880: 23 23 0d 0a 0d 0a 72 75 6e 53 51 4c 69 74 65 54  ##....runSQLiteT
a890: 65 73 74 45 70 69 6c 6f 67 75 65 0d 0a 72 75 6e  estEpilogue..run
a8a0: 54 65 73 74 45 70 69 6c 6f 67 75 65 0d 0a        TestEpilogue..