2008-06-21 22:07:37 +04:00
|
|
|
# 2008 June 21
|
|
|
|
#
|
|
|
|
# The author disclaims copyright to this source code. In place of
|
|
|
|
# a legal notice, here is a blessing:
|
|
|
|
#
|
|
|
|
# May you do good and not evil.
|
|
|
|
# May you find forgiveness for yourself and forgive others.
|
|
|
|
# May you share freely, never taking more than you give.
|
|
|
|
#
|
|
|
|
#***********************************************************************
|
|
|
|
#
|
2009-01-10 21:51:40 +03:00
|
|
|
# $Id: permutations.test,v 1.45 2009/01/10 18:51:40 danielk1977 Exp $
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
set testdir [file dirname $argv0]
|
|
|
|
source $testdir/tester.tcl
|
|
|
|
|
|
|
|
# Argument processing.
|
|
|
|
#
|
2008-08-25 21:23:29 +04:00
|
|
|
#puts "PERM-DEBUG: argv=$argv"
|
|
|
|
namespace eval ::perm {
|
2008-08-27 03:08:04 +04:00
|
|
|
variable testmode [lindex $::argv 0]
|
|
|
|
variable testfile [lindex $::argv 1]
|
2008-08-25 21:23:29 +04:00
|
|
|
}
|
2008-06-21 22:07:37 +04:00
|
|
|
set argv [lrange $argv 2 end]
|
2008-08-27 03:08:04 +04:00
|
|
|
#puts "PERM-DEBUG: testmode=$::perm::testmode tstfile=$::perm::testfile"
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
set ::permutations_presql ""
|
|
|
|
set ::permutations_test_prefix ""
|
|
|
|
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode eq "veryquick"} {
|
|
|
|
set ::perm::testmode [list persistent_journal no_journal]
|
2008-06-21 22:07:37 +04:00
|
|
|
set ISQUICK 1
|
|
|
|
}
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode eq "quick"} {
|
|
|
|
set ::perm::testmode [list persistent_journal no_journal autovacuum_ioerr]
|
2008-06-21 22:07:37 +04:00
|
|
|
set ISQUICK 1
|
|
|
|
}
|
2008-08-25 23:09:01 +04:00
|
|
|
if {$::perm::testmode eq "all" || $::perm::testmode eq ""} {
|
2008-08-25 21:23:29 +04:00
|
|
|
set ::perm::testmode {
|
2008-06-21 22:07:37 +04:00
|
|
|
memsubsys1 memsubsys2 singlethread multithread onefile utf16 exclusive
|
|
|
|
persistent_journal persistent_journal_error no_journal no_journal_error
|
2008-12-22 13:58:46 +03:00
|
|
|
autovacuum_ioerr no_mutex_try fullmutex journaltest
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
}
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode eq "targets"} {
|
2008-06-21 22:07:37 +04:00
|
|
|
puts ""
|
|
|
|
puts -nonewline "veryquick "
|
|
|
|
puts "Same as persistent_journal and no_journal"
|
|
|
|
puts -nonewline "quick "
|
|
|
|
puts "Same as persistent_journal, no_journal and autovacuum_ioerr"
|
|
|
|
puts -nonewline "all "
|
|
|
|
puts "Everything except autovacuum_crash"
|
|
|
|
}
|
2008-08-25 23:09:01 +04:00
|
|
|
#puts "PERM-DEBUG: testmode=$::perm::testmode"
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
set EXCLUDE {
|
2008-07-10 22:13:42 +04:00
|
|
|
all.test in2.test onefile.test
|
|
|
|
async2.test incrvacuum_ioerr.test permutations.test
|
|
|
|
async.test jrnlmode2.test quick.test
|
|
|
|
autovacuum_crash.test jrnlmode3.test shared_err.test
|
|
|
|
autovacuum_ioerr.test jrnlmode4.test soak.test
|
|
|
|
btree8.test loadext.test speed1p.test
|
|
|
|
corrupt.test malloc2.test speed1.test
|
|
|
|
crash2.test malloc3.test speed2.test
|
|
|
|
crash3.test malloc4.test speed3.test
|
|
|
|
crash4.test mallocAll.test speed4p.test
|
|
|
|
crash6.test malloc.test speed4.test
|
|
|
|
crash7.test memleak.test sqllimits1.test
|
|
|
|
crash.test memsubsys1.test thread001.test
|
|
|
|
exclusive3.test memsubsys2.test thread002.test
|
|
|
|
fts3.test misc7.test utf16.test
|
|
|
|
fuzz_malloc.test misuse.test veryquick.test
|
|
|
|
fuzz.test mutex2.test vtab_err.test
|
2008-12-30 16:21:50 +03:00
|
|
|
lookaside.test fuzz3.test savepoint4.test
|
2009-01-03 18:06:38 +03:00
|
|
|
savepoint6.test
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
set ALLTESTS [list]
|
|
|
|
foreach filename [glob $testdir/*.test] {
|
|
|
|
set filename [file tail $filename]
|
|
|
|
if {[lsearch $EXCLUDE $filename] < 0} { lappend ALLTESTS $filename }
|
|
|
|
}
|
2008-08-30 20:07:03 +04:00
|
|
|
set ALLTESTS [lsort $ALLTESTS]
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
rename finish_test really_finish_test2
|
|
|
|
proc finish_test {} {}
|
|
|
|
|
|
|
|
rename do_test really_do_test
|
|
|
|
|
|
|
|
proc do_test {name args} {
|
|
|
|
eval really_do_test [list "perm-$::permutations_test_prefix.$name"] $args
|
|
|
|
}
|
|
|
|
|
|
|
|
# Overload the [sqlite3] command
|
|
|
|
rename sqlite3 really_sqlite3
|
|
|
|
proc sqlite3 {args} {
|
|
|
|
set r [eval really_sqlite3 $args]
|
|
|
|
if { [llength $args] == 2 && $::permutations_presql ne "" } {
|
|
|
|
[lindex $args 0] eval $::permutations_presql
|
|
|
|
}
|
|
|
|
set r
|
|
|
|
}
|
|
|
|
|
|
|
|
# run_tests OPTIONS
|
|
|
|
#
|
|
|
|
# where available options are:
|
|
|
|
#
|
|
|
|
# -initialize SCRIPT (default "")
|
|
|
|
# -shutdown SCRIPT (default "")
|
|
|
|
# -include LIST-OF-FILES (default $::ALLTESTS)
|
|
|
|
# -exclude LIST-OF-FILES (default "")
|
|
|
|
# -presql SQL (default "")
|
|
|
|
# -description TITLE (default "")
|
|
|
|
#
|
|
|
|
proc run_tests {name args} {
|
|
|
|
set ::permutations_test_prefix $name
|
|
|
|
set options(-shutdown) ""
|
|
|
|
set options(-initialize) ""
|
|
|
|
set options(-exclude) ""
|
|
|
|
set options(-include) $::ALLTESTS
|
|
|
|
set options(-presql) ""
|
|
|
|
set options(-description) "no description supplied (fixme)"
|
|
|
|
array set options $args
|
2008-08-25 21:23:29 +04:00
|
|
|
#puts "PERM-DEBUG: name=$name testfile=$::perm::testfile"
|
|
|
|
#puts "PERM-DEBUG: [array get options]"
|
2008-06-21 22:07:37 +04:00
|
|
|
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode eq "targets"} {
|
2008-06-21 22:07:37 +04:00
|
|
|
puts [format "% -20s %s" $name [string trim $options(-description)]]
|
|
|
|
return
|
|
|
|
}
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode ne "" && [lsearch $::perm::testmode $name]<0} {
|
|
|
|
puts "skipping permutation test $name..."
|
|
|
|
return
|
|
|
|
}
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
uplevel $options(-initialize)
|
|
|
|
set ::permutations_presql $options(-presql)
|
|
|
|
|
2008-08-30 17:25:10 +04:00
|
|
|
foreach file [lsort $options(-include)] {
|
2008-08-25 21:23:29 +04:00
|
|
|
if {[lsearch $options(-exclude) $file] < 0 &&
|
|
|
|
( $::perm::testfile eq "" ||
|
|
|
|
$::perm::testfile eq $file ||
|
|
|
|
"$::perm::testfile.test" eq $file )
|
|
|
|
} {
|
2008-08-30 17:25:10 +04:00
|
|
|
set ::perm::shared_cache_setting [shared_cache_setting]
|
2008-06-21 22:07:37 +04:00
|
|
|
uplevel source $::testdir/$file
|
2008-08-30 17:25:10 +04:00
|
|
|
if {$::perm::shared_cache_setting ne [shared_cache_setting]} {
|
|
|
|
error "File $::testdir/$file changed the shared cache setting from $::perm::shared_cache_setting to [shared_cache_setting]"
|
|
|
|
}
|
2008-08-25 21:23:29 +04:00
|
|
|
} else {
|
|
|
|
# puts "skipping file $file"
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uplevel $options(-shutdown)
|
2008-10-07 19:00:08 +04:00
|
|
|
set ::permutations_test_prefix ""
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
|
2008-08-30 17:25:10 +04:00
|
|
|
proc shared_cache_setting {} {
|
|
|
|
set ret 0
|
|
|
|
catch {
|
|
|
|
set ret [sqlite3_enable_shared_cache]
|
|
|
|
}
|
|
|
|
return $ret
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
#############################################################################
|
|
|
|
# Start of tests
|
|
|
|
|
|
|
|
# Run some tests using pre-allocated page and scratch blocks.
|
|
|
|
#
|
|
|
|
run_tests "memsubsys1" -description {
|
|
|
|
Tests using pre-allocated page and scratch blocks
|
2008-08-21 19:54:01 +04:00
|
|
|
} -exclude {
|
|
|
|
ioerr5.test
|
|
|
|
malloc5.test
|
2008-06-21 22:07:37 +04:00
|
|
|
} -initialize {
|
2008-07-30 17:15:46 +04:00
|
|
|
catch {db close}
|
2008-06-21 22:07:37 +04:00
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_pagecache 4096 24
|
|
|
|
sqlite3_config_scratch 25000 1
|
|
|
|
sqlite3_initialize
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_pagecache 0 0
|
|
|
|
sqlite3_config_scratch 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some tests using pre-allocated page and scratch blocks. This time
|
|
|
|
# the allocations are too small to use in most cases.
|
|
|
|
#
|
2008-08-29 16:00:20 +04:00
|
|
|
# Both ioerr5.test and malloc5.test are excluded because they test the
|
|
|
|
# sqlite3_soft_heap_limit() and sqlite3_release_memory() functionality.
|
|
|
|
# This functionality is disabled if a pre-allocated page block is provided.
|
|
|
|
#
|
2008-06-21 22:07:37 +04:00
|
|
|
run_tests "memsubsys2" -description {
|
|
|
|
Tests using small pre-allocated page and scratch blocks
|
2008-08-29 16:00:20 +04:00
|
|
|
} -exclude {
|
|
|
|
ioerr5.test
|
|
|
|
malloc5.test
|
2008-06-21 22:07:37 +04:00
|
|
|
} -initialize {
|
2008-07-30 17:15:46 +04:00
|
|
|
catch {db close}
|
2008-06-21 22:07:37 +04:00
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_pagecache 512 5
|
|
|
|
sqlite3_config_scratch 1000 1
|
|
|
|
sqlite3_initialize
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_pagecache 0 0
|
|
|
|
sqlite3_config_scratch 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
|
|
|
|
2008-08-01 19:06:30 +04:00
|
|
|
# Run all tests with the lookaside allocator disabled.
|
|
|
|
#
|
2008-10-11 21:04:04 +04:00
|
|
|
run_tests "nolookaside" -description {
|
2008-08-01 19:06:30 +04:00
|
|
|
OOM tests with lookaside disabled
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_lookaside 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_lookaside 100 500
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# Run some tests in SQLITE_CONFIG_SINGLETHREAD mode.
|
|
|
|
#
|
|
|
|
run_tests "singlethread" -description {
|
|
|
|
Tests run in SQLITE_CONFIG_SINGLETHREAD mode
|
|
|
|
} -initialize {
|
2009-01-06 17:50:11 +03:00
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
catch {sqlite3_config singlethread}
|
2008-06-21 22:07:37 +04:00
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test types.test
|
|
|
|
types2.test types3.test
|
|
|
|
} -shutdown {
|
2009-01-06 17:50:11 +03:00
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
catch {sqlite3_config serialized}
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
|
2008-07-10 21:52:49 +04:00
|
|
|
run_tests "nomutex" -description {
|
2008-09-03 04:43:15 +04:00
|
|
|
Tests run with the SQLITE_OPEN_MULTITHREADED flag passed to sqlite3_open().
|
2008-07-10 21:52:49 +04:00
|
|
|
} -initialize {
|
|
|
|
rename sqlite3 sqlite3_nomutex
|
|
|
|
proc sqlite3 {args} {
|
|
|
|
if {[string range [lindex $args 0] 0 0] ne "-"} {
|
2008-09-03 05:08:00 +04:00
|
|
|
lappend args -fullmutex 0 -nomutex 1
|
2008-07-10 21:52:49 +04:00
|
|
|
}
|
|
|
|
uplevel [concat sqlite3_nomutex $args]
|
|
|
|
}
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test types.test
|
|
|
|
types2.test types3.test
|
|
|
|
} -shutdown {
|
|
|
|
rename sqlite3 {}
|
|
|
|
rename sqlite3_nomutex sqlite3
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# Run some tests in SQLITE_CONFIG_MULTITHREAD mode.
|
|
|
|
#
|
|
|
|
run_tests "multithread" -description {
|
|
|
|
Tests run in SQLITE_CONFIG_MULTITHREAD mode
|
|
|
|
} -initialize {
|
2009-01-06 17:50:11 +03:00
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
catch {sqlite3_config multithread}
|
2008-06-21 22:07:37 +04:00
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test types.test
|
|
|
|
types2.test types3.test
|
|
|
|
} -shutdown {
|
2009-01-06 17:50:11 +03:00
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
catch {sqlite3_config serialized}
|
2008-06-21 22:07:37 +04:00
|
|
|
}
|
|
|
|
|
2008-09-03 04:43:15 +04:00
|
|
|
# Run some tests in SQLITE_OPEN_FULLMUTEX mode.
|
|
|
|
#
|
|
|
|
run_tests "fullmutex" -description {
|
|
|
|
Tests run in SQLITE_OPEN_FULLMUTEX mode
|
|
|
|
} -initialize {
|
|
|
|
rename sqlite3 sqlite3_fullmutex
|
|
|
|
proc sqlite3 {args} {
|
|
|
|
if {[string range [lindex $args 0] 0 0] ne "-"} {
|
2008-09-03 05:08:00 +04:00
|
|
|
lappend args -nomutex 0 -fullmutex 1
|
2008-09-03 04:43:15 +04:00
|
|
|
}
|
|
|
|
uplevel [concat sqlite3_fullmutex $args]
|
|
|
|
}
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test types.test
|
|
|
|
types2.test types3.test
|
|
|
|
} -shutdown {
|
|
|
|
rename sqlite3 {}
|
|
|
|
rename sqlite3_fullmutex sqlite3
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# Run some tests using the "onefile" demo.
|
|
|
|
#
|
|
|
|
run_tests "onefile" -description {
|
|
|
|
Run some tests using the "test_onefile.c" demo
|
|
|
|
} -initialize {
|
|
|
|
rename sqlite3 sqlite3_onefile
|
|
|
|
proc sqlite3 {args} {
|
|
|
|
if {[string range [lindex $args 0] 0 0] ne "-"} {
|
|
|
|
lappend args -vfs fs
|
|
|
|
}
|
|
|
|
uplevel [concat sqlite3_onefile $args]
|
|
|
|
}
|
|
|
|
} -include {
|
|
|
|
conflict.test insert.test insert2.test insert3.test
|
|
|
|
rollback.test select1.test select2.test select3.test
|
|
|
|
} -shutdown {
|
|
|
|
rename sqlite3 {}
|
|
|
|
rename sqlite3_onefile sqlite3
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some tests using UTF-16 databases.
|
|
|
|
#
|
|
|
|
run_tests "utf16" -description {
|
|
|
|
Run tests using UTF-16 databases
|
2008-06-21 23:10:27 +04:00
|
|
|
} -presql {
|
2008-06-21 22:07:37 +04:00
|
|
|
pragma encoding = 'UTF-16'
|
|
|
|
} -include {
|
|
|
|
alter.test alter3.test
|
|
|
|
auth.test bind.test blob.test capi2.test capi3.test collate1.test
|
|
|
|
collate2.test collate3.test collate4.test collate5.test collate6.test
|
|
|
|
conflict.test date.test delete.test expr.test fkey1.test func.test
|
|
|
|
hook.test index.test insert2.test insert.test interrupt.test in.test
|
|
|
|
intpkey.test ioerr.test join2.test join.test lastinsert.test
|
|
|
|
laststmtchanges.test limit.test lock2.test lock.test main.test
|
|
|
|
memdb.test minmax.test misc1.test misc2.test misc3.test notnull.test
|
|
|
|
null.test progress.test quote.test rowid.test select1.test select2.test
|
|
|
|
select3.test select4.test select5.test select6.test sort.test
|
|
|
|
subselect.test tableapi.test table.test temptable.test
|
|
|
|
trace.test trigger1.test trigger2.test trigger3.test
|
|
|
|
trigger4.test types2.test types.test unique.test update.test
|
|
|
|
vacuum.test view.test where.test
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some tests in exclusive locking mode.
|
|
|
|
#
|
|
|
|
run_tests "exclusive" -description {
|
|
|
|
Run tests in exclusive locking mode.
|
|
|
|
} -presql {
|
|
|
|
pragma locking_mode = 'exclusive'
|
|
|
|
} -include {
|
|
|
|
rollback.test select1.test select2.test
|
|
|
|
malloc.test ioerr.test
|
|
|
|
}
|
|
|
|
|
2008-09-27 01:08:08 +04:00
|
|
|
# Run some tests in exclusive locking mode with truncated journals.
|
|
|
|
#
|
|
|
|
run_tests "exclusive-truncate" -description {
|
|
|
|
Run tests in exclusive locking mode and truncate journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma locking_mode = 'exclusive';
|
|
|
|
pragma journal_mode = TRUNCATE;
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test update.test malloc.test ioerr.test
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# Run some tests in persistent journal mode.
|
|
|
|
#
|
|
|
|
run_tests "persistent_journal" -description {
|
|
|
|
Run tests in persistent-journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = persist
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test
|
|
|
|
}
|
|
|
|
|
2008-09-27 01:08:08 +04:00
|
|
|
# Run some tests in truncating journal mode.
|
|
|
|
#
|
|
|
|
run_tests "truncate_journal" -description {
|
|
|
|
Run tests in persistent-journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = truncate
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test
|
|
|
|
malloc.test ioerr.test
|
|
|
|
}
|
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# Run some error tests in persistent journal mode.
|
|
|
|
#
|
|
|
|
run_tests "persistent_journal_error" -description {
|
|
|
|
Run malloc.test and ioerr.test in persistent-journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = persist
|
|
|
|
} -include {
|
|
|
|
malloc.test ioerr.test
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some tests in no journal mode.
|
|
|
|
#
|
|
|
|
run_tests "no_journal" -description {
|
|
|
|
Run tests in no-journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = persist
|
|
|
|
} -include {
|
|
|
|
delete.test delete2.test insert.test rollback.test select1.test
|
|
|
|
select2.test trans.test update.test vacuum.test
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some error tests in no journal mode.
|
|
|
|
#
|
|
|
|
run_tests "no_journal_error" -description {
|
|
|
|
Run malloc.test and ioerr.test in no-journal mode.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = persist
|
|
|
|
} -include {
|
|
|
|
malloc.test ioerr.test
|
|
|
|
}
|
|
|
|
|
|
|
|
# Run some crash-tests in autovacuum mode.
|
|
|
|
#
|
|
|
|
run_tests "autovacuum_crash" -description {
|
|
|
|
Run crash.test in autovacuum mode.
|
|
|
|
} -presql {
|
|
|
|
pragma auto_vacuum = 1
|
|
|
|
} -include crash.test
|
|
|
|
|
|
|
|
# Run some ioerr-tests in autovacuum mode.
|
|
|
|
#
|
|
|
|
run_tests "autovacuum_ioerr" -description {
|
|
|
|
Run ioerr.test in autovacuum mode.
|
|
|
|
} -presql {
|
|
|
|
pragma auto_vacuum = 1
|
|
|
|
} -include ioerr.test
|
|
|
|
|
2008-10-17 22:51:52 +04:00
|
|
|
# Run tests with an in-memory journal.
|
|
|
|
#
|
|
|
|
run_tests "inmemory_journal" -description {
|
|
|
|
Run tests with an in-memory journal file.
|
|
|
|
} -presql {
|
|
|
|
pragma journal_mode = 'memory'
|
|
|
|
} -exclude {
|
|
|
|
# Exclude all tests that simulate IO errors.
|
|
|
|
autovacuum_ioerr2.test incrvacuum_ioerr.test ioerr.test
|
|
|
|
ioerr.test ioerr2.test ioerr3.test ioerr4.test ioerr5.test
|
|
|
|
vacuum3.test incrblob_err.test diskfull.test
|
|
|
|
|
|
|
|
# Exclude test scripts that use tcl IO to access journal files or count
|
|
|
|
# the number of fsync() calls.
|
|
|
|
pager.test exclusive.test jrnlmode.test sync.test misc1.test
|
|
|
|
journal1.test conflict.test
|
|
|
|
}
|
|
|
|
|
2008-06-25 18:57:53 +04:00
|
|
|
ifcapable mem3 {
|
|
|
|
run_tests "memsys3" -description {
|
|
|
|
Run tests using the allocator in mem3.c.
|
|
|
|
} -exclude {
|
2008-07-10 22:13:42 +04:00
|
|
|
autovacuum.test delete3.test manydb.test
|
|
|
|
bigrow.test incrblob2.test memdb.test
|
|
|
|
bitvec.test index2.test memsubsys1.test
|
|
|
|
capi3c.test ioerr.test memsubsys2.test
|
|
|
|
capi3.test join3.test pagesize.test
|
|
|
|
collate5.test limit.test
|
2008-06-25 18:57:53 +04:00
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-07-16 16:25:32 +04:00
|
|
|
sqlite3_config_heap 25000000 0
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 0 0
|
2008-06-25 18:57:53 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-06-27 18:05:24 +04:00
|
|
|
sqlite3_config_heap 0 0
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 100 500
|
2008-06-25 18:57:53 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
2008-06-24 23:02:55 +04:00
|
|
|
}
|
|
|
|
|
2008-06-25 18:57:53 +04:00
|
|
|
ifcapable mem5 {
|
|
|
|
run_tests "memsys5" -description {
|
|
|
|
Run tests using the allocator in mem5.c.
|
|
|
|
} -exclude {
|
2008-07-10 22:13:42 +04:00
|
|
|
autovacuum.test delete3.test manydb.test
|
|
|
|
bigrow.test incrblob2.test memdb.test
|
|
|
|
bitvec.test index2.test memsubsys1.test
|
|
|
|
capi3c.test ioerr.test memsubsys2.test
|
|
|
|
capi3.test join3.test pagesize.test
|
2008-11-13 19:21:50 +03:00
|
|
|
collate5.test limit.test zeroblob.test
|
2008-06-25 18:57:53 +04:00
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-07-16 16:25:32 +04:00
|
|
|
sqlite3_config_heap 25000000 64
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 0 0
|
2008-06-27 17:27:03 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-06-27 18:05:24 +04:00
|
|
|
sqlite3_config_heap 0 0
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 100 500
|
2008-06-27 17:27:03 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
|
|
|
|
|
|
|
run_tests "memsys5-2" -description {
|
|
|
|
Run tests using the allocator in mem5.c in a different configuration.
|
2008-07-10 22:13:42 +04:00
|
|
|
} -include {
|
|
|
|
select1.test
|
2008-06-27 17:27:03 +04:00
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-07-16 16:25:32 +04:00
|
|
|
sqlite3_config_heap 40000000 16
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 0 0
|
2008-06-25 18:57:53 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
2008-06-27 18:05:24 +04:00
|
|
|
sqlite3_config_heap 0 0
|
2008-08-01 19:06:30 +04:00
|
|
|
sqlite3_config_lookaside 100 500
|
2008-06-25 18:57:53 +04:00
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
}
|
2008-06-25 18:26:07 +04:00
|
|
|
}
|
|
|
|
|
2008-07-10 22:13:42 +04:00
|
|
|
ifcapable threadsafe {
|
|
|
|
run_tests "no_mutex_try" -description {
|
|
|
|
The sqlite3_mutex_try() interface always fails
|
2008-08-25 21:23:29 +04:00
|
|
|
} -exclude [concat $EXCLUDE mutex1.test mutex2.test] \
|
|
|
|
-initialize {
|
2008-07-10 22:13:42 +04:00
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
install_mutex_counters 1
|
|
|
|
set ::disable_mutex_try 1
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_shutdown
|
|
|
|
install_mutex_counters 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-06-23 19:55:52 +04:00
|
|
|
# run_tests "crash_safe_append" -description {
|
|
|
|
# Run crash.test with persistent journals on a SAFE_APPEND file-system.
|
|
|
|
# } -initialize {
|
|
|
|
# rename crashsql sa_crashsql
|
|
|
|
# proc crashsql {args} {
|
|
|
|
# set options [lrange $args 0 [expr {[llength $args]-2}]]
|
|
|
|
# lappend options -char safe_append
|
|
|
|
# set sql [lindex $args end]
|
|
|
|
# lappend options "
|
|
|
|
# PRAGMA journal_mode=persistent;
|
|
|
|
# $sql
|
|
|
|
# "
|
|
|
|
# set fd [open test.db-journal w]
|
|
|
|
# puts $fd [string repeat 1234567890 100000]
|
|
|
|
# close $fd
|
|
|
|
# eval sa_crashsql $options
|
|
|
|
# }
|
|
|
|
# } -shutdown {
|
|
|
|
# rename crashsql {}
|
|
|
|
# rename sa_crashsql crashsql
|
|
|
|
# } -include crash.test
|
|
|
|
|
2008-09-12 14:22:40 +04:00
|
|
|
run_tests "safe_append" -description {
|
|
|
|
Run some tests on a SAFE_APPEND file-system.
|
|
|
|
} -initialize {
|
|
|
|
rename sqlite3 sqlite3_safeappend
|
|
|
|
proc sqlite3 {args} {
|
|
|
|
if {[string range [lindex $args 0] 0 0] ne "-"} {
|
|
|
|
lappend args -vfs devsym
|
|
|
|
}
|
|
|
|
uplevel [concat sqlite3_safeappend $args]
|
|
|
|
}
|
|
|
|
sqlite3_simulate_device -char safe_append
|
|
|
|
} -shutdown {
|
|
|
|
rename sqlite3 {}
|
|
|
|
rename sqlite3_shutdown sqlite3
|
|
|
|
} -include [lsort [concat shared_err.test $ALLTESTS]] \
|
|
|
|
-exclude async3.test
|
|
|
|
|
2008-11-19 04:20:26 +03:00
|
|
|
# The set of tests to run on the alternative-pcache
|
|
|
|
set perm-alt-pcache-testset {
|
|
|
|
async.test
|
|
|
|
attach.test
|
|
|
|
delete.test delete2.test
|
|
|
|
index.test
|
|
|
|
insert.test insert2.test
|
|
|
|
join.test join2.test
|
|
|
|
rollback.test
|
|
|
|
select1.test select2.test
|
|
|
|
trans.test
|
|
|
|
update.test
|
|
|
|
}
|
|
|
|
|
|
|
|
run_tests "pcache0" -description {
|
|
|
|
Alternative pcache implementation without random discard
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 1 0 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 0 0 0
|
|
|
|
sqlite3_config_lookaside 100 500
|
|
|
|
install_malloc_faultsim 1
|
|
|
|
sqlite3_initialize
|
|
|
|
} -include ${perm-alt-pcache-testset}
|
|
|
|
|
|
|
|
run_tests "pcache10" -description {
|
|
|
|
Alternative pcache implementation without 10% random discard
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 1 50 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 0 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
} -include ${perm-alt-pcache-testset}
|
|
|
|
|
|
|
|
run_tests "pcache50" -description {
|
|
|
|
Alternative pcache implementation without 50% random discard
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 1 50 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 0 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
} -include ${perm-alt-pcache-testset}
|
|
|
|
|
|
|
|
run_tests "pcache90" -description {
|
|
|
|
Alternative pcache implementation without 90% random discard
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 1 50 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 0 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
} -include ${perm-alt-pcache-testset}
|
|
|
|
|
|
|
|
run_tests "pcache100" -description {
|
|
|
|
Alternative pcache implementation that always discards when unpinning
|
|
|
|
} -initialize {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 1 100 1
|
|
|
|
sqlite3_initialize
|
|
|
|
autoinstall_test_functions
|
|
|
|
} -shutdown {
|
|
|
|
catch {db close}
|
|
|
|
sqlite3_reset_auto_extension
|
|
|
|
sqlite3_shutdown
|
|
|
|
sqlite3_config_alt_pcache 0 0 0
|
|
|
|
sqlite3_initialize
|
|
|
|
} -include ${perm-alt-pcache-testset}
|
2008-06-23 19:55:52 +04:00
|
|
|
|
2008-12-22 13:58:46 +03:00
|
|
|
run_tests "journaltest" -description {
|
|
|
|
Check that pages are synced before being written (test_journal.c).
|
|
|
|
} -initialize {
|
|
|
|
set ISQUICK 1
|
|
|
|
catch {db close}
|
|
|
|
register_jt_vfs -default ""
|
2009-01-06 16:40:08 +03:00
|
|
|
#sqlite3_instvfs binarylog -default binarylog ostrace.bin
|
2008-12-22 13:58:46 +03:00
|
|
|
} -shutdown {
|
2009-01-06 16:40:08 +03:00
|
|
|
#sqlite3_instvfs destroy binarylog
|
2008-12-22 13:58:46 +03:00
|
|
|
unregister_jt_vfs
|
2009-01-03 18:06:38 +03:00
|
|
|
} -include [concat $::ALLTESTS savepoint6.test
|
|
|
|
] -exclude {
|
2008-12-22 13:58:46 +03:00
|
|
|
incrvacuum.test
|
|
|
|
ioerr.test
|
|
|
|
corrupt4.test
|
|
|
|
io.test
|
2009-01-10 21:51:40 +03:00
|
|
|
crash8.test
|
2009-01-03 18:06:38 +03:00
|
|
|
}
|
2008-12-22 13:58:46 +03:00
|
|
|
|
2008-06-21 22:07:37 +04:00
|
|
|
# End of tests
|
|
|
|
#############################################################################
|
|
|
|
|
2008-08-25 21:23:29 +04:00
|
|
|
if {$::perm::testmode eq "targets"} { puts "" ; exit }
|
2008-06-21 22:07:37 +04:00
|
|
|
|
|
|
|
# Restore the [sqlite3] command.
|
|
|
|
#
|
|
|
|
rename sqlite3 {}
|
|
|
|
rename really_sqlite3 sqlite3
|
|
|
|
|
|
|
|
# Restore the [finish_test] command.
|
|
|
|
#
|
|
|
|
rename finish_test ""
|
|
|
|
rename really_finish_test2 finish_test
|
|
|
|
|
|
|
|
# Restore the [do_test] command.
|
|
|
|
#
|
|
|
|
rename do_test ""
|
|
|
|
rename really_do_test do_test
|
|
|
|
|
|
|
|
finish_test
|