2014-11-25 21:59:55 +03:00
|
|
|
# 2014 November 26
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
#***********************************************************************
|
|
|
|
#
|
|
|
|
|
|
|
|
set testdir [file dirname $argv0]
|
|
|
|
source $testdir/tester.tcl
|
|
|
|
set testprefix bigsort
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# At one point there was an overflow problem if the product of the
|
|
|
|
# cache-size and page-size was larger than 2^31. Causing an infinite
|
|
|
|
# loop if the product was also an integer multiple of 2^32, or
|
|
|
|
# inefficiency otherwise.
|
|
|
|
#
|
2014-12-31 22:58:32 +03:00
|
|
|
# This test causes thrashing on machines with smaller amounts of
|
|
|
|
# memory. Make sure the host has at least 8GB available before running
|
|
|
|
# this test.
|
|
|
|
#
|
2022-11-14 20:48:26 +03:00
|
|
|
# Update: https://sqlite.org/src/info/7c96a56 adds assert() statements
|
|
|
|
# that make this test too slow to run with SQLITE_DEBUG builds.
|
|
|
|
#
|
2014-12-31 22:58:32 +03:00
|
|
|
if {[catch {exec free | grep Mem:} out] || [lindex $out 1]<8000000} {
|
|
|
|
finish_test
|
|
|
|
return
|
|
|
|
}
|
2022-11-14 20:48:26 +03:00
|
|
|
ifcapable debug {
|
|
|
|
finish_test
|
|
|
|
return
|
|
|
|
}
|
2014-12-31 22:58:32 +03:00
|
|
|
|
2014-11-25 21:59:55 +03:00
|
|
|
do_execsql_test 1.0 {
|
|
|
|
PRAGMA page_size = 1024;
|
|
|
|
CREATE TABLE t1(a, b);
|
|
|
|
BEGIN;
|
|
|
|
WITH data(x,y) AS (
|
|
|
|
SELECT 1, zeroblob(10000)
|
|
|
|
UNION ALL
|
|
|
|
SELECT x+1, y FROM data WHERE x < 300000
|
|
|
|
)
|
|
|
|
INSERT INTO t1 SELECT * FROM data;
|
|
|
|
COMMIT;
|
|
|
|
}
|
|
|
|
do_execsql_test 1.1 {
|
|
|
|
PRAGMA cache_size = 4194304;
|
|
|
|
CREATE INDEX i1 ON t1(a, b);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
finish_test
|