xref: /illumos-gate/usr/src/lib/libsqlite/test/laststmtchanges.test (revision 1da57d551424de5a9d469760be7c4b4d4f10a755)
1*1da57d55SToomas Soome#
2c5c4113dSnw141292# The author disclaims copyright to this source code.  In place of
3c5c4113dSnw141292# a legal notice, here is a blessing:
4c5c4113dSnw141292#
5c5c4113dSnw141292#    May you do good and not evil.
6c5c4113dSnw141292#    May you find forgiveness for yourself and forgive others.
7c5c4113dSnw141292#    May you share freely, never taking more than you give.
8c5c4113dSnw141292#
9c5c4113dSnw141292#***********************************************************************
10c5c4113dSnw141292#
11c5c4113dSnw141292# Tests to make sure that value returned by last_statement_change_count()
12c5c4113dSnw141292# (LSCC) is updated properly, especially inside triggers
13c5c4113dSnw141292#
14c5c4113dSnw141292# Note 1: LSCC remains constant within a statement and only updates once
15c5c4113dSnw141292#           the statement is finished (triggers count as part of statement)
16c5c4113dSnw141292# Note 2: LSCC is changed within the context of a trigger
17c5c4113dSnw141292#           much like last_insert_rowid() (see lastinsert.test),
18c5c4113dSnw141292#           but is restored once the trigger exits
19c5c4113dSnw141292# Note 3: LSCC is not changed by a change to a view (since everything
20c5c4113dSnw141292#           is done within instead of trigger context)
21c5c4113dSnw141292#
22c5c4113dSnw141292
23c5c4113dSnw141292set testdir [file dirname $argv0]
24c5c4113dSnw141292source $testdir/tester.tcl
25c5c4113dSnw141292
26c5c4113dSnw141292# ----------------------------------------------------------------------------
27c5c4113dSnw141292# 1.x - basic tests (no triggers)
28c5c4113dSnw141292
29c5c4113dSnw141292# LSCC set properly after insert
30c5c4113dSnw141292do_test laststmtchanges-1.1 {
31c5c4113dSnw141292    catchsql {
32c5c4113dSnw141292        create table t0 (x);
33c5c4113dSnw141292        insert into t0 values (1);
34c5c4113dSnw141292        insert into t0 values (1);
35c5c4113dSnw141292        insert into t0 values (2);
36c5c4113dSnw141292        insert into t0 values (2);
37c5c4113dSnw141292        insert into t0 values (1);
38c5c4113dSnw141292        insert into t0 values (1);
39c5c4113dSnw141292        insert into t0 values (1);
40c5c4113dSnw141292        insert into t0 values (2);
41c5c4113dSnw141292        select last_statement_change_count();
42c5c4113dSnw141292    }
43c5c4113dSnw141292} {0 1}
44c5c4113dSnw141292
45c5c4113dSnw141292# LSCC set properly after update
46c5c4113dSnw141292do_test laststmtchanges-1.2 {
47c5c4113dSnw141292    catchsql {
48c5c4113dSnw141292        update t0 set x=3 where x=1;
49c5c4113dSnw141292        select last_statement_change_count();
50c5c4113dSnw141292    }
51c5c4113dSnw141292} {0 5}
52c5c4113dSnw141292
53c5c4113dSnw141292# LSCC unchanged within an update statement
54c5c4113dSnw141292do_test laststmtchanges-1.3 {
55c5c4113dSnw141292    catchsql {
56c5c4113dSnw141292        update t0 set x=x+last_statement_change_count() where x=3;
57c5c4113dSnw141292        select count() from t0 where x=8;
58c5c4113dSnw141292    }
59c5c4113dSnw141292} {0 5}
60c5c4113dSnw141292
61c5c4113dSnw141292# LSCC set properly after update on table where no rows changed
62c5c4113dSnw141292do_test laststmtchanges-1.4 {
63c5c4113dSnw141292    catchsql {
64c5c4113dSnw141292        update t0 set x=77 where x=88;
65c5c4113dSnw141292        select last_statement_change_count();
66c5c4113dSnw141292    }
67c5c4113dSnw141292} {0 0}
68c5c4113dSnw141292
69c5c4113dSnw141292# LSCC set properly after delete from table
70c5c4113dSnw141292do_test laststmtchanges-1.5 {
71c5c4113dSnw141292    catchsql {
72c5c4113dSnw141292        delete from t0 where x=2;
73c5c4113dSnw141292        select last_statement_change_count();
74c5c4113dSnw141292    }
75c5c4113dSnw141292} {0 3}
76c5c4113dSnw141292
77c5c4113dSnw141292# ----------------------------------------------------------------------------
78c5c4113dSnw141292# 2.x - tests with after insert trigger
79c5c4113dSnw141292
80c5c4113dSnw141292# LSCC changed properly after insert into table containing after trigger
81c5c4113dSnw141292do_test laststmtchanges-2.1 {
82c5c4113dSnw141292    catchsql {
83c5c4113dSnw141292        create table t1 (k integer primary key);
84c5c4113dSnw141292        create table t2 (k integer primary key, v1, v2);
85c5c4113dSnw141292        create trigger r1 after insert on t1 for each row begin
86c5c4113dSnw141292            insert into t2 values (NULL, last_statement_change_count(), NULL);
87c5c4113dSnw141292            update t0 set x=x;
88c5c4113dSnw141292            update t2 set v2=last_statement_change_count();
89c5c4113dSnw141292        end;
90c5c4113dSnw141292        insert into t1 values (77);
91c5c4113dSnw141292        select last_statement_change_count();
92c5c4113dSnw141292    }
93c5c4113dSnw141292} {0 1}
94c5c4113dSnw141292
95c5c4113dSnw141292# LSCC unchanged upon entry into after insert trigger
96c5c4113dSnw141292do_test laststmtchanges-2.2 {
97c5c4113dSnw141292    catchsql {
98c5c4113dSnw141292        select v1 from t2;
99c5c4113dSnw141292    }
100c5c4113dSnw141292} {0 3}
101c5c4113dSnw141292
102c5c4113dSnw141292# LSCC changed properly by update within context of after insert trigger
103c5c4113dSnw141292do_test laststmtchanges-2.3 {
104c5c4113dSnw141292    catchsql {
105c5c4113dSnw141292        select v2 from t2;
106c5c4113dSnw141292    }
107c5c4113dSnw141292} {0 5}
108c5c4113dSnw141292
109c5c4113dSnw141292# ----------------------------------------------------------------------------
110c5c4113dSnw141292# 3.x - tests with after update trigger
111c5c4113dSnw141292
112c5c4113dSnw141292# LSCC changed properly after update into table containing after trigger
113c5c4113dSnw141292do_test laststmtchanges-3.1 {
114c5c4113dSnw141292    catchsql {
115c5c4113dSnw141292        drop trigger r1;
116c5c4113dSnw141292        delete from t2; delete from t2;
117c5c4113dSnw141292        create trigger r1 after update on t1 for each row begin
118c5c4113dSnw141292            insert into t2 values (NULL, last_statement_change_count(), NULL);
119c5c4113dSnw141292            delete from t0 where oid=1 or oid=2;
120c5c4113dSnw141292            update t2 set v2=last_statement_change_count();
121c5c4113dSnw141292        end;
122c5c4113dSnw141292        update t1 set k=k;
123c5c4113dSnw141292        select last_statement_change_count();
124c5c4113dSnw141292    }
125c5c4113dSnw141292} {0 1}
126c5c4113dSnw141292
127c5c4113dSnw141292# LSCC unchanged upon entry into after update trigger
128c5c4113dSnw141292do_test laststmtchanges-3.2 {
129c5c4113dSnw141292    catchsql {
130c5c4113dSnw141292        select v1 from t2;
131c5c4113dSnw141292    }
132c5c4113dSnw141292} {0 0}
133c5c4113dSnw141292
134c5c4113dSnw141292# LSCC changed properly by delete within context of after update trigger
135c5c4113dSnw141292do_test laststmtchanges-3.3 {
136c5c4113dSnw141292    catchsql {
137c5c4113dSnw141292        select v2 from t2;
138c5c4113dSnw141292    }
139c5c4113dSnw141292} {0 2}
140c5c4113dSnw141292
141c5c4113dSnw141292# ----------------------------------------------------------------------------
142c5c4113dSnw141292# 4.x - tests with before delete trigger
143c5c4113dSnw141292
144c5c4113dSnw141292# LSCC changed properly on delete from table containing before trigger
145c5c4113dSnw141292do_test laststmtchanges-4.1 {
146c5c4113dSnw141292    catchsql {
147c5c4113dSnw141292        drop trigger r1;
148c5c4113dSnw141292        delete from t2; delete from t2;
149c5c4113dSnw141292        create trigger r1 before delete on t1 for each row begin
150c5c4113dSnw141292            insert into t2 values (NULL, last_statement_change_count(), NULL);
151c5c4113dSnw141292            insert into t0 values (5);
152c5c4113dSnw141292            update t2 set v2=last_statement_change_count();
153c5c4113dSnw141292        end;
154c5c4113dSnw141292        delete from t1;
155c5c4113dSnw141292        select last_statement_change_count();
156c5c4113dSnw141292    }
157c5c4113dSnw141292} {0 1}
158c5c4113dSnw141292
159c5c4113dSnw141292# LSCC unchanged upon entry into before delete trigger
160c5c4113dSnw141292do_test laststmtchanges-4.2 {
161c5c4113dSnw141292    catchsql {
162c5c4113dSnw141292        select v1 from t2;
163c5c4113dSnw141292    }
164c5c4113dSnw141292} {0 0}
165c5c4113dSnw141292
166c5c4113dSnw141292# LSCC changed properly by insert within context of before delete trigger
167c5c4113dSnw141292do_test laststmtchanges-4.3 {
168c5c4113dSnw141292    catchsql {
169c5c4113dSnw141292        select v2 from t2;
170c5c4113dSnw141292    }
171c5c4113dSnw141292} {0 1}
172c5c4113dSnw141292
173c5c4113dSnw141292# ----------------------------------------------------------------------------
174c5c4113dSnw141292# 5.x - complex tests with temporary tables and nested instead of triggers
175c5c4113dSnw141292
176c5c4113dSnw141292do_test laststmtchanges-5.1 {
177c5c4113dSnw141292    catchsql {
178c5c4113dSnw141292        drop table t0; drop table t1; drop table t2;
179c5c4113dSnw141292        create temp table t0(x);
180c5c4113dSnw141292        create temp table t1 (k integer primary key);
181c5c4113dSnw141292        create temp table t2 (k integer primary key);
182c5c4113dSnw141292        create temp view v1 as select * from t1;
183c5c4113dSnw141292        create temp view v2 as select * from t2;
184c5c4113dSnw141292        create temp table n1 (k integer primary key, n);
185c5c4113dSnw141292        create temp table n2 (k integer primary key, n);
186c5c4113dSnw141292        insert into t0 values (1);
187c5c4113dSnw141292        insert into t0 values (2);
188c5c4113dSnw141292        insert into t0 values (1);
189c5c4113dSnw141292        insert into t0 values (1);
190c5c4113dSnw141292        insert into t0 values (1);
191c5c4113dSnw141292        insert into t0 values (2);
192c5c4113dSnw141292        insert into t0 values (2);
193c5c4113dSnw141292        insert into t0 values (1);
194c5c4113dSnw141292        create temp trigger r1 instead of insert on v1 for each row begin
195c5c4113dSnw141292            insert into n1 values (NULL, last_statement_change_count());
196c5c4113dSnw141292            update t0 set x=x*10 where x=1;
197c5c4113dSnw141292            insert into n1 values (NULL, last_statement_change_count());
198c5c4113dSnw141292            insert into t1 values (NEW.k);
199c5c4113dSnw141292            insert into n1 values (NULL, last_statement_change_count());
200c5c4113dSnw141292            update t0 set x=x*10 where x=0;
201c5c4113dSnw141292            insert into v2 values (100+NEW.k);
202c5c4113dSnw141292            insert into n1 values (NULL, last_statement_change_count());
203c5c4113dSnw141292        end;
204c5c4113dSnw141292        create temp trigger r2 instead of insert on v2 for each row begin
205c5c4113dSnw141292            insert into n2 values (NULL, last_statement_change_count());
206c5c4113dSnw141292            insert into t2 values (1000+NEW.k);
207c5c4113dSnw141292            insert into n2 values (NULL, last_statement_change_count());
208c5c4113dSnw141292            update t0 set x=x*100 where x=0;
209c5c4113dSnw141292            insert into n2 values (NULL, last_statement_change_count());
210c5c4113dSnw141292            delete from t0 where x=2;
211c5c4113dSnw141292            insert into n2 values (NULL, last_statement_change_count());
212c5c4113dSnw141292        end;
213c5c4113dSnw141292        insert into t1 values (77);
214c5c4113dSnw141292        select last_statement_change_count();
215c5c4113dSnw141292    }
216c5c4113dSnw141292} {0 1}
217c5c4113dSnw141292
218c5c4113dSnw141292do_test laststmtchanges-5.2 {
219c5c4113dSnw141292    catchsql {
220c5c4113dSnw141292        delete from t1 where k=88;
221c5c4113dSnw141292        select last_statement_change_count();
222c5c4113dSnw141292    }
223c5c4113dSnw141292} {0 0}
224c5c4113dSnw141292
225c5c4113dSnw141292do_test laststmtchanges-5.3 {
226c5c4113dSnw141292    catchsql {
227c5c4113dSnw141292        insert into v1 values (5);
228c5c4113dSnw141292        select last_statement_change_count();
229c5c4113dSnw141292    }
230c5c4113dSnw141292} {0 0}
231c5c4113dSnw141292
232c5c4113dSnw141292do_test laststmtchanges-5.4 {
233c5c4113dSnw141292    catchsql {
234c5c4113dSnw141292        select n from n1;
235c5c4113dSnw141292    }
236c5c4113dSnw141292} {0 {0 5 1 0}}
237c5c4113dSnw141292
238c5c4113dSnw141292do_test laststmtchanges-5.5 {
239c5c4113dSnw141292    catchsql {
240c5c4113dSnw141292        select n from n2;
241c5c4113dSnw141292    }
242c5c4113dSnw141292} {0 {0 1 0 3}}
243c5c4113dSnw141292
244c5c4113dSnw141292finish_test
245c5c4113dSnw141292
246