System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact ed0aa7542183a435756bd6e20cd36520362b345e:


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 33 31 31 33 37 33  .#..# tkt-311373
0060: 34 36 30 35 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  4605.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 33  Test {test tkt-3
0280: 31 31 33 37 33 34 36 30 35 2d 31 2e 31 20 7b 43  113734605-1.1 {C
0290: 6f 6c 75 6d 6e 53 69 7a 65 20 61 6e 64 20 4e 75  olumnSize and Nu
02a0: 6d 65 72 69 63 50 72 65 63 69 73 69 6f 6e 7d 20  mericPrecision} 
02b0: 2d 73 65 74 75 70 20 7b 0d 0a 20 20 73 65 74 75  -setup {..  setu
02c0: 70 44 62 20 5b 73 65 74 20 66 69 6c 65 4e 61 6d  pDb [set fileNam
02d0: 65 20 74 6b 74 2d 33 31 31 33 37 33 34 36 30 35  e tkt-3113734605
02e0: 2d 31 2e 31 2e 64 62 5d 0d 0a 7d 20 2d 62 6f 64  -1.1.db]..} -bod
02f0: 79 20 7b 0d 0a 20 20 73 65 74 20 63 6f 6e 6e 65  y {..  set conne
0300: 63 74 69 6f 6e 20 5b 67 65 74 44 62 43 6f 6e 6e  ction [getDbConn
0310: 65 63 74 69 6f 6e 5d 0d 0a 0d 0a 20 20 73 65 74  ection]....  set
0320: 20 72 65 73 75 6c 74 20 5b 6c 69 73 74 5d 0d 0a   result [list]..
0330: 0d 0a 20 20 73 71 6c 20 65 78 65 63 75 74 65 20  ..  sql execute 
0340: 24 64 62 20 7b 0d 0a 20 20 20 20 43 52 45 41 54  $db {..    CREAT
0350: 45 20 54 41 42 4c 45 20 74 31 28 0d 0a 20 20 20  E TABLE t1(..   
0360: 20 20 20 76 20 42 49 4e 41 52 59 28 31 32 29 2c     v BINARY(12),
0370: 20 77 20 43 48 41 52 28 32 33 29 2c 20 78 20 4e   w CHAR(23), x N
0380: 43 48 41 52 28 33 34 29 2c 20 79 20 56 41 52 43  CHAR(34), y VARC
0390: 48 41 52 28 34 35 29 2c 20 7a 20 4e 56 41 52 43  HAR(45), z NVARC
03a0: 48 41 52 28 35 36 29 0d 0a 20 20 20 20 29 3b 0d  HAR(56)..    );.
03b0: 0a 20 20 7d 0d 0a 0d 0a 20 20 73 71 6c 20 65 78  .  }....  sql ex
03c0: 65 63 75 74 65 20 24 64 62 20 22 43 52 45 41 54  ecute $db "CREAT
03d0: 45 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c  E VIEW v1 AS SEL
03e0: 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b 22 0d  ECT * FROM t1;".
03f0: 0a 0d 0a 20 20 66 6f 72 65 61 63 68 20 63 6f 6c  ...  foreach col
0400: 6c 65 63 74 69 6f 6e 4e 61 6d 65 20 5b 6c 69 73  lectionName [lis
0410: 74 20 54 41 42 4c 45 43 4f 4c 55 4d 4e 53 20 56  t TABLECOLUMNS V
0420: 49 45 57 43 4f 4c 55 4d 4e 53 5d 20 7b 0d 0a 20  IEWCOLUMNS] {.. 
0430: 20 20 20 73 65 74 20 64 61 74 61 54 61 62 6c 65     set dataTable
0440: 20 5b 6f 62 6a 65 63 74 20 69 6e 76 6f 6b 65 20   [object invoke 
0450: 2d 61 6c 69 61 73 20 24 63 6f 6e 6e 65 63 74 69  -alias $connecti
0460: 6f 6e 20 47 65 74 53 63 68 65 6d 61 20 24 63 6f  on GetSchema $co
0470: 6c 6c 65 63 74 69 6f 6e 4e 61 6d 65 5d 0d 0a 0d  llectionName]...
0480: 0a 20 20 20 20 69 66 20 7b 5b 73 74 72 69 6e 67  .    if {[string
0490: 20 6c 65 6e 67 74 68 20 24 64 61 74 61 54 61 62   length $dataTab
04a0: 6c 65 5d 20 3e 20 30 7d 20 74 68 65 6e 20 7b 0d  le] > 0} then {.
04b0: 0a 20 20 20 20 20 20 73 65 74 20 64 61 74 61 52  .      set dataR
04c0: 6f 77 73 20 5b 24 64 61 74 61 54 61 62 6c 65 20  ows [$dataTable 
04d0: 52 6f 77 73 5d 0d 0a 0d 0a 20 20 20 20 20 20 6f  Rows]....      o
04e0: 62 6a 65 63 74 20 66 6f 72 65 61 63 68 20 2d 61  bject foreach -a
04f0: 6c 69 61 73 20 64 61 74 61 52 6f 77 20 24 64 61  lias dataRow $da
0500: 74 61 52 6f 77 73 20 7b 0d 0a 20 20 20 20 20 20  taRows {..      
0510: 20 20 6c 61 70 70 65 6e 64 20 72 65 73 75 6c 74    lappend result
0520: 20 5b 73 65 74 20 76 61 6c 75 65 20 5b 24 64 61   [set value [$da
0530: 74 61 52 6f 77 20 67 65 74 5f 49 74 65 6d 20 54  taRow get_Item T
0540: 41 42 4c 45 5f 4e 41 4d 45 5d 5d 0d 0a 20 20 20  ABLE_NAME]]..   
0550: 20 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65 73       lappend res
0560: 75 6c 74 20 5b 73 65 74 20 76 61 6c 75 65 20 5b  ult [set value [
0570: 24 64 61 74 61 52 6f 77 20 67 65 74 5f 49 74 65  $dataRow get_Ite
0580: 6d 20 43 4f 4c 55 4d 4e 5f 4e 41 4d 45 5d 5d 0d  m COLUMN_NAME]].
0590: 0a 20 20 20 20 20 20 20 20 6c 61 70 70 65 6e 64  .        lappend
05a0: 20 72 65 73 75 6c 74 20 5b 73 65 74 20 76 61 6c   result [set val
05b0: 75 65 20 5b 24 64 61 74 61 52 6f 77 20 67 65 74  ue [$dataRow get
05c0: 5f 49 74 65 6d 20 43 48 41 52 41 43 54 45 52 5f  _Item CHARACTER_
05d0: 4d 41 58 49 4d 55 4d 5f 4c 45 4e 47 54 48 5d 5d  MAXIMUM_LENGTH]]
05e0: 0d 0a 20 20 20 20 20 20 20 20 6c 61 70 70 65 6e  ..        lappen
05f0: 64 20 72 65 73 75 6c 74 20 5b 73 65 74 20 76 61  d result [set va
0600: 6c 75 65 20 5b 24 64 61 74 61 52 6f 77 20 67 65  lue [$dataRow ge
0610: 74 5f 49 74 65 6d 20 4e 55 4d 45 52 49 43 5f 50  t_Item NUMERIC_P
0620: 52 45 43 49 53 49 4f 4e 5d 5d 0d 0a 20 20 20 20  RECISION]]..    
0630: 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d    }..    }..  }.
0640: 0a 0d 0a 20 20 73 65 74 20 72 65 73 75 6c 74 0d  ...  set result.
0650: 0a 7d 20 2d 63 6c 65 61 6e 75 70 20 7b 0d 0a 20  .} -cleanup {.. 
0660: 20 63 6c 65 61 6e 75 70 44 62 20 24 66 69 6c 65   cleanupDb $file
0670: 4e 61 6d 65 0d 0a 0d 0a 20 20 66 72 65 65 44 62  Name....  freeDb
0680: 43 6f 6e 6e 65 63 74 69 6f 6e 0d 0a 0d 0a 20 20  Connection....  
0690: 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69  unset -nocomplai
06a0: 6e 20 76 61 6c 75 65 20 64 61 74 61 52 6f 77 20  n value dataRow 
06b0: 64 61 74 61 52 6f 77 73 20 64 61 74 61 54 61 62  dataRows dataTab
06c0: 6c 65 20 63 6f 6c 6c 65 63 74 69 6f 6e 4e 61 6d  le collectionNam
06d0: 65 20 72 65 73 75 6c 74 20 5c 0d 0a 20 20 20 20  e result \..    
06e0: 20 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 64 62 20    connection db 
06f0: 66 69 6c 65 4e 61 6d 65 0d 0a 7d 20 2d 63 6f 6e  fileName..} -con
0700: 73 74 72 61 69 6e 74 73 20 5c 0d 0a 7b 65 61 67  straints \..{eag
0710: 6c 65 20 6d 6f 6e 6f 42 75 67 32 38 20 63 6f 6d  le monoBug28 com
0720: 6d 61 6e 64 2e 73 71 6c 20 63 6f 6d 70 69 6c 65  mand.sql compile
0730: 2e 44 41 54 41 20 53 51 4c 69 74 65 20 53 79 73  .DATA SQLite Sys
0740: 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 7d  tem.Data.SQLite}
0750: 20 2d 6d 61 74 63 68 20 5c 0d 0a 72 65 67 65 78   -match \..regex
0760: 70 20 2d 72 65 73 75 6c 74 20 7b 5e 74 31 20 76  p -result {^t1 v
0770: 20 31 32 20 53 79 73 74 65 6d 23 44 42 4e 75 6c   12 System#DBNul
0780: 6c 23 5c 64 2b 20 74 31 20 77 20 32 33 20 53 79  l#\d+ t1 w 23 Sy
0790: 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20  stem#DBNull#\d+ 
07a0: 74 31 20 78 20 33 34 5c 0d 0a 53 79 73 74 65 6d  t1 x 34\..System
07b0: 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 74 31 20 79  #DBNull#\d+ t1 y
07c0: 20 34 35 20 53 79 73 74 65 6d 23 44 42 4e 75 6c   45 System#DBNul
07d0: 6c 23 5c 64 2b 20 74 31 20 7a 20 35 36 20 53 79  l#\d+ t1 z 56 Sy
07e0: 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20  stem#DBNull#\d+ 
07f0: 76 31 20 76 20 31 32 5c 0d 0a 53 79 73 74 65 6d  v1 v 12\..System
0800: 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 76 31 20 77  #DBNull#\d+ v1 w
0810: 20 32 33 20 53 79 73 74 65 6d 23 44 42 4e 75 6c   23 System#DBNul
0820: 6c 23 5c 64 2b 20 76 31 20 78 20 33 34 20 53 79  l#\d+ v1 x 34 Sy
0830: 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20  stem#DBNull#\d+ 
0840: 76 31 20 79 20 34 35 5c 0d 0a 53 79 73 74 65 6d  v1 y 45\..System
0850: 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 76 31 20 7a  #DBNull#\d+ v1 z
0860: 20 35 36 20 53 79 73 74 65 6d 23 44 42 4e 75 6c   56 System#DBNul
0870: 6c 23 5c 64 2b 20 74 31 20 76 20 31 32 20 53 79  l#\d+ t1 v 12 Sy
0880: 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20  stem#DBNull#\d+ 
0890: 74 31 20 77 20 32 33 5c 0d 0a 53 79 73 74 65 6d  t1 w 23\..System
08a0: 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 74 31 20 78  #DBNull#\d+ t1 x
08b0: 20 33 34 20 53 79 73 74 65 6d 23 44 42 4e 75 6c   34 System#DBNul
08c0: 6c 23 5c 64 2b 20 74 31 20 79 20 34 35 20 53 79  l#\d+ t1 y 45 Sy
08d0: 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20  stem#DBNull#\d+ 
08e0: 74 31 20 7a 20 35 36 5c 0d 0a 53 79 73 74 65 6d  t1 z 56\..System
08f0: 23 44 42 4e 75 6c 6c 23 5c 64 2b 24 7d 7d 0d 0a  #DBNull#\d+$}}..
0900: 0d 0a 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ..##############
0910: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0920: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0930: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0940: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0950: 23 0d 0a 0d 0a 72 75 6e 53 51 4c 69 74 65 54 65  #....runSQLiteTe
0960: 73 74 45 70 69 6c 6f 67 75 65 0d 0a 72 75 6e 54  stEpilogue..runT
0970: 65 73 74 45 70 69 6c 6f 67 75 65 0d 0a           estEpilogue..