|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
source [file join [file dirname [info script]] fts5_common.tcl] |
|
|
set testprefix fts5corrupt8 |
|
|
|
|
|
|
|
|
ifcapable !fts5 { |
|
|
finish_test |
|
|
return |
|
|
} |
|
|
|
|
|
do_execsql_test 1.0 { |
|
|
CREATE VIRTUAL TABLE t1 USING fts5(x); |
|
|
} |
|
|
|
|
|
do_execsql_test 1.1 { |
|
|
UPDATE t1_data SET block='hello world' WHERE id=10 |
|
|
} |
|
|
|
|
|
db close |
|
|
sqlite3 db test.db |
|
|
|
|
|
do_catchsql_test 1.2 { |
|
|
SELECT * FROM t1 |
|
|
} {1 {fts5: corrupt structure record for table "t1"}} |
|
|
do_catchsql_test 1.3 { |
|
|
DROP TABLE t1 |
|
|
} {0 {}} |
|
|
do_execsql_test 1.4 { |
|
|
SELECT * FROM sqlite_schema |
|
|
} |
|
|
|
|
|
do_execsql_test 2.0 { |
|
|
CREATE VIRTUAL TABLE t1 USING fts5(x); |
|
|
} |
|
|
do_execsql_test 2.1 { |
|
|
UPDATE t1_config SET v=555 WHERE k='version' |
|
|
} |
|
|
db close |
|
|
sqlite3 db test.db |
|
|
do_catchsql_test 2.2 { |
|
|
SELECT * FROM t1 |
|
|
} {1 {invalid fts5 file format (found 555, expected 4 or 5) - run 'rebuild'}} |
|
|
do_catchsql_test 2.3 { |
|
|
DROP TABLE t1 |
|
|
} {1 {invalid fts5 file format (found 555, expected 4 or 5) - run 'rebuild'}} |
|
|
do_test 2.4 { |
|
|
sqlite3_fts5_drop_corrupt_table db main t1 |
|
|
} {} |
|
|
do_execsql_test 2.5 { |
|
|
SELECT * FROM sqlite_schema |
|
|
} |
|
|
|
|
|
do_execsql_test 3.0 { |
|
|
CREATE VIRTUAL TABLE t1 USING fts5(x); |
|
|
} |
|
|
do_execsql_test 3.1 { |
|
|
DELETE FROM t1_config; |
|
|
} |
|
|
db close |
|
|
sqlite3 db test.db |
|
|
do_catchsql_test 3.2 { |
|
|
SELECT * FROM t1 |
|
|
} {1 {invalid fts5 file format (found 0, expected 4 or 5) - run 'rebuild'}} |
|
|
do_catchsql_test 3.3 { |
|
|
DROP TABLE t1 |
|
|
} {1 {invalid fts5 file format (found 0, expected 4 or 5) - run 'rebuild'}} |
|
|
|
|
|
|
|
|
do_test 3.4 { |
|
|
sqlite3_db_config db DEFENSIVE 1 |
|
|
} {1} |
|
|
do_test 3.5 { |
|
|
sqlite3_fts5_drop_corrupt_table db main t1 |
|
|
} {} |
|
|
do_test 3.6 { |
|
|
sqlite3_db_config db DEFENSIVE -1 |
|
|
} {1} |
|
|
do_execsql_test 3.7 { |
|
|
SELECT * FROM sqlite_schema |
|
|
} |
|
|
|
|
|
|
|
|
reset_db |
|
|
|
|
|
proc hex_to_blob {hex} { |
|
|
binary encode hex $hex |
|
|
} |
|
|
db func hex_to_blob hex_to_blob |
|
|
|
|
|
do_execsql_test 4.0 { |
|
|
CREATE VIRTUAL TABLE x1 USING fts5(x, content='', contentless_delete=1); |
|
|
BEGIN; |
|
|
INSERT INTO x1(rowid, x) VALUES(1, 'a b c d e f g h'); |
|
|
INSERT INTO x1(rowid, x) VALUES(2, 'a b c d e f g h'); |
|
|
COMMIT; |
|
|
DELETE FROM x1 WHERE rowid=1; |
|
|
} |
|
|
|
|
|
do_execsql_test 4.1 { |
|
|
SELECT hex(block) FROM x1_data WHERE id=10 |
|
|
} { |
|
|
00000000FF00000101010200010101010101010102 |
|
|
} |
|
|
|
|
|
do_execsql_test 4.2.1 { |
|
|
UPDATE x1_data SET block= |
|
|
X'00000000FF00000101010200010101010101819C9B95A8000102' |
|
|
WHERE id=10; |
|
|
} |
|
|
|
|
|
do_catchsql_test 4.2.2 { |
|
|
SELECT * FROM x1('c d e'); |
|
|
} {1 {out of memory}} |
|
|
|
|
|
do_execsql_test 4.3.1 { |
|
|
UPDATE x1_data SET block= |
|
|
X'00000000FF000001010102000101010101019282AFF9A0000102' |
|
|
WHERE id=10; |
|
|
} |
|
|
|
|
|
do_catchsql_test 4.3.2 { |
|
|
SELECT * FROM x1('c d e'); |
|
|
} {1 {out of memory}} |
|
|
|
|
|
do_execsql_test 4.4.1 { |
|
|
UPDATE x1_data SET block= |
|
|
X'00000000FF000001010102000101010101018181808080130102' |
|
|
WHERE id=10; |
|
|
} |
|
|
|
|
|
do_catchsql_test 4.3.2 { |
|
|
SELECT * FROM x1('c d e'); |
|
|
} {1 {out of memory}} |
|
|
|
|
|
finish_test |
|
|
|
|
|
|