/ Hex Artifact Content
Login

Artifact c424309743fdd203f8e56a1f1cd7872cd66cc0ee:


0000: 23 20 32 30 31 32 20 4d 61 72 63 68 20 30 36 0a  # 2012 March 06.
0010: 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64  #.# The author d
0020: 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67  isclaims copyrig
0030: 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63  ht to this sourc
0040: 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63  e code.  In plac
0050: 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e  e of.# a legal n
0060: 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73 20 61  otice, here is a
0070: 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20   blessing:.#.#  
0080: 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f    May you do goo
0090: 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a  d and not evil..
00a0: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e  #    May you fin
00b0: 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f  d forgiveness fo
00c0: 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66  r yourself and f
00d0: 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23  orgive others..#
00e0: 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72      May you shar
00f0: 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20  e freely, never 
0100: 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e  taking more than
0110: 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a   you give..#.#**
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73 20 66  *******.# This f
0170: 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20 72  ile implements r
0180: 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73 20  egression tests 
0190: 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72 61  for SQLite libra
01a0: 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63 75 73  ry.  The.# focus
01b0: 20 6f 66 20 74 68 69 73 20 73 63 72 69 70 74 20   of this script 
01c0: 69 73 20 74 65 73 74 69 6e 67 20 74 68 65 20 69  is testing the i
01d0: 6e 63 72 65 6d 65 6e 74 61 6c 20 6d 65 72 67 65  ncremental merge
01e0: 20 66 75 6e 63 74 69 6f 6e 2e 0a 23 0a 0a 73 65   function..#..se
01f0: 74 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65 20  t testdir [file 
0200: 64 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a  dirname $argv0].
0210: 73 6f 75 72 63 65 20 24 74 65 73 74 64 69 72 2f  source $testdir/
0220: 74 65 73 74 65 72 2e 74 63 6c 0a 73 6f 75 72 63  tester.tcl.sourc
0230: 65 20 24 74 65 73 74 64 69 72 2f 66 74 73 33 5f  e $testdir/fts3_
0240: 63 6f 6d 6d 6f 6e 2e 74 63 6c 0a 0a 23 20 49 66  common.tcl..# If
0250: 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 46   SQLITE_ENABLE_F
0260: 54 53 33 20 69 73 20 64 65 66 69 6e 65 64 2c 20  TS3 is defined, 
0270: 6f 6d 69 74 20 74 68 69 73 20 66 69 6c 65 2e 0a  omit this file..
0280: 69 66 63 61 70 61 62 6c 65 20 21 66 74 73 33 20  ifcapable !fts3 
0290: 7b 0a 20 20 66 69 6e 69 73 68 5f 74 65 73 74 0a  {.  finish_test.
02a0: 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 70 72 6f 63    return.}..proc
02b0: 20 66 74 73 33 5f 69 6e 74 65 67 72 69 74 79 5f   fts3_integrity_
02c0: 63 68 65 63 6b 20 7b 74 62 6c 7d 20 7b 0a 20 20  check {tbl} {.  
02d0: 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20  db eval "INSERT 
02e0: 49 4e 54 4f 20 24 74 62 6c 20 28 24 74 62 6c 29  INTO $tbl ($tbl)
02f0: 20 56 41 4c 55 45 53 28 27 69 6e 74 65 67 72 69   VALUES('integri
0300: 74 79 2d 63 68 65 63 6b 27 29 22 0a 20 20 72 65  ty-check')".  re
0310: 74 75 72 6e 20 22 6f 6b 22 0a 7d 0a 0a 66 6f 72  turn "ok".}..for
0320: 65 61 63 68 20 6d 6f 64 20 7b 66 74 73 33 20 66  each mod {fts3 f
0330: 74 73 34 7d 20 7b 0a 20 20 73 65 74 20 3a 3a 74  ts4} {.  set ::t
0340: 65 73 74 70 72 65 66 69 78 20 66 74 73 34 6d 65  estprefix fts4me
0350: 72 67 65 2d 24 6d 6f 64 0a 20 20 72 65 73 65 74  rge-$mod.  reset
0360: 5f 64 62 0a 0a 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d  _db..  #--------
0370: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0390: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03b0: 2d 0a 20 20 23 20 54 65 73 74 20 63 61 73 65 73  -.  # Test cases
03c0: 20 31 2e 2a 0a 20 20 23 0a 20 20 64 6f 5f 74 65   1.*.  #.  do_te
03d0: 73 74 20 31 2e 30 20 7b 20 66 74 73 33 5f 62 75  st 1.0 { fts3_bu
03e0: 69 6c 64 5f 64 62 5f 31 20 2d 6d 6f 64 75 6c 65  ild_db_1 -module
03f0: 20 24 6d 6f 64 20 31 30 30 34 20 7d 20 7b 7d 0a   $mod 1004 } {}.
0400: 20 20 64 6f 5f 74 65 73 74 20 31 2e 31 20 7b 20    do_test 1.1 { 
0410: 66 74 73 33 5f 69 6e 74 65 67 72 69 74 79 5f 63  fts3_integrity_c
0420: 68 65 63 6b 20 74 31 20 7d 20 7b 6f 6b 7d 0a 20  heck t1 } {ok}. 
0430: 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74   do_execsql_test
0440: 20 31 2e 31 20 7b 20 0a 20 20 20 20 53 45 4c 45   1.1 { .    SELE
0450: 43 54 20 6c 65 76 65 6c 2c 20 67 72 6f 75 70 5f  CT level, group_
0460: 63 6f 6e 63 61 74 28 69 64 78 2c 20 27 20 27 29  concat(idx, ' ')
0470: 20 46 52 4f 4d 20 74 31 5f 73 65 67 64 69 72 20   FROM t1_segdir 
0480: 47 52 4f 55 50 20 42 59 20 6c 65 76 65 6c 20 0a  GROUP BY level .
0490: 20 20 7d 20 7b 0a 20 20 20 20 30 20 7b 30 20 31    } {.    0 {0 1
04a0: 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20 39   2 3 4 5 6 7 8 9
04b0: 20 31 30 20 31 31 7d 20 0a 20 20 20 20 31 20 7b   10 11} .    1 {
04c0: 30 20 31 20 32 20 33 20 34 20 35 20 36 20 37 20  0 1 2 3 4 5 6 7 
04d0: 38 20 39 20 31 30 20 31 31 20 31 32 20 31 33 7d  8 9 10 11 12 13}
04e0: 0a 20 20 20 20 32 20 7b 30 20 31 20 32 7d 0a 20  .    2 {0 1 2}. 
04f0: 20 7d 0a 20 20 0a 20 20 66 6f 72 20 7b 73 65 74   }.  .  for {set
0500: 20 69 20 30 7d 20 7b 24 69 3c 32 30 7d 20 7b 69   i 0} {$i<20} {i
0510: 6e 63 72 20 69 7d 20 7b 0a 20 20 20 20 64 6f 5f  ncr i} {.    do_
0520: 65 78 65 63 73 71 6c 5f 74 65 73 74 20 31 2e 32  execsql_test 1.2
0530: 2e 24 69 2e 31 20 7b 20 49 4e 53 45 52 54 20 49  .$i.1 { INSERT I
0540: 4e 54 4f 20 74 31 28 74 31 29 20 56 41 4c 55 45  NTO t1(t1) VALUE
0550: 53 28 27 6d 65 72 67 65 3d 31 27 29 20 7d 0a 20  S('merge=1') }. 
0560: 20 20 20 64 6f 5f 74 65 73 74 20 31 2e 32 2e 24     do_test 1.2.$
0570: 69 2e 32 20 7b 20 66 74 73 33 5f 69 6e 74 65 67  i.2 { fts3_integ
0580: 72 69 74 79 5f 63 68 65 63 6b 20 74 31 20 7d 20  rity_check t1 } 
0590: 6f 6b 0a 20 20 20 20 64 6f 5f 65 78 65 63 73 71  ok.    do_execsq
05a0: 6c 5f 74 65 73 74 20 31 2e 32 2e 24 69 2e 33 20  l_test 1.2.$i.3 
05b0: 7b 20 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20  { .      SELECT 
05c0: 64 6f 63 69 64 20 46 52 4f 4d 20 74 31 20 57 48  docid FROM t1 WH
05d0: 45 52 45 20 74 31 20 4d 41 54 43 48 20 27 7a 65  ERE t1 MATCH 'ze
05e0: 72 6f 20 6f 6e 65 20 74 77 6f 20 74 68 72 65 65  ro one two three
05f0: 27 0a 20 20 20 20 7d 20 7b 31 32 33 20 31 33 32  '.    } {123 132
0600: 20 32 31 33 20 32 33 31 20 33 31 32 20 33 32 31   213 231 312 321
0610: 7d 0a 20 20 7d 0a 20 20 0a 20 20 64 6f 5f 65 78  }.  }.  .  do_ex
0620: 65 63 73 71 6c 5f 74 65 73 74 20 31 2e 33 20 7b  ecsql_test 1.3 {
0630: 20 0a 20 20 20 20 53 45 4c 45 43 54 20 6c 65 76   .    SELECT lev
0640: 65 6c 2c 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74  el, group_concat
0650: 28 69 64 78 2c 20 27 20 27 29 20 46 52 4f 4d 20  (idx, ' ') FROM 
0660: 74 31 5f 73 65 67 64 69 72 20 47 52 4f 55 50 20  t1_segdir GROUP 
0670: 42 59 20 6c 65 76 65 6c 20 0a 20 20 7d 20 7b 0a  BY level .  } {.
0680: 20 20 20 20 30 20 7b 30 20 31 20 32 20 33 7d 20      0 {0 1 2 3} 
0690: 0a 20 20 20 20 31 20 7b 30 20 31 20 32 20 33 20  .    1 {0 1 2 3 
06a0: 34 20 35 20 36 7d 20 0a 20 20 20 20 32 20 7b 30  4 5 6} .    2 {0
06b0: 20 31 20 32 20 33 7d 0a 20 20 7d 0a 20 20 0a 20   1 2 3}.  }.  . 
06c0: 20 66 6f 72 20 7b 73 65 74 20 69 20 30 7d 20 7b   for {set i 0} {
06d0: 24 69 3c 31 30 30 7d 20 7b 69 6e 63 72 20 69 7d  $i<100} {incr i}
06e0: 20 7b 0a 20 20 20 20 64 6f 5f 65 78 65 63 73 71   {.    do_execsq
06f0: 6c 5f 74 65 73 74 20 31 2e 34 2e 24 69 20 7b 20  l_test 1.4.$i { 
0700: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 28 74  INSERT INTO t1(t
0710: 31 29 20 56 41 4c 55 45 53 28 27 6d 65 72 67 65  1) VALUES('merge
0720: 3d 31 2c 34 27 29 20 7d 0a 20 20 20 20 64 6f 5f  =1,4') }.    do_
0730: 74 65 73 74 20 31 2e 34 2e 24 69 2e 32 20 7b 20  test 1.4.$i.2 { 
0740: 66 74 73 33 5f 69 6e 74 65 67 72 69 74 79 5f 63  fts3_integrity_c
0750: 68 65 63 6b 20 74 31 20 7d 20 6f 6b 0a 20 20 20  heck t1 } ok.   
0760: 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74   do_execsql_test
0770: 20 31 2e 34 2e 24 69 2e 33 20 7b 20 0a 20 20 20   1.4.$i.3 { .   
0780: 20 20 20 53 45 4c 45 43 54 20 64 6f 63 69 64 20     SELECT docid 
0790: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 74 31  FROM t1 WHERE t1
07a0: 20 4d 41 54 43 48 20 27 7a 65 72 6f 20 6f 6e 65   MATCH 'zero one
07b0: 20 74 77 6f 20 74 68 72 65 65 27 0a 20 20 20 20   two three'.    
07c0: 7d 20 7b 31 32 33 20 31 33 32 20 32 31 33 20 32  } {123 132 213 2
07d0: 33 31 20 33 31 32 20 33 32 31 7d 0a 20 20 7d 0a  31 312 321}.  }.
07e0: 20 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f    .  do_execsql_
07f0: 74 65 73 74 20 31 2e 35 20 7b 20 0a 20 20 20 20  test 1.5 { .    
0800: 53 45 4c 45 43 54 20 6c 65 76 65 6c 2c 20 67 72  SELECT level, gr
0810: 6f 75 70 5f 63 6f 6e 63 61 74 28 69 64 78 2c 20  oup_concat(idx, 
0820: 27 20 27 29 20 46 52 4f 4d 20 74 31 5f 73 65 67  ' ') FROM t1_seg
0830: 64 69 72 20 47 52 4f 55 50 20 42 59 20 6c 65 76  dir GROUP BY lev
0840: 65 6c 20 0a 20 20 7d 20 7b 0a 20 20 20 20 32 20  el .  } {.    2 
0850: 7b 30 20 31 7d 0a 20 20 20 20 33 20 30 0a 20 20  {0 1}.    3 0.  
0860: 7d 0a 20 20 0a 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d  }.  .  #--------
0870: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0880: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0890: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
08a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
08b0: 2d 0a 20 20 23 20 54 65 73 74 20 63 61 73 65 73  -.  # Test cases
08c0: 20 32 2e 2a 20 74 65 73 74 20 74 68 61 74 20 65   2.* test that e
08d0: 72 72 6f 72 73 20 69 6e 20 74 68 65 20 78 78 78  rrors in the xxx
08e0: 20 70 61 72 74 20 6f 66 20 74 68 65 20 27 6d 65   part of the 'me
08f0: 72 67 65 3d 78 78 78 27 20 61 72 65 0a 20 20 23  rge=xxx' are.  #
0900: 20 68 61 6e 64 6c 65 64 20 63 6f 72 72 65 63 74   handled correct
0910: 6c 79 2e 0a 20 20 23 0a 20 20 64 6f 5f 65 78 65  ly..  #.  do_exe
0920: 63 73 71 6c 5f 74 65 73 74 20 32 2e 30 20 22 43  csql_test 2.0 "C
0930: 52 45 41 54 45 20 56 49 52 54 55 41 4c 20 54 41  REATE VIRTUAL TA
0940: 42 4c 45 20 74 32 20 55 53 49 4e 47 20 24 6d 6f  BLE t2 USING $mo
0950: 64 22 0a 20 20 0a 20 20 66 6f 72 65 61 63 68 20  d".  .  foreach 
0960: 7b 74 6e 20 61 72 67 7d 20 7b 0a 20 20 20 20 31  {tn arg} {.    1
0970: 20 20 20 7b 6d 65 72 67 65 3d 61 62 63 7d 0a 20     {merge=abc}. 
0980: 20 20 20 32 20 20 20 7b 6d 65 72 67 65 3d 25 25     2   {merge=%%
0990: 25 7d 0a 20 20 20 20 33 20 20 20 7b 6d 65 72 67  %}.    3   {merg
09a0: 65 3d 2c 7d 0a 20 20 20 20 34 20 20 20 7b 6d 65  e=,}.    4   {me
09b0: 72 67 65 3d 35 2c 7d 0a 20 20 20 20 35 20 20 20  rge=5,}.    5   
09c0: 7b 6d 65 72 67 65 3d 36 2c 25 7d 0a 20 20 20 20  {merge=6,%}.    
09d0: 36 20 20 20 7b 6d 65 72 67 65 3d 36 2c 73 69 78  6   {merge=6,six
09e0: 7d 0a 20 20 20 20 37 20 20 20 7b 6d 65 72 67 65  }.    7   {merge
09f0: 3d 36 2c 31 7d 0a 20 20 20 20 38 20 20 20 7b 6d  =6,1}.    8   {m
0a00: 65 72 67 65 3d 36 2c 30 7d 0a 20 20 7d 20 7b 0a  erge=6,0}.  } {.
0a10: 20 20 20 20 64 6f 5f 63 61 74 63 68 73 71 6c 5f      do_catchsql_
0a20: 74 65 73 74 20 32 2e 24 74 6e 20 7b 20 0a 20 20  test 2.$tn { .  
0a30: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0a40: 74 32 28 74 32 29 20 56 41 4c 55 45 53 28 24 61  t2(t2) VALUES($a
0a50: 72 67 29 3b 0a 20 20 20 20 7d 20 7b 31 20 7b 53  rg);.    } {1 {S
0a60: 51 4c 20 6c 6f 67 69 63 20 65 72 72 6f 72 20 6f  QL logic error o
0a70: 72 20 6d 69 73 73 69 6e 67 20 64 61 74 61 62 61  r missing databa
0a80: 73 65 7d 7d 0a 20 20 7d 0a 20 20 0a 20 20 23 2d  se}}.  }.  .  #-
0a90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ac0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ad0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 20 23 20 54 65 73  --------.  # Tes
0ae0: 74 20 63 61 73 65 73 20 33 2e 2a 0a 20 20 23 0a  t cases 3.*.  #.
0af0: 20 20 64 6f 5f 74 65 73 74 20 33 2e 30 20 7b 20    do_test 3.0 { 
0b00: 0a 20 20 20 20 72 65 73 65 74 5f 64 62 0a 20 20  .    reset_db.  
0b10: 20 20 65 78 65 63 73 71 6c 20 7b 20 50 52 41 47    execsql { PRAG
0b20: 4d 41 20 70 61 67 65 5f 73 69 7a 65 20 3d 20 35  MA page_size = 5
0b30: 31 32 20 7d 0a 20 20 20 20 66 74 73 33 5f 62 75  12 }.    fts3_bu
0b40: 69 6c 64 5f 64 62 5f 32 20 2d 6d 6f 64 75 6c 65  ild_db_2 -module
0b50: 20 24 6d 6f 64 20 33 30 30 34 30 20 0a 20 20 7d   $mod 30040 .  }
0b60: 20 7b 7d 0a 20 20 64 6f 5f 74 65 73 74 20 33 2e   {}.  do_test 3.
0b70: 31 20 7b 20 66 74 73 33 5f 69 6e 74 65 67 72 69  1 { fts3_integri
0b80: 74 79 5f 63 68 65 63 6b 20 74 32 20 7d 20 7b 6f  ty_check t2 } {o
0b90: 6b 7d 0a 20 20 0a 20 20 64 6f 5f 65 78 65 63 73  k}.  .  do_execs
0ba0: 71 6c 5f 74 65 73 74 20 33 2e 32 20 7b 20 0a 20  ql_test 3.2 { . 
0bb0: 20 20 20 53 45 4c 45 43 54 20 6c 65 76 65 6c 2c     SELECT level,
0bc0: 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74 28 69 64   group_concat(id
0bd0: 78 2c 20 27 20 27 29 20 46 52 4f 4d 20 74 32 5f  x, ' ') FROM t2_
0be0: 73 65 67 64 69 72 20 47 52 4f 55 50 20 42 59 20  segdir GROUP BY 
0bf0: 6c 65 76 65 6c 20 0a 20 20 7d 20 7b 0a 20 20 20  level .  } {.   
0c00: 20 30 20 7b 30 20 31 20 32 20 33 20 34 20 35 20   0 {0 1 2 3 4 5 
0c10: 36 7d 20 0a 20 20 20 20 31 20 7b 30 20 31 20 32  6} .    1 {0 1 2
0c20: 20 33 20 34 7d 20 0a 20 20 20 20 32 20 7b 30 20   3 4} .    2 {0 
0c30: 31 20 32 20 33 20 34 7d 20 0a 20 20 20 20 33 20  1 2 3 4} .    3 
0c40: 7b 30 20 31 20 32 20 33 20 34 20 35 20 36 7d 0a  {0 1 2 3 4 5 6}.
0c50: 20 20 7d 0a 20 20 0a 20 20 64 6f 5f 65 78 65 63    }.  .  do_exec
0c60: 73 71 6c 5f 74 65 73 74 20 33 2e 33 20 7b 20 0a  sql_test 3.3 { .
0c70: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0c80: 74 32 28 74 32 29 20 56 41 4c 55 45 53 28 27 6d  t2(t2) VALUES('m
0c90: 65 72 67 65 3d 31 30 30 30 30 30 30 2c 32 27 29  erge=1000000,2')
0ca0: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 6c 65 76  ;.    SELECT lev
0cb0: 65 6c 2c 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74  el, group_concat
0cc0: 28 69 64 78 2c 20 27 20 27 29 20 46 52 4f 4d 20  (idx, ' ') FROM 
0cd0: 74 32 5f 73 65 67 64 69 72 20 47 52 4f 55 50 20  t2_segdir GROUP 
0ce0: 42 59 20 6c 65 76 65 6c 20 0a 20 20 7d 20 7b 0a  BY level .  } {.
0cf0: 20 20 20 20 30 20 30 20 0a 20 20 20 20 32 20 30      0 0 .    2 0
0d00: 0a 20 20 20 20 33 20 30 20 0a 20 20 20 20 34 20  .    3 0 .    4 
0d10: 30 0a 20 20 20 20 36 20 30 0a 20 20 7d 0a 20 20  0.    6 0.  }.  
0d20: 0a 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .  #------------
0d30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0d60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 20  -------------.  
0d70: 23 20 54 65 73 74 20 63 61 73 65 73 20 34 2e 2a  # Test cases 4.*
0d80: 0a 20 20 23 0a 20 20 72 65 73 65 74 5f 64 62 0a  .  #.  reset_db.
0d90: 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73    do_execsql_tes
0da0: 74 20 34 2e 31 20 22 0a 20 20 20 20 50 52 41 47  t 4.1 ".    PRAG
0db0: 4d 41 20 70 61 67 65 5f 73 69 7a 65 20 3d 20 35  MA page_size = 5
0dc0: 31 32 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56  12;.    CREATE V
0dd0: 49 52 54 55 41 4c 20 54 41 42 4c 45 20 74 34 20  IRTUAL TABLE t4 
0de0: 55 53 49 4e 47 20 24 6d 6f 64 3b 0a 20 20 20 20  USING $mod;.    
0df0: 50 52 41 47 4d 41 20 6d 61 69 6e 2e 70 61 67 65  PRAGMA main.page
0e00: 5f 73 69 7a 65 3b 0a 20 20 22 20 7b 35 31 32 7d  _size;.  " {512}
0e10: 0a 20 20 0a 20 20 64 6f 5f 74 65 73 74 20 34 2e  .  .  do_test 4.
0e20: 32 20 7b 0a 20 20 20 20 66 6f 72 65 61 63 68 20  2 {.    foreach 
0e30: 78 20 7b 61 20 63 20 62 20 64 20 65 20 66 20 67  x {a c b d e f g
0e40: 20 68 20 69 20 6a 20 6b 20 6c 20 6d 20 6e 20 6f   h i j k l m n o
0e50: 20 70 7d 20 7b 0a 20 20 20 20 20 20 65 78 65 63   p} {.      exec
0e60: 73 71 6c 20 22 49 4e 53 45 52 54 20 49 4e 54 4f  sql "INSERT INTO
0e70: 20 74 34 20 56 41 4c 55 45 53 28 27 5b 73 74 72   t4 VALUES('[str
0e80: 69 6e 67 20 72 65 70 65 61 74 20 24 78 20 36 30  ing repeat $x 60
0e90: 30 5d 27 29 22 0a 20 20 20 20 7d 0a 20 20 20 20  0]')".    }.    
0ea0: 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20  execsql {SELECT 
0eb0: 6c 65 76 65 6c 2c 20 67 72 6f 75 70 5f 63 6f 6e  level, group_con
0ec0: 63 61 74 28 69 64 78 2c 20 27 20 27 29 20 46 52  cat(idx, ' ') FR
0ed0: 4f 4d 20 74 34 5f 73 65 67 64 69 72 20 47 52 4f  OM t4_segdir GRO
0ee0: 55 50 20 42 59 20 6c 65 76 65 6c 7d 0a 20 20 7d  UP BY level}.  }
0ef0: 20 7b 30 20 7b 30 20 31 20 32 20 33 20 34 20 35   {0 {0 1 2 3 4 5
0f00: 20 36 20 37 20 38 20 39 20 31 30 20 31 31 20 31   6 7 8 9 10 11 1
0f10: 32 20 31 33 20 31 34 20 31 35 7d 7d 0a 20 20 0a  2 13 14 15}}.  .
0f20: 20 20 66 6f 72 65 61 63 68 20 7b 74 6e 20 65 78    foreach {tn ex
0f30: 70 65 63 74 7d 20 7b 0a 20 20 20 20 31 20 20 22  pect} {.    1  "
0f40: 30 20 7b 30 20 31 20 32 20 33 20 34 20 35 20 36  0 {0 1 2 3 4 5 6
0f50: 20 37 20 38 20 39 20 31 30 20 31 31 20 31 32 20   7 8 9 10 11 12 
0f60: 31 33 7d 20 31 20 30 22 0a 20 20 20 20 32 20 20  13} 1 0".    2  
0f70: 22 30 20 7b 30 20 31 20 32 20 33 20 34 20 35 20  "0 {0 1 2 3 4 5 
0f80: 36 20 37 20 38 20 39 20 31 30 20 31 31 20 31 32  6 7 8 9 10 11 12
0f90: 7d 20 20 20 20 31 20 30 22 0a 20 20 20 20 33 20  }    1 0".    3 
0fa0: 20 22 30 20 7b 30 20 31 20 32 20 33 20 34 20 35   "0 {0 1 2 3 4 5
0fb0: 20 36 20 37 20 38 20 39 20 31 30 20 31 31 7d 20   6 7 8 9 10 11} 
0fc0: 20 20 20 20 20 20 31 20 30 22 0a 20 20 20 20 34        1 0".    4
0fd0: 20 20 22 30 20 7b 30 20 31 20 32 20 33 20 34 20    "0 {0 1 2 3 4 
0fe0: 35 20 36 20 37 20 38 20 39 20 31 30 7d 20 20 20  5 6 7 8 9 10}   
0ff0: 20 20 20 20 20 20 20 31 20 30 22 0a 20 20 20 20         1 0".    
1000: 35 20 20 22 30 20 7b 30 20 31 20 32 20 33 20 34  5  "0 {0 1 2 3 4
1010: 20 35 20 36 20 37 20 38 20 39 7d 20 20 20 20 20   5 6 7 8 9}     
1020: 20 20 20 20 20 20 20 20 31 20 30 22 0a 20 20 20          1 0".   
1030: 20 36 20 20 22 30 20 7b 30 20 31 20 32 20 33 20   6  "0 {0 1 2 3 
1040: 34 20 35 20 36 20 37 20 38 7d 20 20 20 20 20 20  4 5 6 7 8}      
1050: 20 20 20 20 20 20 20 20 20 31 20 30 22 0a 20 20           1 0".  
1060: 20 20 37 20 20 22 30 20 7b 30 20 31 20 32 20 33    7  "0 {0 1 2 3
1070: 20 34 20 35 20 36 20 37 7d 20 20 20 20 20 20 20   4 5 6 7}       
1080: 20 20 20 20 20 20 20 20 20 20 31 20 30 22 0a 20            1 0". 
1090: 20 20 20 38 20 20 22 30 20 7b 30 20 31 20 32 20     8  "0 {0 1 2 
10a0: 33 20 34 20 35 20 36 7d 20 20 20 20 20 20 20 20  3 4 5 6}        
10b0: 20 20 20 20 20 20 20 20 20 20 20 31 20 30 22 0a             1 0".
10c0: 20 20 20 20 39 20 20 22 30 20 7b 30 20 31 20 32      9  "0 {0 1 2
10d0: 20 33 20 34 20 35 7d 20 20 20 20 20 20 20 20 20   3 4 5}         
10e0: 20 20 20 20 20 20 20 20 20 20 20 20 31 20 30 22              1 0"
10f0: 0a 20 20 7d 20 7b 0a 20 20 20 20 64 6f 5f 65 78  .  } {.    do_ex
1100: 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 33 2e 24  ecsql_test 4.3.$
1110: 74 6e 20 7b 0a 20 20 20 20 20 20 49 4e 53 45 52  tn {.      INSER
1120: 54 20 49 4e 54 4f 20 74 34 28 74 34 29 20 56 41  T INTO t4(t4) VA
1130: 4c 55 45 53 28 27 6d 65 72 67 65 3d 31 2c 31 36  LUES('merge=1,16
1140: 27 29 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  ');.      SELECT
1150: 20 6c 65 76 65 6c 2c 20 67 72 6f 75 70 5f 63 6f   level, group_co
1160: 6e 63 61 74 28 69 64 78 2c 20 27 20 27 29 20 46  ncat(idx, ' ') F
1170: 52 4f 4d 20 74 34 5f 73 65 67 64 69 72 20 47 52  ROM t4_segdir GR
1180: 4f 55 50 20 42 59 20 6c 65 76 65 6c 3b 0a 20 20  OUP BY level;.  
1190: 20 20 7d 20 24 65 78 70 65 63 74 0a 20 20 7d 0a    } $expect.  }.
11a0: 20 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f    .  do_execsql_
11b0: 74 65 73 74 20 34 2e 34 2e 31 20 7b 0a 20 20 20  test 4.4.1 {.   
11c0: 20 53 45 4c 45 43 54 20 71 75 6f 74 65 28 76 61   SELECT quote(va
11d0: 6c 75 65 29 20 46 52 4f 4d 20 74 34 5f 73 74 61  lue) FROM t4_sta
11e0: 74 20 57 48 45 52 45 20 72 6f 77 69 64 3d 31 0a  t WHERE rowid=1.
11f0: 20 20 7d 20 7b 58 27 30 30 30 36 27 7d 0a 20 20    } {X'0006'}.  
1200: 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .  do_execsql_te
1210: 73 74 20 34 2e 34 2e 32 20 7b 0a 20 20 20 20 44  st 4.4.2 {.    D
1220: 45 4c 45 54 45 20 46 52 4f 4d 20 74 34 5f 73 74  ELETE FROM t4_st
1230: 61 74 20 57 48 45 52 45 20 72 6f 77 69 64 3d 31  at WHERE rowid=1
1240: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
1250: 4f 20 74 34 28 74 34 29 20 56 41 4c 55 45 53 28  O t4(t4) VALUES(
1260: 27 6d 65 72 67 65 3d 31 2c 31 32 27 29 3b 0a 20  'merge=1,12');. 
1270: 20 20 20 53 45 4c 45 43 54 20 6c 65 76 65 6c 2c     SELECT level,
1280: 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74 28 69 64   group_concat(id
1290: 78 2c 20 27 20 27 29 20 46 52 4f 4d 20 74 34 5f  x, ' ') FROM t4_
12a0: 73 65 67 64 69 72 20 47 52 4f 55 50 20 42 59 20  segdir GROUP BY 
12b0: 6c 65 76 65 6c 3b 0a 20 20 7d 20 22 30 20 7b 30  level;.  } "0 {0
12c0: 20 31 20 32 20 33 20 34 20 35 7d 20 20 20 20 20   1 2 3 4 5}     
12d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
12e0: 31 20 30 22 0a 20 20 0a 20 20 0a 20 20 23 2d 2d  1 0".  .  .  #--
12f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1300: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1310: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1320: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1330: 2d 2d 2d 2d 2d 2d 2d 0a 20 20 23 20 54 65 73 74  -------.  # Test
1340: 20 63 61 73 65 73 20 35 2e 2a 0a 20 20 23 0a 20   cases 5.*.  #. 
1350: 20 23 20 54 65 73 74 20 74 68 61 74 20 69 66 20   # Test that if 
1360: 61 20 63 72 69 73 69 73 2d 6d 65 72 67 65 20 6f  a crisis-merge o
1370: 63 63 75 72 73 20 74 68 61 74 20 64 69 73 72 75  ccurs that disru
1380: 70 74 73 20 61 6e 20 6f 6e 67 6f 69 6e 67 20 69  pts an ongoing i
1390: 6e 63 72 65 6d 65 6e 74 61 6c 0a 20 20 23 20 6d  ncremental.  # m
13a0: 65 72 67 65 2c 20 74 68 65 20 6e 65 78 74 20 63  erge, the next c
13b0: 61 6c 6c 20 74 6f 20 22 6d 65 72 67 65 3d 41 2c  all to "merge=A,
13c0: 42 22 20 69 64 65 6e 74 69 66 69 65 73 20 74 68  B" identifies th
13d0: 69 73 20 61 6e 64 20 73 74 61 72 74 73 20 61 20  is and starts a 
13e0: 6e 65 77 0a 20 20 23 20 69 6e 63 72 65 6d 65 6e  new.  # incremen
13f0: 74 61 6c 20 6d 65 72 67 65 2e 20 54 68 65 72 65  tal merge. There
1400: 20 61 72 65 20 74 77 6f 20 73 63 65 6e 61 72 69   are two scenari
1410: 6f 73 3a 0a 20 20 23 0a 20 20 23 20 20 20 2a 20  os:.  #.  #   * 
1420: 54 68 65 72 65 20 61 72 65 20 6c 65 73 73 20 73  There are less s
1430: 65 67 6d 65 6e 74 73 20 6f 6e 20 74 68 65 20 69  egments on the i
1440: 6e 70 75 74 20 6c 65 76 65 6c 20 74 68 61 74 20  nput level that 
1450: 74 68 65 20 64 69 73 72 75 70 74 65 64 0a 20 20  the disrupted.  
1460: 23 20 20 20 20 20 69 6e 63 72 65 6d 65 6e 74 61  #     incrementa
1470: 6c 20 6d 65 72 67 65 20 6f 70 65 72 61 74 65 64  l merge operated
1480: 20 6f 6e 2c 20 6f 72 0a 20 20 23 20 20 20 0a 20   on, or.  #   . 
1490: 20 23 20 20 20 2a 20 53 75 66 66 69 63 69 65 6e   #   * Sufficien
14a0: 74 20 73 65 67 6d 65 6e 74 73 20 65 78 69 73 74  t segments exist
14b0: 20 6f 6e 20 74 68 65 20 69 6e 70 75 74 20 6c 65   on the input le
14c0: 76 65 6c 20 62 75 74 20 74 68 65 20 73 65 67 6d  vel but the segm
14d0: 65 6e 74 73 20 0a 20 20 23 20 20 20 20 20 63 6f  ents .  #     co
14e0: 6e 74 61 69 6e 20 6b 65 79 73 20 73 6d 61 6c 6c  ntain keys small
14f0: 65 72 20 74 68 61 6e 20 74 68 65 20 6c 61 72 67  er than the larg
1500: 65 73 74 20 6b 65 79 20 69 6e 20 74 68 65 20 70  est key in the p
1510: 6f 74 65 6e 74 69 61 6c 20 6f 75 74 70 75 74 20  otential output 
1520: 0a 20 20 23 20 20 20 20 20 73 65 67 6d 65 6e 74  .  #     segment
1530: 2e 0a 20 20 23 20 0a 20 20 64 6f 5f 74 65 73 74  ..  # .  do_test
1540: 20 35 2e 31 20 7b 0a 20 20 20 20 72 65 73 65 74   5.1 {.    reset
1550: 5f 64 62 0a 20 20 20 20 66 74 73 33 5f 62 75 69  _db.    fts3_bui
1560: 6c 64 5f 64 62 5f 31 20 2d 6d 6f 64 75 6c 65 20  ld_db_1 -module 
1570: 24 6d 6f 64 20 31 30 30 30 0a 20 20 7d 20 7b 7d  $mod 1000.  } {}
1580: 0a 20 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c  .  .  do_execsql
1590: 5f 74 65 73 74 20 35 2e 32 20 7b 0a 20 20 20 20  _test 5.2 {.    
15a0: 53 45 4c 45 43 54 20 6c 65 76 65 6c 2c 20 67 72  SELECT level, gr
15b0: 6f 75 70 5f 63 6f 6e 63 61 74 28 69 64 78 2c 20  oup_concat(idx, 
15c0: 27 20 27 29 20 46 52 4f 4d 20 74 31 5f 73 65 67  ' ') FROM t1_seg
15d0: 64 69 72 20 47 52 4f 55 50 20 42 59 20 6c 65 76  dir GROUP BY lev
15e0: 65 6c 3b 0a 20 20 7d 20 7b 0a 20 20 20 20 30 20  el;.  } {.    0 
15f0: 7b 30 20 31 20 32 20 33 20 34 20 35 20 36 20 37  {0 1 2 3 4 5 6 7
1600: 7d 20 0a 20 20 20 20 31 20 7b 30 20 31 20 32 20  } .    1 {0 1 2 
1610: 33 20 34 20 35 20 36 20 37 20 38 20 39 20 31 30  3 4 5 6 7 8 9 10
1620: 20 31 31 20 31 32 20 31 33 7d 20 0a 20 20 20 20   11 12 13} .    
1630: 32 20 7b 30 20 31 20 32 7d 0a 20 20 7d 0a 20 20  2 {0 1 2}.  }.  
1640: 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .  do_execsql_te
1650: 73 74 20 35 2e 33 20 7b 0a 20 20 20 20 49 4e 53  st 5.3 {.    INS
1660: 45 52 54 20 49 4e 54 4f 20 74 31 28 74 31 29 20  ERT INTO t1(t1) 
1670: 56 41 4c 55 45 53 28 27 6d 65 72 67 65 3d 31 2c  VALUES('merge=1,
1680: 35 27 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  5');.    INSERT 
1690: 49 4e 54 4f 20 74 31 28 74 31 29 20 56 41 4c 55  INTO t1(t1) VALU
16a0: 45 53 28 27 6d 65 72 67 65 3d 31 2c 35 27 29 3b  ES('merge=1,5');
16b0: 0a 20 20 20 20 53 45 4c 45 43 54 20 6c 65 76 65  .    SELECT leve
16c0: 6c 2c 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74 28  l, group_concat(
16d0: 69 64 78 2c 20 27 20 27 29 20 46 52 4f 4d 20 74  idx, ' ') FROM t
16e0: 31 5f 73 65 67 64 69 72 20 47 52 4f 55 50 20 42  1_segdir GROUP B
16f0: 59 20 6c 65 76 65 6c 3b 0a 20 20 7d 20 7b 0a 20  Y level;.  } {. 
1700: 20 20 20 30 20 7b 30 20 31 20 32 7d 0a 20 20 20     0 {0 1 2}.   
1710: 20 31 20 7b 30 20 31 20 32 20 33 20 34 20 35 20   1 {0 1 2 3 4 5 
1720: 36 20 37 20 38 20 39 20 31 30 20 31 31 20 31 32  6 7 8 9 10 11 12
1730: 20 31 33 20 31 34 7d 20 0a 20 20 20 20 32 20 7b   13 14} .    2 {
1740: 30 20 31 20 32 20 33 7d 0a 20 20 7d 0a 20 20 0a  0 1 2 3}.  }.  .
1750: 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73    do_execsql_tes
1760: 74 20 35 2e 34 20 7b 53 45 4c 45 43 54 20 71 75  t 5.4 {SELECT qu
1770: 6f 74 65 28 76 61 6c 75 65 29 20 66 72 6f 6d 20  ote(value) from 
1780: 74 31 5f 73 74 61 74 20 57 48 45 52 45 20 72 6f  t1_stat WHERE ro
1790: 77 69 64 3d 31 7d 20 7b 58 27 30 31 30 35 27 7d  wid=1} {X'0105'}
17a0: 0a 20 20 64 6f 5f 74 65 73 74 20 35 2e 35 20 7b  .  do_test 5.5 {
17b0: 0a 20 20 20 20 66 6f 72 65 61 63 68 20 64 6f 63  .    foreach doc
17c0: 69 64 20 5b 65 78 65 63 73 71 6c 20 7b 53 45 4c  id [execsql {SEL
17d0: 45 43 54 20 64 6f 63 69 64 20 46 52 4f 4d 20 74  ECT docid FROM t
17e0: 31 7d 5d 20 7b 0a 20 20 20 20 20 20 65 78 65 63  1}] {.      exec
17f0: 73 71 6c 20 7b 49 4e 53 45 52 54 20 49 4e 54 4f  sql {INSERT INTO
1800: 20 74 31 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   t1 SELECT * FRO
1810: 4d 20 74 31 20 57 48 45 52 45 20 64 6f 63 69 64  M t1 WHERE docid
1820: 3d 24 64 6f 63 69 64 7d 0a 20 20 20 20 7d 0a 20  =$docid}.    }. 
1830: 20 7d 20 7b 7d 0a 20 20 0a 20 20 64 6f 5f 65 78   } {}.  .  do_ex
1840: 65 63 73 71 6c 5f 74 65 73 74 20 35 2e 36 20 7b  ecsql_test 5.6 {
1850: 53 45 4c 45 43 54 20 71 75 6f 74 65 28 76 61 6c  SELECT quote(val
1860: 75 65 29 20 66 72 6f 6d 20 74 31 5f 73 74 61 74  ue) from t1_stat
1870: 20 57 48 45 52 45 20 72 6f 77 69 64 3d 31 7d 20   WHERE rowid=1} 
1880: 7b 58 27 30 31 30 35 27 7d 0a 20 20 0a 20 20 64  {X'0105'}.  .  d
1890: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 35  o_execsql_test 5
18a0: 2e 37 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  .7 {.    SELECT 
18b0: 6c 65 76 65 6c 2c 20 67 72 6f 75 70 5f 63 6f 6e  level, group_con
18c0: 63 61 74 28 69 64 78 2c 20 27 20 27 29 20 46 52  cat(idx, ' ') FR
18d0: 4f 4d 20 74 31 5f 73 65 67 64 69 72 20 47 52 4f  OM t1_segdir GRO
18e0: 55 50 20 42 59 20 6c 65 76 65 6c 3b 0a 20 20 20  UP BY level;.   
18f0: 20 53 45 4c 45 43 54 20 71 75 6f 74 65 28 76 61   SELECT quote(va
1900: 6c 75 65 29 20 66 72 6f 6d 20 74 31 5f 73 74 61  lue) from t1_sta
1910: 74 20 57 48 45 52 45 20 72 6f 77 69 64 3d 31 3b  t WHERE rowid=1;
1920: 0a 20 20 7d 20 7b 0a 20 20 20 20 30 20 7b 30 20  .  } {.    0 {0 
1930: 31 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20  1 2 3 4 5 6 7 8 
1940: 39 20 31 30 7d 20 0a 20 20 20 20 31 20 7b 30 20  9 10} .    1 {0 
1950: 31 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20  1 2 3 4 5 6 7 8 
1960: 39 20 31 30 20 31 31 20 31 32 7d 20 0a 20 20 20  9 10 11 12} .   
1970: 20 32 20 7b 30 20 31 20 32 20 33 20 34 20 35 20   2 {0 1 2 3 4 5 
1980: 36 20 37 7d 0a 20 20 20 20 58 27 30 31 30 35 27  6 7}.    X'0105'
1990: 0a 20 20 7d 0a 20 20 0a 20 20 64 6f 5f 65 78 65  .  }.  .  do_exe
19a0: 63 73 71 6c 5f 74 65 73 74 20 35 2e 38 20 7b 0a  csql_test 5.8 {.
19b0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
19c0: 74 31 28 74 31 29 20 56 41 4c 55 45 53 28 27 6d  t1(t1) VALUES('m
19d0: 65 72 67 65 3d 31 2c 36 27 29 3b 0a 20 20 20 20  erge=1,6');.    
19e0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 28 74  INSERT INTO t1(t
19f0: 31 29 20 56 41 4c 55 45 53 28 27 6d 65 72 67 65  1) VALUES('merge
1a00: 3d 31 2c 36 27 29 3b 0a 20 20 20 20 53 45 4c 45  =1,6');.    SELE
1a10: 43 54 20 6c 65 76 65 6c 2c 20 67 72 6f 75 70 5f  CT level, group_
1a20: 63 6f 6e 63 61 74 28 69 64 78 2c 20 27 20 27 29  concat(idx, ' ')
1a30: 20 46 52 4f 4d 20 74 31 5f 73 65 67 64 69 72 20   FROM t1_segdir 
1a40: 47 52 4f 55 50 20 42 59 20 6c 65 76 65 6c 3b 0a  GROUP BY level;.
1a50: 20 20 20 20 53 45 4c 45 43 54 20 71 75 6f 74 65      SELECT quote
1a60: 28 76 61 6c 75 65 29 20 66 72 6f 6d 20 74 31 5f  (value) from t1_
1a70: 73 74 61 74 20 57 48 45 52 45 20 72 6f 77 69 64  stat WHERE rowid
1a80: 3d 31 3b 0a 20 20 7d 20 7b 0a 20 20 20 20 30 20  =1;.  } {.    0 
1a90: 7b 30 20 31 20 32 20 33 20 34 7d 20 0a 20 20 20  {0 1 2 3 4} .   
1aa0: 20 31 20 7b 30 20 31 20 32 20 33 20 34 20 35 20   1 {0 1 2 3 4 5 
1ab0: 36 20 37 20 38 20 39 20 31 30 20 31 31 20 31 32  6 7 8 9 10 11 12
1ac0: 20 31 33 7d 20 0a 20 20 20 20 32 20 7b 30 20 31   13} .    2 {0 1
1ad0: 20 32 20 33 20 34 20 35 20 36 20 37 20 38 7d 20   2 3 4 5 6 7 8} 
1ae0: 58 27 30 31 30 36 27 0a 20 20 7d 0a 20 20 0a 20  X'0106'.  }.  . 
1af0: 20 64 6f 5f 74 65 73 74 20 35 2e 38 2e 31 20 7b   do_test 5.8.1 {
1b00: 20 66 74 73 33 5f 69 6e 74 65 67 72 69 74 79 5f   fts3_integrity_
1b10: 63 68 65 63 6b 20 74 31 20 7d 20 6f 6b 0a 20 20  check t1 } ok.  
1b20: 0a 20 20 64 6f 5f 74 65 73 74 20 35 2e 39 20 7b  .  do_test 5.9 {
1b30: 0a 20 20 20 20 73 65 74 20 4c 20 5b 65 78 70 72  .    set L [expr
1b40: 20 31 36 2a 31 36 2a 37 20 2b 20 31 36 2a 33 20   16*16*7 + 16*3 
1b50: 2b 20 31 32 5d 0a 20 20 20 20 66 6f 72 65 61 63  + 12].    foreac
1b60: 68 20 64 6f 63 69 64 20 5b 65 78 65 63 73 71 6c  h docid [execsql
1b70: 20 7b 0a 20 20 20 20 20 20 20 20 53 45 4c 45 43   {.        SELEC
1b80: 54 20 64 6f 63 69 64 20 46 52 4f 4d 20 74 31 20  T docid FROM t1 
1b90: 55 4e 49 4f 4e 20 41 4c 4c 20 53 45 4c 45 43 54  UNION ALL SELECT
1ba0: 20 64 6f 63 69 64 20 46 52 4f 4d 20 74 31 20 4c   docid FROM t1 L
1bb0: 49 4d 49 54 20 24 4c 0a 20 20 20 20 7d 5d 20 7b  IMIT $L.    }] {
1bc0: 0a 20 20 20 20 20 20 65 78 65 63 73 71 6c 20 7b  .      execsql {
1bd0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 53  INSERT INTO t1 S
1be0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20  ELECT * FROM t1 
1bf0: 57 48 45 52 45 20 64 6f 63 69 64 3d 24 64 6f 63  WHERE docid=$doc
1c00: 69 64 7d 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d  id}.    }.  } {}
1c10: 0a 20 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c  .  .  do_execsql
1c20: 5f 74 65 73 74 20 35 2e 31 30 20 7b 0a 20 20 20  _test 5.10 {.   
1c30: 20 53 45 4c 45 43 54 20 6c 65 76 65 6c 2c 20 67   SELECT level, g
1c40: 72 6f 75 70 5f 63 6f 6e 63 61 74 28 69 64 78 2c  roup_concat(idx,
1c50: 20 27 20 27 29 20 46 52 4f 4d 20 74 31 5f 73 65   ' ') FROM t1_se
1c60: 67 64 69 72 20 47 52 4f 55 50 20 42 59 20 6c 65  gdir GROUP BY le
1c70: 76 65 6c 3b 0a 20 20 20 20 53 45 4c 45 43 54 20  vel;.    SELECT 
1c80: 71 75 6f 74 65 28 76 61 6c 75 65 29 20 66 72 6f  quote(value) fro
1c90: 6d 20 74 31 5f 73 74 61 74 20 57 48 45 52 45 20  m t1_stat WHERE 
1ca0: 72 6f 77 69 64 3d 31 3b 0a 20 20 7d 20 7b 0a 20  rowid=1;.  } {. 
1cb0: 20 20 20 30 20 30 20 31 20 7b 30 20 31 7d 20 32     0 0 1 {0 1} 2
1cc0: 20 30 20 33 20 30 20 58 27 30 31 30 36 27 0a 20   0 3 0 X'0106'. 
1cd0: 20 7d 0a 20 20 0a 20 20 64 6f 5f 65 78 65 63 73   }.  .  do_execs
1ce0: 71 6c 5f 74 65 73 74 20 35 2e 31 31 20 7b 0a 20  ql_test 5.11 {. 
1cf0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
1d00: 31 28 74 31 29 20 56 41 4c 55 45 53 28 27 6d 65  1(t1) VALUES('me
1d10: 72 67 65 3d 31 2c 36 27 29 3b 0a 20 20 20 20 53  rge=1,6');.    S
1d20: 45 4c 45 43 54 20 6c 65 76 65 6c 2c 20 67 72 6f  ELECT level, gro
1d30: 75 70 5f 63 6f 6e 63 61 74 28 69 64 78 2c 20 27  up_concat(idx, '
1d40: 20 27 29 20 46 52 4f 4d 20 74 31 5f 73 65 67 64   ') FROM t1_segd
1d50: 69 72 20 47 52 4f 55 50 20 42 59 20 6c 65 76 65  ir GROUP BY leve
1d60: 6c 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 71 75  l;.    SELECT qu
1d70: 6f 74 65 28 76 61 6c 75 65 29 20 66 72 6f 6d 20  ote(value) from 
1d80: 74 31 5f 73 74 61 74 20 57 48 45 52 45 20 72 6f  t1_stat WHERE ro
1d90: 77 69 64 3d 31 3b 0a 20 20 7d 20 7b 0a 20 20 20  wid=1;.  } {.   
1da0: 20 30 20 30 20 31 20 7b 30 20 31 7d 20 32 20 30   0 0 1 {0 1} 2 0
1db0: 20 33 20 30 20 58 27 27 0a 20 20 7d 0a 20 20 0a   3 0 X''.  }.  .
1dc0: 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d    #-------------
1dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1de0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1df0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 20 23  ------------.  #
1e10: 20 54 65 73 74 20 63 61 73 65 73 20 36 2e 2a 0a   Test cases 6.*.
1e20: 20 20 23 0a 20 20 23 20 41 74 20 6f 6e 65 20 70    #.  # At one p
1e30: 6f 69 6e 74 20 74 68 65 20 66 6f 6c 6c 6f 77 69  oint the followi
1e40: 6e 67 20 74 65 73 74 20 63 61 75 73 65 64 20 61  ng test caused a
1e50: 6e 20 61 73 73 65 72 74 28 29 20 74 6f 20 66 61  n assert() to fa
1e60: 69 6c 20 28 62 65 63 61 75 73 65 20 74 68 65 0a  il (because the.
1e70: 20 20 23 20 73 65 63 6f 6e 64 20 27 6d 65 72 67    # second 'merg
1e80: 65 3d 31 2c 32 27 20 6f 70 65 72 61 74 69 6f 6e  e=1,2' operation
1e90: 20 62 65 6c 6f 77 20 61 63 74 75 61 6c 6c 79 20   below actually 
1ea0: 22 6d 65 72 67 65 73 22 20 61 20 73 69 6e 67 6c  "merges" a singl
1eb0: 65 20 69 6e 70 75 74 0a 20 20 23 20 73 65 67 6d  e input.  # segm
1ec0: 65 6e 74 2c 20 77 68 69 63 68 20 77 61 73 20 75  ent, which was u
1ed0: 6e 65 78 70 65 63 74 65 64 29 2e 0a 20 20 23 0a  nexpected)..  #.
1ee0: 20 20 64 6f 5f 74 65 73 74 20 36 2e 31 20 7b 0a    do_test 6.1 {.
1ef0: 20 20 20 20 72 65 73 65 74 5f 64 62 0a 20 20 20      reset_db.   
1f00: 20 73 65 74 20 61 20 5b 73 74 72 69 6e 67 20 72   set a [string r
1f10: 65 70 65 61 74 20 61 20 39 30 30 5d 0a 20 20 20  epeat a 900].   
1f20: 20 73 65 74 20 62 20 5b 73 74 72 69 6e 67 20 72   set b [string r
1f30: 65 70 65 61 74 20 62 20 39 30 30 5d 0a 20 20 20  epeat b 900].   
1f40: 20 73 65 74 20 63 20 5b 73 74 72 69 6e 67 20 72   set c [string r
1f50: 65 70 65 61 74 20 63 20 39 30 30 5d 0a 20 20 20  epeat c 900].   
1f60: 20 73 65 74 20 64 20 5b 73 74 72 69 6e 67 20 72   set d [string r
1f70: 65 70 65 61 74 20 64 20 39 30 30 5d 0a 0a 20 20  epeat d 900]..  
1f80: 20 20 65 78 65 63 73 71 6c 20 22 43 52 45 41 54    execsql "CREAT
1f90: 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45 20  E VIRTUAL TABLE 
1fa0: 74 31 20 55 53 49 4e 47 20 24 6d 6f 64 22 0a 20  t1 USING $mod". 
1fb0: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
1fc0: 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20     BEGIN;.      
1fd0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
1fe0: 20 56 41 4c 55 45 53 28 24 61 29 3b 0a 20 20 20   VALUES($a);.   
1ff0: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
2000: 20 74 31 20 56 41 4c 55 45 53 28 24 62 29 3b 0a   t1 VALUES($b);.
2010: 20 20 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20        COMMIT;.  
2020: 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20      BEGIN;.     
2030: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
2040: 31 20 56 41 4c 55 45 53 28 24 63 29 3b 0a 20 20  1 VALUES($c);.  
2050: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
2060: 4f 20 74 31 20 56 41 4c 55 45 53 28 24 64 29 3b  O t1 VALUES($d);
2070: 0a 20 20 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20  .      COMMIT;. 
2080: 20 20 20 7d 0a 20 20 0a 20 20 20 20 65 78 65 63     }.  .    exec
2090: 73 71 6c 20 7b 0a 20 20 20 20 20 20 49 4e 53 45  sql {.      INSE
20a0: 52 54 20 49 4e 54 4f 20 74 31 28 74 31 29 20 56  RT INTO t1(t1) V
20b0: 41 4c 55 45 53 28 27 6d 65 72 67 65 3d 31 2c 32  ALUES('merge=1,2
20c0: 27 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54  ');.      INSERT
20d0: 20 49 4e 54 4f 20 74 31 28 74 31 29 20 56 41 4c   INTO t1(t1) VAL
20e0: 55 45 53 28 27 6d 65 72 67 65 3d 31 2c 32 27 29  UES('merge=1,2')
20f0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 7d 0a 20  ;.    }.  } {}. 
2100: 20 0a 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   .  #-----------
2110: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2120: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2130: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2140: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20  --------------. 
2150: 20 23 20 54 65 73 74 20 63 61 73 65 73 20 37 2e   # Test cases 7.
2160: 2a 0a 20 20 23 0a 20 20 23 20 54 65 73 74 20 74  *.  #.  # Test t
2170: 68 61 74 20 74 68 65 20 76 61 6c 75 65 20 72 65  hat the value re
2180: 74 75 72 6e 65 64 20 62 79 20 73 71 6c 69 74 65  turned by sqlite
2190: 33 5f 74 6f 74 61 6c 5f 63 68 61 6e 67 65 73 28  3_total_changes(
21a0: 29 20 69 6e 63 72 65 61 73 65 73 20 62 79 0a 20  ) increases by. 
21b0: 20 23 20 31 20 66 6f 6c 6c 6f 77 69 6e 67 20 61   # 1 following a
21c0: 20 6e 6f 2d 6f 70 20 22 6d 65 72 67 65 3d 41 2c   no-op "merge=A,
21d0: 42 22 2c 20 6f 72 20 62 79 20 6d 6f 72 65 20 74  B", or by more t
21e0: 68 61 6e 20 31 20 69 66 20 61 63 74 75 61 6c 20  han 1 if actual 
21f0: 77 6f 72 6b 20 69 73 0a 20 20 23 20 70 65 72 66  work is.  # perf
2200: 6f 72 6d 65 64 2e 0a 20 20 23 0a 20 20 64 6f 5f  ormed..  #.  do_
2210: 74 65 73 74 20 37 2e 30 20 7b 0a 20 20 20 20 72  test 7.0 {.    r
2220: 65 73 65 74 5f 64 62 0a 20 20 20 20 66 74 73 33  eset_db.    fts3
2230: 5f 62 75 69 6c 64 5f 64 62 5f 31 20 2d 6d 6f 64  _build_db_1 -mod
2240: 75 6c 65 20 24 6d 6f 64 20 31 30 30 30 0a 20 20  ule $mod 1000.  
2250: 7d 20 7b 7d 0a 20 20 0a 20 20 64 6f 5f 65 78 65  } {}.  .  do_exe
2260: 63 73 71 6c 5f 74 65 73 74 20 37 2e 31 20 7b 0a  csql_test 7.1 {.
2270: 20 20 20 20 53 45 4c 45 43 54 20 6c 65 76 65 6c      SELECT level
2280: 2c 20 67 72 6f 75 70 5f 63 6f 6e 63 61 74 28 69  , group_concat(i
2290: 64 78 2c 20 27 20 27 29 20 46 52 4f 4d 20 74 31  dx, ' ') FROM t1
22a0: 5f 73 65 67 64 69 72 20 47 52 4f 55 50 20 42 59  _segdir GROUP BY
22b0: 20 6c 65 76 65 6c 0a 20 20 7d 20 7b 0a 20 20 20   level.  } {.   
22c0: 20 30 20 7b 30 20 31 20 32 20 33 20 34 20 35 20   0 {0 1 2 3 4 5 
22d0: 36 20 37 7d 20 0a 20 20 20 20 31 20 7b 30 20 31  6 7} .    1 {0 1
22e0: 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20 39   2 3 4 5 6 7 8 9
22f0: 20 31 30 20 31 31 20 31 32 20 31 33 7d 20 0a 20   10 11 12 13} . 
2300: 20 20 20 32 20 7b 30 20 31 20 32 7d 0a 20 20 7d     2 {0 1 2}.  }
2310: 0a 20 20 64 6f 5f 74 65 73 74 20 37 2e 32 20 7b  .  do_test 7.2 {
2320: 0a 20 20 20 20 73 65 74 20 78 20 5b 64 62 20 74  .    set x [db t
2330: 6f 74 61 6c 5f 63 68 61 6e 67 65 73 5d 0a 20 20  otal_changes].  
2340: 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45    execsql { INSE
2350: 52 54 20 49 4e 54 4f 20 74 31 28 74 31 29 20 56  RT INTO t1(t1) V
2360: 41 4c 55 45 53 28 27 6d 65 72 67 65 3d 32 2c 31  ALUES('merge=2,1
2370: 30 27 29 20 7d 0a 20 20 20 20 65 78 70 72 20 7b  0') }.    expr {
2380: 20 28 5b 64 62 20 74 6f 74 61 6c 5f 63 68 61 6e   ([db total_chan
2390: 67 65 73 5d 20 2d 20 24 78 29 3e 31 20 7d 0a 20  ges] - $x)>1 }. 
23a0: 20 7d 20 7b 31 7d 0a 20 20 64 6f 5f 74 65 73 74   } {1}.  do_test
23b0: 20 37 2e 33 20 7b 0a 20 20 20 20 73 65 74 20 78   7.3 {.    set x
23c0: 20 5b 64 62 20 74 6f 74 61 6c 5f 63 68 61 6e 67   [db total_chang
23d0: 65 73 5d 0a 20 20 20 20 65 78 65 63 73 71 6c 20  es].    execsql 
23e0: 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31  { INSERT INTO t1
23f0: 28 74 31 29 20 56 41 4c 55 45 53 28 27 6d 65 72  (t1) VALUES('mer
2400: 67 65 3d 32 30 30 2c 31 30 27 29 20 7d 0a 20 20  ge=200,10') }.  
2410: 20 20 65 78 70 72 20 7b 20 28 5b 64 62 20 74 6f    expr { ([db to
2420: 74 61 6c 5f 63 68 61 6e 67 65 73 5d 20 2d 20 24  tal_changes] - $
2430: 78 29 3e 31 20 7d 0a 20 20 7d 20 7b 31 7d 0a 20  x)>1 }.  } {1}. 
2440: 20 64 6f 5f 74 65 73 74 20 37 2e 34 20 7b 0a 20   do_test 7.4 {. 
2450: 20 20 20 73 65 74 20 78 20 5b 64 62 20 74 6f 74     set x [db tot
2460: 61 6c 5f 63 68 61 6e 67 65 73 5d 0a 20 20 20 20  al_changes].    
2470: 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54  execsql { INSERT
2480: 20 49 4e 54 4f 20 74 31 28 74 31 29 20 56 41 4c   INTO t1(t1) VAL
2490: 55 45 53 28 27 6d 65 72 67 65 3d 32 30 30 2c 31  UES('merge=200,1
24a0: 30 27 29 20 7d 0a 20 20 20 20 65 78 70 72 20 7b  0') }.    expr {
24b0: 20 28 5b 64 62 20 74 6f 74 61 6c 5f 63 68 61 6e   ([db total_chan
24c0: 67 65 73 5d 20 2d 20 24 78 29 3e 31 20 7d 0a 20  ges] - $x)>1 }. 
24d0: 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73 74   } {0}.  do_test
24e0: 20 37 2e 35 20 7b 0a 20 20 20 20 73 65 74 20 78   7.5 {.    set x
24f0: 20 5b 64 62 20 74 6f 74 61 6c 5f 63 68 61 6e 67   [db total_chang
2500: 65 73 5d 0a 20 20 20 20 65 78 65 63 73 71 6c 20  es].    execsql 
2510: 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31  { INSERT INTO t1
2520: 28 74 31 29 20 56 41 4c 55 45 53 28 27 6d 65 72  (t1) VALUES('mer
2530: 67 65 3d 32 30 30 2c 31 30 27 29 20 7d 0a 20 20  ge=200,10') }.  
2540: 20 20 65 78 70 72 20 7b 20 28 5b 64 62 20 74 6f    expr { ([db to
2550: 74 61 6c 5f 63 68 61 6e 67 65 73 5d 20 2d 20 24  tal_changes] - $
2560: 78 29 3e 31 20 7d 0a 20 20 7d 20 7b 30 7d 0a 0a  x)>1 }.  } {0}..
2570: 7d 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a     }..finish_test.