/ Hex Artifact Content
Login

Artifact 249f139ef2f75710db1b49bb79e8b27767eacae1:


0000: 23 20 32 30 30 31 20 53 65 70 74 65 6d 62 65 72  # 2001 September
0010: 20 31 35 0a 23 0a 23 20 54 68 65 20 61 75 74 68   15.#.# The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67  place of.# a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23  is a blessing:.#
0080: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f  .#    May you do
0090: 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76   good and not ev
00a0: 69 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75  il..#    May you
00b0: 20 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73   find forgivenes
00c0: 73 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61  s for yourself a
00d0: 6e 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72  nd forgive other
00e0: 73 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  s..#    May you 
00f0: 73 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65  share freely, ne
0100: 76 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20  ver taking more 
0110: 74 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23  than you give..#
0120: 0a 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .#**************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73  *********.# This
0170: 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73   file implements
0180: 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74   regression test
0190: 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62  s for SQLite lib
01a0: 72 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63  rary.  The.# foc
01b0: 75 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20  us of this file 
01c0: 69 73 20 65 78 65 72 63 69 73 69 6e 67 20 74 68  is exercising th
01d0: 65 20 63 6f 64 65 20 69 6e 20 6d 61 69 6e 2e 63  e code in main.c
01e0: 2e 0a 23 0a 23 20 24 49 64 3a 20 6d 61 69 6e 2e  ..#.# $Id: main.
01f0: 74 65 73 74 2c 76 20 31 2e 32 31 20 32 30 30 35  test,v 1.21 2005
0200: 2f 30 38 2f 31 32 20 32 32 3a 35 38 3a 35 33 20  /08/12 22:58:53 
0210: 64 72 68 20 45 78 70 20 24 0a 0a 73 65 74 20 74  drh Exp $..set t
0220: 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69 72  estdir [file dir
0230: 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f 75  name $argv0].sou
0240: 72 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73  rce $testdir/tes
0250: 74 65 72 2e 74 63 6c 0a 0a 23 20 4f 6e 6c 79 20  ter.tcl..# Only 
0260: 64 6f 20 74 68 65 20 6e 65 78 74 20 67 72 6f 75  do the next grou
0270: 70 20 6f 66 20 74 65 73 74 73 20 69 66 20 74 68  p of tests if th
0280: 65 20 73 71 6c 69 74 65 33 5f 63 6f 6d 70 6c 65  e sqlite3_comple
0290: 74 65 20 41 50 49 20 69 73 20 61 76 61 69 6c 61  te API is availa
02a0: 62 6c 65 0a 23 0a 69 66 63 61 70 61 62 6c 65 20  ble.#.ifcapable 
02b0: 7b 63 6f 6d 70 6c 65 74 65 7d 20 7b 0a 0a 23 20  {complete} {..# 
02c0: 54 65 73 74 73 20 6f 66 20 74 68 65 20 73 71 6c  Tests of the sql
02d0: 69 74 65 5f 63 6f 6d 70 6c 65 74 65 28 29 20 66  ite_complete() f
02e0: 75 6e 63 74 69 6f 6e 2e 0a 23 0a 64 6f 5f 74 65  unction..#.do_te
02f0: 73 74 20 6d 61 69 6e 2d 31 2e 31 20 7b 0a 20 20  st main-1.1 {.  
0300: 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 54 68 69  db complete {Thi
0310: 73 20 69 73 20 61 20 74 65 73 74 7d 0a 7d 20 7b  s is a test}.} {
0320: 30 7d 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d  0}.do_test main-
0330: 31 2e 32 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c  1.2 {.  db compl
0340: 65 74 65 20 7b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a  ete {.  }.} {1}.
0350: 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 33  do_test main-1.3
0360: 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65   {.  db complete
0370: 20 7b 0a 20 20 20 20 20 2d 2d 20 61 20 63 6f 6d   {.     -- a com
0380: 6d 65 6e 74 20 3b 0a 20 20 7d 0a 7d 20 7b 31 7d  ment ;.  }.} {1}
0390: 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e  .do_test main-1.
03a0: 34 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74  4 {.  db complet
03b0: 65 20 7b 0a 20 20 20 20 20 2d 2d 20 61 20 63 6f  e {.     -- a co
03c0: 6d 6d 65 6e 74 20 3b 0a 20 20 20 20 20 3b 0a 20  mment ;.     ;. 
03d0: 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74   }.} {1}.do_test
03e0: 20 6d 61 69 6e 2d 31 2e 35 20 7b 0a 20 20 64 62   main-1.5 {.  db
03f0: 20 63 6f 6d 70 6c 65 74 65 20 7b 44 52 4f 50 20   complete {DROP 
0400: 54 41 42 4c 45 20 27 78 79 7a 3b 7d 0a 7d 20 7b  TABLE 'xyz;}.} {
0410: 30 7d 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d  0}.do_test main-
0420: 31 2e 36 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c  1.6 {.  db compl
0430: 65 74 65 20 7b 44 52 4f 50 20 54 41 42 4c 45 20  ete {DROP TABLE 
0440: 27 78 79 7a 27 3b 7d 0a 7d 20 7b 31 7d 0a 64 6f  'xyz';}.} {1}.do
0450: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 37 20 7b  _test main-1.7 {
0460: 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b  .  db complete {
0470: 44 52 4f 50 20 54 41 42 4c 45 20 22 78 79 7a 3b  DROP TABLE "xyz;
0480: 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20  }.} {0}.do_test 
0490: 6d 61 69 6e 2d 31 2e 38 20 7b 0a 20 20 64 62 20  main-1.8 {.  db 
04a0: 63 6f 6d 70 6c 65 74 65 20 7b 44 52 4f 50 20 54  complete {DROP T
04b0: 41 42 4c 45 20 22 78 79 7a 27 3b 7d 0a 7d 20 7b  ABLE "xyz';}.} {
04c0: 30 7d 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d  0}.do_test main-
04d0: 31 2e 39 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c  1.9 {.  db compl
04e0: 65 74 65 20 7b 44 52 4f 50 20 54 41 42 4c 45 20  ete {DROP TABLE 
04f0: 22 78 79 7a 22 3b 7d 0a 7d 20 7b 31 7d 0a 64 6f  "xyz";}.} {1}.do
0500: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 31 30 20  _test main-1.10 
0510: 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20  {.  db complete 
0520: 7b 44 52 4f 50 20 54 41 42 4c 45 20 78 79 7a 3b  {DROP TABLE xyz;
0530: 20 68 69 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65   hi}.} {0}.do_te
0540: 73 74 20 6d 61 69 6e 2d 31 2e 31 31 20 7b 0a 20  st main-1.11 {. 
0550: 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 44 52   db complete {DR
0560: 4f 50 20 54 41 42 4c 45 20 78 79 7a 3b 20 7d 0a  OP TABLE xyz; }.
0570: 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 6d 61  } {1}.do_test ma
0580: 69 6e 2d 31 2e 31 32 20 7b 0a 20 20 64 62 20 63  in-1.12 {.  db c
0590: 6f 6d 70 6c 65 74 65 20 7b 44 52 4f 50 20 54 41  omplete {DROP TA
05a0: 42 4c 45 20 78 79 7a 3b 20 2d 2d 20 68 69 20 7d  BLE xyz; -- hi }
05b0: 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 6d  .} {1}.do_test m
05c0: 61 69 6e 2d 31 2e 31 33 20 7b 0a 20 20 64 62 20  ain-1.13 {.  db 
05d0: 63 6f 6d 70 6c 65 74 65 20 7b 44 52 4f 50 20 54  complete {DROP T
05e0: 41 42 4c 45 20 78 79 7a 3b 20 2d 2d 20 68 69 0a  ABLE xyz; -- hi.
05f0: 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73    }.} {1}.do_tes
0600: 74 20 6d 61 69 6e 2d 31 2e 31 34 20 7b 0a 20 20  t main-1.14 {.  
0610: 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 53 45 4c  db complete {SEL
0620: 45 43 54 20 61 2d 62 20 46 52 4f 4d 20 74 31 3b  ECT a-b FROM t1;
0630: 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74   }.} {1}.do_test
0640: 20 6d 61 69 6e 2d 31 2e 31 35 20 7b 0a 20 20 64   main-1.15 {.  d
0650: 62 20 63 6f 6d 70 6c 65 74 65 20 7b 53 45 4c 45  b complete {SELE
0660: 43 54 20 61 2f 65 20 46 52 4f 4d 20 74 31 20 7d  CT a/e FROM t1 }
0670: 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 6d  .} {0}.do_test m
0680: 61 69 6e 2d 31 2e 31 36 20 7b 0a 20 20 64 62 20  ain-1.16 {.  db 
0690: 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 43  complete {.    C
06a0: 52 45 41 54 45 20 54 41 42 4c 45 20 61 62 63 28  REATE TABLE abc(
06b0: 78 2c 79 29 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a  x,y);.  }.} {1}.
06c0: 69 66 63 61 70 61 62 6c 65 20 7b 74 72 69 67 67  ifcapable {trigg
06d0: 65 72 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20  er} {.  do_test 
06e0: 6d 61 69 6e 2d 31 2e 31 37 20 7b 0a 20 20 20 20  main-1.17 {.    
06f0: 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20  db complete {.  
0700: 20 20 20 20 43 52 45 41 54 45 20 54 52 49 47 47      CREATE TRIGG
0710: 45 52 20 78 79 7a 20 41 46 54 45 52 20 44 45 4c  ER xyz AFTER DEL
0720: 45 54 45 20 61 62 63 20 42 45 47 49 4e 20 55 50  ETE abc BEGIN UP
0730: 44 41 54 45 20 70 71 72 3b 0a 20 20 20 20 7d 0a  DATE pqr;.    }.
0740: 20 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73    } {0}.  do_tes
0750: 74 20 6d 61 69 6e 2d 31 2e 31 38 20 7b 0a 20 20  t main-1.18 {.  
0760: 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a    db complete {.
0770: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 52 49        CREATE TRI
0780: 47 47 45 52 20 78 79 7a 20 41 46 54 45 52 20 44  GGER xyz AFTER D
0790: 45 4c 45 54 45 20 61 62 63 20 42 45 47 49 4e 20  ELETE abc BEGIN 
07a0: 55 50 44 41 54 45 20 70 71 72 3b 20 45 4e 44 3b  UPDATE pqr; END;
07b0: 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 31 7d 0a 20  .    }.  } {1}. 
07c0: 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e   do_test main-1.
07d0: 31 39 20 7b 0a 20 20 20 20 64 62 20 63 6f 6d 70  19 {.    db comp
07e0: 6c 65 74 65 20 7b 0a 20 20 20 20 20 20 43 52 45  lete {.      CRE
07f0: 41 54 45 20 54 52 49 47 47 45 52 20 78 79 7a 20  ATE TRIGGER xyz 
0800: 41 46 54 45 52 20 44 45 4c 45 54 45 20 61 62 63  AFTER DELETE abc
0810: 20 42 45 47 49 4e 0a 20 20 20 20 20 20 20 20 20   BEGIN.         
0820: 55 50 44 41 54 45 20 70 71 72 3b 0a 20 20 20 20  UPDATE pqr;.    
0830: 20 20 20 20 20 75 6e 6b 6e 6f 77 6e 20 63 6f 6d       unknown com
0840: 6d 61 6e 64 3b 0a 20 20 20 20 7d 0a 20 20 7d 20  mand;.    }.  } 
0850: 7b 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d 61  {0}.  do_test ma
0860: 69 6e 2d 31 2e 32 30 20 7b 0a 20 20 20 20 64 62  in-1.20 {.    db
0870: 20 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20   complete {.    
0880: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
0890: 20 78 79 7a 20 41 46 54 45 52 20 44 45 4c 45 54   xyz AFTER DELET
08a0: 45 20 62 61 63 6b 65 6e 64 20 42 45 47 49 4e 0a  E backend BEGIN.
08b0: 20 20 20 20 20 20 20 20 20 55 50 44 41 54 45 20           UPDATE 
08c0: 70 71 72 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b  pqr;.    }.  } {
08d0: 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d 61 69  0}.  do_test mai
08e0: 6e 2d 31 2e 32 31 20 7b 0a 20 20 20 20 64 62 20  n-1.21 {.    db 
08f0: 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 20  complete {.     
0900: 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20   CREATE TRIGGER 
0910: 78 79 7a 20 41 46 54 45 52 20 44 45 4c 45 54 45  xyz AFTER DELETE
0920: 20 65 6e 64 20 42 45 47 49 4e 0a 20 20 20 20 20   end BEGIN.     
0930: 20 20 20 20 53 45 4c 45 43 54 20 61 2c 20 62 20      SELECT a, b 
0940: 46 52 4f 4d 20 65 6e 64 3b 0a 20 20 20 20 7d 0a  FROM end;.    }.
0950: 20 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73    } {0}.  do_tes
0960: 74 20 6d 61 69 6e 2d 31 2e 32 32 20 7b 0a 20 20  t main-1.22 {.  
0970: 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a    db complete {.
0980: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 52 49        CREATE TRI
0990: 47 47 45 52 20 78 79 7a 20 41 46 54 45 52 20 44  GGER xyz AFTER D
09a0: 45 4c 45 54 45 20 65 6e 64 20 42 45 47 49 4e 0a  ELETE end BEGIN.
09b0: 20 20 20 20 20 20 20 20 20 53 45 4c 45 43 54 20           SELECT 
09c0: 61 2c 20 62 20 46 52 4f 4d 20 65 6e 64 3b 0a 20  a, b FROM end;. 
09d0: 20 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 7d 0a       END;.    }.
09e0: 20 20 7d 20 7b 31 7d 0a 20 20 64 6f 5f 74 65 73    } {1}.  do_tes
09f0: 74 20 6d 61 69 6e 2d 31 2e 32 33 20 7b 0a 20 20  t main-1.23 {.  
0a00: 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a    db complete {.
0a10: 20 20 20 20 20 20 43 52 45 41 54 45 20 54 52 49        CREATE TRI
0a20: 47 47 45 52 20 78 79 7a 20 41 46 54 45 52 20 44  GGER xyz AFTER D
0a30: 45 4c 45 54 45 20 65 6e 64 20 42 45 47 49 4e 0a  ELETE end BEGIN.
0a40: 20 20 20 20 20 20 20 20 20 53 45 4c 45 43 54 20           SELECT 
0a50: 61 2c 20 62 20 46 52 4f 4d 20 65 6e 64 3b 0a 20  a, b FROM end;. 
0a60: 20 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 20 20       END;.      
0a70: 53 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f 4d  SELECT a, b FROM
0a80: 20 65 6e 64 3b 0a 20 20 20 20 7d 0a 20 20 7d 20   end;.    }.  } 
0a90: 7b 31 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d 61  {1}.  do_test ma
0aa0: 69 6e 2d 31 2e 32 34 20 7b 0a 20 20 20 20 64 62  in-1.24 {.    db
0ab0: 20 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20   complete {.    
0ac0: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
0ad0: 20 78 79 7a 20 41 46 54 45 52 20 44 45 4c 45 54   xyz AFTER DELET
0ae0: 45 20 5b 3b 65 6e 64 3b 5d 20 42 45 47 49 4e 0a  E [;end;] BEGIN.
0af0: 20 20 20 20 20 20 20 20 20 55 50 44 41 54 45 20           UPDATE 
0b00: 70 71 72 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b  pqr;.    }.  } {
0b10: 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d 61 69  0}.  do_test mai
0b20: 6e 2d 31 2e 32 35 20 7b 0a 20 20 20 20 64 62 20  n-1.25 {.    db 
0b30: 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 20  complete {.     
0b40: 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20   CREATE TRIGGER 
0b50: 78 79 7a 20 41 46 54 45 52 20 44 45 4c 45 54 45  xyz AFTER DELETE
0b60: 20 62 61 63 6b 65 6e 64 20 42 45 47 49 4e 0a 20   backend BEGIN. 
0b70: 20 20 20 20 20 20 20 20 55 50 44 41 54 45 20 70          UPDATE p
0b80: 71 72 20 53 45 54 20 61 3d 5b 3b 65 6e 64 3b 5d  qr SET a=[;end;]
0b90: 3b 3b 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 30  ;;;.    }.  } {0
0ba0: 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e  }.  do_test main
0bb0: 2d 31 2e 32 36 20 7b 0a 20 20 20 20 64 62 20 63  -1.26 {.    db c
0bc0: 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 20 20  omplete {.      
0bd0: 43 52 45 41 54 45 20 2d 2d 20 61 20 63 6f 6d 6d  CREATE -- a comm
0be0: 65 6e 74 0a 20 20 20 20 20 20 54 52 49 47 47 45  ent.      TRIGGE
0bf0: 52 20 78 79 7a 20 41 46 54 45 52 20 44 45 4c 45  R xyz AFTER DELE
0c00: 54 45 20 62 61 63 6b 65 6e 64 20 42 45 47 49 4e  TE backend BEGIN
0c10: 0a 20 20 20 20 20 20 20 20 20 55 50 44 41 54 45  .         UPDATE
0c20: 20 70 71 72 20 53 45 54 20 61 3d 35 3b 0a 20 20   pqr SET a=5;.  
0c30: 20 20 7d 0a 20 20 7d 20 7b 30 7d 0a 20 20 64 6f    }.  } {0}.  do
0c40: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 32 37 2e  _test main-1.27.
0c50: 31 20 7b 0a 20 20 20 20 64 62 20 63 6f 6d 70 6c  1 {.    db compl
0c60: 65 74 65 20 7b 0a 20 20 20 20 20 20 43 52 45 41  ete {.      CREA
0c70: 54 45 20 2d 2d 20 61 20 63 6f 6d 6d 65 6e 74 0a  TE -- a comment.
0c80: 20 20 20 20 20 20 54 52 49 47 47 45 52 58 20 78        TRIGGERX x
0c90: 79 7a 20 41 46 54 45 52 20 44 45 4c 45 54 45 20  yz AFTER DELETE 
0ca0: 62 61 63 6b 65 6e 64 20 42 45 47 49 4e 0a 20 20  backend BEGIN.  
0cb0: 20 20 20 20 20 20 20 55 50 44 41 54 45 20 70 71         UPDATE pq
0cc0: 72 20 53 45 54 20 61 3d 35 3b 0a 20 20 20 20 7d  r SET a=5;.    }
0cd0: 0a 20 20 7d 20 7b 31 7d 0a 20 20 64 6f 5f 74 65  .  } {1}.  do_te
0ce0: 73 74 20 6d 61 69 6e 2d 31 2e 32 37 2e 32 20 7b  st main-1.27.2 {
0cf0: 0a 20 20 20 20 64 62 20 63 6f 6d 70 6c 65 74 65  .    db complete
0d00: 20 7b 0a 20 20 20 20 20 20 43 52 45 41 54 45 2f   {.      CREATE/
0d10: 2a 2a 2f 54 52 49 47 47 45 52 20 78 79 7a 20 41  **/TRIGGER xyz A
0d20: 46 54 45 52 20 44 45 4c 45 54 45 20 62 61 63 6b  FTER DELETE back
0d30: 65 6e 64 20 42 45 47 49 4e 0a 20 20 20 20 20 20  end BEGIN.      
0d40: 20 20 20 55 50 44 41 54 45 20 70 71 72 20 53 45     UPDATE pqr SE
0d50: 54 20 61 3d 35 3b 0a 20 20 20 20 7d 0a 20 20 7d  T a=5;.    }.  }
0d60: 20 7b 30 7d 0a 20 20 69 66 63 61 70 61 62 6c 65   {0}.  ifcapable
0d70: 20 7b 65 78 70 6c 61 69 6e 7d 20 7b 0a 20 20 20   {explain} {.   
0d80: 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e   do_test main-1.
0d90: 32 37 2e 33 20 7b 0a 20 20 20 20 20 20 64 62 20  27.3 {.      db 
0da0: 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 20  complete {.     
0db0: 20 20 20 2f 2a 20 2a 2f 20 45 58 50 4c 41 49 4e     /* */ EXPLAIN
0dc0: 20 2d 2d 20 41 20 63 6f 6d 6d 65 6e 74 0a 20 20   -- A comment.  
0dd0: 20 20 20 20 20 20 43 52 45 41 54 45 2f 2a 2a 2f        CREATE/**/
0de0: 54 52 49 47 47 45 52 20 78 79 7a 20 41 46 54 45  TRIGGER xyz AFTE
0df0: 52 20 44 45 4c 45 54 45 20 62 61 63 6b 65 6e 64  R DELETE backend
0e00: 20 42 45 47 49 4e 0a 20 20 20 20 20 20 20 20 20   BEGIN.         
0e10: 20 20 55 50 44 41 54 45 20 70 71 72 20 53 45 54    UPDATE pqr SET
0e20: 20 61 3d 35 3b 0a 20 20 20 20 20 20 7d 0a 20 20   a=5;.      }.  
0e30: 20 20 7d 20 7b 30 7d 0a 20 20 7d 0a 20 20 64 6f    } {0}.  }.  do
0e40: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 32 37 2e  _test main-1.27.
0e50: 34 20 7b 0a 20 20 20 20 64 62 20 63 6f 6d 70 6c  4 {.    db compl
0e60: 65 74 65 20 7b 0a 20 20 20 20 20 20 42 4f 47 55  ete {.      BOGU
0e70: 53 20 74 6f 6b 65 6e 0a 20 20 20 20 20 20 43 52  S token.      CR
0e80: 45 41 54 45 20 20 54 52 49 47 47 45 52 20 78 79  EATE  TRIGGER xy
0e90: 7a 20 41 46 54 45 52 20 44 45 4c 45 54 45 20 62  z AFTER DELETE b
0ea0: 61 63 6b 65 6e 64 20 42 45 47 49 4e 0a 20 20 20  ackend BEGIN.   
0eb0: 20 20 20 20 20 20 55 50 44 41 54 45 20 70 71 72        UPDATE pqr
0ec0: 20 53 45 54 20 61 3d 35 3b 0a 20 20 20 20 7d 0a   SET a=5;.    }.
0ed0: 20 20 7d 20 7b 31 7d 0a 20 20 69 66 63 61 70 61    } {1}.  ifcapa
0ee0: 62 6c 65 20 7b 65 78 70 6c 61 69 6e 7d 20 7b 0a  ble {explain} {.
0ef0: 20 20 20 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e      do_test main
0f00: 2d 31 2e 32 37 2e 35 20 7b 0a 20 20 20 20 20 20  -1.27.5 {.      
0f10: 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20  db complete {.  
0f20: 20 20 20 20 20 20 45 58 50 4c 41 49 4e 20 0a 20        EXPLAIN . 
0f30: 20 20 20 20 20 20 20 43 52 45 41 54 45 20 54 45         CREATE TE
0f40: 4d 50 20 54 52 49 47 47 45 52 20 78 79 7a 20 41  MP TRIGGER xyz A
0f50: 46 54 45 52 20 44 45 4c 45 54 45 20 62 61 63 6b  FTER DELETE back
0f60: 65 6e 64 20 42 45 47 49 4e 0a 20 20 20 20 20 20  end BEGIN.      
0f70: 20 20 20 20 20 55 50 44 41 54 45 20 70 71 72 20       UPDATE pqr 
0f80: 53 45 54 20 61 3d 35 3b 0a 20 20 20 20 20 20 7d  SET a=5;.      }
0f90: 0a 20 20 20 20 7d 20 7b 30 7d 0a 20 20 7d 0a 20  .    } {0}.  }. 
0fa0: 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e   do_test main-1.
0fb0: 32 38 20 7b 0a 20 20 20 20 64 62 20 63 6f 6d 70  28 {.    db comp
0fc0: 6c 65 74 65 20 7b 0a 20 20 20 20 20 20 43 52 45  lete {.      CRE
0fd0: 41 54 45 20 54 45 4d 50 4f 52 41 52 59 20 54 52  ATE TEMPORARY TR
0fe0: 49 47 47 45 52 20 78 79 7a 20 41 46 54 45 52 20  IGGER xyz AFTER 
0ff0: 44 45 4c 45 54 45 20 62 61 63 6b 65 6e 64 20 42  DELETE backend B
1000: 45 47 49 4e 0a 20 20 20 20 20 20 20 20 20 55 50  EGIN.         UP
1010: 44 41 54 45 20 70 71 72 20 53 45 54 20 61 3d 35  DATE pqr SET a=5
1020: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 30 7d 0a  ;.    }.  } {0}.
1030: 20 20 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31    do_test main-1
1040: 2e 32 39 20 7b 0a 20 20 20 20 64 62 20 63 6f 6d  .29 {.    db com
1050: 70 6c 65 74 65 20 7b 0a 20 20 20 20 20 20 43 52  plete {.      CR
1060: 45 41 54 45 20 54 52 49 47 47 45 52 20 78 79 7a  EATE TRIGGER xyz
1070: 20 41 46 54 45 52 20 44 45 4c 45 54 45 20 62 61   AFTER DELETE ba
1080: 63 6b 65 6e 64 20 42 45 47 49 4e 0a 20 20 20 20  ckend BEGIN.    
1090: 20 20 20 20 20 55 50 44 41 54 45 20 70 71 72 20       UPDATE pqr 
10a0: 53 45 54 20 61 3d 35 3b 0a 20 20 20 20 20 20 20  SET a=5;.       
10b0: 20 20 45 58 50 4c 41 49 4e 20 73 65 6c 65 63 74    EXPLAIN select
10c0: 20 2a 20 66 72 6f 6d 20 78 79 7a 3b 0a 20 20 20   * from xyz;.   
10d0: 20 7d 0a 20 20 7d 20 7b 30 7d 0a 7d 0a 64 6f 5f   }.  } {0}.}.do_
10e0: 74 65 73 74 20 6d 61 69 6e 2d 31 2e 33 30 20 7b  test main-1.30 {
10f0: 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b  .  db complete {
1100: 0a 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42  .     CREATE TAB
1110: 4c 45 20 2f 2a 20 49 6e 20 63 6f 6d 6d 65 6e 74  LE /* In comment
1120: 20 3b 20 2a 2f 0a 20 20 7d 0a 7d 20 7b 30 7d 0a   ; */.  }.} {0}.
1130: 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 33  do_test main-1.3
1140: 31 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74  1 {.  db complet
1150: 65 20 7b 0a 20 20 20 20 20 43 52 45 41 54 45 20  e {.     CREATE 
1160: 54 41 42 4c 45 20 2f 2a 20 49 6e 20 63 6f 6d 6d  TABLE /* In comm
1170: 65 6e 74 20 3b 20 2a 2f 20 68 69 3b 0a 20 20 7d  ent ; */ hi;.  }
1180: 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 6d  .} {1}.do_test m
1190: 61 69 6e 2d 31 2e 33 31 20 7b 0a 20 20 64 62 20  ain-1.31 {.  db 
11a0: 63 6f 6d 70 6c 65 74 65 20 7b 0a 20 20 20 20 20  complete {.     
11b0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 2f 2a 20  CREATE TABLE /* 
11c0: 49 6e 20 63 6f 6d 6d 65 6e 74 20 3b 20 2a 2f 3b  In comment ; */;
11d0: 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65  .  }.} {1}.do_te
11e0: 73 74 20 6d 61 69 6e 2d 31 2e 33 32 20 7b 0a 20  st main-1.32 {. 
11f0: 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 0a 20   db complete {. 
1200: 20 20 20 20 73 74 75 66 66 3b 0a 20 20 20 20 20      stuff;.     
1210: 2f 2a 0a 20 20 20 20 20 20 20 43 52 45 41 54 45  /*.       CREATE
1220: 20 54 41 42 4c 45 0a 20 20 20 20 20 20 20 6d 75   TABLE.       mu
1230: 6c 74 69 70 6c 65 20 6c 69 6e 65 73 0a 20 20 20  ltiple lines.   
1240: 20 20 20 20 6f 66 20 74 65 78 74 0a 20 20 20 20      of text.    
1250: 20 2a 2f 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f   */.  }.} {1}.do
1260: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 33 33 20  _test main-1.33 
1270: 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20  {.  db complete 
1280: 7b 0a 20 20 20 20 20 2f 2a 0a 20 20 20 20 20 20  {.     /*.      
1290: 20 43 52 45 41 54 45 20 54 41 42 4c 45 0a 20 20   CREATE TABLE.  
12a0: 20 20 20 20 20 6d 75 6c 74 69 70 6c 65 20 6c 69       multiple li
12b0: 6e 65 73 0a 20 20 20 20 20 20 20 6f 66 20 74 65  nes.       of te
12c0: 78 74 3b 0a 20 20 7d 0a 7d 20 7b 30 7d 0a 64 6f  xt;.  }.} {0}.do
12d0: 5f 74 65 73 74 20 6d 61 69 6e 2d 31 2e 33 34 20  _test main-1.34 
12e0: 7b 0a 20 20 64 62 20 63 6f 6d 70 6c 65 74 65 20  {.  db complete 
12f0: 7b 0a 20 20 20 20 20 2f 2a 0a 20 20 20 20 20 20  {.     /*.      
1300: 20 43 52 45 41 54 45 20 54 41 42 4c 45 0a 20 20   CREATE TABLE.  
1310: 20 20 20 20 20 6d 75 6c 74 69 70 6c 65 20 6c 69       multiple li
1320: 6e 65 73 20 22 2a 2f 0a 20 20 20 20 20 20 20 6f  nes "*/.       o
1330: 66 20 74 65 78 74 3b 0a 20 20 7d 0a 7d 20 7b 31  f text;.  }.} {1
1340: 7d 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 31  }.do_test main-1
1350: 2e 33 35 20 7b 0a 20 20 64 62 20 63 6f 6d 70 6c  .35 {.  db compl
1360: 65 74 65 20 7b 68 69 20 2f 2a 2a 2f 20 74 68 65  ete {hi /**/ the
1370: 72 65 3b 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65  re;}.} {1}.do_te
1380: 73 74 20 6d 61 69 6e 2d 31 2e 33 36 20 7b 0a 20  st main-1.36 {. 
1390: 20 64 62 20 63 6f 6d 70 6c 65 74 65 20 7b 68 69   db complete {hi
13a0: 20 74 68 65 72 65 2f 2a 2a 2a 2f 3b 7d 0a 7d 20   there/***/;}.} 
13b0: 7b 31 7d 0a 0a 7d 20 3b 23 20 65 6e 64 20 69 66  {1}..} ;# end if
13c0: 63 61 70 61 62 6c 65 20 7b 63 6f 6d 70 6c 65 74  capable {complet
13d0: 65 7d 0a 0a 0a 23 20 54 72 79 20 74 6f 20 6f 70  e}...# Try to op
13e0: 65 6e 20 61 20 64 61 74 61 62 61 73 65 20 77 69  en a database wi
13f0: 74 68 20 61 20 63 6f 72 72 75 70 74 20 64 61 74  th a corrupt dat
1400: 61 62 61 73 65 20 66 69 6c 65 2e 0a 23 0a 64 6f  abase file..#.do
1410: 5f 74 65 73 74 20 6d 61 69 6e 2d 32 2e 30 20 7b  _test main-2.0 {
1420: 0a 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f  .  catch {db clo
1430: 73 65 7d 0a 20 20 66 69 6c 65 20 64 65 6c 65 74  se}.  file delet
1440: 65 20 2d 66 6f 72 63 65 20 74 65 73 74 2e 64 62  e -force test.db
1450: 0a 20 20 73 65 74 20 66 64 20 5b 6f 70 65 6e 20  .  set fd [open 
1460: 74 65 73 74 2e 64 62 20 77 5d 0a 20 20 70 75 74  test.db w].  put
1470: 73 20 24 66 64 20 68 69 21 0a 20 20 63 6c 6f 73  s $fd hi!.  clos
1480: 65 20 24 66 64 0a 20 20 73 65 74 20 76 20 5b 63  e $fd.  set v [c
1490: 61 74 63 68 20 7b 73 71 6c 69 74 65 33 20 64 62  atch {sqlite3 db
14a0: 20 74 65 73 74 2e 64 62 7d 20 6d 73 67 5d 0a 20   test.db} msg]. 
14b0: 20 69 66 20 7b 24 76 7d 20 7b 6c 61 70 70 65 6e   if {$v} {lappen
14c0: 64 20 76 20 24 6d 73 67 7d 20 7b 6c 61 70 70 65  d v $msg} {lappe
14d0: 6e 64 20 76 20 7b 7d 7d 0a 7d 20 7b 30 20 7b 7d  nd v {}}.} {0 {}
14e0: 7d 0a 0a 23 20 48 65 72 65 20 61 72 65 20 73 6f  }..# Here are so
14f0: 6d 65 20 74 65 73 74 73 20 66 6f 72 20 74 6f 6b  me tests for tok
1500: 65 6e 69 7a 65 2e 63 2e 20 20 0a 23 0a 64 6f 5f  enize.c.  .#.do_
1510: 74 65 73 74 20 6d 61 69 6e 2d 33 2e 31 20 7b 0a  test main-3.1 {.
1520: 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73    catch {db clos
1530: 65 7d 0a 20 20 66 6f 72 65 61 63 68 20 66 20 5b  e}.  foreach f [
1540: 67 6c 6f 62 20 2d 6e 6f 63 6f 6d 70 6c 61 69 6e  glob -nocomplain
1550: 20 74 65 73 74 64 62 2f 2a 5d 20 7b 66 69 6c 65   testdb/*] {file
1560: 20 64 65 6c 65 74 65 20 2d 66 6f 72 63 65 20 24   delete -force $
1570: 66 7d 0a 20 20 66 69 6c 65 20 64 65 6c 65 74 65  f}.  file delete
1580: 20 2d 66 6f 72 63 65 20 74 65 73 74 64 62 0a 20   -force testdb. 
1590: 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74   sqlite3 db test
15a0: 64 62 0a 20 20 73 65 74 20 76 20 5b 63 61 74 63  db.  set v [catc
15b0: 68 20 7b 65 78 65 63 73 71 6c 20 7b 53 45 4c 45  h {execsql {SELE
15c0: 43 54 20 2a 20 66 72 6f 6d 20 54 31 20 77 68 65  CT * from T1 whe
15d0: 72 65 20 78 21 21 35 7d 7d 20 6d 73 67 5d 0a 20  re x!!5}} msg]. 
15e0: 20 6c 61 70 70 65 6e 64 20 76 20 24 6d 73 67 0a   lappend v $msg.
15f0: 7d 20 7b 31 20 7b 75 6e 72 65 63 6f 67 6e 69 7a  } {1 {unrecogniz
1600: 65 64 20 74 6f 6b 65 6e 3a 20 22 21 21 22 7d 7d  ed token: "!!"}}
1610: 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 33 2e  .do_test main-3.
1620: 32 20 7b 0a 20 20 63 61 74 63 68 20 7b 64 62 20  2 {.  catch {db 
1630: 63 6c 6f 73 65 7d 0a 20 20 66 6f 72 65 61 63 68  close}.  foreach
1640: 20 66 20 5b 67 6c 6f 62 20 2d 6e 6f 63 6f 6d 70   f [glob -nocomp
1650: 6c 61 69 6e 20 74 65 73 74 64 62 2f 2a 5d 20 7b  lain testdb/*] {
1660: 66 69 6c 65 20 64 65 6c 65 74 65 20 2d 66 6f 72  file delete -for
1670: 63 65 20 24 66 7d 0a 20 20 66 69 6c 65 20 64 65  ce $f}.  file de
1680: 6c 65 74 65 20 2d 66 6f 72 63 65 20 74 65 73 74  lete -force test
1690: 64 62 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20  db.  sqlite3 db 
16a0: 74 65 73 74 64 62 0a 20 20 73 65 74 20 76 20 5b  testdb.  set v [
16b0: 63 61 74 63 68 20 7b 65 78 65 63 73 71 6c 20 7b  catch {execsql {
16c0: 53 45 4c 45 43 54 20 2a 20 66 72 6f 6d 20 54 31  SELECT * from T1
16d0: 20 77 68 65 72 65 20 40 78 7d 7d 20 6d 73 67 5d   where @x}} msg]
16e0: 0a 20 20 6c 61 70 70 65 6e 64 20 76 20 24 6d 73  .  lappend v $ms
16f0: 67 0a 7d 20 7b 31 20 7b 75 6e 72 65 63 6f 67 6e  g.} {1 {unrecogn
1700: 69 7a 65 64 20 74 6f 6b 65 6e 3a 20 22 40 22 7d  ized token: "@"}
1710: 7d 0a 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d  }..do_test main-
1720: 33 2e 33 20 7b 0a 20 20 63 61 74 63 68 20 7b 64  3.3 {.  catch {d
1730: 62 20 63 6c 6f 73 65 7d 0a 20 20 66 6f 72 65 61  b close}.  forea
1740: 63 68 20 66 20 5b 67 6c 6f 62 20 2d 6e 6f 63 6f  ch f [glob -noco
1750: 6d 70 6c 61 69 6e 20 74 65 73 74 64 62 2f 2a 5d  mplain testdb/*]
1760: 20 7b 66 69 6c 65 20 64 65 6c 65 74 65 20 2d 66   {file delete -f
1770: 6f 72 63 65 20 24 66 7d 0a 20 20 66 69 6c 65 20  orce $f}.  file 
1780: 64 65 6c 65 74 65 20 2d 66 6f 72 63 65 20 74 65  delete -force te
1790: 73 74 64 62 0a 20 20 73 71 6c 69 74 65 33 20 64  stdb.  sqlite3 d
17a0: 62 20 74 65 73 74 64 62 0a 20 20 65 78 65 63 73  b testdb.  execs
17b0: 71 6c 20 7b 0a 20 20 20 20 63 72 65 61 74 65 20  ql {.    create 
17c0: 74 61 62 6c 65 20 54 31 28 58 20 52 45 41 4c 29  table T1(X REAL)
17d0: 3b 20 20 2f 2a 20 43 2d 73 74 79 6c 65 20 63 6f  ;  /* C-style co
17e0: 6d 6d 65 6e 74 73 20 61 6c 6c 6f 77 65 64 20 2a  mments allowed *
17f0: 2f 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74  /.    insert int
1800: 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e 35 29  o T1 values(0.5)
1810: 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74  ;.    insert int
1820: 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e 35 65  o T1 values(0.5e
1830: 32 29 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69  2);.    insert i
1840: 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e  nto T1 values(0.
1850: 35 65 2d 30 30 32 29 3b 0a 20 20 20 20 69 6e 73  5e-002);.    ins
1860: 65 72 74 20 69 6e 74 6f 20 54 31 20 76 61 6c 75  ert into T1 valu
1870: 65 73 28 35 65 2d 30 30 32 29 3b 0a 20 20 20 20  es(5e-002);.    
1880: 69 6e 73 65 72 74 20 69 6e 74 6f 20 54 31 20 76  insert into T1 v
1890: 61 6c 75 65 73 28 2d 35 2e 30 65 2d 32 29 3b 0a  alues(-5.0e-2);.
18a0: 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20      insert into 
18b0: 54 31 20 76 61 6c 75 65 73 28 2d 35 2e 31 65 2d  T1 values(-5.1e-
18c0: 32 29 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69  2);.    insert i
18d0: 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e  nto T1 values(0.
18e0: 35 65 32 29 3b 0a 20 20 20 20 69 6e 73 65 72 74  5e2);.    insert
18f0: 20 69 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28   into T1 values(
1900: 30 2e 35 45 2b 30 32 29 3b 0a 20 20 20 20 69 6e  0.5E+02);.    in
1910: 73 65 72 74 20 69 6e 74 6f 20 54 31 20 76 61 6c  sert into T1 val
1920: 75 65 73 28 35 45 2b 30 32 29 3b 0a 20 20 20 20  ues(5E+02);.    
1930: 69 6e 73 65 72 74 20 69 6e 74 6f 20 54 31 20 76  insert into T1 v
1940: 61 6c 75 65 73 28 35 2e 30 45 2b 30 33 29 3b 0a  alues(5.0E+03);.
1950: 20 20 20 20 73 65 6c 65 63 74 20 78 2a 31 30 20      select x*10 
1960: 66 72 6f 6d 20 54 31 20 6f 72 64 65 72 20 62 79  from T1 order by
1970: 20 78 2a 35 3b 0a 20 20 7d 0a 7d 20 7b 2d 30 2e   x*5;.  }.} {-0.
1980: 35 31 20 2d 30 2e 35 20 30 2e 30 35 20 30 2e 35  51 -0.5 0.05 0.5
1990: 20 35 2e 30 20 35 30 30 2e 30 20 35 30 30 2e 30   5.0 500.0 500.0
19a0: 20 35 30 30 2e 30 20 35 30 30 30 2e 30 20 35 30   500.0 5000.0 50
19b0: 30 30 30 2e 30 7d 0a 64 6f 5f 74 65 73 74 20 6d  000.0}.do_test m
19c0: 61 69 6e 2d 33 2e 34 20 7b 0a 20 20 73 65 74 20  ain-3.4 {.  set 
19d0: 76 20 5b 63 61 74 63 68 20 7b 65 78 65 63 73 71  v [catch {execsq
19e0: 6c 20 7b 63 72 65 61 74 65 20 62 6f 67 75 73 7d  l {create bogus}
19f0: 7d 20 6d 73 67 5d 0a 20 20 6c 61 70 70 65 6e 64  } msg].  lappend
1a00: 20 76 20 24 6d 73 67 0a 7d 20 7b 31 20 7b 6e 65   v $msg.} {1 {ne
1a10: 61 72 20 22 62 6f 67 75 73 22 3a 20 73 79 6e 74  ar "bogus": synt
1a20: 61 78 20 65 72 72 6f 72 7d 7d 0a 64 6f 5f 74 65  ax error}}.do_te
1a30: 73 74 20 6d 61 69 6e 2d 33 2e 35 20 7b 0a 20 20  st main-3.5 {.  
1a40: 73 65 74 20 76 20 5b 63 61 74 63 68 20 7b 65 78  set v [catch {ex
1a50: 65 63 73 71 6c 20 7b 63 72 65 61 74 65 7d 7d 20  ecsql {create}} 
1a60: 6d 73 67 5d 0a 20 20 6c 61 70 70 65 6e 64 20 76  msg].  lappend v
1a70: 20 24 6d 73 67 0a 7d 20 7b 31 20 7b 6e 65 61 72   $msg.} {1 {near
1a80: 20 22 63 72 65 61 74 65 22 3a 20 73 79 6e 74 61   "create": synta
1a90: 78 20 65 72 72 6f 72 7d 7d 0a 64 6f 5f 74 65 73  x error}}.do_tes
1aa0: 74 20 6d 61 69 6e 2d 33 2e 36 20 7b 0a 20 20 63  t main-3.6 {.  c
1ab0: 61 74 63 68 73 71 6c 20 7b 53 45 4c 45 43 54 20  atchsql {SELECT 
1ac0: 27 61 62 63 27 20 2b 20 23 39 7d 0a 7d 20 7b 31  'abc' + #9}.} {1
1ad0: 20 7b 6e 65 61 72 20 22 23 39 22 3a 20 73 79 6e   {near "#9": syn
1ae0: 74 61 78 20 65 72 72 6f 72 7d 7d 0a 0a 0a 66 69  tax error}}...fi
1af0: 6e 69 73 68 5f 74 65 73 74 0a                    nish_test.