System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 9d1298c1980020a5da88d2bd04558c6ba74b8765:


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 30 30 66 38 36 66  .#..# tkt-00f86f
0060: 39 37 33 39 2e 65 61 67 6c 65 20 2d 2d 0d 0a 23  9739.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 23 0d 0a  #########....#..
0270: 23 20 4e 4f 54 45 3a 20 53 65 74 75 70 20 74 68  # NOTE: Setup th
0280: 65 20 76 61 72 69 61 62 6c 65 73 20 74 68 61 74  e variables that
0290: 20 72 65 66 65 72 20 74 6f 20 74 68 65 20 76 61   refer to the va
02a0: 72 69 6f 75 73 20 66 69 6c 65 73 20 72 65 71 75  rious files requ
02b0: 69 72 65 64 20 62 79 20 74 68 65 0d 0a 23 20 20  ired by the..#  
02c0: 20 20 20 20 20 74 65 73 74 73 20 69 6e 20 74 68       tests in th
02d0: 69 73 20 66 69 6c 65 2e 0d 0a 23 0d 0a 73 65 74  is file...#..set
02e0: 20 65 6e 74 69 74 79 46 72 61 6d 65 77 6f 72 6b   entityFramework
02f0: 44 6c 6c 46 69 6c 65 20 5b 67 65 74 42 75 69 6c  DllFile [getBuil
0300: 64 46 69 6c 65 4e 61 6d 65 20 45 6e 74 69 74 79  dFileName Entity
0310: 46 72 61 6d 65 77 6f 72 6b 2e 64 6c 6c 5d 0d 0a  Framework.dll]..
0320: 73 65 74 20 73 79 73 74 65 6d 44 61 74 61 53 51  set systemDataSQ
0330: 4c 69 74 65 44 6c 6c 46 69 6c 65 20 5b 67 65 74  LiteDllFile [get
0340: 42 75 69 6c 64 46 69 6c 65 4e 61 6d 65 20 53 79  BuildFileName Sy
0350: 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65  stem.Data.SQLite
0360: 2e 64 6c 6c 5d 0d 0a 73 65 74 20 73 79 73 74 65  .dll]..set syste
0370: 6d 44 61 74 61 53 51 4c 69 74 65 4c 69 6e 71 44  mDataSQLiteLinqD
0380: 6c 6c 46 69 6c 65 20 5b 67 65 74 42 75 69 6c 64  llFile [getBuild
0390: 46 69 6c 65 4e 61 6d 65 20 53 79 73 74 65 6d 2e  FileName System.
03a0: 44 61 74 61 2e 53 51 4c 69 74 65 2e 4c 69 6e 71  Data.SQLite.Linq
03b0: 2e 64 6c 6c 5d 0d 0a 73 65 74 20 73 79 73 74 65  .dll]..set syste
03c0: 6d 44 61 74 61 53 51 4c 69 74 65 45 66 36 44 6c  mDataSQLiteEf6Dl
03d0: 6c 46 69 6c 65 20 5b 67 65 74 42 75 69 6c 64 46  lFile [getBuildF
03e0: 69 6c 65 4e 61 6d 65 20 53 79 73 74 65 6d 2e 44  ileName System.D
03f0: 61 74 61 2e 53 51 4c 69 74 65 2e 45 46 36 2e 64  ata.SQLite.EF6.d
0400: 6c 6c 5d 0d 0a 73 65 74 20 74 65 73 74 4c 69 6e  ll]..set testLin
0410: 71 45 78 65 46 69 6c 65 20 5b 67 65 74 42 75 69  qExeFile [getBui
0420: 6c 64 46 69 6c 65 4e 61 6d 65 20 74 65 73 74 6c  ldFileName testl
0430: 69 6e 71 2e 65 78 65 5d 0d 0a 73 65 74 20 74 65  inq.exe]..set te
0440: 73 74 45 66 36 45 78 65 46 69 6c 65 20 5b 67 65  stEf6ExeFile [ge
0450: 74 42 75 69 6c 64 46 69 6c 65 4e 61 6d 65 20 74  tBuildFileName t
0460: 65 73 74 65 66 36 2e 65 78 65 5d 0d 0a 73 65 74  estef6.exe]..set
0470: 20 6e 6f 72 74 68 77 69 6e 64 45 66 44 62 46 69   northwindEfDbFi
0480: 6c 65 20 5b 66 69 6c 65 20 6e 61 74 69 76 65 6e  le [file nativen
0490: 61 6d 65 20 5b 66 69 6c 65 20 6a 6f 69 6e 20 5b  ame [file join [
04a0: 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 70 61  file dirname $pa
04b0: 74 68 5d 20 5c 0d 0a 20 20 20 20 74 65 73 74 6c  th] \..    testl
04c0: 69 6e 71 20 6e 6f 72 74 68 77 69 6e 64 45 46 2e  inq northwindEF.
04d0: 64 62 5d 5d 0d 0a 0d 0a 23 0d 0a 23 20 4e 4f 54  db]]....#..# NOT
04e0: 45 3a 20 53 65 74 75 70 20 74 68 65 20 74 65 73  E: Setup the tes
04f0: 74 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 73 70  t constraints sp
0500: 65 63 69 66 69 63 20 74 6f 20 74 68 65 20 74 65  ecific to the te
0510: 73 74 73 20 69 6e 20 74 68 69 73 20 66 69 6c 65  sts in this file
0520: 2e 0d 0a 23 0d 0a 69 66 20 7b 21 5b 68 61 76 65  ...#..if {![have
0530: 43 6f 6e 73 74 72 61 69 6e 74 20 5b 61 70 70 65  Constraint [appe
0540: 6e 64 41 72 67 73 20 66 69 6c 65 5f 20 5c 0d 0a  ndArgs file_ \..
0550: 20 20 20 20 5b 66 69 6c 65 20 74 61 69 6c 20 24      [file tail $
0560: 65 6e 74 69 74 79 46 72 61 6d 65 77 6f 72 6b 44  entityFrameworkD
0570: 6c 6c 46 69 6c 65 5d 5d 5d 7d 20 74 68 65 6e 20  llFile]]]} then 
0580: 7b 0d 0a 20 20 63 68 65 63 6b 46 6f 72 46 69 6c  {..  checkForFil
0590: 65 20 24 74 65 73 74 5f 63 68 61 6e 6e 65 6c 20  e $test_channel 
05a0: 24 65 6e 74 69 74 79 46 72 61 6d 65 77 6f 72 6b  $entityFramework
05b0: 44 6c 6c 46 69 6c 65 0d 0a 7d 0d 0a 0d 0a 69 66  DllFile..}....if
05c0: 20 7b 21 5b 68 61 76 65 43 6f 6e 73 74 72 61 69   {![haveConstrai
05d0: 6e 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20 66  nt [appendArgs f
05e0: 69 6c 65 5f 20 5c 0d 0a 20 20 20 20 5b 66 69 6c  ile_ \..    [fil
05f0: 65 20 74 61 69 6c 20 24 73 79 73 74 65 6d 44 61  e tail $systemDa
0600: 74 61 53 51 4c 69 74 65 44 6c 6c 46 69 6c 65 5d  taSQLiteDllFile]
0610: 5d 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 63 68  ]]} then {..  ch
0620: 65 63 6b 46 6f 72 46 69 6c 65 20 24 74 65 73 74  eckForFile $test
0630: 5f 63 68 61 6e 6e 65 6c 20 24 73 79 73 74 65 6d  _channel $system
0640: 44 61 74 61 53 51 4c 69 74 65 44 6c 6c 46 69 6c  DataSQLiteDllFil
0650: 65 0d 0a 7d 0d 0a 0d 0a 69 66 20 7b 21 5b 68 61  e..}....if {![ha
0660: 76 65 43 6f 6e 73 74 72 61 69 6e 74 20 5b 61 70  veConstraint [ap
0670: 70 65 6e 64 41 72 67 73 20 66 69 6c 65 5f 20 5c  pendArgs file_ \
0680: 0d 0a 20 20 20 20 5b 66 69 6c 65 20 74 61 69 6c  ..    [file tail
0690: 20 24 73 79 73 74 65 6d 44 61 74 61 53 51 4c 69   $systemDataSQLi
06a0: 74 65 4c 69 6e 71 44 6c 6c 46 69 6c 65 5d 5d 5d  teLinqDllFile]]]
06b0: 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 63 68 65 63  } then {..  chec
06c0: 6b 46 6f 72 46 69 6c 65 20 24 74 65 73 74 5f 63  kForFile $test_c
06d0: 68 61 6e 6e 65 6c 20 24 73 79 73 74 65 6d 44 61  hannel $systemDa
06e0: 74 61 53 51 4c 69 74 65 4c 69 6e 71 44 6c 6c 46  taSQLiteLinqDllF
06f0: 69 6c 65 0d 0a 7d 0d 0a 0d 0a 69 66 20 7b 21 5b  ile..}....if {![
0700: 68 61 76 65 43 6f 6e 73 74 72 61 69 6e 74 20 5b  haveConstraint [
0710: 61 70 70 65 6e 64 41 72 67 73 20 66 69 6c 65 5f  appendArgs file_
0720: 20 5c 0d 0a 20 20 20 20 5b 66 69 6c 65 20 74 61   \..    [file ta
0730: 69 6c 20 24 73 79 73 74 65 6d 44 61 74 61 53 51  il $systemDataSQ
0740: 4c 69 74 65 45 66 36 44 6c 6c 46 69 6c 65 5d 5d  LiteEf6DllFile]]
0750: 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 63 68 65  ]} then {..  che
0760: 63 6b 46 6f 72 46 69 6c 65 20 24 74 65 73 74 5f  ckForFile $test_
0770: 63 68 61 6e 6e 65 6c 20 24 73 79 73 74 65 6d 44  channel $systemD
0780: 61 74 61 53 51 4c 69 74 65 45 66 36 44 6c 6c 46  ataSQLiteEf6DllF
0790: 69 6c 65 0d 0a 7d 0d 0a 0d 0a 69 66 20 7b 21 5b  ile..}....if {![
07a0: 68 61 76 65 43 6f 6e 73 74 72 61 69 6e 74 20 5b  haveConstraint [
07b0: 61 70 70 65 6e 64 41 72 67 73 20 66 69 6c 65 5f  appendArgs file_
07c0: 20 5b 66 69 6c 65 20 74 61 69 6c 20 24 74 65 73   [file tail $tes
07d0: 74 4c 69 6e 71 45 78 65 46 69 6c 65 5d 5d 5d 7d  tLinqExeFile]]]}
07e0: 20 74 68 65 6e 20 7b 0d 0a 20 20 63 68 65 63 6b   then {..  check
07f0: 46 6f 72 46 69 6c 65 20 24 74 65 73 74 5f 63 68  ForFile $test_ch
0800: 61 6e 6e 65 6c 20 24 74 65 73 74 4c 69 6e 71 45  annel $testLinqE
0810: 78 65 46 69 6c 65 0d 0a 7d 0d 0a 0d 0a 69 66 20  xeFile..}....if 
0820: 7b 21 5b 68 61 76 65 43 6f 6e 73 74 72 61 69 6e  {![haveConstrain
0830: 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20 66 69  t [appendArgs fi
0840: 6c 65 5f 20 5b 66 69 6c 65 20 74 61 69 6c 20 24  le_ [file tail $
0850: 74 65 73 74 45 66 36 45 78 65 46 69 6c 65 5d 5d  testEf6ExeFile]]
0860: 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20 20 63 68 65  ]} then {..  che
0870: 63 6b 46 6f 72 46 69 6c 65 20 24 74 65 73 74 5f  ckForFile $test_
0880: 63 68 61 6e 6e 65 6c 20 24 74 65 73 74 45 66 36  channel $testEf6
0890: 45 78 65 46 69 6c 65 0d 0a 7d 0d 0a 0d 0a 69 66  ExeFile..}....if
08a0: 20 7b 21 5b 68 61 76 65 43 6f 6e 73 74 72 61 69   {![haveConstrai
08b0: 6e 74 20 5b 61 70 70 65 6e 64 41 72 67 73 20 66  nt [appendArgs f
08c0: 69 6c 65 5f 20 5b 66 69 6c 65 20 74 61 69 6c 20  ile_ [file tail 
08d0: 24 6e 6f 72 74 68 77 69 6e 64 45 66 44 62 46 69  $northwindEfDbFi
08e0: 6c 65 5d 5d 5d 7d 20 74 68 65 6e 20 7b 0d 0a 20  le]]]} then {.. 
08f0: 20 63 68 65 63 6b 46 6f 72 46 69 6c 65 20 24 74   checkForFile $t
0900: 65 73 74 5f 63 68 61 6e 6e 65 6c 20 24 6e 6f 72  est_channel $nor
0910: 74 68 77 69 6e 64 45 66 44 62 46 69 6c 65 0d 0a  thwindEfDbFile..
0920: 7d 0d 0a 0d 0a 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 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 0d 0a 0d 0a 72 75 6e 54 65 73 74 20  ####....runTest 
0980: 7b 74 65 73 74 20 74 6b 74 2d 30 30 66 38 36 66  {test tkt-00f86f
0990: 39 37 33 39 2d 31 2e 31 20 7b 4c 49 4e 51 20 77  9739-1.1 {LINQ w
09a0: 69 74 68 20 53 74 61 72 74 73 57 69 74 68 7d 20  ith StartsWith} 
09b0: 2d 62 6f 64 79 20 7b 0d 0a 20 20 23 0d 0a 20 20  -body {..  #..  
09c0: 23 20 4e 4f 54 45 3a 20 52 65 2d 63 6f 70 79 20  # NOTE: Re-copy 
09d0: 74 68 65 20 72 65 66 65 72 65 6e 63 65 20 64 61  the reference da
09e0: 74 61 62 61 73 65 20 66 69 6c 65 20 75 73 65 64  tabase file used
09f0: 20 66 6f 72 20 74 68 69 73 20 75 6e 69 74 20 74   for this unit t
0a00: 65 73 74 20 74 6f 20 74 68 65 0d 0a 20 20 23 20  est to the..  # 
0a10: 20 20 20 20 20 20 62 75 69 6c 64 20 64 69 72 65        build dire
0a20: 63 74 6f 72 79 20 69 6e 20 63 61 73 65 20 69 74  ctory in case it
0a30: 20 68 61 73 20 62 65 65 6e 20 63 68 61 6e 67 65   has been change
0a40: 64 20 62 79 20 61 20 70 72 65 76 69 6f 75 73 20  d by a previous 
0a50: 74 65 73 74 20 72 75 6e 2e 0d 0a 20 20 23 0d 0a  test run...  #..
0a60: 20 20 66 69 6c 65 20 63 6f 70 79 20 2d 66 6f 72    file copy -for
0a70: 63 65 20 24 6e 6f 72 74 68 77 69 6e 64 45 66 44  ce $northwindEfD
0a80: 62 46 69 6c 65 20 5c 0d 0a 20 20 20 20 20 20 5b  bFile \..      [
0a90: 66 69 6c 65 20 6a 6f 69 6e 20 5b 67 65 74 42 75  file join [getBu
0aa0: 69 6c 64 44 69 72 65 63 74 6f 72 79 5d 20 5b 66  ildDirectory] [f
0ab0: 69 6c 65 20 74 61 69 6c 20 24 6e 6f 72 74 68 77  ile tail $northw
0ac0: 69 6e 64 45 66 44 62 46 69 6c 65 5d 5d 0d 0a 0d  indEfDbFile]]...
0ad0: 0a 20 20 73 65 74 20 72 65 73 75 6c 74 20 5b 6c  .  set result [l
0ae0: 69 73 74 5d 0d 0a 0d 0a 20 20 66 6f 72 65 61 63  ist]....  foreac
0af0: 68 20 76 61 6c 75 65 20 5b 6c 69 73 74 20 22 22  h value [list ""
0b00: 20 61 20 62 20 7a 20 31 2b 31 20 64 6f 6e 20 6e   a b z 1+1 don n
0b10: 6f 74 74 68 65 72 65 5d 20 7b 0d 0a 20 20 20 20  otthere] {..    
0b20: 73 65 74 20 6f 75 74 70 75 74 20 22 22 0d 0a 0d  set output ""...
0b30: 0a 20 20 20 20 73 65 74 20 63 6f 64 65 20 5b 63  .    set code [c
0b40: 61 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 74 65  atch {..      te
0b50: 73 74 43 6c 72 45 78 65 63 20 24 74 65 73 74 4c  stClrExec $testL
0b60: 69 6e 71 45 78 65 46 69 6c 65 20 5b 6c 69 73 74  inqExeFile [list
0b70: 20 2d 65 76 65 6e 74 66 6c 61 67 73 20 57 61 69   -eventflags Wai
0b80: 74 20 2d 64 69 72 65 63 74 6f 72 79 20 5c 0d 0a  t -directory \..
0b90: 20 20 20 20 20 20 20 20 20 20 5b 66 69 6c 65 20            [file 
0ba0: 64 69 72 6e 61 6d 65 20 24 74 65 73 74 4c 69 6e  dirname $testLin
0bb0: 71 45 78 65 46 69 6c 65 5d 20 2d 6e 6f 63 61 72  qExeFile] -nocar
0bc0: 72 69 61 67 65 72 65 74 75 72 6e 73 20 2d 73 74  riagereturns -st
0bd0: 64 6f 75 74 20 6f 75 74 70 75 74 20 5c 0d 0a 20  dout output \.. 
0be0: 20 20 20 20 20 20 20 20 20 2d 73 75 63 63 65 73           -succes
0bf0: 73 20 30 5d 20 2d 73 74 61 72 74 73 57 69 74 68  s 0] -startsWith
0c00: 20 24 76 61 6c 75 65 0d 0a 20 20 20 20 7d 20 65   $value..    } e
0c10: 72 72 6f 72 5d 0d 0a 0d 0a 20 20 20 20 74 6c 6f  rror]....    tlo
0c20: 67 20 22 2d 2d 2d 2d 20 42 45 47 49 4e 20 53 54  g "---- BEGIN ST
0c30: 44 4f 55 54 20 4f 55 54 50 55 54 5c 6e 22 0d 0a  DOUT OUTPUT\n"..
0c40: 20 20 20 20 74 6c 6f 67 20 24 6f 75 74 70 75 74      tlog $output
0c50: 0d 0a 20 20 20 20 74 6c 6f 67 20 22 5c 6e 2d 2d  ..    tlog "\n--
0c60: 2d 2d 20 45 4e 44 20 53 54 44 4f 55 54 20 4f 55  -- END STDOUT OU
0c70: 54 50 55 54 5c 6e 22 0d 0a 0d 0a 20 20 20 20 6c  TPUT\n"....    l
0c80: 61 70 70 65 6e 64 20 72 65 73 75 6c 74 20 24 63  append result $c
0c90: 6f 64 65 0d 0a 0d 0a 20 20 20 20 69 66 20 7b 24  ode....    if {$
0ca0: 63 6f 64 65 20 3d 3d 20 30 7d 20 74 68 65 6e 20  code == 0} then 
0cb0: 7b 0d 0a 20 20 20 20 20 20 6c 61 70 70 65 6e 64  {..      lappend
0cc0: 20 72 65 73 75 6c 74 20 5b 73 74 72 69 6e 67 20   result [string 
0cd0: 74 72 69 6d 20 24 6f 75 74 70 75 74 5d 0d 0a 20  trim $output].. 
0ce0: 20 20 20 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20     } else {..   
0cf0: 20 20 20 6c 61 70 70 65 6e 64 20 72 65 73 75 6c     lappend resul
0d00: 74 20 5b 73 74 72 69 6e 67 20 74 72 69 6d 20 24  t [string trim $
0d10: 65 72 72 6f 72 5d 0d 0a 20 20 20 20 7d 0d 0a 20  error]..    }.. 
0d20: 20 7d 0d 0a 0d 0a 20 20 73 65 74 20 72 65 73 75   }....  set resu
0d30: 6c 74 0d 0a 7d 20 2d 63 6c 65 61 6e 75 70 20 7b  lt..} -cleanup {
0d40: 0d 0a 20 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d  ..  unset -nocom
0d50: 70 6c 61 69 6e 20 63 6f 64 65 20 6f 75 74 70 75  plain code outpu
0d60: 74 20 65 72 72 6f 72 20 72 65 73 75 6c 74 20 76  t error result v
0d70: 61 6c 75 65 0d 0a 7d 20 2d 63 6f 6e 73 74 72 61  alue..} -constra
0d80: 69 6e 74 73 20 5c 0d 0a 7b 65 61 67 6c 65 20 6d  ints \..{eagle m
0d90: 6f 6e 6f 54 6f 44 6f 20 64 65 66 69 6e 65 43 6f  onoToDo defineCo
0da0: 6e 73 74 61 6e 74 2e 53 79 73 74 65 6d 2e 44 61  nstant.System.Da
0db0: 74 61 2e 53 51 4c 69 74 65 2e 55 53 45 5f 49 4e  ta.SQLite.USE_IN
0dc0: 54 45 52 4f 50 5f 44 4c 4c 5c 0d 0a 64 65 66 69  TEROP_DLL\..defi
0dd0: 6e 65 43 6f 6e 73 74 61 6e 74 2e 53 79 73 74 65  neConstant.Syste
0de0: 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e 49 4e  m.Data.SQLite.IN
0df0: 54 45 52 4f 50 5f 45 58 54 45 4e 53 49 4f 4e 5f  TEROP_EXTENSION_
0e00: 46 55 4e 43 54 49 4f 4e 53 20 53 51 4c 69 74 65  FUNCTIONS SQLite
0e10: 20 74 65 73 74 45 78 65 63 5c 0d 0a 66 69 6c 65   testExec\..file
0e20: 5f 53 79 73 74 65 6d 2e 44 61 74 61 2e 53 51 4c  _System.Data.SQL
0e30: 69 74 65 2e 64 6c 6c 20 66 69 6c 65 5f 53 79 73  ite.dll file_Sys
0e40: 74 65 6d 2e 44 61 74 61 2e 53 51 4c 69 74 65 2e  tem.Data.SQLite.
0e50: 4c 69 6e 71 2e 64 6c 6c 20 66 69 6c 65 5f 74 65  Linq.dll file_te
0e60: 73 74 6c 69 6e 71 2e 65 78 65 5c 0d 0a 66 69 6c  stlinq.exe\..fil
0e70: 65 5f 6e 6f 72 74 68 77 69 6e 64 45 46 2e 64 62  e_northwindEF.db
0e80: 7d 20 2d 72 65 73 75 6c 74 20 7b 30 20 7b 7d 20  } -result {0 {} 
0e90: 30 20 7b 44 52 41 43 44 20 4f 4c 44 57 4f 20 52  0 {DRACD OLDWO R
0ea0: 41 54 54 43 7d 20 30 20 7b 41 4c 46 4b 49 20 43  ATTC} 0 {ALFKI C
0eb0: 41 43 54 55 20 43 48 4f 50 53 5c 0d 0a 46 4f 4c  ACTU CHOPS\..FOL
0ec0: 4b 4f 20 47 41 4c 45 44 20 4b 4f 45 4e 45 20 4c  KO GALED KOENE L
0ed0: 49 4c 41 53 20 4d 41 47 41 41 20 4d 41 49 53 44  ILAS MAGAA MAISD
0ee0: 20 4f 43 45 41 4e 20 52 41 4e 43 48 20 53 41 56   OCEAN RANCH SAV
0ef0: 45 41 20 54 48 45 43 52 7d 20 30 20 7b 7d 20 30  EA THECR} 0 {} 0
0f00: 20 7b 7d 20 30 20 7b 7d 20 30 5c 0d 0a 7b 7d 7d   {} 0 {} 0\..{}}
0f10: 7d 0d 0a 0d 0a 23 23 23 23 23 23 23 23 23 23 23  }....###########
0f20: 23 23 23 23 23 23 23 23 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 0d 0a 0d 0a 72 75 6e 54 65 73 74 20  ####....runTest 
0f70: 7b 74 65 73 74 20 74 6b 74 2d 30 30 66 38 36 66  {test tkt-00f86f
0f80: 39 37 33 39 2d 31 2e 32 20 7b 45 46 36 20 77 69  9739-1.2 {EF6 wi
0f90: 74 68 20 53 74 61 72 74 73 57 69 74 68 7d 20 2d  th StartsWith} -
0fa0: 62 6f 64 79 20 7b 0d 0a 20 20 23 0d 0a 20 20 23  body {..  #..  #
0fb0: 20 4e 4f 54 45 3a 20 52 65 2d 63 6f 70 79 20 74   NOTE: Re-copy t
0fc0: 68 65 20 72 65 66 65 72 65 6e 63 65 20 64 61 74  he reference dat
0fd0: 61 62 61 73 65 20 66 69 6c 65 20 75 73 65 64 20  abase file used 
0fe0: 66 6f 72 20 74 68 69 73 20 75 6e 69 74 20 74 65  for this unit te
0ff0: 73 74 20 74 6f 20 74 68 65 0d 0a 20 20 23 20 20  st to the..  #  
1000: 20 20 20 20 20 62 75 69 6c 64 20 64 69 72 65 63       build direc
1010: 74 6f 72 79 20 69 6e 20 63 61 73 65 20 69 74 20  tory in case it 
1020: 68 61 73 20 62 65 65 6e 20 63 68 61 6e 67 65 64  has been changed
1030: 20 62 79 20 61 20 70 72 65 76 69 6f 75 73 20 74   by a previous t
1040: 65 73 74 20 72 75 6e 2e 0d 0a 20 20 23 0d 0a 20  est run...  #.. 
1050: 20 66 69 6c 65 20 63 6f 70 79 20 2d 66 6f 72 63   file copy -forc
1060: 65 20 24 6e 6f 72 74 68 77 69 6e 64 45 66 44 62  e $northwindEfDb
1070: 46 69 6c 65 20 5c 0d 0a 20 20 20 20 20 20 5b 66  File \..      [f
1080: 69 6c 65 20 6a 6f 69 6e 20 5b 67 65 74 42 75 69  ile join [getBui
1090: 6c 64 44 69 72 65 63 74 6f 72 79 5d 20 5b 66 69  ldDirectory] [fi
10a0: 6c 65 20 74 61 69 6c 20 24 6e 6f 72 74 68 77 69  le tail $northwi
10b0: 6e 64 45 66 44 62 46 69 6c 65 5d 5d 0d 0a 0d 0a  ndEfDbFile]]....
10c0: 20 20 73 65 74 20 72 65 73 75 6c 74 20 5b 6c 69    set result [li
10d0: 73 74 5d 0d 0a 0d 0a 20 20 66 6f 72 65 61 63 68  st]....  foreach
10e0: 20 76 61 6c 75 65 20 5b 6c 69 73 74 20 22 22 20   value [list "" 
10f0: 61 20 62 20 7a 20 31 2b 31 20 64 6f 6e 20 6e 6f  a b z 1+1 don no
1100: 74 74 68 65 72 65 5d 20 7b 0d 0a 20 20 20 20 73  tthere] {..    s
1110: 65 74 20 6f 75 74 70 75 74 20 22 22 0d 0a 0d 0a  et output ""....
1120: 20 20 20 20 73 65 74 20 63 6f 64 65 20 5b 63 61      set code [ca
1130: 74 63 68 20 7b 0d 0a 20 20 20 20 20 20 74 65 73  tch {..      tes
1140: 74 43 6c 72 45 78 65 63 20 24 74 65 73 74 45 66  tClrExec $testEf
1150: 36 45 78 65 46 69 6c 65 20 5b 6c 69 73 74 20 2d  6ExeFile [list -
1160: 65 76 65 6e 74 66 6c 61 67 73 20 57 61 69 74 20  eventflags Wait 
1170: 2d 64 69 72 65 63 74 6f 72 79 20 5c 0d 0a 20 20  -directory \..  
1180: 20 20 20 20 20 20 20 20 5b 66 69 6c 65 20 64 69          [file di
1190: 72 6e 61 6d 65 20 24 74 65 73 74 45 66 36 45 78  rname $testEf6Ex
11a0: 65 46 69 6c 65 5d 20 2d 6e 6f 63 61 72 72 69 61  eFile] -nocarria
11b0: 67 65 72 65 74 75 72 6e 73 20 2d 73 74 64 6f 75  gereturns -stdou
11c0: 74 20 6f 75 74 70 75 74 20 5c 0d 0a 20 20 20 20  t output \..    
11d0: 20 20 20 20 20 20 2d 73 75 63 63 65 73 73 20 30        -success 0
11e0: 5d 20 2d 73 74 61 72 74 73 57 69 74 68 20 24 76  ] -startsWith $v
11f0: 61 6c 75 65 0d 0a 20 20 20 20 7d 20 65 72 72 6f  alue..    } erro
1200: 72 5d 0d 0a 0d 0a 20 20 20 20 74 6c 6f 67 20 22  r]....    tlog "
1210: 2d 2d 2d 2d 20 42 45 47 49 4e 20 53 54 44 4f 55  ---- BEGIN STDOU
1220: 54 20 4f 55 54 50 55 54 5c 6e 22 0d 0a 20 20 20  T OUTPUT\n"..   
1230: 20 74 6c 6f 67 20 24 6f 75 74 70 75 74 0d 0a 20   tlog $output.. 
1240: 20 20 20 74 6c 6f 67 20 22 5c 6e 2d 2d 2d 2d 20     tlog "\n---- 
1250: 45 4e 44 20 53 54 44 4f 55 54 20 4f 55 54 50 55  END STDOUT OUTPU
1260: 54 5c 6e 22 0d 0a 0d 0a 20 20 20 20 6c 61 70 70  T\n"....    lapp
1270: 65 6e 64 20 72 65 73 75 6c 74 20 24 63 6f 64 65  end result $code
1280: 0d 0a 0d 0a 20 20 20 20 69 66 20 7b 24 63 6f 64  ....    if {$cod
1290: 65 20 3d 3d 20 30 7d 20 74 68 65 6e 20 7b 0d 0a  e == 0} then {..
12a0: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65        lappend re
12b0: 73 75 6c 74 20 5b 73 74 72 69 6e 67 20 74 72 69  sult [string tri
12c0: 6d 20 24 6f 75 74 70 75 74 5d 0d 0a 20 20 20 20  m $output]..    
12d0: 7d 20 65 6c 73 65 20 7b 0d 0a 20 20 20 20 20 20  } else {..      
12e0: 6c 61 70 70 65 6e 64 20 72 65 73 75 6c 74 20 5b  lappend result [
12f0: 73 74 72 69 6e 67 20 74 72 69 6d 20 24 65 72 72  string trim $err
1300: 6f 72 5d 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d  or]..    }..  }.
1310: 0a 0d 0a 20 20 73 65 74 20 72 65 73 75 6c 74 0d  ...  set result.
1320: 0a 7d 20 2d 63 6c 65 61 6e 75 70 20 7b 0d 0a 20  .} -cleanup {.. 
1330: 20 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61   unset -nocompla
1340: 69 6e 20 63 6f 64 65 20 6f 75 74 70 75 74 20 65  in code output e
1350: 72 72 6f 72 20 72 65 73 75 6c 74 20 76 61 6c 75  rror result valu
1360: 65 0d 0a 7d 20 2d 63 6f 6e 73 74 72 61 69 6e 74  e..} -constraint
1370: 73 20 5c 0d 0a 7b 65 61 67 6c 65 20 6d 6f 6e 6f  s \..{eagle mono
1380: 54 6f 44 6f 20 64 65 66 69 6e 65 43 6f 6e 73 74  ToDo defineConst
1390: 61 6e 74 2e 53 79 73 74 65 6d 2e 44 61 74 61 2e  ant.System.Data.
13a0: 53 51 4c 69 74 65 2e 55 53 45 5f 49 4e 54 45 52  SQLite.USE_INTER
13b0: 4f 50 5f 44 4c 4c 5c 0d 0a 64 65 66 69 6e 65 43  OP_DLL\..defineC
13c0: 6f 6e 73 74 61 6e 74 2e 53 79 73 74 65 6d 2e 44  onstant.System.D
13d0: 61 74 61 2e 53 51 4c 69 74 65 2e 49 4e 54 45 52  ata.SQLite.INTER
13e0: 4f 50 5f 45 58 54 45 4e 53 49 4f 4e 5f 46 55 4e  OP_EXTENSION_FUN
13f0: 43 54 49 4f 4e 53 20 53 51 4c 69 74 65 20 74 65  CTIONS SQLite te
1400: 73 74 45 78 65 63 5c 0d 0a 66 69 6c 65 5f 45 6e  stExec\..file_En
1410: 74 69 74 79 46 72 61 6d 65 77 6f 72 6b 2e 64 6c  tityFramework.dl
1420: 6c 20 66 69 6c 65 5f 53 79 73 74 65 6d 2e 44 61  l file_System.Da
1430: 74 61 2e 53 51 4c 69 74 65 2e 64 6c 6c 5c 0d 0a  ta.SQLite.dll\..
1440: 66 69 6c 65 5f 53 79 73 74 65 6d 2e 44 61 74 61  file_System.Data
1450: 2e 53 51 4c 69 74 65 2e 45 46 36 2e 64 6c 6c 20  .SQLite.EF6.dll 
1460: 66 69 6c 65 5f 74 65 73 74 65 66 36 2e 65 78 65  file_testef6.exe
1470: 20 66 69 6c 65 5f 6e 6f 72 74 68 77 69 6e 64 45   file_northwindE
1480: 46 2e 64 62 7d 20 2d 72 65 73 75 6c 74 20 5c 0d  F.db} -result \.
1490: 0a 7b 30 20 7b 7d 20 30 20 7b 44 52 41 43 44 20  .{0 {} 0 {DRACD 
14a0: 4f 4c 44 57 4f 20 52 41 54 54 43 7d 20 30 20 7b  OLDWO RATTC} 0 {
14b0: 41 4c 46 4b 49 20 43 41 43 54 55 20 43 48 4f 50  ALFKI CACTU CHOP
14c0: 53 20 46 4f 4c 4b 4f 20 47 41 4c 45 44 20 4b 4f  S FOLKO GALED KO
14d0: 45 4e 45 20 4c 49 4c 41 53 20 4d 41 47 41 41 5c  ENE LILAS MAGAA\
14e0: 0d 0a 4d 41 49 53 44 20 4f 43 45 41 4e 20 52 41  ..MAISD OCEAN RA
14f0: 4e 43 48 20 53 41 56 45 41 20 54 48 45 43 52 7d  NCH SAVEA THECR}
1500: 20 30 20 7b 7d 20 30 20 7b 7d 20 30 20 7b 7d 20   0 {} 0 {} 0 {} 
1510: 30 20 7b 7d 7d 7d 0d 0a 0d 0a 23 23 23 23 23 23  0 {}}}....######
1520: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1530: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1540: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1550: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1560: 23 23 23 23 23 23 23 23 23 0d 0a 0d 0a 75 6e 73  #########....uns
1570: 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e 20 6e  et -nocomplain n
1580: 6f 72 74 68 77 69 6e 64 45 66 44 62 46 69 6c 65  orthwindEfDbFile
1590: 20 74 65 73 74 45 66 36 45 78 65 46 69 6c 65 20   testEf6ExeFile 
15a0: 74 65 73 74 4c 69 6e 71 45 78 65 46 69 6c 65 20  testLinqExeFile 
15b0: 5c 0d 0a 20 20 20 20 73 79 73 74 65 6d 44 61 74  \..    systemDat
15c0: 61 53 51 4c 69 74 65 45 66 36 44 6c 6c 46 69 6c  aSQLiteEf6DllFil
15d0: 65 20 73 79 73 74 65 6d 44 61 74 61 53 51 4c 69  e systemDataSQLi
15e0: 74 65 4c 69 6e 71 44 6c 6c 46 69 6c 65 20 5c 0d  teLinqDllFile \.
15f0: 0a 20 20 20 20 73 79 73 74 65 6d 44 61 74 61 53  .    systemDataS
1600: 51 4c 69 74 65 44 6c 6c 46 69 6c 65 20 65 6e 74  QLiteDllFile ent
1610: 69 74 79 46 72 61 6d 65 77 6f 72 6b 44 6c 6c 46  ityFrameworkDllF
1620: 69 6c 65 0d 0a 0d 0a 23 23 23 23 23 23 23 23 23  ile....#########
1630: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1640: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1650: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1660: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1670: 23 23 23 23 23 23 0d 0a 0d 0a 72 75 6e 53 51 4c  ######....runSQL
1680: 69 74 65 54 65 73 74 45 70 69 6c 6f 67 75 65 0d  iteTestEpilogue.
1690: 0a 72 75 6e 54 65 73 74 45 70 69 6c 6f 67 75 65  .runTestEpilogue
16a0: 0d 0a                                            ..