import less(1)
[unleashed/tickless.git] / usr / src / lib / libsqlite / test / crashme2.off
bloba6a4e773532f614392861d6502f18098ed00702e
2 #pragma ident   "%Z%%M% %I%     %E% SMI"
5 set testdir [file dirname $argv0]
6 source $testdir/tester.tcl
8 db close
9 set DB [sqlite db test.db]
11 execsql {
12   CREATE TABLE t1(a);
13   INSERT INTO t1 VALUES(1);
14   INSERT INTO t1 VALUES(2);
15   INSERT INTO t1 VALUES(3);
16   INSERT INTO t1 VALUES(4);
19 do_test capi3-13.1 {
20   execsql {
21     CREATE TABLE t3(a unique on conflict rollback);
22     INSERT INTO t3 SELECT a FROM t1;
23     BEGIN;
24     INSERT INTO t1 SELECT * FROM t1;
25   }
26 } {}
27 do_test capi3-13.2 {
28   set STMT [sqlite_compile $DB "SELECT a FROM t1" TAIL]
29   sqlite_step $STMT
30   sqlite_step $STMT
31   sqlite_step $STMT
32   sqlite_step $STMT
33   sqlite_step $STMT
34 } {SQLITE_ROW}
35 do_test capi3-13.3 {
36 # This causes a ROLLBACK, which deletes the table out from underneath the
37 # SELECT statement. Causes a crash.
38   catchsql {
39     INSERT INTO t3 SELECT a FROM t1;
40   }
41 } {1 {column a is not unique}}
42 do_test capi3-13.4 {
43   sqlite_step $STMT
44   sqlite_step $STMT
45   sqlite_step $STMT
46   sqlite_step $STMT
47 } {SQLITE_DONE}
48 do_test capi3-13.5 {
49   sqlite_finalize $STMT
50 } {SQLITE_OK}
52 finish_test