System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 92f70806ef632b2b6282a157bed76cf1d77961cf:


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 74 6b 74 2d 34 37 63 36 66 61  .#..# tkt-47c6fa
0060: 30 34 64 33 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  04d3.eagle --..#
0070: 0d 0a 23 20 57 72 69 74 74 65 6e 20 62 79 20 4a  ..# Written by J
0080: 6f 65 20 4d 69 73 74 61 63 68 6b 69 6e 2e 0d 0a  oe Mistachkin...
0090: 23 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  # Released to th
00a0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00b0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00c0: 20 72 69 73 6b 21 0d 0a 23 0d 0a 23 23 23 23 23   risk!..#..#####
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 23 23 23 23 23 23 23 23 0d 0a 0d 0a 70 61  ##########....pa
0120: 63 6b 61 67 65 20 72 65 71 75 69 72 65 20 45 61  ckage require Ea
0130: 67 6c 65 0d 0a 70 61 63 6b 61 67 65 20 72 65 71  gle..package req
0140: 75 69 72 65 20 45 61 67 6c 65 2e 4c 69 62 72 61  uire Eagle.Libra
0150: 72 79 0d 0a 70 61 63 6b 61 67 65 20 72 65 71 75  ry..package requ
0160: 69 72 65 20 45 61 67 6c 65 2e 54 65 73 74 0d 0a  ire Eagle.Test..
0170: 0d 0a 72 75 6e 54 65 73 74 50 72 6f 6c 6f 67 75  ..runTestPrologu
0180: 65 0d 0a 0d 0a 23 23 23 23 23 23 23 23 23 23 23  e....###########
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 23 23 23 23  ################
01d0: 23 23 23 23 0d 0a 0d 0a 70 61 63 6b 61 67 65 20  ####....package 
01e0: 72 65 71 75 69 72 65 20 53 79 73 74 65 6d 2e 44  require System.D
01f0: 61 74 61 2e 53 51 4c 69 74 65 2e 54 65 73 74 0d  ata.SQLite.Test.
0200: 0a 72 75 6e 53 51 4c 69 74 65 54 65 73 74 50 72  .runSQLiteTestPr
0210: 6f 6c 6f 67 75 65 0d 0a 0d 0a 23 23 23 23 23 23  ologue....######
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 23 23 23 23 23 23 23 23 0d 0a 0d 0a 72 75 6e  #########....run
0270: 54 65 73 74 20 7b 74 65 73 74 20 74 6b 74 2d 34  Test {test tkt-4
0280: 37 63 36 66 61 30 34 64 33 2d 31 2e 31 20 7b 6c  7c6fa04d3-1.1 {l
0290: 6f 61 64 69 6e 67 20 44 61 74 61 54 61 62 6c 65  oading DataTable
02a0: 20 77 69 74 68 20 4a 4f 49 4e 7d 20 2d 73 65 74   with JOIN} -set
02b0: 75 70 20 7b 0d 0a 20 20 73 65 74 75 70 44 62 20  up {..  setupDb 
02c0: 5b 73 65 74 20 66 69 6c 65 4e 61 6d 65 20 74 6b  [set fileName tk
02d0: 74 2d 34 37 63 36 66 61 30 34 64 33 2d 31 2e 31  t-47c6fa04d3-1.1
02e0: 2e 64 62 5d 0d 0a 7d 20 2d 62 6f 64 79 20 7b 0d  .db]..} -body {.
02f0: 0a 20 20 73 71 6c 20 65 78 65 63 75 74 65 20 24  .  sql execute $
0300: 64 62 20 7b 0d 0a 20 20 20 20 43 52 45 41 54 45  db {..    CREATE
0310: 20 54 41 42 4c 45 20 74 31 28 0d 0a 20 20 20 20   TABLE t1(..    
0320: 20 20 74 31 78 20 49 4e 54 45 47 45 52 20 50 52    t1x INTEGER PR
0330: 49 4d 41 52 59 20 4b 45 59 20 4e 4f 54 20 4e 55  IMARY KEY NOT NU
0340: 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 31 79 20 54  LL,..      t1y T
0350: 45 58 54 20 4e 4f 54 20 4e 55 4c 4c 0d 0a 20 20  EXT NOT NULL..  
0360: 20 20 29 3b 0d 0a 0d 0a 20 20 20 20 49 4e 53 45    );....    INSE
0370: 52 54 20 49 4e 54 4f 20 74 31 20 28 74 31 78 2c  RT INTO t1 (t1x,
0380: 20 74 31 79 29 20 56 41 4c 55 45 53 28 31 2c 20   t1y) VALUES(1, 
0390: 27 6f 6e 65 5f 74 31 27 29 3b 0d 0a 20 20 20 20  'one_t1');..    
03a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28  INSERT INTO t1 (
03b0: 74 31 78 2c 20 74 31 79 29 20 56 41 4c 55 45 53  t1x, t1y) VALUES
03c0: 28 32 2c 20 27 74 77 6f 5f 74 31 27 29 3b 0d 0a  (2, 'two_t1');..
03d0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
03e0: 74 31 20 28 74 31 78 2c 20 74 31 79 29 20 56 41  t1 (t1x, t1y) VA
03f0: 4c 55 45 53 28 33 2c 20 27 74 68 72 65 65 5f 74  LUES(3, 'three_t
0400: 31 27 29 3b 0d 0a 0d 0a 20 20 20 20 43 52 45 41  1');....    CREA
0410: 54 45 20 54 41 42 4c 45 20 74 32 28 0d 0a 20 20  TE TABLE t2(..  
0420: 20 20 20 20 74 32 78 20 49 4e 54 45 47 45 52 20      t2x INTEGER 
0430: 50 52 49 4d 41 52 59 20 4b 45 59 20 4e 4f 54 20  PRIMARY KEY NOT 
0440: 4e 55 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 32 74  NULL,..      t2t
0450: 31 78 20 49 4e 54 45 47 45 52 20 4e 4f 54 20 4e  1x INTEGER NOT N
0460: 55 4c 4c 2c 0d 0a 20 20 20 20 20 20 74 32 79 20  ULL,..      t2y 
0470: 54 45 58 54 2c 0d 0a 20 20 20 20 20 20 74 32 7a  TEXT,..      t2z
0480: 20 49 4e 54 45 47 45 52 20 4e 4f 54 20 4e 55 4c   INTEGER NOT NUL
0490: 4c 20 44 45 46 41 55 4c 54 28 30 29 0d 0a 20 20  L DEFAULT(0)..  
04a0: 20 20 29 3b 0d 0a 0d 0a 20 20 20 20 49 4e 53 45    );....    INSE
04b0: 52 54 20 49 4e 54 4f 20 74 32 20 28 74 32 78 2c  RT INTO t2 (t2x,
04c0: 20 74 32 74 31 78 2c 20 74 32 79 2c 20 74 32 7a   t2t1x, t2y, t2z
04d0: 29 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 27  ) VALUES(1, 2, '
04e0: 6f 6e 65 5f 74 32 27 2c 20 31 29 3b 0d 0a 20 20  one_t2', 1);..  
04f0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32    INSERT INTO t2
0500: 20 28 74 32 78 2c 20 74 32 74 31 78 2c 20 74 32   (t2x, t2t1x, t2
0510: 79 2c 20 74 32 7a 29 20 56 41 4c 55 45 53 28 32  y, t2z) VALUES(2
0520: 2c 20 32 2c 20 27 74 77 6f 5f 74 32 27 2c 20 32  , 2, 'two_t2', 2
0530: 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20 49  );..    INSERT I
0540: 4e 54 4f 20 74 32 20 28 74 32 78 2c 20 74 32 74  NTO t2 (t2x, t2t
0550: 31 78 2c 20 74 32 79 2c 20 74 32 7a 29 20 56 41  1x, t2y, t2z) VA
0560: 4c 55 45 53 28 33 2c 20 32 2c 20 27 74 68 72 65  LUES(3, 2, 'thre
0570: 65 5f 74 32 27 2c 20 33 29 3b 0d 0a 0d 0a 20 20  e_t2', 3);....  
0580: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0590: 33 28 0d 0a 20 20 20 20 20 20 74 33 78 20 49 4e  3(..      t3x IN
05a0: 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45  TEGER PRIMARY KE
05b0: 59 20 4e 4f 54 20 4e 55 4c 4c 2c 0d 0a 20 20 20  Y NOT NULL,..   
05c0: 20 20 20 74 33 79 20 49 4e 54 45 47 45 52 20 4e     t3y INTEGER N
05d0: 4f 54 20 4e 55 4c 4c 2c 0d 0a 20 20 20 20 20 20  OT NULL,..      
05e0: 74 33 7a 20 49 4e 54 45 47 45 52 20 4e 4f 54 20  t3z INTEGER NOT 
05f0: 4e 55 4c 4c 0d 0a 20 20 20 20 29 3b 0d 0a 0d 0a  NULL..    );....
0600: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0610: 74 33 20 28 74 33 78 2c 20 74 33 79 2c 20 74 33  t3 (t3x, t3y, t3
0620: 7a 29 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20  z) VALUES(1, 2, 
0630: 33 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20  3);..    INSERT 
0640: 49 4e 54 4f 20 74 33 20 28 74 33 78 2c 20 74 33  INTO t3 (t3x, t3
0650: 79 2c 20 74 33 7a 29 20 56 41 4c 55 45 53 28 32  y, t3z) VALUES(2
0660: 2c 20 31 2c 20 32 29 3b 0d 0a 20 20 7d 0d 0a 0d  , 1, 2);..  }...
0670: 0a 20 20 73 65 74 20 69 64 20 5b 6f 62 6a 65 63  .  set id [objec
0680: 74 20 69 6e 76 6f 6b 65 20 49 6e 74 65 72 70 72  t invoke Interpr
0690: 65 74 65 72 2e 47 65 74 41 63 74 69 76 65 20 4e  eter.GetActive N
06a0: 65 78 74 49 64 5d 0d 0a 20 20 73 65 74 20 64 61  extId]..  set da
06b0: 74 61 53 6f 75 72 63 65 20 5b 66 69 6c 65 20 6a  taSource [file j
06c0: 6f 69 6e 20 5b 67 65 74 44 61 74 61 62 61 73 65  oin [getDatabase
06d0: 44 69 72 65 63 74 6f 72 79 5d 20 24 66 69 6c 65  Directory] $file
06e0: 4e 61 6d 65 5d 0d 0a 0d 0a 20 20 73 65 74 20 73  Name]....  set s
06f0: 71 6c 20 7b 0d 0a 20 20 20 20 53 45 4c 45 43 54  ql {..    SELECT
0700: 20 74 31 2e 74 31 78 20 41 53 20 69 64 2c 20 74   t1.t1x AS id, t
0710: 33 2e 74 33 79 20 41 53 20 6d 69 6e 2c 20 74 33  3.t3y AS min, t3
0720: 2e 74 33 7a 20 41 53 20 6d 61 78 2c 0d 0a 20 20  .t3z AS max,..  
0730: 20 20 20 20 20 20 20 20 20 53 55 4d 28 74 32 2e           SUM(t2.
0740: 74 32 7a 29 20 41 53 20 73 75 6d 0d 0a 20 20 20  t2z) AS sum..   
0750: 20 46 52 4f 4d 20 74 31 20 74 31 20 49 4e 4e 45   FROM t1 t1 INNE
0760: 52 20 4a 4f 49 4e 20 74 33 20 74 33 20 49 4e 4e  R JOIN t3 t3 INN
0770: 45 52 20 4a 4f 49 4e 20 74 32 20 74 32 0d 0a 20  ER JOIN t2 t2.. 
0780: 20 20 20 4f 4e 20 74 32 2e 74 32 74 31 78 20 3d     ON t2.t2t1x =
0790: 20 74 31 2e 74 31 78 20 41 4e 44 20 74 32 2e 74   t1.t1x AND t2.t
07a0: 32 7a 20 42 45 54 57 45 45 4e 20 74 33 2e 74 33  2z BETWEEN t3.t3
07b0: 79 20 41 4e 44 20 74 33 2e 74 33 7a 0d 0a 20 20  y AND t3.t3z..  
07c0: 20 20 47 52 4f 55 50 20 42 59 20 74 31 2e 74 31    GROUP BY t1.t1
07d0: 78 2c 20 74 33 2e 74 33 78 2c 20 74 33 2e 74 33  x, t3.t3x, t3.t3
07e0: 79 2c 20 74 33 2e 74 33 7a 3b 0d 0a 20 20 7d 0d  y, t3.t3z;..  }.
07f0: 0a 0d 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f  ...  unset -noco
0800: 6d 70 6c 61 69 6e 20 72 65 73 75 6c 74 73 20 65  mplain results e
0810: 72 72 6f 72 73 0d 0a 0d 0a 20 20 73 65 74 20 63  rrors....  set c
0820: 6f 64 65 20 5b 63 6f 6d 70 69 6c 65 43 53 68 61  ode [compileCSha
0830: 72 70 57 69 74 68 20 5b 73 75 62 73 74 20 7b 0d  rpWith [subst {.
0840: 0a 20 20 20 20 75 73 69 6e 67 20 53 79 73 74 65  .    using Syste
0850: 6d 2e 44 61 74 61 3b 0d 0a 20 20 20 20 75 73 69  m.Data;..    usi
0860: 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 2e 53  ng System.Data.S
0870: 51 4c 69 74 65 3b 0d 0a 0d 0a 20 20 20 20 6e 61  QLite;....    na
0880: 6d 65 73 70 61 63 65 20 5f 44 79 6e 61 6d 69 63  mespace _Dynamic
0890: 24 7b 69 64 7d 0d 0a 20 20 20 20 7b 0d 0a 20 20  ${id}..    {..  
08a0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
08b0: 63 20 63 6c 61 73 73 20 54 65 73 74 24 7b 69 64  c class Test${id
08c0: 7d 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  }..      {..    
08d0: 20 20 20 20 70 75 62 6c 69 63 20 73 74 61 74 69      public stati
08e0: 63 20 44 61 74 61 54 61 62 6c 65 20 47 65 74 44  c DataTable GetD
08f0: 61 74 61 54 61 62 6c 65 28 29 0d 0a 20 20 20 20  ataTable()..    
0900: 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20      {..         
0910: 20 44 61 74 61 54 61 62 6c 65 20 64 61 74 61 54   DataTable dataT
0920: 61 62 6c 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  able;....       
0930: 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65     using (SQLite
0940: 43 6f 6e 6e 65 63 74 69 6f 6e 20 63 6f 6e 6e 65  Connection conne
0950: 63 74 69 6f 6e 20 3d 20 6e 65 77 20 53 51 4c 69  ction = new SQLi
0960: 74 65 43 6f 6e 6e 65 63 74 69 6f 6e 28 0d 0a 20  teConnection(.. 
0970: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 44 61               "Da
0980: 74 61 20 53 6f 75 72 63 65 3d 24 7b 64 61 74 61  ta Source=${data
0990: 53 6f 75 72 63 65 7d 3b 5b 67 65 74 54 65 73 74  Source};[getTest
09a0: 50 72 6f 70 65 72 74 69 65 73 5d 22 29 29 0d 0a  Properties]"))..
09b0: 20 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20            {..   
09c0: 20 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74           connect
09d0: 69 6f 6e 2e 4f 70 65 6e 28 29 3b 0d 0a 0d 0a 20  ion.Open();.... 
09e0: 20 20 20 20 20 20 20 20 20 20 20 75 73 69 6e 67             using
09f0: 20 28 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64 20   (SQLiteCommand 
0a00: 63 6f 6d 6d 61 6e 64 20 3d 20 6e 65 77 20 53 51  command = new SQ
0a10: 4c 69 74 65 43 6f 6d 6d 61 6e 64 28 40 22 24 7b  LiteCommand(@"${
0a20: 73 71 6c 7d 22 2c 0d 0a 20 20 20 20 20 20 20 20  sql}",..        
0a30: 20 20 20 20 20 20 20 20 63 6f 6e 6e 65 63 74 69          connecti
0a40: 6f 6e 29 29 0d 0a 20 20 20 20 20 20 20 20 20 20  on))..          
0a50: 20 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20    {..           
0a60: 20 20 20 75 73 69 6e 67 20 28 53 51 4c 69 74 65     using (SQLite
0a70: 44 61 74 61 52 65 61 64 65 72 20 64 61 74 61 52  DataReader dataR
0a80: 65 61 64 65 72 20 3d 20 63 6f 6d 6d 61 6e 64 2e  eader = command.
0a90: 45 78 65 63 75 74 65 52 65 61 64 65 72 28 29 29  ExecuteReader())
0aa0: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ..              
0ab0: 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  {..             
0ac0: 20 20 20 64 61 74 61 54 61 62 6c 65 20 3d 20 6e     dataTable = n
0ad0: 65 77 20 44 61 74 61 54 61 62 6c 65 28 29 3b 0d  ew DataTable();.
0ae0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
0af0: 20 64 61 74 61 54 61 62 6c 65 2e 4c 6f 61 64 28   dataTable.Load(
0b00: 64 61 74 61 52 65 61 64 65 72 29 3b 0d 0a 0d 0a  dataReader);....
0b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b20: 72 65 74 75 72 6e 20 64 61 74 61 54 61 62 6c 65  return dataTable
0b30: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ;..             
0b40: 20 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   }..            
0b50: 7d 0d 0a 20 20 20 20 20 20 20 20 20 20 7d 0d 0a  }..          }..
0b60: 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20          }....   
0b70: 20 20 20 20 20 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f       ///////////
0b80: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0b90: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0ba0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f  ////////////////
0bb0: 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 2f 0d 0a 0d 0a  ////////////....
0bc0: 20 20 20 20 20 20 20 20 70 75 62 6c 69 63 20 73          public s
0bd0: 74 61 74 69 63 20 76 6f 69 64 20 4d 61 69 6e 28  tatic void Main(
0be0: 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20 20  )..        {..  
0bf0: 20 20 20 20 20 20 20 20 2f 2f 20 64 6f 20 6e 6f          // do no
0c00: 74 68 69 6e 67 2e 0d 0a 20 20 20 20 20 20 20 20  thing...        
0c10: 7d 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20 20 20  }..      }..    
0c20: 7d 0d 0a 20 20 7d 5d 20 74 72 75 65 20 74 72 75  }..  }] true tru
0c30: 65 20 74 72 75 65 20 72 65 73 75 6c 74 73 20 65  e true results e
0c40: 72 72 6f 72 73 20 53 79 73 74 65 6d 2e 44 61 74  rrors System.Dat
0c50: 61 2e 53 51 4c 69 74 65 2e 64 6c 6c 5d 0d 0a 0d  a.SQLite.dll]...
0c60: 0a 20 20 6c 69 73 74 20 24 63 6f 64 65 20 24 72  .  list $code $r
0c70: 65 73 75 6c 74 73 20 5c 0d 0a 20 20 20 20 20 20  esults \..      
0c80: 5b 65 78 70 72 20 7b 5b 69 6e 66 6f 20 65 78 69  [expr {[info exi
0c90: 73 74 73 20 65 72 72 6f 72 73 5d 20 3f 20 24 65  sts errors] ? $e
0ca0: 72 72 6f 72 73 20 3a 20 22 22 7d 5d 20 5c 0d 0a  rrors : ""}] \..
0cb0: 20 20 20 20 20 20 5b 65 78 70 72 20 7b 24 63 6f        [expr {$co
0cc0: 64 65 20 65 71 20 22 4f 6b 22 20 3f 20 5b 63 61  de eq "Ok" ? [ca
0cd0: 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 20 20 6f  tch {..        o
0ce0: 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20 2d 61 6c  bject invoke -al
0cf0: 69 61 73 20 5f 44 79 6e 61 6d 69 63 24 7b 69 64  ias _Dynamic${id
0d00: 7d 2e 54 65 73 74 24 7b 69 64 7d 20 47 65 74 44  }.Test${id} GetD
0d10: 61 74 61 54 61 62 6c 65 0d 0a 20 20 20 20 20 20  ataTable..      
0d20: 7d 20 72 65 73 75 6c 74 5d 20 3a 20 5b 73 65 74  } result] : [set
0d30: 20 72 65 73 75 6c 74 20 22 22 5d 7d 5d 20 24 72   result ""]}] $r
0d40: 65 73 75 6c 74 20 5b 67 65 74 52 6f 77 73 46 72  esult [getRowsFr
0d50: 6f 6d 44 61 74 61 54 61 62 6c 65 20 24 72 65 73  omDataTable $res
0d60: 75 6c 74 5d 0d 0a 7d 20 2d 63 6c 65 61 6e 75 70  ult]..} -cleanup
0d70: 20 7b 0d 0a 20 20 63 6c 65 61 6e 75 70 44 62 20   {..  cleanupDb 
0d80: 24 66 69 6c 65 4e 61 6d 65 0d 0a 0d 0a 20 20 75  $fileName....  u
0d90: 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e  nset -nocomplain
0da0: 20 72 65 73 75 6c 74 20 72 65 73 75 6c 74 73 20   result results 
0db0: 65 72 72 6f 72 73 20 63 6f 64 65 20 73 71 6c 20  errors code sql 
0dc0: 64 61 74 61 53 6f 75 72 63 65 20 69 64 20 64 62  dataSource id db
0dd0: 20 66 69 6c 65 4e 61 6d 65 0d 0a 7d 20 2d 63 6f   fileName..} -co
0de0: 6e 73 74 72 61 69 6e 74 73 20 7b 65 61 67 6c 65  nstraints {eagle
0df0: 20 63 6f 6d 6d 61 6e 64 2e 6f 62 6a 65 63 74 20   command.object 
0e00: 6d 6f 6e 6f 42 75 67 32 31 31 20 6d 6f 6e 6f 42  monoBug211 monoB
0e10: 75 67 34 30 20 63 6f 6d 6d 61 6e 64 2e 73 71 6c  ug40 command.sql
0e20: 5c 0d 0a 63 6f 6d 70 69 6c 65 2e 44 41 54 41 20  \..compile.DATA 
0e30: 53 51 4c 69 74 65 20 53 79 73 74 65 6d 2e 44 61  SQLite System.Da
0e40: 74 61 2e 53 51 4c 69 74 65 20 63 6f 6d 70 69 6c  ta.SQLite compil
0e50: 65 43 53 68 61 72 70 7d 20 2d 6d 61 74 63 68 20  eCSharp} -match 
0e60: 72 65 67 65 78 70 20 2d 72 65 73 75 6c 74 20 5c  regexp -result \
0e70: 0d 0a 7b 5e 4f 6b 20 53 79 73 74 65 6d 23 43 6f  ..{^Ok System#Co
0e80: 64 65 44 6f 6d 23 43 6f 6d 70 69 6c 65 72 23 43  deDom#Compiler#C
0e90: 6f 6d 70 69 6c 65 72 52 65 73 75 6c 74 73 23 5c  ompilerResults#\
0ea0: 64 2b 20 5c 7b 5c 7d 20 30 5c 0d 0a 53 79 73 74  d+ \{\} 0\..Syst
0eb0: 65 6d 23 44 61 74 61 23 44 61 74 61 54 61 62 6c  em#Data#DataTabl
0ec0: 65 23 5c 64 2b 20 5c 7b 5c 7b 5c 7b 69 64 20 32  e#\d+ \{\{\{id 2
0ed0: 5c 7d 20 5c 7b 6d 69 6e 20 32 5c 7d 20 5c 7b 6d  \} \{min 2\} \{m
0ee0: 61 78 20 33 5c 7d 20 5c 7b 73 75 6d 20 35 5c 7d  ax 3\} \{sum 5\}
0ef0: 5c 7d 20 5c 7b 5c 7b 69 64 5c 0d 0a 32 5c 7d 20  \} \{\{id\..2\} 
0f00: 5c 7b 6d 69 6e 20 31 5c 7d 20 5c 7b 6d 61 78 20  \{min 1\} \{max 
0f10: 32 5c 7d 20 5c 7b 73 75 6d 20 33 5c 7d 5c 7d 5c  2\} \{sum 3\}\}\
0f20: 7d 24 7d 7d 0d 0a 0d 0a 23 23 23 23 23 23 23 23  }$}}....########
0f30: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f40: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f50: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f60: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0f70: 23 23 23 23 23 23 23 0d 0a 0d 0a 72 75 6e 53 51  #######....runSQ
0f80: 4c 69 74 65 54 65 73 74 45 70 69 6c 6f 67 75 65  LiteTestEpilogue
0f90: 0d 0a 72 75 6e 54 65 73 74 45 70 69 6c 6f 67 75  ..runTestEpilogu
0fa0: 65 0d 0a                                         e..