/ Hex Artifact Content
Login

Artifact 9d6b20606afe712374952eec4f8fd74b1a8097ef:


0000: 23 20 32 30 31 31 20 4e 6f 76 65 6d 62 65 72 20  # 2011 November 
0010: 31 36 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  16.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 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 2a 0a 23 0a 23 20 54 68 69  ********.#.# Thi
0170: 73 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20  s file contains 
0180: 66 61 75 6c 74 2d 69 6e 6a 65 63 74 69 6f 6e 20  fault-injection 
0190: 74 65 73 74 20 63 61 73 65 73 20 66 6f 72 20 74  test cases for t
01a0: 68 65 20 0a 23 20 73 71 6c 69 74 65 33 5f 64 62  he .# sqlite3_db
01b0: 5f 63 61 63 68 65 66 6c 75 73 68 20 41 50 49 2e  _cacheflush API.
01c0: 0a 23 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20  .#..set testdir 
01d0: 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61  [file dirname $a
01e0: 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65  rgv0].source $te
01f0: 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c  stdir/tester.tcl
0200: 0a 73 65 74 20 74 65 73 74 70 72 65 66 69 78 20  .set testprefix 
0210: 63 66 66 61 75 6c 74 0a 73 6f 75 72 63 65 20 24  cffault.source $
0220: 74 65 73 74 64 69 72 2f 6d 61 6c 6c 6f 63 5f 63  testdir/malloc_c
0230: 6f 6d 6d 6f 6e 2e 74 63 6c 0a 0a 23 20 52 75 6e  ommon.tcl..# Run
0240: 20 74 68 65 20 73 75 70 70 6c 69 65 64 20 53 51   the supplied SQ
0250: 4c 20 6f 6e 20 61 20 63 6f 70 79 20 6f 66 20 74  L on a copy of t
0260: 68 65 20 64 61 74 61 62 61 73 65 20 63 75 72 72  he database curr
0270: 65 6e 74 6c 79 20 73 74 6f 72 65 64 20 6f 6e 20  ently stored on 
0280: 0a 23 20 64 69 73 6b 20 69 6e 20 66 69 6c 65 20  .# disk in file 
0290: 24 64 62 66 69 6c 65 2e 0a 70 72 6f 63 20 64 69  $dbfile..proc di
02a0: 73 6b 71 75 65 72 79 20 7b 64 62 66 69 6c 65 20  skquery {dbfile 
02b0: 73 71 6c 7d 20 7b 0a 20 20 66 6f 72 63 65 63 6f  sql} {.  forceco
02c0: 70 79 20 24 64 62 66 69 6c 65 20 64 71 2e 64 62  py $dbfile dq.db
02d0: 0a 20 20 73 71 6c 69 74 65 33 20 64 71 20 64 71  .  sqlite3 dq dq
02e0: 2e 64 62 0a 20 20 73 65 74 20 72 65 73 20 5b 65  .db.  set res [e
02f0: 78 65 63 73 71 6c 20 24 73 71 6c 20 64 71 5d 0a  xecsql $sql dq].
0300: 20 20 64 71 20 63 6c 6f 73 65 0a 20 20 73 65 74    dq close.  set
0310: 20 72 65 73 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73   res.}..do_execs
0320: 71 6c 5f 74 65 73 74 20 31 2e 30 20 7b 0a 20 20  ql_test 1.0 {.  
0330: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28  CREATE TABLE t1(
0340: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
0350: 29 3b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45  );.  CREATE INDE
0360: 58 20 69 31 20 4f 4e 20 74 31 28 62 29 3b 0a 20  X i1 ON t1(b);. 
0370: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0380: 56 41 4c 55 45 53 28 31 2c 20 32 29 3b 0a 20 20  VALUES(1, 2);.  
0390: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
03a0: 41 4c 55 45 53 28 33 2c 20 34 29 3b 0a 20 20 49  ALUES(3, 4);.  I
03b0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
03c0: 4c 55 45 53 28 35 2c 20 36 29 3b 0a 20 20 49 4e  LUES(5, 6);.  IN
03d0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
03e0: 55 45 53 28 37 2c 20 38 29 3b 0a 7d 0a 66 61 75  UES(7, 8);.}.fau
03f0: 6c 74 73 69 6d 5f 73 61 76 65 5f 61 6e 64 5f 63  ltsim_save_and_c
0400: 6c 6f 73 65 0a 0a 64 6f 5f 66 61 75 6c 74 73 69  lose..do_faultsi
0410: 6d 5f 74 65 73 74 20 31 2e 31 20 2d 70 72 65 70  m_test 1.1 -prep
0420: 20 7b 0a 20 20 66 61 75 6c 74 73 69 6d 5f 72 65   {.  faultsim_re
0430: 73 74 6f 72 65 5f 61 6e 64 5f 72 65 6f 70 65 6e  store_and_reopen
0440: 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a 20 20 20  .  db eval {.   
0450: 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 55 50   BEGIN;.      UP
0460: 44 41 54 45 20 74 31 20 53 45 54 20 62 3d 62 2b  DATE t1 SET b=b+
0470: 31 3b 0a 20 20 7d 0a 7d 20 2d 62 6f 64 79 20 7b  1;.  }.} -body {
0480: 0a 20 20 73 71 6c 69 74 65 33 5f 64 62 5f 63 61  .  sqlite3_db_ca
0490: 63 68 65 66 6c 75 73 68 20 64 62 0a 7d 20 2d 74  cheflush db.} -t
04a0: 65 73 74 20 7b 0a 20 20 69 66 20 7b 5b 73 71 6c  est {.  if {[sql
04b0: 69 74 65 33 5f 67 65 74 5f 61 75 74 6f 63 6f 6d  ite3_get_autocom
04c0: 6d 69 74 20 64 62 5d 7d 20 7b 20 65 72 72 6f 72  mit db]} { error
04d0: 20 22 54 72 61 6e 73 61 63 74 69 6f 6e 20 72 6f   "Transaction ro
04e0: 6c 6c 65 64 20 62 61 63 6b 21 22 20 7d 0a 20 20  lled back!" }.  
04f0: 66 61 75 6c 74 73 69 6d 5f 74 65 73 74 5f 72 65  faultsim_test_re
0500: 73 75 6c 74 20 7b 30 20 7b 7d 7d 20 7b 31 20 7b  sult {0 {}} {1 {
0510: 64 69 73 6b 20 49 2f 4f 20 65 72 72 6f 72 7d 7d  disk I/O error}}
0520: 0a 20 20 63 61 74 63 68 20 7b 20 64 62 20 65 76  .  catch { db ev
0530: 61 6c 20 43 4f 4d 4d 49 54 20 7d 0a 20 20 66 61  al COMMIT }.  fa
0540: 75 6c 74 73 69 6d 5f 69 6e 74 65 67 72 69 74 79  ultsim_integrity
0550: 5f 63 68 65 63 6b 0a 7d 0a 0a 64 6f 5f 66 61 75  _check.}..do_fau
0560: 6c 74 73 69 6d 5f 74 65 73 74 20 31 2e 32 20 2d  ltsim_test 1.2 -
0570: 70 72 65 70 20 7b 0a 20 20 66 61 75 6c 74 73 69  prep {.  faultsi
0580: 6d 5f 72 65 73 74 6f 72 65 5f 61 6e 64 5f 72 65  m_restore_and_re
0590: 6f 70 65 6e 0a 20 20 64 62 20 65 76 61 6c 20 7b  open.  db eval {
05a0: 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20  .    BEGIN;.    
05b0: 20 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20    UPDATE t1 SET 
05c0: 62 3d 62 2b 31 3b 0a 20 20 7d 0a 7d 20 2d 62 6f  b=b+1;.  }.} -bo
05d0: 64 79 20 7b 0a 20 20 73 65 74 20 72 65 73 75 6c  dy {.  set resul
05e0: 74 20 5b 6c 69 73 74 5d 0a 20 20 64 62 20 65 76  t [list].  db ev
05f0: 61 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  al { SELECT * FR
0600: 4f 4d 20 74 31 20 7d 20 7b 0a 20 20 20 20 69 66  OM t1 } {.    if
0610: 20 7b 24 61 3d 3d 35 7d 20 7b 20 63 61 74 63 68   {$a==5} { catch
0620: 20 7b 20 73 71 6c 69 74 65 33 5f 64 62 5f 63 61   { sqlite3_db_ca
0630: 63 68 65 66 6c 75 73 68 20 64 62 20 7d 20 7d 0a  cheflush db } }.
0640: 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65 73 75      lappend resu
0650: 6c 74 20 24 61 20 24 62 0a 20 20 7d 0a 20 20 73  lt $a $b.  }.  s
0660: 65 74 20 72 65 73 75 6c 74 0a 7d 20 2d 74 65 73  et result.} -tes
0670: 74 20 7b 0a 20 20 66 61 75 6c 74 73 69 6d 5f 74  t {.  faultsim_t
0680: 65 73 74 5f 72 65 73 75 6c 74 20 7b 30 20 7b 31  est_result {0 {1
0690: 20 33 20 33 20 35 20 35 20 37 20 37 20 39 7d 7d   3 3 5 5 7 7 9}}
06a0: 20 7b 31 20 7b 64 69 73 6b 20 49 2f 4f 20 65 72   {1 {disk I/O er
06b0: 72 6f 72 7d 7d 0a 20 20 63 61 74 63 68 20 7b 20  ror}}.  catch { 
06c0: 64 62 20 65 76 61 6c 20 43 4f 4d 4d 49 54 20 7d  db eval COMMIT }
06d0: 0a 20 20 66 61 75 6c 74 73 69 6d 5f 69 6e 74 65  .  faultsim_inte
06e0: 67 72 69 74 79 5f 63 68 65 63 6b 0a 7d 0a 0a 23  grity_check.}..#
06f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0700: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0710: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0720: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0730: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 72 65 73 65 74 5f  ---------.reset_
0740: 64 62 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  db.do_execsql_te
0750: 73 74 20 32 2e 30 20 7b 0a 20 20 43 52 45 41 54  st 2.0 {.  CREAT
0760: 45 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49  E TABLE t1(a PRI
0770: 4d 41 52 59 20 4b 45 59 2c 20 62 2c 20 63 29 3b  MARY KEY, b, c);
0780: 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20  .  CREATE INDEX 
0790: 69 31 20 4f 4e 20 74 31 28 62 29 3b 0a 20 20 43  i1 ON t1(b);.  C
07a0: 52 45 41 54 45 20 49 4e 44 45 58 20 69 32 20 4f  REATE INDEX i2 O
07b0: 4e 20 74 31 28 63 2c 20 62 29 3b 0a 20 20 49 4e  N t1(c, b);.  IN
07c0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
07d0: 55 45 53 28 31 2c 20 32 2c 20 20 72 61 6e 64 6f  UES(1, 2,  rando
07e0: 6d 62 6c 6f 62 28 36 30 30 29 29 3b 0a 20 20 49  mblob(600));.  I
07f0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
0800: 4c 55 45 53 28 33 2c 20 34 2c 20 20 72 61 6e 64  LUES(3, 4,  rand
0810: 6f 6d 62 6c 6f 62 28 36 30 30 29 29 3b 0a 20 20  omblob(600));.  
0820: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
0830: 41 4c 55 45 53 28 35 2c 20 36 2c 20 20 72 61 6e  ALUES(5, 6,  ran
0840: 64 6f 6d 62 6c 6f 62 28 36 30 30 29 29 3b 0a 20  domblob(600));. 
0850: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0860: 56 41 4c 55 45 53 28 37 2c 20 38 2c 20 20 72 61  VALUES(7, 8,  ra
0870: 6e 64 6f 6d 62 6c 6f 62 28 36 30 30 29 29 3b 0a  ndomblob(600));.
0880: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
0890: 20 56 41 4c 55 45 53 28 39 2c 20 31 30 2c 20 72   VALUES(9, 10, r
08a0: 61 6e 64 6f 6d 62 6c 6f 62 28 36 30 30 29 29 3b  andomblob(600));
08b0: 0a 7d 0a 66 61 75 6c 74 73 69 6d 5f 73 61 76 65  .}.faultsim_save
08c0: 5f 61 6e 64 5f 63 6c 6f 73 65 0a 0a 64 6f 5f 66  _and_close..do_f
08d0: 61 75 6c 74 73 69 6d 5f 74 65 73 74 20 32 2e 31  aultsim_test 2.1
08e0: 20 2d 70 72 65 70 20 7b 0a 20 20 66 61 75 6c 74   -prep {.  fault
08f0: 73 69 6d 5f 72 65 73 74 6f 72 65 5f 61 6e 64 5f  sim_restore_and_
0900: 72 65 6f 70 65 6e 0a 20 20 64 62 20 65 76 61 6c  reopen.  db eval
0910: 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20   {.    BEGIN;.  
0920: 20 20 20 20 55 50 44 41 54 45 20 74 31 20 53 45      UPDATE t1 SE
0930: 54 20 62 3d 62 2b 31 3b 0a 20 20 7d 0a 7d 20 2d  T b=b+1;.  }.} -
0940: 62 6f 64 79 20 7b 0a 20 20 73 65 74 20 72 65 73  body {.  set res
0950: 75 6c 74 20 5b 6c 69 73 74 5d 0a 20 20 64 62 20  ult [list].  db 
0960: 65 76 61 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20  eval { SELECT * 
0970: 46 52 4f 4d 20 74 31 20 7d 20 7b 0a 20 20 20 20  FROM t1 } {.    
0980: 69 66 20 7b 24 61 3d 3d 35 7d 20 7b 20 63 61 74  if {$a==5} { cat
0990: 63 68 20 7b 20 73 71 6c 69 74 65 33 5f 64 62 5f  ch { sqlite3_db_
09a0: 63 61 63 68 65 66 6c 75 73 68 20 64 62 20 7d 20  cacheflush db } 
09b0: 7d 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65  }.    lappend re
09c0: 73 75 6c 74 20 24 61 20 24 62 0a 20 20 7d 0a 20  sult $a $b.  }. 
09d0: 20 73 65 74 20 72 65 73 75 6c 74 0a 7d 20 2d 74   set result.} -t
09e0: 65 73 74 20 7b 0a 20 20 66 61 75 6c 74 73 69 6d  est {.  faultsim
09f0: 5f 74 65 73 74 5f 72 65 73 75 6c 74 20 7b 30 20  _test_result {0 
0a00: 7b 31 20 33 20 33 20 35 20 35 20 37 20 37 20 39  {1 3 3 5 5 7 7 9
0a10: 20 39 20 31 31 7d 7d 20 7b 31 20 7b 64 69 73 6b   9 11}} {1 {disk
0a20: 20 49 2f 4f 20 65 72 72 6f 72 7d 7d 0a 20 20 63   I/O error}}.  c
0a30: 61 74 63 68 20 7b 20 64 62 20 65 76 61 6c 20 7b  atch { db eval {
0a40: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
0a50: 56 41 4c 55 45 53 28 31 31 2c 20 31 32 2c 20 72  VALUES(11, 12, r
0a60: 61 6e 64 6f 6d 62 6c 6f 62 28 36 30 30 29 29 20  andomblob(600)) 
0a70: 7d 20 7d 0a 20 20 63 61 74 63 68 20 7b 20 64 62  } }.  catch { db
0a80: 20 65 76 61 6c 20 43 4f 4d 4d 49 54 20 7d 0a 20   eval COMMIT }. 
0a90: 20 66 61 75 6c 74 73 69 6d 5f 69 6e 74 65 67 72   faultsim_integr
0aa0: 69 74 79 5f 63 68 65 63 6b 0a 7d 0a 0a 64 6f 5f  ity_check.}..do_
0ab0: 66 61 75 6c 74 73 69 6d 5f 74 65 73 74 20 32 2e  faultsim_test 2.
0ac0: 32 20 2d 70 72 65 70 20 7b 0a 20 20 66 61 75 6c  2 -prep {.  faul
0ad0: 74 73 69 6d 5f 72 65 73 74 6f 72 65 5f 61 6e 64  tsim_restore_and
0ae0: 5f 72 65 6f 70 65 6e 0a 20 20 64 62 20 65 76 61  _reopen.  db eva
0af0: 6c 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20  l {.    BEGIN;. 
0b00: 20 20 20 20 20 55 50 44 41 54 45 20 74 31 20 53       UPDATE t1 S
0b10: 45 54 20 62 3d 62 2b 31 3b 0a 20 20 7d 0a 7d 20  ET b=b+1;.  }.} 
0b20: 2d 62 6f 64 79 20 7b 0a 20 20 73 71 6c 69 74 65  -body {.  sqlite
0b30: 33 5f 64 62 5f 63 61 63 68 65 66 6c 75 73 68 20  3_db_cacheflush 
0b40: 64 62 0a 7d 20 2d 74 65 73 74 20 7b 0a 20 20 69  db.} -test {.  i
0b50: 66 20 7b 5b 73 71 6c 69 74 65 33 5f 67 65 74 5f  f {[sqlite3_get_
0b60: 61 75 74 6f 63 6f 6d 6d 69 74 20 64 62 5d 7d 20  autocommit db]} 
0b70: 7b 20 65 72 72 6f 72 20 22 54 72 61 6e 73 61 63  { error "Transac
0b80: 74 69 6f 6e 20 72 6f 6c 6c 65 64 20 62 61 63 6b  tion rolled back
0b90: 21 22 20 7d 0a 20 20 66 61 75 6c 74 73 69 6d 5f  !" }.  faultsim_
0ba0: 74 65 73 74 5f 72 65 73 75 6c 74 20 7b 30 20 7b  test_result {0 {
0bb0: 7d 7d 20 7b 31 20 7b 64 69 73 6b 20 49 2f 4f 20  }} {1 {disk I/O 
0bc0: 65 72 72 6f 72 7d 7d 0a 20 20 63 61 74 63 68 20  error}}.  catch 
0bd0: 7b 20 64 62 20 65 76 61 6c 20 7b 20 53 45 4c 45  { db eval { SELE
0be0: 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 7d 20 7d  CT * FROM t1 } }
0bf0: 0a 20 20 63 61 74 63 68 20 7b 20 64 62 20 65 76  .  catch { db ev
0c00: 61 6c 20 43 4f 4d 4d 49 54 20 7d 0a 20 20 66 61  al COMMIT }.  fa
0c10: 75 6c 74 73 69 6d 5f 69 6e 74 65 67 72 69 74 79  ultsim_integrity
0c20: 5f 63 68 65 63 6b 0a 7d 0a 0a 64 6f 5f 66 61 75  _check.}..do_fau
0c30: 6c 74 73 69 6d 5f 74 65 73 74 20 32 2e 33 20 2d  ltsim_test 2.3 -
0c40: 70 72 65 70 20 7b 0a 20 20 66 61 75 6c 74 73 69  prep {.  faultsi
0c50: 6d 5f 72 65 73 74 6f 72 65 5f 61 6e 64 5f 72 65  m_restore_and_re
0c60: 6f 70 65 6e 0a 20 20 64 62 20 65 76 61 6c 20 7b  open.  db eval {
0c70: 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20  .    BEGIN;.    
0c80: 20 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20    UPDATE t1 SET 
0c90: 62 3d 62 2d 31 3b 0a 20 20 7d 0a 7d 20 2d 62 6f  b=b-1;.  }.} -bo
0ca0: 64 79 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 64  dy {.  sqlite3_d
0cb0: 62 5f 63 61 63 68 65 66 6c 75 73 68 20 64 62 0a  b_cacheflush db.
0cc0: 7d 20 2d 74 65 73 74 20 7b 0a 20 20 69 66 20 7b  } -test {.  if {
0cd0: 5b 73 71 6c 69 74 65 33 5f 67 65 74 5f 61 75 74  [sqlite3_get_aut
0ce0: 6f 63 6f 6d 6d 69 74 20 64 62 5d 7d 20 7b 20 65  ocommit db]} { e
0cf0: 72 72 6f 72 20 22 54 72 61 6e 73 61 63 74 69 6f  rror "Transactio
0d00: 6e 20 72 6f 6c 6c 65 64 20 62 61 63 6b 21 22 20  n rolled back!" 
0d10: 7d 0a 20 20 66 61 75 6c 74 73 69 6d 5f 74 65 73  }.  faultsim_tes
0d20: 74 5f 72 65 73 75 6c 74 20 7b 30 20 7b 7d 7d 20  t_result {0 {}} 
0d30: 7b 31 20 7b 64 69 73 6b 20 49 2f 4f 20 65 72 72  {1 {disk I/O err
0d40: 6f 72 7d 7d 0a 20 20 63 61 74 63 68 20 7b 20 64  or}}.  catch { d
0d50: 62 20 65 76 61 6c 20 7b 20 49 4e 53 45 52 54 20  b eval { INSERT 
0d60: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31  INTO t1 VALUES(1
0d70: 31 2c 20 31 32 2c 20 72 61 6e 64 6f 6d 62 6c 6f  1, 12, randomblo
0d80: 62 28 36 30 30 29 29 20 7d 20 7d 0a 20 20 63 61  b(600)) } }.  ca
0d90: 74 63 68 20 7b 20 64 62 20 65 76 61 6c 20 43 4f  tch { db eval CO
0da0: 4d 4d 49 54 20 7d 0a 20 20 66 61 75 6c 74 73 69  MMIT }.  faultsi
0db0: 6d 5f 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63  m_integrity_chec
0dc0: 6b 0a 7d 0a 0a 64 6f 5f 66 61 75 6c 74 73 69 6d  k.}..do_faultsim
0dd0: 5f 74 65 73 74 20 32 2e 34 20 2d 70 72 65 70 20  _test 2.4 -prep 
0de0: 7b 0a 20 20 66 61 75 6c 74 73 69 6d 5f 72 65 73  {.  faultsim_res
0df0: 74 6f 72 65 5f 61 6e 64 5f 72 65 6f 70 65 6e 0a  tore_and_reopen.
0e00: 20 20 64 62 20 65 76 61 6c 20 7b 0a 20 20 20 20    db eval {.    
0e10: 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 55 50 44  BEGIN;.      UPD
0e20: 41 54 45 20 74 31 20 53 45 54 20 62 3d 62 2d 31  ATE t1 SET b=b-1
0e30: 3b 0a 20 20 7d 0a 7d 20 2d 62 6f 64 79 20 7b 0a  ;.  }.} -body {.
0e40: 20 20 63 61 74 63 68 20 7b 20 73 71 6c 69 74 65    catch { sqlite
0e50: 33 5f 64 62 5f 63 61 63 68 65 66 6c 75 73 68 20  3_db_cacheflush 
0e60: 64 62 20 7d 0a 20 20 63 61 74 63 68 20 7b 20 73  db }.  catch { s
0e70: 71 6c 69 74 65 33 5f 64 62 5f 72 65 6c 65 61 73  qlite3_db_releas
0e80: 65 5f 6d 65 6d 6f 72 79 20 64 62 20 7d 0a 20 20  e_memory db }.  
0e90: 63 61 74 63 68 20 7b 20 73 71 6c 69 74 65 33 5f  catch { sqlite3_
0ea0: 64 62 5f 63 61 63 68 65 66 6c 75 73 68 20 64 62  db_cacheflush db
0eb0: 20 7d 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 53   }.  execsql { S
0ec0: 45 4c 45 43 54 20 61 2c 20 62 20 46 52 4f 4d 20  ELECT a, b FROM 
0ed0: 74 31 20 7d 0a 7d 20 2d 74 65 73 74 20 7b 0a 20  t1 }.} -test {. 
0ee0: 20 66 61 75 6c 74 73 69 6d 5f 74 65 73 74 5f 72   faultsim_test_r
0ef0: 65 73 75 6c 74 20 7b 30 20 7b 31 20 31 20 33 20  esult {0 {1 1 3 
0f00: 33 20 35 20 35 20 37 20 37 20 39 20 39 7d 7d 20  3 5 5 7 7 9 9}} 
0f10: 7b 31 20 7b 64 69 73 6b 20 49 2f 4f 20 65 72 72  {1 {disk I/O err
0f20: 6f 72 7d 7d 0a 20 20 63 61 74 63 68 73 71 6c 20  or}}.  catchsql 
0f30: 52 4f 4c 4c 42 41 43 4b 0a 20 20 66 61 75 6c 74  ROLLBACK.  fault
0f40: 73 69 6d 5f 69 6e 74 65 67 72 69 74 79 5f 63 68  sim_integrity_ch
0f50: 65 63 6b 0a 7d 0a 0a 66 69 6e 69 73 68 5f 74 65  eck.}..finish_te
0f60: 73 74 0a                                         st.