/ Hex Artifact Content
Login

Artifact d6c6cc7a1326e8e23b9820f30bd3054f22092e503fadfd2a660ae006653f6d80:


0000: 23 20 32 30 31 34 20 41 75 67 75 73 74 20 33 30  # 2014 August 30
0010: 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20  .#.# The author 
0020: 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69  disclaims copyri
0030: 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72  ght to this sour
0040: 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61  ce code.  In pla
0050: 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20  ce of.# a legal 
0060: 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73 20  notice, here is 
0070: 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20  a blessing:.#.# 
0080: 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f     May you do go
0090: 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e  od and not evil.
00a0: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69  .#    May you fi
00b0: 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66  nd forgiveness f
00c0: 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20  or yourself and 
00d0: 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a  forgive others..
00e0: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61  #    May you sha
00f0: 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72  re freely, never
0100: 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61   taking more tha
0110: 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a  n 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 0a 23 0a 0a 69 66 20 7b 21 5b  ******.#..if {![
0170: 69 6e 66 6f 20 65 78 69 73 74 73 20 74 65 73 74  info exists test
0180: 64 69 72 5d 7d 20 7b 0a 20 20 73 65 74 20 74 65  dir]} {.  set te
0190: 73 74 64 69 72 20 5b 66 69 6c 65 20 6a 6f 69 6e  stdir [file join
01a0: 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 5b   [file dirname [
01b0: 69 6e 66 6f 20 73 63 72 69 70 74 5d 5d 20 2e 2e  info script]] ..
01c0: 20 2e 2e 20 74 65 73 74 5d 0a 7d 0a 73 6f 75 72   .. test].}.sour
01d0: 63 65 20 24 74 65 73 74 64 69 72 2f 74 65 73 74  ce $testdir/test
01e0: 65 72 2e 74 63 6c 0a 73 65 74 20 3a 3a 74 65 73  er.tcl.set ::tes
01f0: 74 70 72 65 66 69 78 20 72 62 75 33 0a 0a 0a 23  tprefix rbu3...#
0200: 20 52 75 6e 20 74 68 65 20 52 42 55 20 69 6e 20   Run the RBU in 
0210: 66 69 6c 65 20 24 72 62 75 20 6f 6e 20 74 61 72  file $rbu on tar
0220: 67 65 74 20 64 61 74 61 62 61 73 65 20 24 74 61  get database $ta
0230: 72 67 65 74 20 75 6e 74 69 6c 20 63 6f 6d 70 6c  rget until compl
0240: 65 74 69 6f 6e 2e 0a 23 0a 70 72 6f 63 20 72 75  etion..#.proc ru
0250: 6e 5f 72 62 75 20 7b 74 61 72 67 65 74 20 72 62  n_rbu {target rb
0260: 75 7d 20 7b 0a 20 20 73 71 6c 69 74 65 33 72 62  u} {.  sqlite3rb
0270: 75 20 72 62 75 20 24 74 61 72 67 65 74 20 24 72  u rbu $target $r
0280: 62 75 0a 20 20 77 68 69 6c 65 20 7b 20 5b 72 62  bu.  while { [rb
0290: 75 20 73 74 65 70 5d 3d 3d 22 53 51 4c 49 54 45  u step]=="SQLITE
02a0: 5f 4f 4b 22 20 7d 20 7b 7d 0a 20 20 72 62 75 20  _OK" } {}.  rbu 
02b0: 63 6c 6f 73 65 0a 7d 0a 0a 66 6f 72 63 65 64 65  close.}..forcede
02c0: 6c 65 74 65 20 74 65 73 74 2e 64 62 2d 6f 61 6c  lete test.db-oal
02d0: 20 72 62 75 2e 64 62 0a 64 62 20 63 6c 6f 73 65   rbu.db.db close
02e0: 0a 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77  .sqlite3_shutdow
02f0: 6e 0a 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67  n.sqlite3_config
0300: 5f 75 72 69 20 31 0a 72 65 73 65 74 5f 64 62 0a  _uri 1.reset_db.
0310: 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .#--------------
0320: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0330: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0340: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0350: 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73 74 20 74 68  ------.# Test th
0360: 61 74 20 66 6f 72 20 61 6e 20 52 42 55 20 74 6f  at for an RBU to
0370: 20 62 65 20 61 70 70 6c 69 65 64 2c 20 6e 6f 20   be applied, no 
0380: 63 6f 72 72 75 70 74 69 6f 6e 20 72 65 73 75 6c  corruption resul
0390: 74 73 20 69 66 20 74 68 65 0a 23 20 61 66 66 69  ts if the.# affi
03a0: 6e 69 74 69 65 73 20 6f 6e 20 74 68 65 20 73 6f  nities on the so
03b0: 75 72 63 65 20 61 6e 64 20 74 61 72 67 65 74 20  urce and target 
03c0: 74 61 62 6c 65 20 64 6f 20 6e 6f 74 20 6d 61 74  table do not mat
03d0: 63 68 2e 0a 23 0a 64 6f 5f 65 78 65 63 73 71 6c  ch..#.do_execsql
03e0: 5f 74 65 73 74 20 31 2e 30 20 7b 0a 20 20 43 52  _test 1.0 {.  CR
03f0: 45 41 54 45 20 54 41 42 4c 45 20 78 31 28 61 20  EATE TABLE x1(a 
0400: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
0410: 4b 45 59 2c 20 62 20 54 45 58 54 2c 20 63 20 52  KEY, b TEXT, c R
0420: 45 41 4c 29 3b 0a 20 20 43 52 45 41 54 45 20 49  EAL);.  CREATE I
0430: 4e 44 45 58 20 69 31 20 4f 4e 20 78 31 28 62 2c  NDEX i1 ON x1(b,
0440: 20 63 29 3b 0a 7d 20 7b 7d 0a 0a 64 6f 5f 74 65   c);.} {}..do_te
0450: 73 74 20 31 2e 31 20 7b 0a 20 20 73 71 6c 69 74  st 1.1 {.  sqlit
0460: 65 33 20 64 62 32 20 72 62 75 2e 64 62 0a 20 20  e3 db2 rbu.db.  
0470: 64 62 32 20 65 76 61 6c 20 7b 0a 20 20 20 20 43  db2 eval {.    C
0480: 52 45 41 54 45 20 54 41 42 4c 45 20 64 61 74 61  REATE TABLE data
0490: 5f 78 31 28 61 2c 20 62 2c 20 63 2c 20 72 62 75  _x1(a, b, c, rbu
04a0: 5f 63 6f 6e 74 72 6f 6c 29 3b 0a 20 20 20 20 49  _control);.    I
04b0: 4e 53 45 52 54 20 49 4e 54 4f 20 64 61 74 61 5f  NSERT INTO data_
04c0: 78 31 20 56 41 4c 55 45 53 28 31 2c 20 27 31 32  x1 VALUES(1, '12
04d0: 33 27 2c 20 27 31 32 33 27 2c 20 30 29 3b 0a 20  3', '123', 0);. 
04e0: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 64     INSERT INTO d
04f0: 61 74 61 5f 78 31 20 56 41 4c 55 45 53 28 32 2c  ata_x1 VALUES(2,
0500: 20 31 32 33 2c 20 31 32 33 2c 20 30 29 3b 0a 20   123, 123, 0);. 
0510: 20 7d 0a 20 20 64 62 32 20 63 6c 6f 73 65 0a 20   }.  db2 close. 
0520: 20 72 75 6e 5f 72 62 75 20 74 65 73 74 2e 64 62   run_rbu test.db
0530: 20 72 62 75 2e 64 62 0a 7d 20 7b 53 51 4c 49 54   rbu.db.} {SQLIT
0540: 45 5f 44 4f 4e 45 7d 0a 0a 64 6f 5f 65 78 65 63  E_DONE}..do_exec
0550: 73 71 6c 5f 74 65 73 74 20 31 2e 32 20 7b 0a 20  sql_test 1.2 {. 
0560: 20 50 52 41 47 4d 41 20 69 6e 74 65 67 72 69 74   PRAGMA integrit
0570: 79 5f 63 68 65 63 6b 3b 0a 7d 20 7b 6f 6b 7d 0a  y_check;.} {ok}.
0580: 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .#--------------
0590: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
05a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
05b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
05c0: 2d 2d 2d 2d 2d 2d 0a 23 20 54 65 73 74 20 74 68  ------.# Test th
05d0: 61 74 20 4e 55 4c 4c 20 76 61 6c 75 65 73 20 6d  at NULL values m
05e0: 61 79 20 6e 6f 74 20 62 65 20 69 6e 73 65 72 74  ay not be insert
05f0: 65 64 20 69 6e 74 6f 20 49 4e 54 45 47 45 52 20  ed into INTEGER 
0600: 50 52 49 4d 41 52 59 20 4b 45 59 0a 23 20 63 6f  PRIMARY KEY.# co
0610: 6c 75 6d 6e 73 2e 0a 23 0a 66 6f 72 63 65 64 65  lumns..#.forcede
0620: 6c 65 74 65 20 72 62 75 2e 64 62 0a 72 65 73 65  lete rbu.db.rese
0630: 74 5f 64 62 0a 0a 64 6f 5f 65 78 65 63 73 71 6c  t_db..do_execsql
0640: 5f 74 65 73 74 20 32 2e 30 20 7b 0a 20 20 43 52  _test 2.0 {.  CR
0650: 45 41 54 45 20 54 41 42 4c 45 20 78 31 28 61 20  EATE TABLE x1(a 
0660: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
0670: 4b 45 59 2c 20 62 20 54 45 58 54 2c 20 63 20 52  KEY, b TEXT, c R
0680: 45 41 4c 29 3b 0a 20 20 43 52 45 41 54 45 20 49  EAL);.  CREATE I
0690: 4e 44 45 58 20 69 31 20 4f 4e 20 78 31 28 62 2c  NDEX i1 ON x1(b,
06a0: 20 63 29 3b 0a 7d 20 7b 7d 0a 0a 66 6f 72 65 61   c);.} {}..forea
06b0: 63 68 20 7b 74 6e 20 72 62 75 64 62 7d 20 7b 0a  ch {tn rbudb} {.
06c0: 20 20 31 20 7b 0a 20 20 20 20 43 52 45 41 54 45    1 {.    CREATE
06d0: 20 54 41 42 4c 45 20 64 61 74 61 5f 78 31 28 61   TABLE data_x1(a
06e0: 2c 20 62 2c 20 63 2c 20 72 62 75 5f 63 6f 6e 74  , b, c, rbu_cont
06f0: 72 6f 6c 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  rol);.    INSERT
0700: 20 49 4e 54 4f 20 64 61 74 61 5f 78 31 20 56 41   INTO data_x1 VA
0710: 4c 55 45 53 28 4e 55 4c 4c 2c 20 27 61 27 2c 20  LUES(NULL, 'a', 
0720: 27 62 27 2c 20 30 29 3b 0a 20 20 7d 0a 0a 20 20  'b', 0);.  }..  
0730: 32 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54  2 {.    CREATE T
0740: 41 42 4c 45 20 64 61 74 61 5f 78 31 28 63 2c 20  ABLE data_x1(c, 
0750: 62 2c 20 61 2c 20 72 62 75 5f 63 6f 6e 74 72 6f  b, a, rbu_contro
0760: 6c 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  l);.    INSERT I
0770: 4e 54 4f 20 64 61 74 61 5f 78 31 20 56 41 4c 55  NTO data_x1 VALU
0780: 45 53 28 27 62 27 2c 20 27 61 27 2c 20 4e 55 4c  ES('b', 'a', NUL
0790: 4c 2c 20 30 29 3b 0a 20 20 7d 0a 7d 20 7b 0a 20  L, 0);.  }.} {. 
07a0: 20 64 6f 5f 74 65 73 74 20 32 2e 24 74 6e 2e 31   do_test 2.$tn.1
07b0: 20 7b 0a 20 20 20 20 66 6f 72 63 65 64 65 6c 65   {.    forcedele
07c0: 74 65 20 72 62 75 2e 64 62 0a 20 20 20 20 73 71  te rbu.db.    sq
07d0: 6c 69 74 65 33 20 64 62 32 20 72 62 75 2e 64 62  lite3 db2 rbu.db
07e0: 0a 20 20 20 20 64 62 32 20 65 76 61 6c 20 24 72  .    db2 eval $r
07f0: 62 75 64 62 0a 20 20 20 20 64 62 32 20 63 6c 6f  budb.    db2 clo
0800: 73 65 0a 20 20 20 20 6c 69 73 74 20 5b 63 61 74  se.    list [cat
0810: 63 68 20 7b 20 72 75 6e 5f 72 62 75 20 74 65 73  ch { run_rbu tes
0820: 74 2e 64 62 20 72 62 75 2e 64 62 20 7d 20 6d 73  t.db rbu.db } ms
0830: 67 5d 20 24 6d 73 67 0a 20 20 7d 20 7b 31 20 7b  g] $msg.  } {1 {
0840: 53 51 4c 49 54 45 5f 4d 49 53 4d 41 54 43 48 20  SQLITE_MISMATCH 
0850: 2d 20 64 61 74 61 74 79 70 65 20 6d 69 73 6d 61  - datatype misma
0860: 74 63 68 7d 7d 0a 0a 20 20 64 6f 5f 65 78 65 63  tch}}..  do_exec
0870: 73 71 6c 5f 74 65 73 74 20 32 2e 31 2e 32 20 7b  sql_test 2.1.2 {
0880: 0a 20 20 20 20 50 52 41 47 4d 41 20 69 6e 74 65  .    PRAGMA inte
0890: 67 72 69 74 79 5f 63 68 65 63 6b 3b 0a 20 20 7d  grity_check;.  }
08a0: 20 7b 6f 6b 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d   {ok}.}..#------
08b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
08c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
08d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
08e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
08f0: 20 54 65 73 74 20 74 68 61 74 20 6d 69 73 73 69   Test that missi
0900: 6e 67 20 63 6f 6c 75 6d 6e 73 20 61 72 65 20 64  ng columns are d
0910: 65 74 65 63 74 65 64 2e 0a 23 0a 66 6f 72 63 65  etected..#.force
0920: 64 65 6c 65 74 65 20 72 62 75 2e 64 62 0a 72 65  delete rbu.db.re
0930: 73 65 74 5f 64 62 0a 0a 64 6f 5f 65 78 65 63 73  set_db..do_execs
0940: 71 6c 5f 74 65 73 74 20 32 2e 30 20 7b 0a 20 20  ql_test 2.0 {.  
0950: 43 52 45 41 54 45 20 54 41 42 4c 45 20 78 31 28  CREATE TABLE x1(
0960: 61 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52  a INTEGER PRIMAR
0970: 59 20 4b 45 59 2c 20 62 2c 20 63 29 3b 0a 20 20  Y KEY, b, c);.  
0980: 43 52 45 41 54 45 20 49 4e 44 45 58 20 69 31 20  CREATE INDEX i1 
0990: 4f 4e 20 78 31 28 62 2c 20 63 29 3b 0a 7d 20 7b  ON x1(b, c);.} {
09a0: 7d 0a 0a 64 6f 5f 74 65 73 74 20 32 2e 31 20 7b  }..do_test 2.1 {
09b0: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 32 20 72  .  sqlite3 db2 r
09c0: 62 75 2e 64 62 0a 20 20 64 62 32 20 65 76 61 6c  bu.db.  db2 eval
09d0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
09e0: 42 4c 45 20 64 61 74 61 5f 78 31 28 61 2c 20 62  BLE data_x1(a, b
09f0: 2c 20 72 62 75 5f 63 6f 6e 74 72 6f 6c 29 3b 0a  , rbu_control);.
0a00: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0a10: 64 61 74 61 5f 78 31 20 56 41 4c 55 45 53 28 31  data_x1 VALUES(1
0a20: 2c 20 27 61 27 2c 20 30 29 3b 0a 20 20 7d 0a 20  , 'a', 0);.  }. 
0a30: 20 64 62 32 20 63 6c 6f 73 65 0a 20 20 6c 69 73   db2 close.  lis
0a40: 74 20 5b 63 61 74 63 68 20 7b 20 72 75 6e 5f 72  t [catch { run_r
0a50: 62 75 20 74 65 73 74 2e 64 62 20 72 62 75 2e 64  bu test.db rbu.d
0a60: 62 20 7d 20 6d 73 67 5d 20 24 6d 73 67 0a 7d 20  b } msg] $msg.} 
0a70: 7b 31 20 7b 53 51 4c 49 54 45 5f 45 52 52 4f 52  {1 {SQLITE_ERROR
0a80: 20 2d 20 63 6f 6c 75 6d 6e 20 6d 69 73 73 69 6e   - column missin
0a90: 67 20 66 72 6f 6d 20 64 61 74 61 5f 78 31 3a 20  g from data_x1: 
0aa0: 63 7d 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c 5f  c}}..do_execsql_
0ab0: 74 65 73 74 20 32 2e 32 20 7b 0a 20 20 50 52 41  test 2.2 {.  PRA
0ac0: 47 4d 41 20 69 6e 74 65 67 72 69 74 79 5f 63 68  GMA integrity_ch
0ad0: 65 63 6b 3b 0a 7d 20 7b 6f 6b 7d 0a 0a 23 20 41  eck;.} {ok}..# A
0ae0: 6c 73 6f 20 65 78 74 72 61 20 63 6f 6c 75 6d 6e  lso extra column
0af0: 73 2e 0a 23 0a 64 6f 5f 65 78 65 63 73 71 6c 5f  s..#.do_execsql_
0b00: 74 65 73 74 20 32 2e 33 20 7b 0a 20 20 43 52 45  test 2.3 {.  CRE
0b10: 41 54 45 20 54 41 42 4c 45 20 78 32 28 61 20 49  ATE TABLE x2(a I
0b20: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
0b30: 45 59 2c 20 62 2c 20 63 29 3b 0a 20 20 43 52 45  EY, b, c);.  CRE
0b40: 41 54 45 20 49 4e 44 45 58 20 69 32 20 4f 4e 20  ATE INDEX i2 ON 
0b50: 78 32 28 62 2c 20 63 29 3b 0a 7d 20 7b 7d 0a 0a  x2(b, c);.} {}..
0b60: 64 6f 5f 74 65 73 74 20 32 2e 34 20 7b 0a 20 20  do_test 2.4 {.  
0b70: 66 6f 72 63 65 64 65 6c 65 74 65 20 72 62 75 2e  forcedelete rbu.
0b80: 64 62 0a 20 20 73 71 6c 69 74 65 33 20 64 62 32  db.  sqlite3 db2
0b90: 20 72 62 75 2e 64 62 0a 20 20 64 62 32 20 65 76   rbu.db.  db2 ev
0ba0: 61 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20  al {.    CREATE 
0bb0: 54 41 42 4c 45 20 64 61 74 61 5f 78 32 28 61 2c  TABLE data_x2(a,
0bc0: 20 62 2c 20 63 2c 20 64 2c 20 72 62 75 5f 63 6f   b, c, d, rbu_co
0bd0: 6e 74 72 6f 6c 29 3b 0a 20 20 20 20 49 4e 53 45  ntrol);.    INSE
0be0: 52 54 20 49 4e 54 4f 20 64 61 74 61 5f 78 32 20  RT INTO data_x2 
0bf0: 56 41 4c 55 45 53 28 31 2c 20 27 61 27 2c 20 32  VALUES(1, 'a', 2
0c00: 2c 20 33 2c 20 30 29 3b 0a 20 20 7d 0a 20 20 64  , 3, 0);.  }.  d
0c10: 62 32 20 63 6c 6f 73 65 0a 20 20 6c 69 73 74 20  b2 close.  list 
0c20: 5b 63 61 74 63 68 20 7b 20 72 75 6e 5f 72 62 75  [catch { run_rbu
0c30: 20 74 65 73 74 2e 64 62 20 72 62 75 2e 64 62 20   test.db rbu.db 
0c40: 7d 20 6d 73 67 5d 20 24 6d 73 67 0a 7d 20 7b 31  } msg] $msg.} {1
0c50: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 7d 0a 0a   SQLITE_ERROR}..
0c60: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
0c70: 32 2e 35 20 7b 0a 20 20 50 52 41 47 4d 41 20 69  2.5 {.  PRAGMA i
0c80: 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b 3b 0a  ntegrity_check;.
0c90: 7d 20 7b 6f 6b 7d 0a 0a 0a 23 2d 2d 2d 2d 2d 2d  } {ok}...#------
0ca0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0cb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0cc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0cd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ce0: 2d 2d 2d 0a 23 20 54 65 73 74 20 74 68 61 74 20  ---.# Test that 
0cf0: 73 71 6c 69 74 65 33 72 62 75 5f 63 72 65 61 74  sqlite3rbu_creat
0d00: 65 5f 76 66 73 28 29 20 72 65 74 75 72 6e 73 20  e_vfs() returns 
0d10: 61 6e 20 65 72 72 6f 72 20 69 66 20 74 68 65 20  an error if the 
0d20: 72 65 71 75 65 73 74 65 64 20 0a 23 20 70 61 72  requested .# par
0d30: 65 6e 74 20 56 46 53 20 69 73 20 75 6e 6b 6e 6f  ent VFS is unkno
0d40: 77 6e 2e 0a 23 0a 23 20 41 6e 64 20 74 68 61 74  wn..#.# And that
0d50: 20 6e 6f 74 68 69 6e 67 20 64 69 73 61 73 74 65   nothing disaste
0d60: 72 6f 75 73 20 68 61 70 70 65 6e 73 20 69 66 20  rous happens if 
0d70: 61 20 56 46 53 20 6e 61 6d 65 20 70 61 73 73 65  a VFS name passe
0d80: 64 20 74 6f 0a 23 20 73 71 6c 69 74 65 33 72 62  d to.# sqlite3rb
0d90: 75 5f 64 65 73 74 72 6f 79 5f 76 66 73 28 29 20  u_destroy_vfs() 
0da0: 69 73 20 75 6e 6b 6e 6f 77 6e 20 6f 72 20 6e 6f  is unknown or no
0db0: 74 20 61 6e 20 52 42 55 20 76 66 73 2e 0a 23 0a  t an RBU vfs..#.
0dc0: 64 6f 5f 74 65 73 74 20 33 2e 31 20 7b 0a 20 20  do_test 3.1 {.  
0dd0: 6c 69 73 74 20 5b 63 61 74 63 68 20 7b 73 71 6c  list [catch {sql
0de0: 69 74 65 33 72 62 75 5f 63 72 65 61 74 65 5f 76  ite3rbu_create_v
0df0: 66 73 20 78 79 7a 20 6e 6f 73 75 63 68 70 61 72  fs xyz nosuchpar
0e00: 65 6e 74 7d 20 6d 73 67 5d 20 24 6d 73 67 0a 7d  ent} msg] $msg.}
0e10: 20 7b 31 20 53 51 4c 49 54 45 5f 4e 4f 54 46 4f   {1 SQLITE_NOTFO
0e20: 55 4e 44 7d 0a 0a 64 6f 5f 74 65 73 74 20 33 2e  UND}..do_test 3.
0e30: 32 20 7b 0a 20 20 73 71 6c 69 74 65 33 72 62 75  2 {.  sqlite3rbu
0e40: 5f 64 65 73 74 72 6f 79 5f 76 66 73 20 6e 6f 73  _destroy_vfs nos
0e50: 75 63 68 76 66 73 0a 20 20 73 71 6c 69 74 65 33  uchvfs.  sqlite3
0e60: 72 62 75 5f 64 65 73 74 72 6f 79 5f 76 66 73 20  rbu_destroy_vfs 
0e70: 75 6e 69 78 0a 20 20 73 71 6c 69 74 65 33 72 62  unix.  sqlite3rb
0e80: 75 5f 64 65 73 74 72 6f 79 5f 76 66 73 20 77 69  u_destroy_vfs wi
0e90: 6e 33 32 0a 7d 20 7b 7d 0a 0a 23 2d 2d 2d 2d 2d  n32.} {}..#-----
0ea0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0eb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ec0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ee0: 2d 2d 2d 2d 0a 23 20 54 65 73 74 20 74 68 61 74  ----.# Test that
0ef0: 20 69 74 20 69 73 20 61 6e 20 65 72 72 6f 72 20   it is an error 
0f00: 74 6f 20 73 70 65 63 69 66 79 20 61 6e 20 65 78  to specify an ex
0f10: 70 6c 69 63 69 74 20 56 46 53 20 74 68 61 74 20  plicit VFS that 
0f20: 64 6f 65 73 20 6e 6f 74 20 0a 23 20 69 6e 63 6c  does not .# incl
0f30: 75 64 65 20 72 62 75 20 56 46 53 20 66 75 6e 63  ude rbu VFS func
0f40: 74 69 6f 6e 61 6c 69 74 79 2e 0a 23 0a 64 6f 5f  tionality..#.do_
0f50: 74 65 73 74 20 34 2e 31 20 7b 0a 20 20 74 65 73  test 4.1 {.  tes
0f60: 74 76 66 73 20 74 76 66 73 0a 20 20 73 71 6c 69  tvfs tvfs.  sqli
0f70: 74 65 33 72 62 75 20 72 62 75 20 66 69 6c 65 3a  te3rbu rbu file:
0f80: 74 65 73 74 2e 64 62 3f 76 66 73 3d 74 76 66 73  test.db?vfs=tvfs
0f90: 20 72 62 75 2e 64 62 20 0a 20 20 6c 69 73 74 20   rbu.db .  list 
0fa0: 5b 63 61 74 63 68 20 7b 20 72 62 75 20 73 74 65  [catch { rbu ste
0fb0: 70 20 7d 20 6d 73 67 5d 20 24 6d 73 67 0a 7d 20  p } msg] $msg.} 
0fc0: 7b 30 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 7d  {0 SQLITE_ERROR}
0fd0: 0a 64 6f 5f 74 65 73 74 20 34 2e 32 20 7b 0a 20  .do_test 4.2 {. 
0fe0: 20 6c 69 73 74 20 5b 63 61 74 63 68 20 7b 20 72   list [catch { r
0ff0: 62 75 20 63 6c 6f 73 65 20 7d 20 6d 73 67 5d 20  bu close } msg] 
1000: 24 6d 73 67 0a 7d 20 7b 31 20 7b 53 51 4c 49 54  $msg.} {1 {SQLIT
1010: 45 5f 45 52 52 4f 52 20 2d 20 72 62 75 20 76 66  E_ERROR - rbu vf
1020: 73 20 6e 6f 74 20 66 6f 75 6e 64 7d 7d 0a 74 76  s not found}}.tv
1030: 66 73 20 64 65 6c 65 74 65 0a 0a 23 2d 2d 2d 2d  fs delete..#----
1040: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1050: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1060: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1070: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1080: 2d 2d 2d 2d 2d 0a 23 20 54 65 73 74 20 61 20 6c  -----.# Test a l
1090: 61 72 67 65 20 72 62 75 20 75 70 64 61 74 65 20  arge rbu update 
10a0: 74 6f 20 65 6e 73 75 72 65 20 74 68 61 74 20 77  to ensure that w
10b0: 61 6c 5f 61 75 74 6f 63 68 65 63 6b 70 6f 69 6e  al_autocheckpoin
10c0: 74 20 64 6f 65 73 20 6e 6f 74 20 67 65 74 0a 23  t does not get.#
10d0: 20 69 6e 20 74 68 65 20 77 61 79 2e 0a 23 0a 66   in the way..#.f
10e0: 6f 72 63 65 64 65 6c 65 74 65 20 72 62 75 2e 64  orcedelete rbu.d
10f0: 62 0a 72 65 73 65 74 5f 64 62 0a 64 6f 5f 65 78  b.reset_db.do_ex
1100: 65 63 73 71 6c 5f 74 65 73 74 20 35 2e 31 20 7b  ecsql_test 5.1 {
1110: 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20  .  CREATE TABLE 
1120: 78 31 28 61 2c 20 62 2c 20 63 2c 20 50 52 49 4d  x1(a, b, c, PRIM
1130: 41 52 59 20 4b 45 59 28 61 29 29 20 57 49 54 48  ARY KEY(a)) WITH
1140: 4f 55 54 20 52 4f 57 49 44 3b 0a 20 20 43 52 45  OUT ROWID;.  CRE
1150: 41 54 45 20 49 4e 44 45 58 20 69 31 20 4f 4e 20  ATE INDEX i1 ON 
1160: 78 31 28 61 29 3b 0a 0a 20 20 41 54 54 41 43 48  x1(a);..  ATTACH
1170: 20 27 72 62 75 2e 64 62 27 20 41 53 20 72 62 75   'rbu.db' AS rbu
1180: 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45  ;.  CREATE TABLE
1190: 20 72 62 75 2e 64 61 74 61 5f 78 31 28 61 2c 20   rbu.data_x1(a, 
11a0: 62 2c 20 63 2c 20 72 62 75 5f 63 6f 6e 74 72 6f  b, c, rbu_contro
11b0: 6c 29 3b 0a 20 20 57 49 54 48 20 73 28 61 2c 20  l);.  WITH s(a, 
11c0: 62 2c 20 63 29 20 41 53 20 28 0a 20 20 20 20 53  b, c) AS (.    S
11d0: 45 4c 45 43 54 20 72 61 6e 64 6f 6d 62 6c 6f 62  ELECT randomblob
11e0: 28 33 30 30 29 2c 20 72 61 6e 64 6f 6d 62 6c 6f  (300), randomblo
11f0: 62 28 33 30 30 29 2c 20 31 0a 20 20 20 20 55 4e  b(300), 1.    UN
1200: 49 4f 4e 20 41 4c 4c 0a 20 20 20 20 53 45 4c 45  ION ALL.    SELE
1210: 43 54 20 72 61 6e 64 6f 6d 62 6c 6f 62 28 33 30  CT randomblob(30
1220: 30 29 2c 20 72 61 6e 64 6f 6d 62 6c 6f 62 28 33  0), randomblob(3
1230: 30 30 29 2c 20 63 2b 31 20 46 52 4f 4d 20 73 20  00), c+1 FROM s 
1240: 57 48 45 52 45 20 63 3c 32 30 30 30 0a 20 20 29  WHERE c<2000.  )
1250: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 64  .  INSERT INTO d
1260: 61 74 61 5f 78 31 20 53 45 4c 45 43 54 20 61 2c  ata_x1 SELECT a,
1270: 20 62 2c 20 63 2c 20 30 20 46 52 4f 4d 20 73 3b   b, c, 0 FROM s;
1280: 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20 35 2e 32 20  .}..do_test 5.2 
1290: 7b 0a 20 20 73 71 6c 69 74 65 33 72 62 75 20 72  {.  sqlite3rbu r
12a0: 62 75 20 74 65 73 74 2e 64 62 20 72 62 75 2e 64  bu test.db rbu.d
12b0: 62 0a 20 20 77 68 69 6c 65 20 7b 5b 72 62 75 20  b.  while {[rbu 
12c0: 73 74 65 70 5d 3d 3d 22 53 51 4c 49 54 45 5f 4f  step]=="SQLITE_O
12d0: 4b 22 20 26 26 20 5b 66 69 6c 65 20 65 78 69 73  K" && [file exis
12e0: 74 73 20 74 65 73 74 2e 64 62 2d 77 61 6c 5d 3d  ts test.db-wal]=
12f0: 3d 30 7d 20 7b 7d 0a 20 20 72 62 75 20 63 6c 6f  =0} {}.  rbu clo
1300: 73 65 0a 7d 20 7b 53 51 4c 49 54 45 5f 4f 4b 7d  se.} {SQLITE_OK}
1310: 0a 0a 64 6f 5f 74 65 73 74 20 35 2e 33 20 7b 0a  ..do_test 5.3 {.
1320: 20 20 65 78 70 72 20 7b 5b 66 69 6c 65 20 73 69    expr {[file si
1330: 7a 65 20 74 65 73 74 2e 64 62 2d 77 61 6c 5d 20  ze test.db-wal] 
1340: 3e 20 28 31 30 32 34 20 2a 20 31 32 30 30 29 7d  > (1024 * 1200)}
1350: 0a 7d 20 31 0a 0a 64 6f 5f 74 65 73 74 20 36 2e  .} 1..do_test 6.
1360: 31 20 7b 20 73 71 6c 69 74 65 33 72 62 75 5f 69  1 { sqlite3rbu_i
1370: 6e 74 65 72 6e 61 6c 5f 74 65 73 74 20 7d 20 7b  nternal_test } {
1380: 7d 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a     }..finish_test.