/ Hex Artifact Content
Login

Artifact ce5c97aba6a8a11be5820e694659438c3e982ada:


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 74 68 65 20 74 72 69 67  e tests the trig
0170: 67 65 72 73 20 6f 66 20 76 69 65 77 73 2e 0a 23  gers of views..#
0180: 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b 66  ..set testdir [f
0190: 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72 67  ile dirname $arg
01a0: 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73 74  v0].source $test
01b0: 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a 69  dir/tester.tcl.i
01c0: 66 63 61 70 61 62 6c 65 20 7b 21 74 72 69 67 67  fcapable {!trigg
01d0: 65 72 7d 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74  er} {.  finish_t
01e0: 65 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a  est.  return.}..
01f0: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 34  do_test trigger4
0200: 2d 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -1.1 {.  execsql
0210: 20 7b 0a 20 20 20 20 63 72 65 61 74 65 20 74 61   {.    create ta
0220: 62 6c 65 20 74 65 73 74 31 28 69 64 20 69 6e 74  ble test1(id int
0230: 65 67 65 72 20 70 72 69 6d 61 72 79 20 6b 65 79  eger primary key
0240: 2c 61 29 3b 0a 20 20 20 20 63 72 65 61 74 65 20  ,a);.    create 
0250: 74 61 62 6c 65 20 74 65 73 74 32 28 69 64 20 69  table test2(id i
0260: 6e 74 65 67 65 72 2c 62 29 3b 0a 20 20 20 20 63  nteger,b);.    c
0270: 72 65 61 74 65 20 76 69 65 77 20 74 65 73 74 20  reate view test 
0280: 61 73 0a 20 20 20 20 20 20 73 65 6c 65 63 74 20  as.      select 
0290: 74 65 73 74 31 2e 69 64 20 61 73 20 69 64 2c 61  test1.id as id,a
02a0: 20 61 73 20 61 2c 62 20 61 73 20 62 0a 20 20 20   as a,b as b.   
02b0: 20 20 20 66 72 6f 6d 20 74 65 73 74 31 20 6a 6f     from test1 jo
02c0: 69 6e 20 74 65 73 74 32 20 6f 6e 20 74 65 73 74  in test2 on test
02d0: 32 2e 69 64 20 3d 20 20 74 65 73 74 31 2e 69 64  2.id =  test1.id
02e0: 3b 0a 20 20 20 20 63 72 65 61 74 65 20 74 72 69  ;.    create tri
02f0: 67 67 65 72 20 49 5f 74 65 73 74 20 69 6e 73 74  gger I_test inst
0300: 65 61 64 20 6f 66 20 69 6e 73 65 72 74 20 6f 6e  ead of insert on
0310: 20 74 65 73 74 0a 20 20 20 20 20 20 62 65 67 69   test.      begi
0320: 6e 0a 20 20 20 20 20 20 20 20 69 6e 73 65 72 74  n.        insert
0330: 20 69 6e 74 6f 20 74 65 73 74 31 20 28 69 64 2c   into test1 (id,
0340: 61 29 20 76 61 6c 75 65 73 20 28 4e 45 57 2e 69  a) values (NEW.i
0350: 64 2c 4e 45 57 2e 61 29 3b 0a 20 20 20 20 20 20  d,NEW.a);.      
0360: 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 65    insert into te
0370: 73 74 32 20 28 69 64 2c 62 29 20 76 61 6c 75 65  st2 (id,b) value
0380: 73 20 28 4e 45 57 2e 69 64 2c 4e 45 57 2e 62 29  s (NEW.id,NEW.b)
0390: 3b 0a 20 20 20 20 20 20 65 6e 64 3b 0a 20 20 20  ;.      end;.   
03a0: 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 74 65 73   insert into tes
03b0: 74 20 76 61 6c 75 65 73 28 31 2c 32 2c 33 29 3b  t values(1,2,3);
03c0: 0a 20 20 20 20 73 65 6c 65 63 74 20 2a 20 66 72  .    select * fr
03d0: 6f 6d 20 74 65 73 74 31 3b 0a 20 20 7d 0a 7d 20  om test1;.  }.} 
03e0: 7b 31 20 32 7d 0a 64 6f 5f 74 65 73 74 20 74 72  {1 2}.do_test tr
03f0: 69 67 67 65 72 34 2d 31 2e 32 20 7b 0a 20 20 65  igger4-1.2 {.  e
0400: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 73 65 6c  xecsql {.    sel
0410: 65 63 74 20 2a 20 66 72 6f 6d 20 74 65 73 74 32  ect * from test2
0420: 3b 0a 20 20 7d 0a 7d 20 7b 31 20 33 7d 0a 64 6f  ;.  }.} {1 3}.do
0430: 5f 74 65 73 74 20 74 72 69 67 67 65 72 34 2d 31  _test trigger4-1
0440: 2e 33 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  .3 {.  db close.
0450: 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73    sqlite3 db tes
0460: 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b  t.db.  execsql {
0470: 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f  .    insert into
0480: 20 74 65 73 74 20 76 61 6c 75 65 73 28 34 2c 35   test values(4,5
0490: 2c 36 29 3b 0a 20 20 20 20 73 65 6c 65 63 74 20  ,6);.    select 
04a0: 2a 20 66 72 6f 6d 20 74 65 73 74 31 3b 0a 20 20  * from test1;.  
04b0: 7d 0a 7d 20 7b 31 20 32 20 34 20 35 7d 0a 64 6f  }.} {1 2 4 5}.do
04c0: 5f 74 65 73 74 20 74 72 69 67 67 65 72 34 2d 31  _test trigger4-1
04d0: 2e 34 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .4 {.  execsql {
04e0: 0a 20 20 20 20 73 65 6c 65 63 74 20 2a 20 66 72  .    select * fr
04f0: 6f 6d 20 74 65 73 74 32 3b 0a 20 20 7d 0a 7d 20  om test2;.  }.} 
0500: 7b 31 20 33 20 34 20 36 7d 0a 0a 64 6f 5f 74 65  {1 3 4 6}..do_te
0510: 73 74 20 74 72 69 67 67 65 72 34 2d 32 2e 31 20  st trigger4-2.1 
0520: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0530: 20 20 63 72 65 61 74 65 20 74 72 69 67 67 65 72    create trigger
0540: 20 55 5f 74 65 73 74 20 69 6e 73 74 65 61 64 20   U_test instead 
0550: 6f 66 20 75 70 64 61 74 65 20 6f 6e 20 74 65 73  of update on tes
0560: 74 0a 20 20 20 20 20 20 62 65 67 69 6e 0a 20 20  t.      begin.  
0570: 20 20 20 20 20 20 75 70 64 61 74 65 20 74 65 73        update tes
0580: 74 31 20 73 65 74 20 61 3d 4e 45 57 2e 61 20 77  t1 set a=NEW.a w
0590: 68 65 72 65 20 69 64 3d 4e 45 57 2e 69 64 3b 0a  here id=NEW.id;.
05a0: 20 20 20 20 20 20 20 20 75 70 64 61 74 65 20 74          update t
05b0: 65 73 74 32 20 73 65 74 20 62 3d 4e 45 57 2e 62  est2 set b=NEW.b
05c0: 20 77 68 65 72 65 20 69 64 3d 4e 45 57 2e 69 64   where id=NEW.id
05d0: 3b 0a 20 20 20 20 20 20 65 6e 64 3b 0a 20 20 20  ;.      end;.   
05e0: 20 75 70 64 61 74 65 20 74 65 73 74 20 73 65 74   update test set
05f0: 20 61 3d 32 32 20 77 68 65 72 65 20 69 64 3d 31   a=22 where id=1
0600: 3b 0a 20 20 20 20 73 65 6c 65 63 74 20 2a 20 66  ;.    select * f
0610: 72 6f 6d 20 74 65 73 74 31 3b 0a 20 20 7d 0a 7d  rom test1;.  }.}
0620: 20 7b 31 20 32 32 20 34 20 35 7d 0a 64 6f 5f 74   {1 22 4 5}.do_t
0630: 65 73 74 20 74 72 69 67 67 65 72 34 2d 32 2e 32  est trigger4-2.2
0640: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
0650: 20 20 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d     select * from
0660: 20 74 65 73 74 32 3b 0a 20 20 7d 0a 7d 20 7b 31   test2;.  }.} {1
0670: 20 33 20 34 20 36 7d 0a 64 6f 5f 74 65 73 74 20   3 4 6}.do_test 
0680: 74 72 69 67 67 65 72 34 2d 32 2e 33 20 7b 0a 20  trigger4-2.3 {. 
0690: 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69   db close.  sqli
06a0: 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20  te3 db test.db. 
06b0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 75   execsql {.    u
06c0: 70 64 61 74 65 20 74 65 73 74 20 73 65 74 20 62  pdate test set b
06d0: 3d 36 36 20 77 68 65 72 65 20 69 64 3d 34 3b 0a  =66 where id=4;.
06e0: 20 20 20 20 73 65 6c 65 63 74 20 2a 20 66 72 6f      select * fro
06f0: 6d 20 74 65 73 74 31 3b 0a 20 20 7d 0a 7d 20 7b  m test1;.  }.} {
0700: 31 20 32 32 20 34 20 35 7d 0a 64 6f 5f 74 65 73  1 22 4 5}.do_tes
0710: 74 20 74 72 69 67 67 65 72 34 2d 32 2e 34 20 7b  t trigger4-2.4 {
0720: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0730: 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20 74   select * from t
0740: 65 73 74 32 3b 0a 20 20 7d 0a 7d 20 7b 31 20 33  est2;.  }.} {1 3
0750: 20 34 20 36 36 7d 0a 0a 64 6f 5f 74 65 73 74 20   4 66}..do_test 
0760: 74 72 69 67 67 65 72 34 2d 33 2e 31 20 7b 0a 20  trigger4-3.1 {. 
0770: 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20   catchsql {.    
0780: 64 72 6f 70 20 74 61 62 6c 65 20 74 65 73 74 32  drop table test2
0790: 3b 0a 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74  ;.    insert int
07a0: 6f 20 74 65 73 74 20 76 61 6c 75 65 73 28 37 2c  o test values(7,
07b0: 38 2c 39 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b  8,9);.  }.} {1 {
07c0: 6e 6f 20 73 75 63 68 20 74 61 62 6c 65 3a 20 6d  no such table: m
07d0: 61 69 6e 2e 74 65 73 74 32 7d 7d 0a 64 6f 5f 74  ain.test2}}.do_t
07e0: 65 73 74 20 74 72 69 67 67 65 72 34 2d 33 2e 32  est trigger4-3.2
07f0: 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20   {.  db close.  
0800: 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e  sqlite3 db test.
0810: 64 62 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a  db.  catchsql {.
0820: 20 20 20 20 69 6e 73 65 72 74 20 69 6e 74 6f 20      insert into 
0830: 74 65 73 74 20 76 61 6c 75 65 73 28 37 2c 38 2c  test values(7,8,
0840: 39 29 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f  9);.  }.} {1 {no
0850: 20 73 75 63 68 20 74 61 62 6c 65 3a 20 6d 61 69   such table: mai
0860: 6e 2e 74 65 73 74 32 7d 7d 0a 64 6f 5f 74 65 73  n.test2}}.do_tes
0870: 74 20 74 72 69 67 67 65 72 34 2d 33 2e 33 20 7b  t trigger4-3.3 {
0880: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0890: 20 20 75 70 64 61 74 65 20 74 65 73 74 20 73 65    update test se
08a0: 74 20 61 3d 32 32 32 20 77 68 65 72 65 20 69 64  t a=222 where id
08b0: 3d 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 7b 6e 6f  =1;.  }.} {1 {no
08c0: 20 73 75 63 68 20 74 61 62 6c 65 3a 20 6d 61 69   such table: mai
08d0: 6e 2e 74 65 73 74 32 7d 7d 0a 64 6f 5f 74 65 73  n.test2}}.do_tes
08e0: 74 20 74 72 69 67 67 65 72 34 2d 33 2e 34 20 7b  t trigger4-3.4 {
08f0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0900: 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20 74   select * from t
0910: 65 73 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32  est1;.  }.} {1 2
0920: 32 20 34 20 35 7d 0a 64 6f 5f 74 65 73 74 20 74  2 4 5}.do_test t
0930: 72 69 67 67 65 72 34 2d 33 2e 35 20 7b 0a 20 20  rigger4-3.5 {.  
0940: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 63 72  execsql {.    cr
0950: 65 61 74 65 20 74 61 62 6c 65 20 74 65 73 74 32  eate table test2
0960: 28 69 64 2c 62 29 3b 0a 20 20 20 20 69 6e 73 65  (id,b);.    inse
0970: 72 74 20 69 6e 74 6f 20 74 65 73 74 20 76 61 6c  rt into test val
0980: 75 65 73 28 37 2c 38 2c 39 29 3b 0a 20 20 20 20  ues(7,8,9);.    
0990: 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20 74 65  select * from te
09a0: 73 74 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20 32 32  st1;.  }.} {1 22
09b0: 20 34 20 35 20 37 20 38 7d 0a 64 6f 5f 74 65 73   4 5 7 8}.do_tes
09c0: 74 20 74 72 69 67 67 65 72 34 2d 33 2e 36 20 7b  t trigger4-3.6 {
09d0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
09e0: 20 73 65 6c 65 63 74 20 2a 20 66 72 6f 6d 20 74   select * from t
09f0: 65 73 74 32 3b 0a 20 20 7d 0a 7d 20 7b 37 20 39  est2;.  }.} {7 9
0a00: 7d 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65  }.do_test trigge
0a10: 72 34 2d 33 2e 37 20 7b 0a 20 20 64 62 20 63 6c  r4-3.7 {.  db cl
0a20: 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20 64 62  ose.  sqlite3 db
0a30: 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65 63 73   test.db.  execs
0a40: 71 6c 20 7b 0a 20 20 20 20 75 70 64 61 74 65 20  ql {.    update 
0a50: 74 65 73 74 20 73 65 74 20 62 3d 39 39 20 77 68  test set b=99 wh
0a60: 65 72 65 20 69 64 3d 37 3b 0a 20 20 20 20 73 65  ere id=7;.    se
0a70: 6c 65 63 74 20 2a 20 66 72 6f 6d 20 74 65 73 74  lect * from test
0a80: 32 3b 0a 20 20 7d 0a 7d 20 7b 37 20 39 39 7d 0a  2;.  }.} {7 99}.
0a90: 0a 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b  .integrity_check
0aa0: 20 74 72 69 67 67 65 72 34 2d 34 2e 31 0a 0a 66   trigger4-4.1..f
0ab0: 69 6e 69 73 68 5f 74 65 73 74 0a                 inish_test.