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