1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-07-29 08:01:23 +03:00

Add test case for SQLITE_FULL errors to pagerfault.test. Remove a NEVER macro in pager.c that this hits.

FossilOrigin-Name: 3e9680c4c18140d083b24e05a21ea6792aef2487
This commit is contained in:
dan
2010-06-23 19:27:36 +00:00
parent 75e876be30
commit 346e426753
6 changed files with 55 additions and 28 deletions

View File

@ -306,5 +306,39 @@ do_faultsim_test pagerfault-6.1 -prep {
# faultsim_test_result {0 {5 6 7 8}}
# faultsim_integrity_check
# }
#
do_test pagerfault-7-pre1 {
faultsim_delete_and_reopen
execsql {
CREATE TABLE t2(a INTEGER PRIMARY KEY, b);
BEGIN;
INSERT INTO t2 VALUES(NULL, randomblob(1500));
INSERT INTO t2 VALUES(NULL, randomblob(1500));
INSERT INTO t2 SELECT NULL, randomblob(1500) FROM t2; -- 4
INSERT INTO t2 SELECT NULL, randomblob(1500) FROM t2; -- 8
INSERT INTO t2 SELECT NULL, randomblob(1500) FROM t2; -- 16
INSERT INTO t2 SELECT NULL, randomblob(1500) FROM t2; -- 32
INSERT INTO t2 SELECT NULL, randomblob(1500) FROM t2; -- 64
COMMIT;
CREATE TABLE t1(a PRIMARY KEY, b);
INSERT INTO t1 SELECT * FROM t2;
DROP TABLE t2;
}
faultsim_save_and_close
} {}
do_faultsim_test pagerfault-7 -faults full -prep {
faultsim_restore_and_reopen
execsql {
PRAGMA cache_size = 10;
BEGIN;
UPDATE t1 SET b = randomblob(1500);
}
} -body {
execsql { UPDATE t1 SET a = 65, b = randomblob(1500) WHERE (a+1)>200 }
execsql COMMIT
} -test {
faultsim_test_result {0 {}}
faultsim_integrity_check
}
finish_test