Home | History | Annotate | Download | only in test
      1 # 2009 April 30                                                            
      2 #
      3 # The author disclaims copyright to this source code.  In place of
      4 # a legal notice, here is a blessing:
      5 #
      6 #    May you do good and not evil.
      7 #    May you find forgiveness for yourself and forgive others.
      8 #    May you share freely, never taking more than you give.
      9 #
     10 #***********************************************************************
     11 #
     12 # Ticket #3832
     13 #
     14 # A segfault when using a BEFORE trigger on an INSERT and inserting
     15 # a NULL into the INTEGER PRIMARY KEY.
     16 #
     17 # $Id: tkt3832.test,v 1.1 2009/05/01 02:08:04 drh Exp $
     18 
     19 set testdir [file dirname $argv0]
     20 source $testdir/tester.tcl
     21 ifcapable {!trigger} {
     22   finish_test
     23   return
     24 }
     25 
     26 
     27 do_test tkt3832-1.1 {
     28   db eval {
     29     CREATE TABLE t1(a INT, b INTEGER PRIMARY KEY);
     30     CREATE TABLE log(x);
     31     CREATE TRIGGER t1r1 BEFORE INSERT ON t1 BEGIN
     32       INSERT INTO log VALUES(new.b);
     33     END;
     34     INSERT INTO t1 VALUES(NULL,5);
     35     INSERT INTO t1 SELECT b, a FROM t1 ORDER BY b;
     36     SELECT rowid, * FROM t1;
     37     SELECT rowid, * FROM log;
     38   }
     39 } {5 {} 5 6 5 6 1 5 2 -1}
     40 
     41 finish_test
     42