/ Hex Artifact Content
Login

Artifact 6efd402da3b74e2d9e6a42b8a97413575fbf48f6:


0000: 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73  # The author dis
0010: 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74  claims copyright
0020: 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20   to this source 
0030: 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20  code.  In place 
0040: 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74  of.# a legal not
0050: 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62  ice, here is a b
0060: 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20  lessing:.#.#    
0070: 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20  May you do good 
0080: 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20  and not evil..# 
0090: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00a0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00b0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00c0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20  give others..#  
00d0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
00e0: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
00f0: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0100: 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a  ou give..#.#****
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0120: 2a 2a 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 0a 23 0a 23 20 54 68 69 73 20 66 69 6c  ***.#.# This fil
0160: 65 20 74 65 73 74 73 20 63 72 65 61 74 69 6e 67  e tests creating
0170: 20 61 6e 64 20 64 72 6f 70 70 69 6e 67 20 74 72   and dropping tr
0180: 69 67 67 65 72 73 2c 20 61 6e 64 20 69 6e 74 65  iggers, and inte
0190: 72 61 63 74 69 6f 6e 20 74 68 65 72 65 6f 66 0a  raction thereof.
01a0: 23 20 77 69 74 68 20 74 68 65 20 64 61 74 61 62  # with the datab
01b0: 61 73 65 20 43 4f 4d 4d 49 54 2f 52 4f 4c 4c 42  ase COMMIT/ROLLB
01c0: 41 43 4b 20 6c 6f 67 69 63 2e 0a 23 0a 23 20 31  ACK logic..#.# 1
01d0: 2e 20 43 52 45 41 54 45 20 61 6e 64 20 44 52 4f  . CREATE and DRO
01e0: 50 20 54 52 49 47 47 45 52 20 74 65 73 74 73 0a  P TRIGGER tests.
01f0: 23 20 74 72 69 67 2d 31 2e 31 3a 20 45 72 72 6f  # trig-1.1: Erro
0200: 72 20 69 66 20 74 61 62 6c 65 20 64 6f 65 73 20  r if table does 
0210: 6e 6f 74 20 65 78 69 73 74 0a 23 20 74 72 69 67  not exist.# trig
0220: 2d 31 2e 32 3a 20 45 72 72 6f 72 20 69 66 20 74  -1.2: Error if t
0230: 72 69 67 67 65 72 20 61 6c 72 65 61 64 79 20 65  rigger already e
0240: 78 69 73 74 73 0a 23 20 74 72 69 67 2d 31 2e 33  xists.# trig-1.3
0250: 3a 20 43 72 65 61 74 65 64 20 74 72 69 67 67 65  : Created trigge
0260: 72 73 20 61 72 65 20 64 65 6c 65 74 65 64 20 69  rs are deleted i
0270: 66 20 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f  f the transactio
0280: 6e 20 69 73 20 72 6f 6c 6c 65 64 20 62 61 63 6b  n is rolled back
0290: 0a 23 20 74 72 69 67 2d 31 2e 34 3a 20 44 52 4f  .# trig-1.4: DRO
02a0: 50 20 54 52 49 47 47 45 52 20 72 65 6d 6f 76 65  P TRIGGER remove
02b0: 73 20 74 72 69 67 67 65 72 0a 23 20 74 72 69 67  s trigger.# trig
02c0: 2d 31 2e 35 3a 20 44 72 6f 70 70 65 64 20 74 72  -1.5: Dropped tr
02d0: 69 67 67 65 72 73 20 61 72 65 20 72 65 73 74 6f  iggers are resto
02e0: 72 65 64 20 69 66 20 74 68 65 20 74 72 61 6e 73  red if the trans
02f0: 61 63 74 69 6f 6e 20 69 73 20 72 6f 6c 6c 65 64  action is rolled
0300: 20 62 61 63 6b 0a 23 20 74 72 69 67 2d 31 2e 36   back.# trig-1.6
0310: 3a 20 45 72 72 6f 72 20 69 66 20 64 72 6f 70 70  : Error if dropp
0320: 65 64 20 74 72 69 67 67 65 72 20 64 6f 65 73 6e  ed trigger doesn
0330: 27 74 20 65 78 69 73 74 0a 23 20 74 72 69 67 2d  't exist.# trig-
0340: 31 2e 37 3a 20 44 72 6f 70 70 69 6e 67 20 74 68  1.7: Dropping th
0350: 65 20 74 61 62 6c 65 20 61 75 74 6f 6d 61 74 69  e table automati
0360: 63 61 6c 6c 79 20 64 72 6f 70 73 20 61 6c 6c 20  cally drops all 
0370: 74 72 69 67 67 65 72 73 0a 23 20 74 72 69 67 2d  triggers.# trig-
0380: 31 2e 38 3a 20 41 20 74 72 69 67 67 65 72 20 63  1.8: A trigger c
0390: 72 65 61 74 65 64 20 6f 6e 20 61 20 54 45 4d 50  reated on a TEMP
03a0: 20 74 61 62 6c 65 20 69 73 20 6e 6f 74 20 69 6e   table is not in
03b0: 73 65 72 74 65 64 20 69 6e 74 6f 20 73 71 6c 69  serted into sqli
03c0: 74 65 5f 6d 61 73 74 65 72 0a 23 20 74 72 69 67  te_master.# trig
03d0: 2d 31 2e 39 3a 20 45 6e 73 75 72 65 20 74 68 61  -1.9: Ensure tha
03e0: 74 20 77 65 20 63 61 6e 6e 6f 74 20 63 72 65 61  t we cannot crea
03f0: 74 65 20 61 20 74 72 69 67 67 65 72 20 6f 6e 20  te a trigger on 
0400: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 0a 23 20  sqlite_master.# 
0410: 74 72 69 67 2d 31 2e 31 30 3a 0a 23 20 74 72 69  trig-1.10:.# tri
0420: 67 2d 31 2e 31 31 3a 0a 23 20 74 72 69 67 2d 31  g-1.11:.# trig-1
0430: 2e 31 32 3a 20 45 6e 73 75 72 65 20 74 68 61 74  .12: Ensure that
0440: 20 49 4e 53 54 45 41 44 20 4f 46 20 74 72 69 67   INSTEAD OF trig
0450: 67 65 72 73 20 63 61 6e 6e 6f 74 20 62 65 20 63  gers cannot be c
0460: 72 65 61 74 65 64 20 6f 6e 20 74 61 62 6c 65 73  reated on tables
0470: 0a 23 20 74 72 69 67 2d 31 2e 31 33 3a 20 45 6e  .# trig-1.13: En
0480: 73 75 72 65 20 74 68 61 74 20 41 46 54 45 52 20  sure that AFTER 
0490: 74 72 69 67 67 65 72 73 20 63 61 6e 6e 6f 74 20  triggers cannot 
04a0: 62 65 20 63 72 65 61 74 65 64 20 6f 6e 20 76 69  be created on vi
04b0: 65 77 73 0a 23 20 74 72 69 67 2d 31 2e 31 34 3a  ews.# trig-1.14:
04c0: 20 45 6e 73 75 72 65 20 74 68 61 74 20 42 45 46   Ensure that BEF
04d0: 4f 52 45 20 74 72 69 67 67 65 72 73 20 63 61 6e  ORE triggers can
04e0: 6e 6f 74 20 62 65 20 63 72 65 61 74 65 64 20 6f  not be created o
04f0: 6e 20 76 69 65 77 73 0a 23 0a 0a 73 65 74 20 74  n views.#..set t
0500: 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69 72  estdir [file dir
0510: 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f 75  name $argv0].sou
0520: 72 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73  rce $testdir/tes
0530: 74 65 72 2e 74 63 6c 0a 0a 64 6f 5f 74 65 73 74  ter.tcl..do_test
0540: 20 74 72 69 67 67 65 72 31 2d 31 2e 31 2e 32 20   trigger1-1.1.2 
0550: 7b 0a 20 20 20 63 61 74 63 68 73 71 6c 20 7b 0a  {.   catchsql {.
0560: 20 20 20 20 20 43 52 45 41 54 45 20 54 52 49 47       CREATE TRIG
0570: 47 45 52 20 74 72 69 67 20 55 50 44 41 54 45 20  GER trig UPDATE 
0580: 4f 4e 20 6e 6f 5f 73 75 63 68 5f 74 61 62 6c 65  ON no_such_table
0590: 20 42 45 47 49 4e 0a 20 20 20 20 20 20 20 53 45   BEGIN.       SE
05a0: 4c 45 43 54 20 2a 20 66 72 6f 6d 20 73 71 6c 69  LECT * from sqli
05b0: 74 65 5f 6d 61 73 74 65 72 3b 0a 20 20 20 20 20  te_master;.     
05c0: 45 4e 44 3b 0a 20 20 20 7d 20 0a 7d 20 7b 31 20  END;.   } .} {1 
05d0: 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65 3a 20  {no such table: 
05e0: 6e 6f 5f 73 75 63 68 5f 74 61 62 6c 65 7d 7d 0a  no_such_table}}.
05f0: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 31  do_test trigger1
0600: 2d 31 2e 31 2e 32 20 7b 0a 20 20 20 63 61 74 63  -1.1.2 {.   catc
0610: 68 73 71 6c 20 7b 0a 20 20 20 20 20 43 52 45 41  hsql {.     CREA
0620: 54 45 20 54 45 4d 50 20 54 52 49 47 47 45 52 20  TE TEMP TRIGGER 
0630: 74 72 69 67 20 55 50 44 41 54 45 20 4f 4e 20 6e  trig UPDATE ON n
0640: 6f 5f 73 75 63 68 5f 74 61 62 6c 65 20 42 45 47  o_such_table BEG
0650: 49 4e 0a 20 20 20 20 20 20 20 53 45 4c 45 43 54  IN.       SELECT
0660: 20 2a 20 66 72 6f 6d 20 73 71 6c 69 74 65 5f 6d   * from sqlite_m
0670: 61 73 74 65 72 3b 0a 20 20 20 20 20 45 4e 44 3b  aster;.     END;
0680: 0a 20 20 20 7d 20 0a 7d 20 7b 31 20 7b 6e 6f 20  .   } .} {1 {no 
0690: 73 75 63 68 20 74 61 62 6c 65 3a 20 6e 6f 5f 73  such table: no_s
06a0: 75 63 68 5f 74 61 62 6c 65 7d 7d 0a 0a 65 78 65  uch_table}}..exe
06b0: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
06c0: 45 20 54 41 42 4c 45 20 74 31 28 61 29 3b 0a 7d  E TABLE t1(a);.}
06d0: 0a 65 78 65 63 73 71 6c 20 7b 0a 09 43 52 45 41  .execsql {..CREA
06e0: 54 45 20 54 52 49 47 47 45 52 20 74 72 31 20 49  TE TRIGGER tr1 I
06f0: 4e 53 45 52 54 20 4f 4e 20 74 31 20 42 45 47 49  NSERT ON t1 BEGI
0700: 4e 0a 09 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  N..  INSERT INTO
0710: 20 74 31 20 76 61 6c 75 65 73 28 31 29 3b 0a 20   t1 values(1);. 
0720: 09 45 4e 44 3b 0a 7d 0a 64 6f 5f 74 65 73 74 20  .END;.}.do_test 
0730: 74 72 69 67 67 65 72 31 2d 31 2e 32 20 7b 0a 20  trigger1-1.2 {. 
0740: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 09 43     catchsql {..C
0750: 52 45 41 54 45 20 54 52 49 47 47 45 52 20 74 72  REATE TRIGGER tr
0760: 31 20 44 45 4c 45 54 45 20 4f 4e 20 74 31 20 42  1 DELETE ON t1 B
0770: 45 47 49 4e 0a 09 20 20 20 20 53 45 4c 45 43 54  EGIN..    SELECT
0780: 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d   * FROM sqlite_m
0790: 61 73 74 65 72 3b 0a 20 09 45 4e 44 0a 20 20 20  aster;. .END.   
07a0: 20 20 7d 0a 7d 20 7b 31 20 7b 74 72 69 67 67 65    }.} {1 {trigge
07b0: 72 20 74 72 31 20 61 6c 72 65 61 64 79 20 65 78  r tr1 already ex
07c0: 69 73 74 73 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20  ists}}..do_test 
07d0: 74 72 69 67 67 65 72 31 2d 31 2e 33 20 7b 0a 20  trigger1-1.3 {. 
07e0: 20 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 09 42     catchsql {..B
07f0: 45 47 49 4e 3b 0a 09 43 52 45 41 54 45 20 54 52  EGIN;..CREATE TR
0800: 49 47 47 45 52 20 74 72 32 20 49 4e 53 45 52 54  IGGER tr2 INSERT
0810: 20 4f 4e 20 74 31 20 42 45 47 49 4e 0a 09 20 20   ON t1 BEGIN..  
0820: 20 20 53 45 4c 45 43 54 20 2a 20 66 72 6f 6d 20    SELECT * from 
0830: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 3b 20 45  sqlite_master; E
0840: 4e 44 3b 0a 20 20 20 20 20 20 20 20 52 4f 4c 4c  ND;.        ROLL
0850: 42 41 43 4b 3b 0a 09 43 52 45 41 54 45 20 54 52  BACK;..CREATE TR
0860: 49 47 47 45 52 20 74 72 32 20 49 4e 53 45 52 54  IGGER tr2 INSERT
0870: 20 4f 4e 20 74 31 20 42 45 47 49 4e 0a 09 20 20   ON t1 BEGIN..  
0880: 20 20 53 45 4c 45 43 54 20 2a 20 66 72 6f 6d 20    SELECT * from 
0890: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 3b 20 45  sqlite_master; E
08a0: 4e 44 3b 0a 20 20 20 20 7d 0a 7d 20 7b 30 20 7b  ND;.    }.} {0 {
08b0: 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 74 72 69 67  }}..do_test trig
08c0: 67 65 72 31 2d 31 2e 34 20 7b 0a 20 20 20 20 63  ger1-1.4 {.    c
08d0: 61 74 63 68 73 71 6c 20 7b 0a 09 44 52 4f 50 20  atchsql {..DROP 
08e0: 54 52 49 47 47 45 52 20 74 72 31 3b 0a 09 43 52  TRIGGER tr1;..CR
08f0: 45 41 54 45 20 54 52 49 47 47 45 52 20 74 72 31  EATE TRIGGER tr1
0900: 20 44 45 4c 45 54 45 20 4f 4e 20 74 31 20 42 45   DELETE ON t1 BE
0910: 47 49 4e 0a 09 20 20 20 20 53 45 4c 45 43 54 20  GIN..    SELECT 
0920: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61  * FROM sqlite_ma
0930: 73 74 65 72 3b 0a 09 45 4e 44 0a 20 20 20 20 7d  ster;..END.    }
0940: 0a 7d 20 7b 30 20 7b 7d 7d 0a 0a 64 6f 5f 74 65  .} {0 {}}..do_te
0950: 73 74 20 74 72 69 67 67 65 72 31 2d 31 2e 35 20  st trigger1-1.5 
0960: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
0970: 09 42 45 47 49 4e 3b 0a 09 44 52 4f 50 20 54 52  .BEGIN;..DROP TR
0980: 49 47 47 45 52 20 74 72 32 3b 0a 09 52 4f 4c 4c  IGGER tr2;..ROLL
0990: 42 41 43 4b 3b 0a 09 44 52 4f 50 20 54 52 49 47  BACK;..DROP TRIG
09a0: 47 45 52 20 74 72 32 3b 0a 20 20 20 20 7d 0a 7d  GER tr2;.    }.}
09b0: 20 7b 7d 0a 0a 64 6f 5f 74 65 73 74 20 74 72 69   {}..do_test tri
09c0: 67 67 65 72 31 2d 31 2e 36 20 7b 0a 20 20 20 20  gger1-1.6 {.    
09d0: 63 61 74 63 68 73 71 6c 20 7b 0a 09 44 52 4f 50  catchsql {..DROP
09e0: 20 54 52 49 47 47 45 52 20 62 69 67 67 6c 65 73   TRIGGER biggles
09f0: 3b 0a 20 20 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f  ;.    }.} {1 {no
0a00: 20 73 75 63 68 20 74 72 69 67 67 65 72 3a 20 62   such trigger: b
0a10: 69 67 67 6c 65 73 7d 7d 0a 0a 64 6f 5f 74 65 73  iggles}}..do_tes
0a20: 74 20 74 72 69 67 67 65 72 31 2d 31 2e 37 20 7b  t trigger1-1.7 {
0a30: 0a 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 0a  .    catchsql {.
0a40: 09 44 52 4f 50 20 54 41 42 4c 45 20 74 31 3b 0a  .DROP TABLE t1;.
0a50: 09 44 52 4f 50 20 54 52 49 47 47 45 52 20 74 72  .DROP TRIGGER tr
0a60: 31 3b 0a 20 20 20 20 7d 0a 7d 20 7b 31 20 7b 6e  1;.    }.} {1 {n
0a70: 6f 20 73 75 63 68 20 74 72 69 67 67 65 72 3a 20  o such trigger: 
0a80: 74 72 31 7d 7d 0a 0a 65 78 65 63 73 71 6c 20 7b  tr1}}..execsql {
0a90: 0a 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 54  .  CREATE TEMP T
0aa0: 41 42 4c 45 20 74 65 6d 70 5f 74 61 62 6c 65 28  ABLE temp_table(
0ab0: 61 29 3b 0a 7d 0a 64 6f 5f 74 65 73 74 20 74 72  a);.}.do_test tr
0ac0: 69 67 67 65 72 31 2d 31 2e 38 20 7b 0a 20 20 65  igger1-1.8 {.  e
0ad0: 78 65 63 73 71 6c 20 7b 0a 09 43 52 45 41 54 45  xecsql {..CREATE
0ae0: 20 54 52 49 47 47 45 52 20 74 65 6d 70 5f 74 72   TRIGGER temp_tr
0af0: 69 67 20 55 50 44 41 54 45 20 4f 4e 20 74 65 6d  ig UPDATE ON tem
0b00: 70 5f 74 61 62 6c 65 20 42 45 47 49 4e 0a 09 20  p_table BEGIN.. 
0b10: 20 20 20 53 45 4c 45 43 54 20 2a 20 66 72 6f 6d     SELECT * from
0b20: 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 3b 0a   sqlite_master;.
0b30: 09 45 4e 44 3b 0a 09 53 45 4c 45 43 54 20 63 6f  .END;..SELECT co
0b40: 75 6e 74 28 2a 29 20 46 52 4f 4d 20 73 71 6c 69  unt(*) FROM sqli
0b50: 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52 45 20  te_master WHERE 
0b60: 6e 61 6d 65 20 3d 20 27 74 65 6d 70 5f 74 72 69  name = 'temp_tri
0b70: 67 27 3b 0a 20 20 7d 20 0a 7d 20 7b 30 7d 0a 0a  g';.  } .} {0}..
0b80: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 31  do_test trigger1
0b90: 2d 31 2e 39 20 7b 0a 20 20 63 61 74 63 68 73 71  -1.9 {.  catchsq
0ba0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
0bb0: 52 49 47 47 45 52 20 74 72 31 20 41 46 54 45 52  RIGGER tr1 AFTER
0bc0: 20 55 50 44 41 54 45 20 4f 4e 20 73 71 6c 69 74   UPDATE ON sqlit
0bd0: 65 5f 6d 61 73 74 65 72 20 42 45 47 49 4e 0a 20  e_master BEGIN. 
0be0: 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46        SELECT * F
0bf0: 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65  ROM sqlite_maste
0c00: 72 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20 7d 0a  r;.    END;.  }.
0c10: 7d 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 63 72 65  } {1 {cannot cre
0c20: 61 74 65 20 74 72 69 67 67 65 72 20 6f 6e 20 73  ate trigger on s
0c30: 79 73 74 65 6d 20 74 61 62 6c 65 7d 7d 0a 0a 23  ystem table}}..#
0c40: 20 43 68 65 63 6b 20 74 6f 20 6d 61 6b 65 20 73   Check to make s
0c50: 75 72 65 20 74 68 61 74 20 61 20 44 45 4c 45 54  ure that a DELET
0c60: 45 20 73 74 61 74 65 6d 65 6e 74 20 77 69 74 68  E statement with
0c70: 69 6e 20 74 68 65 20 62 6f 64 79 20 6f 66 0a 23  in the body of.#
0c80: 20 61 20 74 72 69 67 67 65 72 20 64 6f 65 73 20   a trigger does 
0c90: 6e 6f 74 20 6d 65 73 73 20 75 70 20 74 68 65 20  not mess up the 
0ca0: 44 45 4c 45 54 45 20 74 68 61 74 20 63 61 75 73  DELETE that caus
0cb0: 65 64 20 74 68 65 20 74 72 69 67 67 65 72 20 74  ed the trigger t
0cc0: 6f 0a 23 20 72 75 6e 20 69 6e 20 74 68 65 20 66  o.# run in the f
0cd0: 69 72 73 74 20 70 6c 61 63 65 2e 0a 23 0a 64 6f  irst place..#.do
0ce0: 5f 74 65 73 74 20 74 72 69 67 67 65 72 31 2d 31  _test trigger1-1
0cf0: 2e 31 30 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  .10 {.  execsql 
0d00: 7b 0a 20 20 20 20 63 72 65 61 74 65 20 74 61 62  {.    create tab
0d10: 6c 65 20 74 31 28 61 2c 62 29 3b 0a 20 20 20 20  le t1(a,b);.    
0d20: 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 31 20 76  insert into t1 v
0d30: 61 6c 75 65 73 28 31 2c 27 61 27 29 3b 0a 20 20  alues(1,'a');.  
0d40: 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 31    insert into t1
0d50: 20 76 61 6c 75 65 73 28 32 2c 27 62 27 29 3b 0a   values(2,'b');.
0d60: 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20      insert into 
0d70: 74 31 20 76 61 6c 75 65 73 28 33 2c 27 63 27 29  t1 values(3,'c')
0d80: 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74  ;.    insert int
0d90: 6f 20 74 31 20 76 61 6c 75 65 73 28 34 2c 27 64  o t1 values(4,'d
0da0: 27 29 3b 0a 20 20 20 20 63 72 65 61 74 65 20 74  ');.    create t
0db0: 72 69 67 67 65 72 20 72 31 20 61 66 74 65 72 20  rigger r1 after 
0dc0: 64 65 6c 65 74 65 20 6f 6e 20 74 31 20 66 6f 72  delete on t1 for
0dd0: 20 65 61 63 68 20 72 6f 77 20 62 65 67 69 6e 0a   each row begin.
0de0: 20 20 20 20 20 20 64 65 6c 65 74 65 20 66 72 6f        delete fro
0df0: 6d 20 74 31 20 57 48 45 52 45 20 61 3d 6f 6c 64  m t1 WHERE a=old
0e00: 2e 61 2b 32 3b 0a 20 20 20 20 65 6e 64 3b 0a 20  .a+2;.    end;. 
0e10: 20 20 20 64 65 6c 65 74 65 20 66 72 6f 6d 20 74     delete from t
0e20: 31 20 77 68 65 72 65 20 61 20 69 6e 20 28 31 2c  1 where a in (1,
0e30: 33 29 3b 0a 20 20 20 20 73 65 6c 65 63 74 20 2a  3);.    select *
0e40: 20 66 72 6f 6d 20 74 31 3b 0a 20 20 20 20 64 72   from t1;.    dr
0e50: 6f 70 20 74 61 62 6c 65 20 74 31 3b 0a 20 20 7d  op table t1;.  }
0e60: 0a 7d 20 7b 32 20 62 20 34 20 64 7d 0a 64 6f 5f  .} {2 b 4 d}.do_
0e70: 74 65 73 74 20 74 72 69 67 67 65 72 31 2d 31 2e  test trigger1-1.
0e80: 31 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  11 {.  execsql {
0e90: 0a 20 20 20 20 63 72 65 61 74 65 20 74 61 62 6c  .    create tabl
0ea0: 65 20 74 31 28 61 2c 62 29 3b 0a 20 20 20 20 69  e t1(a,b);.    i
0eb0: 6e 73 65 72 74 20 69 6e 74 6f 20 74 31 20 76 61  nsert into t1 va
0ec0: 6c 75 65 73 28 31 2c 27 61 27 29 3b 0a 20 20 20  lues(1,'a');.   
0ed0: 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 31 20   insert into t1 
0ee0: 76 61 6c 75 65 73 28 32 2c 27 62 27 29 3b 0a 20  values(2,'b');. 
0ef0: 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 74     insert into t
0f00: 31 20 76 61 6c 75 65 73 28 33 2c 27 63 27 29 3b  1 values(3,'c');
0f10: 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f  .    insert into
0f20: 20 74 31 20 76 61 6c 75 65 73 28 34 2c 27 64 27   t1 values(4,'d'
0f30: 29 3b 0a 20 20 20 20 63 72 65 61 74 65 20 74 72  );.    create tr
0f40: 69 67 67 65 72 20 72 31 20 61 66 74 65 72 20 75  igger r1 after u
0f50: 70 64 61 74 65 20 6f 6e 20 74 31 20 66 6f 72 20  pdate on t1 for 
0f60: 65 61 63 68 20 72 6f 77 20 62 65 67 69 6e 0a 20  each row begin. 
0f70: 20 20 20 20 20 64 65 6c 65 74 65 20 66 72 6f 6d       delete from
0f80: 20 74 31 20 57 48 45 52 45 20 61 3d 6f 6c 64 2e   t1 WHERE a=old.
0f90: 61 2b 32 3b 0a 20 20 20 20 65 6e 64 3b 0a 20 20  a+2;.    end;.  
0fa0: 20 20 75 70 64 61 74 65 20 74 31 20 73 65 74 20    update t1 set 
0fb0: 62 3d 27 78 2d 27 20 7c 7c 20 62 20 77 68 65 72  b='x-' || b wher
0fc0: 65 20 61 20 69 6e 20 28 31 2c 33 29 3b 0a 20 20  e a in (1,3);.  
0fd0: 20 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20    select * from 
0fe0: 74 31 3b 0a 20 20 20 20 64 72 6f 70 20 74 61 62  t1;.    drop tab
0ff0: 6c 65 20 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20  le t1;.  }.} {1 
1000: 78 2d 61 20 32 20 62 20 34 20 64 7d 0a 0a 23 20  x-a 2 b 4 d}..# 
1010: 45 6e 73 75 72 65 20 74 68 61 74 20 77 65 20 63  Ensure that we c
1020: 61 6e 6e 6f 74 20 63 72 65 61 74 65 20 49 4e 53  annot create INS
1030: 54 45 41 44 20 4f 46 20 74 72 69 67 67 65 72 73  TEAD OF triggers
1040: 20 6f 6e 20 74 61 62 6c 65 73 0a 64 6f 5f 74 65   on tables.do_te
1050: 73 74 20 74 72 69 67 67 65 72 31 2d 31 2e 31 32  st trigger1-1.12
1060: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
1070: 20 20 20 20 63 72 65 61 74 65 20 74 61 62 6c 65      create table
1080: 20 74 31 28 61 2c 62 29 3b 0a 20 20 20 20 63 72   t1(a,b);.    cr
1090: 65 61 74 65 20 74 72 69 67 67 65 72 20 74 31 74  eate trigger t1t
10a0: 20 69 6e 73 74 65 61 64 20 6f 66 20 75 70 64 61   instead of upda
10b0: 74 65 20 6f 6e 20 74 31 20 66 6f 72 20 65 61 63  te on t1 for eac
10c0: 68 20 72 6f 77 20 62 65 67 69 6e 0a 20 20 20 20  h row begin.    
10d0: 20 20 64 65 6c 65 74 65 20 66 72 6f 6d 20 74 31    delete from t1
10e0: 20 57 48 45 52 45 20 61 3d 6f 6c 64 2e 61 2b 32   WHERE a=old.a+2
10f0: 3b 0a 20 20 20 20 65 6e 64 3b 0a 20 20 7d 0a 7d  ;.    end;.  }.}
1100: 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 63 72 65 61   {1 {cannot crea
1110: 74 65 20 49 4e 53 54 45 41 44 20 4f 46 20 74 72  te INSTEAD OF tr
1120: 69 67 67 65 72 20 6f 6e 20 74 61 62 6c 65 3a 20  igger on table: 
1130: 74 31 7d 7d 0a 23 20 45 6e 73 75 72 65 20 74 68  t1}}.# Ensure th
1140: 61 74 20 77 65 20 63 61 6e 6e 6f 74 20 63 72 65  at we cannot cre
1150: 61 74 65 20 42 45 46 4f 52 45 20 74 72 69 67 67  ate BEFORE trigg
1160: 65 72 73 20 6f 6e 20 76 69 65 77 73 0a 64 6f 5f  ers on views.do_
1170: 74 65 73 74 20 74 72 69 67 67 65 72 31 2d 31 2e  test trigger1-1.
1180: 31 33 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20  13 {.  catchsql 
1190: 7b 0a 20 20 20 20 63 72 65 61 74 65 20 76 69 65  {.    create vie
11a0: 77 20 76 31 20 61 73 20 73 65 6c 65 63 74 20 2a  w v1 as select *
11b0: 20 66 72 6f 6d 20 74 31 3b 0a 20 20 20 20 63 72   from t1;.    cr
11c0: 65 61 74 65 20 74 72 69 67 67 65 72 20 76 31 74  eate trigger v1t
11d0: 20 62 65 66 6f 72 65 20 75 70 64 61 74 65 20 6f   before update o
11e0: 6e 20 76 31 20 66 6f 72 20 65 61 63 68 20 72 6f  n v1 for each ro
11f0: 77 20 62 65 67 69 6e 0a 20 20 20 20 20 20 64 65  w begin.      de
1200: 6c 65 74 65 20 66 72 6f 6d 20 74 31 20 57 48 45  lete from t1 WHE
1210: 52 45 20 61 3d 6f 6c 64 2e 61 2b 32 3b 0a 20 20  RE a=old.a+2;.  
1220: 20 20 65 6e 64 3b 0a 20 20 7d 0a 7d 20 7b 31 20    end;.  }.} {1 
1230: 7b 63 61 6e 6e 6f 74 20 63 72 65 61 74 65 20 42  {cannot create B
1240: 45 46 4f 52 45 20 74 72 69 67 67 65 72 20 6f 6e  EFORE trigger on
1250: 20 76 69 65 77 3a 20 76 31 7d 7d 0a 23 20 45 6e   view: v1}}.# En
1260: 73 75 72 65 20 74 68 61 74 20 77 65 20 63 61 6e  sure that we can
1270: 6e 6f 74 20 63 72 65 61 74 65 20 41 46 54 45 52  not create AFTER
1280: 20 74 72 69 67 67 65 72 73 20 6f 6e 20 76 69 65   triggers on vie
1290: 77 73 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67  ws.do_test trigg
12a0: 65 72 31 2d 31 2e 31 34 20 7b 0a 20 20 63 61 74  er1-1.14 {.  cat
12b0: 63 68 73 71 6c 20 7b 0a 20 20 20 20 63 72 65 61  chsql {.    crea
12c0: 74 65 20 74 61 62 6c 65 20 74 31 28 61 2c 62 29  te table t1(a,b)
12d0: 3b 0a 20 20 20 20 63 72 65 61 74 65 20 76 69 65  ;.    create vie
12e0: 77 20 76 31 20 61 73 20 73 65 6c 65 63 74 20 2a  w v1 as select *
12f0: 20 66 72 6f 6d 20 74 31 3b 0a 20 20 20 20 63 72   from t1;.    cr
1300: 65 61 74 65 20 74 72 69 67 67 65 72 20 76 31 74  eate trigger v1t
1310: 20 41 46 54 45 52 20 75 70 64 61 74 65 20 6f 6e   AFTER update on
1320: 20 76 31 20 66 6f 72 20 65 61 63 68 20 72 6f 77   v1 for each row
1330: 20 62 65 67 69 6e 0a 20 20 20 20 20 20 64 65 6c   begin.      del
1340: 65 74 65 20 66 72 6f 6d 20 74 31 20 57 48 45 52  ete from t1 WHER
1350: 45 20 61 3d 6f 6c 64 2e 61 2b 32 3b 0a 20 20 20  E a=old.a+2;.   
1360: 20 65 6e 64 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b   end;.  }.} {1 {
1370: 63 61 6e 6e 6f 74 20 63 72 65 61 74 65 20 41 46  cannot create AF
1380: 54 45 52 20 74 72 69 67 67 65 72 20 6f 6e 20 76  TER trigger on v
1390: 69 65 77 3a 20 76 31 7d 7d 0a 0a 23 20 43 68 65  iew: v1}}..# Che
13a0: 63 6b 20 66 6f 72 20 6d 65 6d 6f 72 79 20 6c 65  ck for memory le
13b0: 61 6b 73 20 69 6e 20 74 68 65 20 74 72 69 67 67  aks in the trigg
13c0: 65 72 20 70 61 72 73 65 72 0a 23 0a 64 6f 5f 74  er parser.#.do_t
13d0: 65 73 74 20 74 72 69 67 67 65 72 31 2d 32 2e 31  est trigger1-2.1
13e0: 20 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a   {.  catchsql {.
13f0: 20 20 20 20 43 52 45 41 54 45 20 54 52 49 47 47      CREATE TRIGG
1400: 45 52 20 72 31 20 41 46 54 45 52 20 49 4e 53 45  ER r1 AFTER INSE
1410: 52 54 20 4f 4e 20 74 31 20 42 45 47 49 4e 0a 20  RT ON t1 BEGIN. 
1420: 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52       SELECT * FR
1430: 4f 4d 3b 20 20 2d 2d 20 53 79 6e 74 61 78 20 65  OM;  -- Syntax e
1440: 72 72 6f 72 0a 20 20 20 20 45 4e 44 3b 0a 20 20  rror.    END;.  
1450: 7d 0a 7d 20 7b 31 20 7b 6e 65 61 72 20 22 3b 22  }.} {1 {near ";"
1460: 3a 20 73 79 6e 74 61 78 20 65 72 72 6f 72 7d 7d  : syntax error}}
1470: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
1480: 31 2d 32 2e 32 20 7b 0a 20 20 63 61 74 63 68 73  1-2.2 {.  catchs
1490: 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  ql {.    CREATE 
14a0: 54 52 49 47 47 45 52 20 72 31 20 41 46 54 45 52  TRIGGER r1 AFTER
14b0: 20 49 4e 53 45 52 54 20 4f 4e 20 74 31 20 42 45   INSERT ON t1 BE
14c0: 47 49 4e 0a 20 20 20 20 20 20 53 45 4c 45 43 54  GIN.      SELECT
14d0: 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20   * FROM t1;.    
14e0: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 3b    SELECT * FROM;
14f0: 20 20 2d 2d 20 53 79 6e 74 61 78 20 65 72 72 6f    -- Syntax erro
1500: 72 0a 20 20 20 20 45 4e 44 3b 0a 20 20 7d 0a 7d  r.    END;.  }.}
1510: 20 7b 31 20 7b 6e 65 61 72 20 22 3b 22 3a 20 73   {1 {near ";": s
1520: 79 6e 74 61 78 20 65 72 72 6f 72 7d 7d 0a 0a 23  yntax error}}..#
1530: 20 43 72 65 61 74 65 20 61 20 74 72 69 67 67 65   Create a trigge
1540: 72 20 74 68 61 74 20 72 65 66 65 72 73 20 74 6f  r that refers to
1550: 20 61 20 74 61 62 6c 65 20 74 68 61 74 20 6d 69   a table that mi
1560: 67 68 74 20 6e 6f 74 20 65 78 69 73 74 2e 0a 23  ght not exist..#
1570: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
1580: 31 2d 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  1-3.1 {.  execsq
1590: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
15a0: 45 4d 50 20 54 41 42 4c 45 20 74 32 28 78 2c 79  EMP TABLE t2(x,y
15b0: 29 3b 0a 20 20 7d 0a 20 20 63 61 74 63 68 73 71  );.  }.  catchsq
15c0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
15d0: 52 49 47 47 45 52 20 72 31 20 41 46 54 45 52 20  RIGGER r1 AFTER 
15e0: 49 4e 53 45 52 54 20 4f 4e 20 74 31 20 42 45 47  INSERT ON t1 BEG
15f0: 49 4e 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20  IN.      INSERT 
1600: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 4e  INTO t2 VALUES(N
1610: 45 57 2e 61 2c 4e 45 57 2e 62 29 3b 0a 20 20 20  EW.a,NEW.b);.   
1620: 20 45 4e 44 3b 0a 20 20 7d 0a 7d 20 7b 30 20 7b   END;.  }.} {0 {
1630: 7d 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67  }}.do_test trigg
1640: 65 72 2d 33 2e 32 20 7b 0a 20 20 63 61 74 63 68  er-3.2 {.  catch
1650: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
1660: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
1670: 31 2c 32 29 3b 0a 20 20 20 20 53 45 4c 45 43 54  1,2);.    SELECT
1680: 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a   * FROM t2;.  }.
1690: 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61  } {1 {no such ta
16a0: 62 6c 65 3a 20 6d 61 69 6e 2e 74 32 7d 7d 0a 64  ble: main.t2}}.d
16b0: 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 2d 33  o_test trigger-3
16c0: 2e 33 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .3 {.  db close.
16d0: 20 20 73 65 74 20 72 63 20 5b 63 61 74 63 68 20    set rc [catch 
16e0: 7b 73 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e  {sqlite db test.
16f0: 64 62 7d 20 65 72 72 5d 0a 20 20 69 66 20 7b 24  db} err].  if {$
1700: 72 63 7d 20 7b 6c 61 70 70 65 6e 64 20 72 63 20  rc} {lappend rc 
1710: 24 65 72 72 7d 0a 20 20 73 65 74 20 72 63 0a 7d  $err}.  set rc.}
1720: 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69   {0}.do_test tri
1730: 67 67 65 72 2d 33 2e 34 20 7b 0a 20 20 63 61 74  gger-3.4 {.  cat
1740: 63 68 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  chsql {.    INSE
1750: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
1760: 53 28 31 2c 32 29 3b 0a 20 20 20 20 53 45 4c 45  S(1,2);.    SELE
1770: 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20  CT * FROM t2;.  
1780: 7d 0a 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20  }.} {1 {no such 
1790: 74 61 62 6c 65 3a 20 6d 61 69 6e 2e 74 32 7d 7d  table: main.t2}}
17a0: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
17b0: 2d 33 2e 35 20 7b 0a 20 20 63 61 74 63 68 73 71  -3.5 {.  catchsq
17c0: 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  l {.    CREATE T
17d0: 45 4d 50 20 54 41 42 4c 45 20 74 32 28 78 2c 79  EMP TABLE t2(x,y
17e0: 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  );.    INSERT IN
17f0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c 32  TO t1 VALUES(1,2
1800: 29 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20  );.    SELECT * 
1810: 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM t2;.  }.} {
1820: 31 20 7b 6e 6f 20 73 75 63 68 20 74 61 62 6c 65  1 {no such table
1830: 3a 20 6d 61 69 6e 2e 74 32 7d 7d 0a 64 6f 5f 74  : main.t2}}.do_t
1840: 65 73 74 20 74 72 69 67 67 65 72 2d 33 2e 36 20  est trigger-3.6 
1850: 7b 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20  {.  catchsql {. 
1860: 20 20 20 44 52 4f 50 20 54 52 49 47 47 45 52 20     DROP TRIGGER 
1870: 72 31 3b 0a 20 20 20 20 43 52 45 41 54 45 20 54  r1;.    CREATE T
1880: 45 4d 50 20 54 52 49 47 47 45 52 20 72 31 20 41  EMP TRIGGER r1 A
1890: 46 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 74  FTER INSERT ON t
18a0: 31 20 42 45 47 49 4e 0a 20 20 20 20 20 20 49 4e  1 BEGIN.      IN
18b0: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
18c0: 55 45 53 28 4e 45 57 2e 61 2c 4e 45 57 2e 62 29  UES(NEW.a,NEW.b)
18d0: 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 49  ;.    END;.    I
18e0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
18f0: 4c 55 45 53 28 31 2c 32 29 3b 0a 20 20 20 20 53  LUES(1,2);.    S
1900: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
1910: 0a 20 20 7d 0a 7d 20 7b 30 20 7b 31 20 32 7d 7d  .  }.} {0 {1 2}}
1920: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
1930: 2d 33 2e 37 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.7 {.  execsql
1940: 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c   {.    DROP TABL
1950: 45 20 74 32 3b 0a 20 20 20 20 43 52 45 41 54 45  E t2;.    CREATE
1960: 20 54 41 42 4c 45 20 74 32 28 78 2c 79 29 3b 0a   TABLE t2(x,y);.
1970: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
1980: 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64  M t2;.  }.} {}.d
1990: 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 2d 33  o_test trigger-3
19a0: 2e 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .8 {.  execsql {
19b0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
19c0: 20 74 31 20 56 41 4c 55 45 53 28 33 2c 34 29 3b   t1 VALUES(3,4);
19d0: 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52  .    SELECT * FR
19e0: 4f 4d 20 74 31 20 55 4e 49 4f 4e 20 41 4c 4c 20  OM t1 UNION ALL 
19f0: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32  SELECT * FROM t2
1a00: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20 34  ;.  }.} {1 2 3 4
1a10: 20 33 20 34 7d 0a 64 6f 5f 74 65 73 74 20 74 72   3 4}.do_test tr
1a20: 69 67 67 65 72 2d 33 2e 39 20 7b 0a 20 20 64 62  igger-3.9 {.  db
1a30: 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 20   close.  sqlite 
1a40: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65  db test.db.  exe
1a50: 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52  csql {.    INSER
1a60: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
1a70: 28 35 2c 36 29 3b 0a 20 20 20 20 53 45 4c 45 43  (5,6);.    SELEC
1a80: 54 20 2a 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f  T * FROM t1 UNIO
1a90: 4e 20 41 4c 4c 20 53 45 4c 45 43 54 20 2a 20 46  N ALL SELECT * F
1aa0: 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b 31  ROM t2;.  }.} {1
1ab0: 20 32 20 33 20 34 20 35 20 36 20 33 20 34 7d 0a   2 3 4 5 6 3 4}.
1ac0: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
1ad0: 2d 34 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -4.1 {.  execsql
1ae0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 45   {.    CREATE TE
1af0: 4d 50 20 54 52 49 47 47 45 52 20 72 31 20 42 45  MP TRIGGER r1 BE
1b00: 46 4f 52 45 20 49 4e 53 45 52 54 20 4f 4e 20 74  FORE INSERT ON t
1b10: 31 20 42 45 47 49 4e 0a 20 20 20 20 20 20 49 4e  1 BEGIN.      IN
1b20: 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c  SERT INTO t2 VAL
1b30: 55 45 53 28 4e 45 57 2e 61 2c 4e 45 57 2e 62 29  UES(NEW.a,NEW.b)
1b40: 3b 0a 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 49  ;.    END;.    I
1b50: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
1b60: 4c 55 45 53 28 37 2c 38 29 3b 0a 20 20 20 20 53  LUES(7,8);.    S
1b70: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b  ELECT * FROM t2;
1b80: 0a 20 20 7d 0a 7d 20 7b 33 20 34 20 37 20 38 7d  .  }.} {3 4 7 8}
1b90: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
1ba0: 2d 34 2e 32 20 7b 0a 20 20 73 71 6c 69 74 65 20  -4.2 {.  sqlite 
1bb0: 64 62 32 20 74 65 73 74 2e 64 62 0a 20 20 65 78  db2 test.db.  ex
1bc0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45  ecsql {.    INSE
1bd0: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
1be0: 53 28 39 2c 31 30 29 3b 0a 20 20 7d 20 64 62 32  S(9,10);.  } db2
1bf0: 3b 0a 20 20 64 62 32 20 63 6c 6f 73 65 0a 20 20  ;.  db2 close.  
1c00: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45  execsql {.    SE
1c10: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a  LECT * FROM t2;.
1c20: 20 20 7d 0a 7d 20 7b 33 20 34 20 37 20 38 7d 0a    }.} {3 4 7 8}.
1c30: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 2d  do_test trigger-
1c40: 34 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  4.3 {.  execsql 
1c50: 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45  {.    DROP TABLE
1c60: 20 74 31 3b 0a 20 20 20 20 53 45 4c 45 43 54 20   t1;.    SELECT 
1c70: 2a 20 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 3b 0a  * FROM t2;.  };.
1c80: 7d 20 7b 33 20 34 20 37 20 38 7d 0a 64 6f 5f 74  } {3 4 7 8}.do_t
1c90: 65 73 74 20 74 72 69 67 67 65 72 2d 34 2e 34 20  est trigger-4.4 
1ca0: 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73  {.  db close.  s
1cb0: 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e 64 62  qlite db test.db
1cc0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1cd0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
1ce0: 32 3b 0a 20 20 7d 3b 0a 7d 20 7b 33 20 34 20 37  2;.  };.} {3 4 7
1cf0: 20 38 7d 0a 0a 69 6e 74 65 67 72 69 74 79 5f 63   8}..integrity_c
1d00: 68 65 63 6b 20 74 72 69 67 67 65 72 2d 35 2e 31  heck trigger-5.1
1d10: 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a        ..finish_test.