System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 97056cb055e471e6c869a8758e7571355359bedf:


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 7b 65 61 67 6c 65 20  straints {eagle 
0710: 63 6f 6d 6d 61 6e 64 2e 6f 62 6a 65 63 74 20 6d  command.object m
0720: 6f 6e 6f 42 75 67 32 38 20 63 6f 6d 6d 61 6e 64  onoBug28 command
0730: 2e 73 71 6c 20 63 6f 6d 70 69 6c 65 2e 44 41 54  .sql compile.DAT
0740: 41 20 53 51 4c 69 74 65 5c 0d 0a 53 79 73 74 65  A SQLite\..Syste
0750: 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 7d 20 2d  m.Data.SQLite} -
0760: 6d 61 74 63 68 20 72 65 67 65 78 70 20 2d 72 65  match regexp -re
0770: 73 75 6c 74 20 7b 5e 74 31 20 76 20 31 32 20 53  sult {^t1 v 12 S
0780: 79 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b  ystem#DBNull#\d+
0790: 20 74 31 20 77 20 32 33 5c 0d 0a 53 79 73 74 65   t1 w 23\..Syste
07a0: 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 74 31 20  m#DBNull#\d+ t1 
07b0: 78 20 33 34 20 53 79 73 74 65 6d 23 44 42 4e 75  x 34 System#DBNu
07c0: 6c 6c 23 5c 64 2b 20 74 31 20 79 20 34 35 20 53  ll#\d+ t1 y 45 S
07d0: 79 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b  ystem#DBNull#\d+
07e0: 20 74 31 20 7a 20 35 36 5c 0d 0a 53 79 73 74 65   t1 z 56\..Syste
07f0: 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 76 31 20  m#DBNull#\d+ v1 
0800: 76 20 31 32 20 53 79 73 74 65 6d 23 44 42 4e 75  v 12 System#DBNu
0810: 6c 6c 23 5c 64 2b 20 76 31 20 77 20 32 33 20 53  ll#\d+ v1 w 23 S
0820: 79 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b  ystem#DBNull#\d+
0830: 20 76 31 20 78 20 33 34 5c 0d 0a 53 79 73 74 65   v1 x 34\..Syste
0840: 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 76 31 20  m#DBNull#\d+ v1 
0850: 79 20 34 35 20 53 79 73 74 65 6d 23 44 42 4e 75  y 45 System#DBNu
0860: 6c 6c 23 5c 64 2b 20 76 31 20 7a 20 35 36 20 53  ll#\d+ v1 z 56 S
0870: 79 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b  ystem#DBNull#\d+
0880: 20 74 31 20 76 20 31 32 5c 0d 0a 53 79 73 74 65   t1 v 12\..Syste
0890: 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 74 31 20  m#DBNull#\d+ t1 
08a0: 77 20 32 33 20 53 79 73 74 65 6d 23 44 42 4e 75  w 23 System#DBNu
08b0: 6c 6c 23 5c 64 2b 20 74 31 20 78 20 33 34 20 53  ll#\d+ t1 x 34 S
08c0: 79 73 74 65 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b  ystem#DBNull#\d+
08d0: 20 74 31 20 79 20 34 35 5c 0d 0a 53 79 73 74 65   t1 y 45\..Syste
08e0: 6d 23 44 42 4e 75 6c 6c 23 5c 64 2b 20 74 31 20  m#DBNull#\d+ t1 
08f0: 7a 20 35 36 20 53 79 73 74 65 6d 23 44 42 4e 75  z 56 System#DBNu
0900: 6c 6c 23 5c 64 2b 24 7d 7d 0d 0a 0d 0a 23 23 23  ll#\d+$}}....###
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 23 23 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a  ############....
0960: 72 75 6e 53 51 4c 69 74 65 54 65 73 74 45 70 69  runSQLiteTestEpi
0970: 6c 6f 67 75 65 0d 0a 72 75 6e 54 65 73 74 45 70  logue..runTestEp
0980: 69 6c 6f 67 75 65 0d 0a                          ilogue..