/ Hex Artifact Content
Login

Artifact 6e44c86e9efaa913659e189713a339cb5d84bb12:


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 32 20 32 30 30 35  test,v 1.22 2005
0200: 2f 31 30 2f 32 33 20 31 31 3a 32 39 3a 34 30 20  /10/23 11:29:40 
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 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d 33  }.do_test main-3
1720: 2e 32 2e 32 20 7b 0a 20 20 63 61 74 63 68 73 71  .2.2 {.  catchsq
1730: 6c 20 7b 73 65 6c 65 63 74 20 27 61 62 63 7d 0a  l {select 'abc}.
1740: 7d 20 7b 31 20 7b 75 6e 72 65 63 6f 67 6e 69 7a  } {1 {unrecogniz
1750: 65 64 20 74 6f 6b 65 6e 3a 20 22 27 61 62 63 22  ed token: "'abc"
1760: 7d 7d 0a 64 6f 5f 74 65 73 74 20 6d 61 69 6e 2d  }}.do_test main-
1770: 33 2e 32 2e 33 20 7b 0a 20 20 63 61 74 63 68 73  3.2.3 {.  catchs
1780: 71 6c 20 7b 73 65 6c 65 63 74 20 22 61 62 63 7d  ql {select "abc}
1790: 0a 7d 20 7b 31 20 7b 75 6e 72 65 63 6f 67 6e 69  .} {1 {unrecogni
17a0: 7a 65 64 20 74 6f 6b 65 6e 3a 20 22 22 61 62 63  zed token: ""abc
17b0: 22 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 6d 61 69  "}}..do_test mai
17c0: 6e 2d 33 2e 33 20 7b 0a 20 20 63 61 74 63 68 20  n-3.3 {.  catch 
17d0: 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 66 6f 72  {db close}.  for
17e0: 65 61 63 68 20 66 20 5b 67 6c 6f 62 20 2d 6e 6f  each f [glob -no
17f0: 63 6f 6d 70 6c 61 69 6e 20 74 65 73 74 64 62 2f  complain testdb/
1800: 2a 5d 20 7b 66 69 6c 65 20 64 65 6c 65 74 65 20  *] {file delete 
1810: 2d 66 6f 72 63 65 20 24 66 7d 0a 20 20 66 69 6c  -force $f}.  fil
1820: 65 20 64 65 6c 65 74 65 20 2d 66 6f 72 63 65 20  e delete -force 
1830: 74 65 73 74 64 62 0a 20 20 73 71 6c 69 74 65 33  testdb.  sqlite3
1840: 20 64 62 20 74 65 73 74 64 62 0a 20 20 65 78 65   db testdb.  exe
1850: 63 73 71 6c 20 7b 0a 20 20 20 20 63 72 65 61 74  csql {.    creat
1860: 65 20 74 61 62 6c 65 20 54 31 28 58 20 52 45 41  e table T1(X REA
1870: 4c 29 3b 20 20 2f 2a 20 43 2d 73 74 79 6c 65 20  L);  /* C-style 
1880: 63 6f 6d 6d 65 6e 74 73 20 61 6c 6c 6f 77 65 64  comments allowed
1890: 20 2a 2f 0a 20 20 20 20 69 6e 73 65 72 74 20 69   */.    insert i
18a0: 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e  nto T1 values(0.
18b0: 35 29 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69  5);.    insert i
18c0: 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28 30 2e  nto T1 values(0.
18d0: 35 65 32 29 3b 0a 20 20 20 20 69 6e 73 65 72 74  5e2);.    insert
18e0: 20 69 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28   into T1 values(
18f0: 30 2e 35 65 2d 30 30 32 29 3b 0a 20 20 20 20 69  0.5e-002);.    i
1900: 6e 73 65 72 74 20 69 6e 74 6f 20 54 31 20 76 61  nsert into T1 va
1910: 6c 75 65 73 28 35 65 2d 30 30 32 29 3b 0a 20 20  lues(5e-002);.  
1920: 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 54 31    insert into T1
1930: 20 76 61 6c 75 65 73 28 2d 35 2e 30 65 2d 32 29   values(-5.0e-2)
1940: 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74  ;.    insert int
1950: 6f 20 54 31 20 76 61 6c 75 65 73 28 2d 35 2e 31  o T1 values(-5.1
1960: 65 2d 32 29 3b 0a 20 20 20 20 69 6e 73 65 72 74  e-2);.    insert
1970: 20 69 6e 74 6f 20 54 31 20 76 61 6c 75 65 73 28   into T1 values(
1980: 30 2e 35 65 32 29 3b 0a 20 20 20 20 69 6e 73 65  0.5e2);.    inse
1990: 72 74 20 69 6e 74 6f 20 54 31 20 76 61 6c 75 65  rt into T1 value
19a0: 73 28 30 2e 35 45 2b 30 32 29 3b 0a 20 20 20 20  s(0.5E+02);.    
19b0: 69 6e 73 65 72 74 20 69 6e 74 6f 20 54 31 20 76  insert into T1 v
19c0: 61 6c 75 65 73 28 35 45 2b 30 32 29 3b 0a 20 20  alues(5E+02);.  
19d0: 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 54 31    insert into T1
19e0: 20 76 61 6c 75 65 73 28 35 2e 30 45 2b 30 33 29   values(5.0E+03)
19f0: 3b 0a 20 20 20 20 73 65 6c 65 63 74 20 78 2a 31  ;.    select x*1
1a00: 30 20 66 72 6f 6d 20 54 31 20 6f 72 64 65 72 20  0 from T1 order 
1a10: 62 79 20 78 2a 35 3b 0a 20 20 7d 0a 7d 20 7b 2d  by x*5;.  }.} {-
1a20: 30 2e 35 31 20 2d 30 2e 35 20 30 2e 30 35 20 30  0.51 -0.5 0.05 0
1a30: 2e 35 20 35 2e 30 20 35 30 30 2e 30 20 35 30 30  .5 5.0 500.0 500
1a40: 2e 30 20 35 30 30 2e 30 20 35 30 30 30 2e 30 20  .0 500.0 5000.0 
1a50: 35 30 30 30 30 2e 30 7d 0a 64 6f 5f 74 65 73 74  50000.0}.do_test
1a60: 20 6d 61 69 6e 2d 33 2e 34 20 7b 0a 20 20 73 65   main-3.4 {.  se
1a70: 74 20 76 20 5b 63 61 74 63 68 20 7b 65 78 65 63  t v [catch {exec
1a80: 73 71 6c 20 7b 63 72 65 61 74 65 20 62 6f 67 75  sql {create bogu
1a90: 73 7d 7d 20 6d 73 67 5d 0a 20 20 6c 61 70 70 65  s}} msg].  lappe
1aa0: 6e 64 20 76 20 24 6d 73 67 0a 7d 20 7b 31 20 7b  nd v $msg.} {1 {
1ab0: 6e 65 61 72 20 22 62 6f 67 75 73 22 3a 20 73 79  near "bogus": sy
1ac0: 6e 74 61 78 20 65 72 72 6f 72 7d 7d 0a 64 6f 5f  ntax error}}.do_
1ad0: 74 65 73 74 20 6d 61 69 6e 2d 33 2e 35 20 7b 0a  test main-3.5 {.
1ae0: 20 20 73 65 74 20 76 20 5b 63 61 74 63 68 20 7b    set v [catch {
1af0: 65 78 65 63 73 71 6c 20 7b 63 72 65 61 74 65 7d  execsql {create}
1b00: 7d 20 6d 73 67 5d 0a 20 20 6c 61 70 70 65 6e 64  } msg].  lappend
1b10: 20 76 20 24 6d 73 67 0a 7d 20 7b 31 20 7b 6e 65   v $msg.} {1 {ne
1b20: 61 72 20 22 63 72 65 61 74 65 22 3a 20 73 79 6e  ar "create": syn
1b30: 74 61 78 20 65 72 72 6f 72 7d 7d 0a 64 6f 5f 74  tax error}}.do_t
1b40: 65 73 74 20 6d 61 69 6e 2d 33 2e 36 20 7b 0a 20  est main-3.6 {. 
1b50: 20 63 61 74 63 68 73 71 6c 20 7b 53 45 4c 45 43   catchsql {SELEC
1b60: 54 20 27 61 62 63 27 20 2b 20 23 39 7d 0a 7d 20  T 'abc' + #9}.} 
1b70: 7b 31 20 7b 6e 65 61 72 20 22 23 39 22 3a 20 73  {1 {near "#9": s
1b80: 79 6e 74 61 78 20 65 72 72 6f 72 7d 7d 0a 0a 0a  yntax error}}...
1b90: 66 69 6e 69 73 68 5f 74 65 73 74 0a              finish_test.