# 2024 Aug 28 # # 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. # #*********************************************************************** # source [file join [file dirname [info script]] fts5_common.tcl] set testprefix fts5corrupt8 # If SQLITE_ENABLE_FTS5 is not defined, omit this file. 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