System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact c90fd8f31f1e650b2dd0371fd2269c4906154af6:


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 35 32 35 31 62 64  .#..# tkt-5251bd
0060: 30 38 37 38 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  0878.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 35  Test {test tkt-5
0280: 32 35 31 62 64 30 38 37 38 2d 31 2e 31 20 7b 69  251bd0878-1.1 {i
0290: 6e 64 65 78 65 64 20 65 78 70 72 65 73 73 69 6f  ndexed expressio
02a0: 6e 73 20 73 63 68 65 6d 61 7d 20 2d 73 65 74 75  ns schema} -setu
02b0: 70 20 7b 0d 0a 20 20 73 65 74 75 70 44 62 20 5b  p {..  setupDb [
02c0: 73 65 74 20 66 69 6c 65 4e 61 6d 65 20 74 6b 74  set fileName tkt
02d0: 2d 35 32 35 31 62 64 30 38 37 38 2d 31 2e 31 2e  -5251bd0878-1.1.
02e0: 64 62 5d 0d 0a 7d 20 2d 62 6f 64 79 20 7b 0d 0a  db]..} -body {..
02f0: 20 20 73 65 74 20 63 6f 6e 6e 65 63 74 69 6f 6e    set connection
0300: 20 5b 67 65 74 44 62 43 6f 6e 6e 65 63 74 69 6f   [getDbConnectio
0310: 6e 5d 0d 0a 0d 0a 20 20 73 71 6c 20 65 78 65 63  n]....  sql exec
0320: 75 74 65 20 24 64 62 20 7b 0d 0a 20 20 20 20 43  ute $db {..    C
0330: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78  REATE TABLE t1(x
0340: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59   INTEGER PRIMARY
0350: 20 4b 45 59 2c 20 79 20 49 4e 54 45 47 45 52 29   KEY, y INTEGER)
0360: 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  ;..    INSERT IN
0370: 54 4f 20 74 31 20 28 79 29 20 56 41 4c 55 45 53  TO t1 (y) VALUES
0380: 20 28 2d 32 30 30 30 29 3b 0d 0a 20 20 20 20 49   (-2000);..    I
0390: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28 79  NSERT INTO t1 (y
03a0: 29 20 56 41 4c 55 45 53 20 28 2d 31 30 30 30 29  ) VALUES (-1000)
03b0: 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  ;..    INSERT IN
03c0: 54 4f 20 74 31 20 28 79 29 20 56 41 4c 55 45 53  TO t1 (y) VALUES
03d0: 20 28 2d 32 30 30 29 3b 0d 0a 20 20 20 20 49 4e   (-200);..    IN
03e0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28 79 29  SERT INTO t1 (y)
03f0: 20 56 41 4c 55 45 53 20 28 2d 31 30 30 29 3b 0d   VALUES (-100);.
0400: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0410: 20 74 31 20 28 79 29 20 56 41 4c 55 45 53 20 28   t1 (y) VALUES (
0420: 2d 32 30 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52  -20);..    INSER
0430: 54 20 49 4e 54 4f 20 74 31 20 28 79 29 20 56 41  T INTO t1 (y) VA
0440: 4c 55 45 53 20 28 2d 31 30 29 3b 0d 0a 20 20 20  LUES (-10);..   
0450: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0460: 28 79 29 20 56 41 4c 55 45 53 20 28 30 29 3b 0d  (y) VALUES (0);.
0470: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
0480: 20 74 31 20 28 79 29 20 56 41 4c 55 45 53 20 28   t1 (y) VALUES (
0490: 31 30 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54  10);..    INSERT
04a0: 20 49 4e 54 4f 20 74 31 20 28 79 29 20 56 41 4c   INTO t1 (y) VAL
04b0: 55 45 53 20 28 32 30 29 3b 0d 0a 20 20 20 20 49  UES (20);..    I
04c0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 28 79  NSERT INTO t1 (y
04d0: 29 20 56 41 4c 55 45 53 20 28 31 30 30 29 3b 0d  ) VALUES (100);.
04e0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
04f0: 20 74 31 20 28 79 29 20 56 41 4c 55 45 53 20 28   t1 (y) VALUES (
0500: 32 30 30 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52  200);..    INSER
0510: 54 20 49 4e 54 4f 20 74 31 20 28 79 29 20 56 41  T INTO t1 (y) VA
0520: 4c 55 45 53 20 28 31 30 30 30 29 3b 0d 0a 20 20  LUES (1000);..  
0530: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
0540: 20 28 79 29 20 56 41 4c 55 45 53 20 28 32 30 30   (y) VALUES (200
0550: 30 29 3b 0d 0a 20 20 20 20 49 4e 53 45 52 54 20  0);..    INSERT 
0560: 49 4e 54 4f 20 74 31 20 28 79 29 20 56 41 4c 55  INTO t1 (y) VALU
0570: 45 53 20 28 31 30 30 30 30 29 3b 0d 0a 20 20 20  ES (10000);..   
0580: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0590: 28 79 29 20 56 41 4c 55 45 53 20 28 32 30 30 30  (y) VALUES (2000
05a0: 30 29 3b 0d 0a 20 20 20 20 43 52 45 41 54 45 20  0);..    CREATE 
05b0: 49 4e 44 45 58 20 69 31 20 4f 4e 20 74 31 28 78  INDEX i1 ON t1(x
05c0: 2c 20 61 62 73 28 79 29 29 3b 0d 0a 20 20 7d 0d  , abs(y));..  }.
05d0: 0a 0d 0a 20 20 73 65 74 20 64 61 74 61 52 65 61  ...  set dataRea
05e0: 64 65 72 20 5b 73 71 6c 20 65 78 65 63 75 74 65  der [sql execute
05f0: 20 2d 65 78 65 63 75 74 65 20 72 65 61 64 65 72   -execute reader
0600: 20 2d 66 6f 72 6d 61 74 20 64 61 74 61 72 65 61   -format datarea
0610: 64 65 72 20 5c 0d 0a 20 20 20 20 20 20 2d 61 6c  der \..      -al
0620: 69 61 73 20 24 64 62 20 22 53 45 4c 45 43 54 20  ias $db "SELECT 
0630: 78 2c 20 79 20 46 52 4f 4d 20 74 31 3b 22 5d 0d  x, y FROM t1;"].
0640: 0a 0d 0a 20 20 73 65 74 20 64 61 74 61 54 61 62  ...  set dataTab
0650: 6c 65 20 5b 24 64 61 74 61 52 65 61 64 65 72 20  le [$dataReader 
0660: 2d 61 6c 69 61 73 20 47 65 74 53 63 68 65 6d 61  -alias GetSchema
0670: 54 61 62 6c 65 5d 0d 0a 20 20 73 65 74 20 72 65  Table]..  set re
0680: 73 75 6c 74 20 5b 6c 69 73 74 5d 0d 0a 0d 0a 20  sult [list].... 
0690: 20 66 6f 72 65 61 63 68 20 72 6f 77 20 5b 67 65   foreach row [ge
06a0: 74 52 6f 77 73 46 72 6f 6d 44 61 74 61 54 61 62  tRowsFromDataTab
06b0: 6c 65 20 24 64 61 74 61 54 61 62 6c 65 5d 20 7b  le $dataTable] {
06c0: 0d 0a 20 20 20 20 66 6f 72 65 61 63 68 20 63 6f  ..    foreach co
06d0: 6c 75 6d 6e 20 24 72 6f 77 20 7b 0d 0a 20 20 20  lumn $row {..   
06e0: 20 20 20 69 66 20 7b 5b 6c 69 6e 64 65 78 20 24     if {[lindex $
06f0: 63 6f 6c 75 6d 6e 20 30 5d 20 69 6e 20 5b 6c 69  column 0] in [li
0700: 73 74 20 43 6f 6c 75 6d 6e 4e 61 6d 65 20 49 73  st ColumnName Is
0710: 4b 65 79 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20  Key]} then {..  
0720: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65        lappend re
0730: 73 75 6c 74 20 24 63 6f 6c 75 6d 6e 0d 0a 20 20  sult $column..  
0740: 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20 20      }..    }..  
0750: 7d 0d 0a 0d 0a 20 20 73 65 74 20 72 65 73 75 6c  }....  set resul
0760: 74 0d 0a 7d 20 2d 63 6c 65 61 6e 75 70 20 7b 0d  t..} -cleanup {.
0770: 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70  .  unset -nocomp
0780: 6c 61 69 6e 20 64 61 74 61 54 61 62 6c 65 20 64  lain dataTable d
0790: 61 74 61 52 65 61 64 65 72 0d 0a 0d 0a 20 20 63  ataReader....  c
07a0: 6c 65 61 6e 75 70 44 62 20 24 66 69 6c 65 4e 61  leanupDb $fileNa
07b0: 6d 65 0d 0a 0d 0a 20 20 66 72 65 65 44 62 43 6f  me....  freeDbCo
07c0: 6e 6e 65 63 74 69 6f 6e 0d 0a 0d 0a 20 20 75 6e  nnection....  un
07d0: 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20  set -nocomplain 
07e0: 63 6f 6c 75 6d 6e 20 72 6f 77 20 72 65 73 75 6c  column row resul
07f0: 74 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 64 62 20  t connection db 
0800: 66 69 6c 65 4e 61 6d 65 0d 0a 7d 20 2d 63 6f 6e  fileName..} -con
0810: 73 74 72 61 69 6e 74 73 20 7b 65 61 67 6c 65 20  straints {eagle 
0820: 63 6f 6d 6d 61 6e 64 2e 6f 62 6a 65 63 74 20 6d  command.object m
0830: 6f 6e 6f 42 75 67 32 38 20 6d 6f 6e 6f 42 75 67  onoBug28 monoBug
0840: 32 31 31 20 63 6f 6d 6d 61 6e 64 2e 73 71 6c 5c  211 command.sql\
0850: 0d 0a 63 6f 6d 70 69 6c 65 2e 44 41 54 41 20 53  ..compile.DATA S
0860: 51 4c 69 74 65 20 53 79 73 74 65 6d 2e 44 61 74  QLite System.Dat
0870: 61 2e 53 51 4c 69 74 65 7d 20 2d 72 65 73 75 6c  a.SQLite} -resul
0880: 74 20 7b 7b 43 6f 6c 75 6d 6e 4e 61 6d 65 20 78  t {{ColumnName x
0890: 7d 20 7b 49 73 4b 65 79 20 54 72 75 65 7d 5c 0d  } {IsKey True}\.
08a0: 0a 7b 43 6f 6c 75 6d 6e 4e 61 6d 65 20 79 7d 20  .{ColumnName y} 
08b0: 7b 49 73 4b 65 79 20 46 61 6c 73 65 7d 7d 7d 0d  {IsKey False}}}.
08c0: 0a 0d 0a 23 23 23 23 23 23 23 23 23 23 23 23 23  ...#############
08d0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
08e0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
08f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0900: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0910: 23 23 0d 0a 0d 0a 72 75 6e 53 51 4c 69 74 65 54  ##....runSQLiteT
0920: 65 73 74 45 70 69 6c 6f 67 75 65 0d 0a 72 75 6e  estEpilogue..run
0930: 54 65 73 74 45 70 69 6c 6f 67 75 65 0d 0a        TestEpilogue..