123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- # 2014 Dec 20
- #
- # 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.
- #
- #***********************************************************************
- #
- # Tests focusing on the fts5 xSetAuxdata() and xGetAuxdata() APIs.
- #
- source [file join [file dirname [info script]] fts5_common.tcl]
- set testprefix fts5auxdata
- # If SQLITE_ENABLE_FTS5 is not defined, omit this file.
- ifcapable !fts5 {
- finish_test
- return
- }
- do_execsql_test 1.0 {
- CREATE VIRTUAL TABLE f1 USING fts5(a, b);
- INSERT INTO f1(rowid, a, b) VALUES(1, 'a', 'b1');
- INSERT INTO f1(rowid, a, b) VALUES(2, 'a', 'b2');
- INSERT INTO f1(rowid, a, b) VALUES(3, 'a', 'b3');
- INSERT INTO f1(rowid, a, b) VALUES(4, 'a', 'b4');
- INSERT INTO f1(rowid, a, b) VALUES(5, 'a', 'b5');
- }
- proc aux_function_1 {cmd tn} {
- switch [$cmd xRowid] {
- 1 {
- do_test $tn.1 [list $cmd xGetAuxdata 0 ] {}
- $cmd xSetAuxdata "one"
- }
- 2 {
- do_test $tn.2 [list $cmd xGetAuxdata 0 ] {one}
- $cmd xSetAuxdata "two"
- }
- 3 {
- do_test $tn.3 [list $cmd xGetAuxdata 0 ] {two}
- }
- 4 {
- do_test $tn.4 [list $cmd xGetAuxdata 1 ] {two}
- }
- 5 {
- do_test $tn.5 [list $cmd xGetAuxdata 0 ] {}
- }
- }
- }
- sqlite3_fts5_create_function db aux_function_1 aux_function_1
- db eval {
- SELECT aux_function_1(f1, 1) FROM f1 WHERE f1 MATCH 'a'
- ORDER BY rowid ASC
- }
- proc aux_function_2 {cmd tn inst} {
- if {$inst == "A"} {
- switch [$cmd xRowid] {
- 1 {
- do_test $tn.1.$inst [list $cmd xGetAuxdata 0 ] {}
- $cmd xSetAuxdata "one $inst"
- }
- 2 {
- do_test $tn.2.$inst [list $cmd xGetAuxdata 0 ] "one $inst"
- $cmd xSetAuxdata "two $inst"
- }
- 3 {
- do_test $tn.3.$inst [list $cmd xGetAuxdata 0 ] "two $inst"
- }
- 4 {
- do_test $tn.4.$inst [list $cmd xGetAuxdata 1 ] "two $inst"
- }
- 5 {
- do_test $tn.5.$inst [list $cmd xGetAuxdata 0 ] {}
- }
- }
- } else {
- switch [$cmd xRowid] {
- 1 {
- do_test $tn.1.$inst [list $cmd xGetAuxdata 0 ] "one A"
- }
- 2 {
- do_test $tn.2.$inst [list $cmd xGetAuxdata 0 ] "two A"
- }
- 3 {
- do_test $tn.3.$inst [list $cmd xGetAuxdata 0 ] "two A"
- }
- 4 {
- do_test $tn.4.$inst [list $cmd xGetAuxdata 0 ] {}
- }
- 5 {
- do_test $tn.5.$inst [list $cmd xGetAuxdata 0 ] {}
- }
- }
- }
- }
- sqlite3_fts5_create_function db aux_function_2 aux_function_2
- db eval {
- SELECT aux_function_2(f1, 2, 'A'), aux_function_2(f1, 2, 'B')
- FROM f1 WHERE f1 MATCH 'a'
- ORDER BY rowid ASC
- }
- finish_test
|