41ebf965cd
FossilOrigin-Name: fb257540d32ced4a5fe0759d3ad9c1b36fd2b7d64d93cb0a0ecdb48355a68b7a
151 lines
3.2 KiB
Plaintext
151 lines
3.2 KiB
Plaintext
# 2010 June 15
|
|
#
|
|
# 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]
|
|
source $testdir/malloc_common.tcl
|
|
set testprefix fts5faultI
|
|
|
|
# If SQLITE_ENABLE_FTS5 is not defined, omit this file.
|
|
ifcapable !fts5 {
|
|
finish_test
|
|
return
|
|
}
|
|
|
|
set ::testprefix fts5faultH
|
|
|
|
do_execsql_test 1.0 {
|
|
PRAGMA encoding = utf16;
|
|
CREATE VIRTUAL TABLE t1 USING fts5(x, locale=1);
|
|
INSERT INTO t1 VALUES('origintext unicode61 ascii porter trigram');
|
|
}
|
|
|
|
faultsim_save_and_close
|
|
faultsim_restore_and_reopen
|
|
|
|
do_faultsim_test 1 -faults oom* -prep {
|
|
} -body {
|
|
execsql {
|
|
SELECT rowid FROM t1(fts5_locale('en_US', 'origintext'));
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 1}
|
|
}
|
|
|
|
do_faultsim_test 2 -faults oom* -prep {
|
|
faultsim_restore_and_reopen
|
|
execsql {
|
|
SELECT * FROM t1('ascii');
|
|
}
|
|
} -body {
|
|
execsql {
|
|
UPDATE t1 SET rowid=rowid+1;
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 {}}
|
|
}
|
|
|
|
fts5_aux_test_functions db
|
|
do_faultsim_test 3 -faults oom* -prep {
|
|
} -body {
|
|
execsql {
|
|
SELECT fts5_columnlocale(t1, 0) FROM t1('unicode*');
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 {{}}} {1 SQLITE_NOMEM}
|
|
}
|
|
|
|
#-------------------------------------------------------------------------
|
|
reset_db
|
|
do_execsql_test 4.0 {
|
|
CREATE VIRTUAL TABLE w1 USING fts5(a);
|
|
}
|
|
faultsim_save_and_close
|
|
|
|
do_faultsim_test 4 -faults oom* -prep {
|
|
faultsim_restore_and_reopen
|
|
execsql {
|
|
BEGIN;
|
|
INSERT INTO w1 VALUES('token token token');
|
|
}
|
|
} -body {
|
|
execsql {
|
|
INSERT INTO w1(w1, rank) VALUES('rank', 'bm25()');
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 {}}
|
|
}
|
|
|
|
do_faultsim_test 5 -faults oom* -prep {
|
|
faultsim_restore_and_reopen
|
|
execsql {
|
|
BEGIN;
|
|
INSERT INTO w1 VALUES('one');
|
|
SAVEPOINT one;
|
|
INSERT INTO w1 VALUES('two');
|
|
ROLLBACK TO one;
|
|
}
|
|
|
|
} -body {
|
|
execsql {
|
|
INSERT INTO w1 VALUES('string');
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 {}}
|
|
}
|
|
|
|
#-------------------------------------------------------------------------
|
|
reset_db
|
|
do_execsql_test 5.0 {
|
|
CREATE VIRTUAL TABLE w1 USING fts5(a);
|
|
INSERT INTO w1 VALUES('one two three');
|
|
}
|
|
fts5_aux_test_functions db
|
|
|
|
do_faultsim_test 5 -faults oom* -prep {
|
|
} -body {
|
|
execsql {
|
|
SELECT fts5_test_insttoken(w1, 0, 0) FROM w1('two');
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 two} {1 SQLITE_NOMEM}
|
|
}
|
|
|
|
#-------------------------------------------------------------------------
|
|
reset_db
|
|
do_execsql_test 6.0 {
|
|
CREATE VIRTUAL TABLE w1 USING fts5(a);
|
|
INSERT INTO w1 VALUES('one two three');
|
|
}
|
|
fts5_aux_test_functions db
|
|
faultsim_save_and_close
|
|
|
|
do_faultsim_test 6 -faults oom* -prep {
|
|
faultsim_restore_and_reopen
|
|
db eval {
|
|
BEGIN;
|
|
INSERT INTO w1 VALUES('four five six');
|
|
SAVEPOINT abc;
|
|
INSERT INTO w1 VALUES('seven eight nine');
|
|
SAVEPOINT def;
|
|
INSERT INTO w1 VALUES('ten eleven twelve');
|
|
}
|
|
} -body {
|
|
execsql {
|
|
RELEASE abc;
|
|
}
|
|
} -test {
|
|
faultsim_test_result {0 {}}
|
|
}
|
|
|
|
finish_test
|
|
|