| Index: third_party/sqlite/sqlite-src-3080704/test/spellfix.test
|
| diff --git a/third_party/sqlite/sqlite-src-3080704/test/spellfix.test b/third_party/sqlite/sqlite-src-3080704/test/spellfix.test
|
| deleted file mode 100644
|
| index 954bdb21f1aa18daef3cae895662db3cbb0f4bd8..0000000000000000000000000000000000000000
|
| --- a/third_party/sqlite/sqlite-src-3080704/test/spellfix.test
|
| +++ /dev/null
|
| @@ -1,289 +0,0 @@
|
| -# 2012 July 12
|
| -#
|
| -# 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.
|
| -#
|
| -#***********************************************************************
|
| -#
|
| -
|
| -set testdir [file dirname $argv0]
|
| -source $testdir/tester.tcl
|
| -set testprefix spellfix
|
| -
|
| -ifcapable !vtab { finish_test ; return }
|
| -
|
| -load_static_extension db spellfix nextchar
|
| -
|
| -set vocab {
|
| -rabbi rabbit rabbits rabble rabid rabies raccoon raccoons race raced racer
|
| -racers races racetrack racial racially racing rack racked racket racketeer
|
| -racketeering racketeers rackets racking racks radar radars radial radially
|
| -radian radiance radiant radiantly radiate radiated radiates radiating radiation
|
| -radiations radiator radiators radical radically radicals radices radii radio
|
| -radioactive radioastronomy radioed radiography radioing radiology radios radish
|
| -radishes radium radius radix radon raft rafter rafters rafts rag rage raged
|
| -rages ragged raggedly raggedness raging rags ragweed raid raided raider raiders
|
| -raiding raids rail railed railer railers railing railroad railroaded railroader
|
| -railroaders railroading railroads rails railway railways raiment rain rainbow
|
| -raincoat raincoats raindrop raindrops rained rainfall rainier rainiest raining
|
| -rains rainstorm rainy raise raised raiser raisers raises raisin raising rake
|
| -raked rakes raking rallied rallies rally rallying ram ramble rambler rambles
|
| -rambling ramblings ramification ramifications ramp rampage rampant rampart
|
| -ramps ramrod rams ran ranch ranched rancher ranchers ranches ranching rancid
|
| -random randomization randomize randomized randomizes randomly randomness randy
|
| -rang range ranged rangeland ranger rangers ranges ranging rangy rank ranked
|
| -ranker rankers rankest ranking rankings rankle rankly rankness ranks ransack
|
| -ransacked ransacking ransacks ransom ransomer ransoming ransoms rant ranted
|
| -ranter ranters ranting rants rap rapacious rape raped raper rapes rapid
|
| -rapidity rapidly rapids rapier raping rapport rapprochement raps rapt raptly
|
| -rapture raptures rapturous rare rarely rareness rarer rarest rarity rascal
|
| -rascally rascals rash rasher rashly rashness rasp raspberry rasped rasping
|
| -rasps raster rat rate rated rater raters rates rather ratification ratified
|
| -ratifies ratify ratifying rating ratings ratio ration rational rationale
|
| -rationales rationalities rationality rationalization rationalizations
|
| -rationalize rationalized rationalizes rationalizing rationally rationals
|
| -rationing rations ratios rats rattle rattled rattler rattlers rattles
|
| -rattlesnake rattlesnakes rattling raucous ravage ravaged ravager ravagers
|
| -ravages ravaging rave raved raven ravening ravenous ravenously ravens raves
|
| -ravine ravines raving ravings raw rawer rawest rawly rawness ray rays raze
|
| -razor razors re reabbreviate reabbreviated reabbreviates reabbreviating reach
|
| -reachability reachable reachably reached reacher reaches reaching reacquired
|
| -react reacted reacting reaction reactionaries reactionary reactions reactivate
|
| -reactivated reactivates reactivating reactivation reactive reactively
|
| -reactivity reactor reactors reacts read readability readable reader readers
|
| -readied readier readies readiest readily readiness reading readings readjusted
|
| -readout readouts reads ready readying real realest realign realigned realigning
|
| -realigns realism realist realistic realistically realists realities reality
|
| -}
|
| -
|
| -do_test 1.1 {
|
| - execsql { CREATE VIRTUAL TABLE t1 USING spellfix1 }
|
| - foreach word $vocab {
|
| - execsql { INSERT INTO t1(word) VALUES($word) }
|
| - }
|
| -} {}
|
| -
|
| -foreach {tn word res} {
|
| - 1 raxpi* {rasping 5 rasped 5 ragweed 5 raspberry 6 rasp 4}
|
| - 2 ril* {rail 4 railed 4 railer 4 railers 4 railing 4}
|
| - 3 rilis* {realism 6 realist 6 realistic 6 realistically 6 realists 6}
|
| - 4 reail* {real 3 realest 3 realign 3 realigned 3 realigning 3}
|
| - 5 ras* {rascal 3 rascally 3 rascals 3 rash 3 rasher 3}
|
| - 6 realistss* {realists 8 realigns 8 realistic 9 realistically 9 realest 7}
|
| - 7 realistss {realists 8 realist 7 realigns 8 realistic 9 realest 7}
|
| - 8 rllation* {realities 9 reality 7 rallied 7 railed 4}
|
| - 9 renstom* {rainstorm 8 ransom 6 ransomer 6 ransoming 6 ransoms 6}
|
| -} {
|
| - do_execsql_test 1.2.$tn {
|
| - SELECT word, matchlen FROM t1 WHERE word MATCH $word
|
| - ORDER BY score, word LIMIT 5
|
| - } $res
|
| -}
|
| -
|
| -# Tests of the next_char function.
|
| -#
|
| -do_test 1.10 {
|
| - db eval {
|
| - CREATE TABLE vocab(w TEXT PRIMARY KEY);
|
| - INSERT INTO vocab SELECT word FROM t1;
|
| - }
|
| -} {}
|
| -do_execsql_test 1.11 {
|
| - SELECT next_char('re','vocab','w');
|
| -} {a}
|
| -do_execsql_test 1.11sub {
|
| - SELECT next_char('re','(SELECT w AS x FROM vocab)','x');
|
| -} {a}
|
| -do_execsql_test 1.12 {
|
| - SELECT next_char('r','vocab','w');
|
| -} {ae}
|
| -do_execsql_test 1.13 {
|
| - SELECT next_char('','vocab','w');
|
| -} {r}
|
| -do_test 1.14 {
|
| - catchsql {SELECT next_char('','xyzzy','a')}
|
| -} {1 {no such table: xyzzy}}
|
| -
|
| -do_execsql_test 1.20 {
|
| - CREATE TABLE vocab2(w TEXT);
|
| - CREATE INDEX vocab2w ON vocab2(w COLLATE nocase);
|
| - INSERT INTO vocab2 VALUES('abc'), ('ABD'), ('aBe'), ('AbF');
|
| - SELECT next_char('ab', 'vocab2', 'w', null, 'nocase');
|
| -} {cDeF}
|
| -do_execsql_test 1.21 {
|
| - SELECT next_char('ab','vocab2','w',null,null);
|
| -} {c}
|
| -do_execsql_test 1.22 {
|
| - SELECT next_char('AB','vocab2','w',null,'NOCASE');
|
| -} {cDeF}
|
| -do_execsql_test 1.23 {
|
| - SELECT next_char('ab','vocab2','w',null,'binary');
|
| -} {c}
|
| -
|
| -do_execsql_test 1.30 {
|
| - SELECT rowid FROM t1 WHERE word='rabbit';
|
| -} {2}
|
| -do_execsql_test 1.31 {
|
| - UPDATE t1 SET rowid=2000 WHERE word='rabbit';
|
| - SELECT rowid FROM t1 WHERE word='rabbit';
|
| -} {2000}
|
| -do_execsql_test 1.32 {
|
| - INSERT INTO t1(rowid, word) VALUES(3000,'melody');
|
| - SELECT rowid, word, matchlen FROM t1 WHERE word MATCH 'melotti'
|
| - ORDER BY score LIMIT 3;
|
| -} {3000 melody 6}
|
| -do_test 1.33 {
|
| - catchsql {INSERT INTO t1(rowid, word) VALUES(3000,'garden');}
|
| -} {1 {constraint failed}}
|
| -
|
| -do_execsql_test 2.1 {
|
| - CREATE VIRTUAL TABLE t2 USING spellfix1;
|
| - INSERT INTO t2 (word, soundslike) VALUES('school', 'skuul');
|
| - INSERT INTO t2 (word, soundslike) VALUES('psalm', 'sarm');
|
| - SELECT word, matchlen FROM t2 WHERE word MATCH 'sar*' LIMIT 5;
|
| -} {psalm 4}
|
| -
|
| -do_execsql_test 2.2 {
|
| - SELECT word, matchlen FROM t2 WHERE word MATCH 'skol*' LIMIT 5;
|
| -} {school 6}
|
| -
|
| -set vocab {
|
| -kangaroo kanji kappa karate keel keeled keeling keels keen keener keenest
|
| -keenly keenness keep keeper keepers keeping keeps ken kennel kennels kept
|
| -kerchief kerchiefs kern kernel kernels kerosene ketchup kettle
|
| -kettles key keyboard keyboards keyed keyhole keying keynote keypad keypads keys
|
| -keystroke keystrokes keyword keywords kick kicked kicker kickers kicking
|
| -kickoff kicks kid kidded kiddie kidding kidnap kidnapper kidnappers kidnapping
|
| -kidnappings kidnaps kidney kidneys kids kill killed killer killers killing
|
| -killingly killings killjoy kills kilobit kilobits kiloblock kilobyte kilobytes
|
| -kilogram kilograms kilohertz kilohm kilojoule kilometer kilometers kiloton
|
| -kilovolt kilowatt kiloword kimono kin kind kinder kindergarten kindest
|
| -kindhearted kindle kindled kindles kindling kindly kindness kindred kinds
|
| -kinetic king kingdom kingdoms kingly kingpin kings kink kinky kinship kinsman
|
| -kiosk kiss kissed kisser kissers kisses kissing kit kitchen kitchenette
|
| -kitchens kite kited kites kiting kits kitten kittenish kittens kitty klaxon
|
| -kludge kludges klystron knack knapsack knapsacks knave knaves knead kneads knee
|
| -kneecap kneed kneeing kneel kneeled kneeling kneels knees knell knells knelt
|
| -knew knife knifed knifes knifing knight knighted knighthood knighting knightly
|
| -knights knit knits knives knob knobs knock knockdown knocked knocker knockers
|
| -knocking knockout knocks knoll knolls knot knots knotted knotting know knowable
|
| -knower knowhow knowing knowingly knowledge knowledgeable known knows knuckle
|
| -knuckled knuckles koala kosher kudo
|
| -}
|
| -
|
| -do_execsql_test 3.1 {
|
| - CREATE TABLE costs(iLang, cFrom, cTo, iCost);
|
| - INSERT INTO costs VALUES(0, 'a', 'e', 1);
|
| - INSERT INTO costs VALUES(0, 'e', 'i', 1);
|
| - INSERT INTO costs VALUES(0, 'i', 'o', 1);
|
| - INSERT INTO costs VALUES(0, 'o', 'u', 1);
|
| - INSERT INTO costs VALUES(0, 'u', 'a', 1);
|
| - CREATE VIRTUAL TABLE t3 USING spellfix1(edit_cost_table=costs);
|
| -}
|
| -
|
| -do_test 3.2 {
|
| - foreach w $vocab {
|
| - execsql { INSERT INTO t3(word) VALUES($w) }
|
| - }
|
| -} {}
|
| -
|
| -foreach {tn word res} {
|
| - 1 kos* {kosher 3 kiosk 4 kudo 2 kiss 3 kissed 3}
|
| - 2 kellj* {killjoy 5 kill 4 killed 4 killer 4 killers 4}
|
| - 3 kellj {kill 4 kills 5 killjoy 7 keel 4 killed 6}
|
| -} {
|
| - do_execsql_test 3.2.$tn {
|
| - SELECT word, matchlen FROM t3 WHERE word MATCH $word
|
| - ORDER BY score, word LIMIT 5
|
| - } $res
|
| -}
|
| -
|
| -do_execsql_test 4.0 {
|
| - INSERT INTO t3(command) VALUES('edit_cost_table=NULL');
|
| -}
|
| -foreach {tn word res} {
|
| - 1 kosher {kosher 0 kisser 51 kissers 76 kissed 126 kisses 126}
|
| - 2 kellj {keels 60 killjoy 68 kills 80 keel 120 kill 125}
|
| - 3 kashar {kosher 80 kisser 91 kissers 116 kissed 166 kisses 166}
|
| -} {
|
| - do_execsql_test 4.1.$tn {
|
| - SELECT word, distance FROM t3 WHERE word MATCH $word
|
| - ORDER BY score, word LIMIT 5
|
| - } $res
|
| -}
|
| -do_execsql_test 5.0 {
|
| - CREATE TABLE costs2(iLang, cFrom, cTo, iCost);
|
| - INSERT INTO costs2 VALUES(0, 'a', 'o', 1);
|
| - INSERT INTO costs2 VALUES(0, 'e', 'o', 4);
|
| - INSERT INTO costs2 VALUES(0, 'i', 'o', 8);
|
| - INSERT INTO costs2 VALUES(0, 'u', 'o', 16);
|
| - INSERT INTO t3(command) VALUES('edit_cost_table="costs2"');
|
| -}
|
| -
|
| -foreach {tn word res} {
|
| - 1 kasher {kosher 1}
|
| - 2 kesher {kosher 4}
|
| - 3 kisher {kosher 8}
|
| - 4 kosher {kosher 0}
|
| - 5 kusher {kosher 16}
|
| -} {
|
| - do_execsql_test 5.1.$tn {
|
| - SELECT word, distance FROM t3 WHERE word MATCH $word
|
| - ORDER BY score, word LIMIT 1
|
| - } $res
|
| -}
|
| -
|
| -#-------------------------------------------------------------------------
|
| -# Try some queries by rowid.
|
| -#
|
| -do_execsql_test 6.1.1 {
|
| - SELECT word FROM t3 WHERE rowid = 10;
|
| -} {keener}
|
| -do_execsql_test 6.1.2 {
|
| - SELECT word, distance FROM t3 WHERE rowid = 10;
|
| -} {keener {}}
|
| -do_execsql_test 6.1.3 {
|
| - SELECT word, distance FROM t3 WHERE rowid = 10 AND word MATCH 'kiiner';
|
| -} {keener 300}
|
| -
|
| -ifcapable trace {
|
| - proc trace_callback {sql} {
|
| - if {[string range $sql 0 2] == "-- "} {
|
| - lappend ::trace [string range $sql 3 end]
|
| - }
|
| - }
|
| -
|
| - proc do_tracesql_test {tn sql {res {}}} {
|
| - set ::trace [list]
|
| - uplevel [list do_test $tn [subst -nocommands {
|
| - set vals [execsql {$sql}]
|
| - concat [set vals] [set ::trace]
|
| - }] [list {*}$res]]
|
| - }
|
| -
|
| - db trace trace_callback
|
| - do_tracesql_test 6.2.1 {
|
| - SELECT word FROM t3 WHERE rowid = 10;
|
| - } {keener
|
| - {SELECT word, rank, NULL, langid, id FROM "main"."t3_vocab" WHERE rowid=?}
|
| - }
|
| - do_tracesql_test 6.2.2 {
|
| - SELECT word, distance FROM t3 WHERE rowid = 10;
|
| - } {keener {}
|
| - {SELECT word, rank, NULL, langid, id FROM "main"."t3_vocab" WHERE rowid=?}
|
| - }
|
| - do_tracesql_test 6.2.3 {
|
| - SELECT word, distance FROM t3 WHERE rowid = 10 AND word MATCH 'kiiner';
|
| - } {keener 300
|
| - {SELECT id, word, rank, k1 FROM "main"."t3_vocab" WHERE langid=0 AND k2>=?1 AND k2<?2}
|
| - }
|
| -}
|
| -
|
| -
|
| -
|
| -
|
| -finish_test
|
|
|