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

1.1       misho       1: # 2008 November 3
                      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: # This file implements regression tests for SQLite library.  The
                     13: # focus of this script is the response of COMMIT and ROLLBACK when
                     14: # statements are still pending.
                     15: #
                     16: # $Id: trans3.test,v 1.2 2008/11/05 16:37:35 drh Exp $
                     17: #
                     18: set testdir [file dirname $argv0]
                     19: source $testdir/tester.tcl
                     20: unset -nocomplain ecode
                     21: 
                     22: do_test trans3-1.1 {
                     23:   db eval {
                     24:     CREATE TABLE t1(x);
                     25:     INSERT INTO t1 VALUES(1);
                     26:     INSERT INTO t1 VALUES(2);
                     27:     INSERT INTO t1 VALUES(3);
                     28:     SELECT * FROM t1;
                     29:   }
                     30: } {1 2 3}
                     31: do_test trans3-1.2 {
                     32:   db eval BEGIN
                     33:   db eval {INSERT INTO t1 VALUES(4);}
                     34:   set ::ecode {}
                     35:   set x [catch {
                     36:      db eval {SELECT * FROM t1 LIMIT 1} {
                     37:         if {[catch {db eval COMMIT} errmsg]} {
                     38:            set ::ecode [sqlite3_extended_errcode db]
                     39:            error $errmsg
                     40:         }
                     41:      }
                     42:   } errmsg]
                     43:   lappend x $errmsg
                     44: } {0 {}}
                     45: do_test trans3-1.3 {
                     46:   set ::ecode
                     47: } {}
                     48: do_test trans3-1.3.1 {
                     49:   sqlite3_get_autocommit db
                     50: } 1
                     51: do_test trans3-1.4 {
                     52:   db eval {SELECT * FROM t1}
                     53: } {1 2 3 4}
                     54: do_test trans3-1.5 {
                     55:   db eval BEGIN
                     56:   db eval {INSERT INTO t1 VALUES(5);}
                     57:   set ::ecode {}
                     58:   set x [catch {
                     59:      db eval {SELECT * FROM t1} {
                     60:         if {[catch {db eval ROLLBACK} errmsg]} {
                     61:            set ::ecode [sqlite3_extended_errcode db]
                     62:            error $errmsg
                     63:         }
                     64:      }
                     65:   } errmsg]
                     66:   lappend x $errmsg
                     67: } {1 {cannot rollback transaction - SQL statements in progress}}
                     68: do_test trans3-1.6 {
                     69:   set ::ecode
                     70: } {SQLITE_BUSY}
                     71: do_test trans3-1.7 {
                     72:   db eval COMMIT
                     73:   db eval {SELECT * FROM t1}
                     74: } {1 2 3 4 5}
                     75: unset -nocomplain ecode
                     76: 
                     77: finish_test

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