Annotation of embedaddon/sqlite3/test/fkey4.test, revision 1.1.1.1

1.1       misho       1: # 2011 Feb 04
                      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: # This file implements regression tests for SQLite library.
                     12: #
                     13: # This file test deferred foreign key constraint processing to make
                     14: # sure that when a statement not within BEGIN...END fails a constraint,
                     15: # that statement doesn't hold the transaction open thus allowing
                     16: # a subsequent statement to fail a deferred constraint with impunity.
                     17: #
                     18: 
                     19: set testdir [file dirname $argv0]
                     20: source $testdir/tester.tcl
                     21: 
                     22: ifcapable {!foreignkey||!trigger} {
                     23:   finish_test
                     24:   return
                     25: }
                     26: 
                     27: # Create a table and some data to work with.
                     28: #
                     29: do_test fkey4-1.1 {
                     30:   execsql {
                     31:     PRAGMA foreign_keys = ON;
                     32:     CREATE TABLE t1(a PRIMARY KEY, b);
                     33:     CREATE TABLE t2(c REFERENCES t1 DEFERRABLE INITIALLY DEFERRED, d);
                     34:     INSERT INTO t1 VALUES(1,2);
                     35:     INSERT INTO t2 VALUES(1,3);
                     36:   }
                     37: } {}
                     38: 
                     39: do_test fkey4-1.2 {
                     40:   set ::DB [sqlite3_connection_pointer db]
                     41:   set ::SQL {INSERT INTO t2 VALUES(2,4)}
                     42:   set ::STMT1 [sqlite3_prepare_v2 $::DB $::SQL -1 TAIL]
                     43:   sqlite3_step $::STMT1
                     44: } {SQLITE_CONSTRAINT}
                     45: do_test fkey4-1.3 {
                     46:   set ::STMT2 [sqlite3_prepare_v2 $::DB $::SQL -1 TAIL]
                     47:   sqlite3_step $::STMT2
                     48: } {SQLITE_CONSTRAINT}
                     49: do_test fkey4-1.4 {
                     50:   db eval {SELECT * FROM t2}
                     51: } {1 3}
                     52: sqlite3_finalize $::STMT1
                     53: sqlite3_finalize $::STMT2
                     54: 
                     55: finish_test

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>