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