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

1.1       misho       1: #
                      2: #    May you do good and not evil.
                      3: #    May you find forgiveness for yourself and forgive others.
                      4: #    May you share freely, never taking more than you give.
                      5: #
                      6: #***********************************************************************
                      7: #
                      8: # $Id: async2.test,v 1.12 2009/04/25 08:39:15 danielk1977 Exp $
                      9: 
                     10: 
                     11: set testdir [file dirname $argv0]
                     12: source $testdir/tester.tcl
                     13: 
                     14: if {
                     15:   [info commands sqlite3async_initialize]=="" ||
                     16:   [info command sqlite3_memdebug_fail]==""
                     17: } {
                     18:   # The async logic is not built into this system
                     19:   puts "Skipping async2 tests: not compiled with required features"
                     20:   finish_test
                     21:   return
                     22: }
                     23: 
                     24: # Enable asynchronous IO.
                     25: 
                     26: set setup_script {
                     27:   CREATE TABLE counter(c);
                     28:   INSERT INTO counter(c) VALUES (1);
                     29: } 
                     30: 
                     31: set sql_script {
                     32:   BEGIN;
                     33:     UPDATE counter SET c = 2;
                     34:     CREATE TABLE t1(a PRIMARY KEY, b, c);
                     35:     CREATE TABLE t2(a PRIMARY KEY, b, c);
                     36:   COMMIT;
                     37: 
                     38:   BEGIN;
                     39:     UPDATE counter SET c = 3;
                     40:     INSERT INTO t1 VALUES('abcdefghij', 'four', 'score');
                     41:     INSERT INTO t2 VALUES('klmnopqrst', 'and', 'seven');
                     42:   COMMIT;
                     43: 
                     44:   UPDATE counter SET c = 'FIN';
                     45: }
                     46: 
                     47: db close
                     48: 
                     49: foreach err [list ioerr malloc-transient malloc-persistent] {
                     50:   set ::go 10
                     51:   for {set n 1} {$::go} {incr n} {
                     52:     set ::sqlite_io_error_pending 0
                     53:     sqlite3_memdebug_fail -1
                     54:     forcedelete test.db test.db-journal
                     55:     sqlite3 db test.db
                     56:     execsql $::setup_script
                     57:     db close
                     58:   
                     59:     sqlite3async_initialize "" 1
                     60:     sqlite3 db test.db
                     61:     sqlite3_db_config_lookaside db 0 0 0
                     62:   
                     63:     switch -- $err {
                     64:       ioerr             { set ::sqlite_io_error_pending $n }
                     65:       malloc-persistent { sqlite3_memdebug_fail $n -repeat 1 }
                     66:       malloc-transient  { sqlite3_memdebug_fail $n -repeat 0 }
                     67:     }
                     68: 
                     69:     catchsql $::sql_script
                     70:     db close
                     71: 
                     72:     sqlite3async_control halt idle
                     73:     sqlite3async_start
                     74:     sqlite3async_wait
                     75:     sqlite3async_control halt never
                     76:     sqlite3async_shutdown
                     77: 
                     78:     set ::sqlite_io_error_pending 0
                     79:     sqlite3_memdebug_fail -1
                     80: 
                     81:     sqlite3 db test.db
                     82:     set c [db one {SELECT c FROM counter LIMIT 1}]
                     83:     switch -- $c {
                     84:       1 {
                     85:         do_test async-$err-1.1.$n {
                     86:           execsql {
                     87:             SELECT name FROM sqlite_master;
                     88:           }
                     89:         } {counter}
                     90:       }
                     91:       2 {
                     92:         do_test async-$err-1.2.$n.1 {
                     93:           execsql {
                     94:             SELECT * FROM t1;
                     95:           }
                     96:         } {}
                     97:         do_test async-$err-1.2.$n.2 {
                     98:           execsql {
                     99:             SELECT * FROM t2;
                    100:           }
                    101:         } {}
                    102:       }
                    103:       3 {
                    104:         do_test async-$err-1.3.$n.1 {
                    105:           execsql {
                    106:             SELECT * FROM t1;
                    107:           }
                    108:         } {abcdefghij four score}
                    109:         do_test async-$err-1.3.$n.2 {
                    110:           execsql {
                    111:             SELECT * FROM t2;
                    112:           }
                    113:         } {klmnopqrst and seven}
                    114:       }
                    115:       FIN {
                    116:         incr ::go -1
                    117:       }
                    118:     }
                    119:   
                    120:     db close
                    121:   }
                    122: }
                    123: 
                    124: catch {db close}
                    125: 
                    126: finish_test

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