/ Hex Artifact Content
Login

Artifact 89372a28f1d98254f03fed705f9efcd34ef61a674df16d2dbb4726944a2de5e9:


0000: 23 20 32 30 30 37 20 4d 61 79 20 31 0a 23 0a 23  # 2007 May 1.#.#
0010: 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73 63   The author disc
0020: 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74 20  laims copyright 
0030: 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20 63  to this source c
0040: 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f  ode.  In place o
0050: 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69  f.# a legal noti
0060: 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c  ce, here is a bl
0070: 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20 4d  essing:.#.#    M
0080: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
0090: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20 20  nd not evil..#  
00a0: 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66    May you find f
00b0: 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79  orgiveness for y
00c0: 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67  ourself and forg
00d0: 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20 20  ive others..#   
00e0: 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20 66   May you share f
00f0: 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b  reely, never tak
0100: 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f  ing more than yo
0110: 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a 2a  u 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 0a 23 0a 23 20 24 49 64 3a 20 69 6e 63 72  **.#.# $Id: incr
0170: 62 6c 6f 62 5f 65 72 72 2e 74 65 73 74 2c 76 20  blob_err.test,v 
0180: 31 2e 31 34 20 32 30 30 38 2f 30 37 2f 31 38 20  1.14 2008/07/18 
0190: 31 37 3a 31 36 3a 32 37 20 64 72 68 20 45 78 70  17:16:27 drh Exp
01a0: 20 24 0a 23 0a 0a 73 65 74 20 74 65 73 74 64 69   $.#..set testdi
01b0: 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20  r [file dirname 
01c0: 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24  $argv0].source $
01d0: 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74  testdir/tester.t
01e0: 63 6c 0a 73 65 74 20 3a 3a 74 65 73 74 70 72 65  cl.set ::testpre
01f0: 66 69 78 20 69 6e 63 72 62 6c 6f 62 5f 65 72 72  fix incrblob_err
0200: 0a 0a 69 66 63 61 70 61 62 6c 65 20 7b 21 69 6e  ..ifcapable {!in
0210: 63 72 62 6c 6f 62 20 20 7c 7c 20 21 74 63 6c 76  crblob  || !tclv
0220: 61 72 7d 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74  ar} {.  finish_t
0230: 65 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a  est.  return.}..
0240: 73 6f 75 72 63 65 20 24 74 65 73 74 64 69 72 2f  source $testdir/
0250: 6d 61 6c 6c 6f 63 5f 63 6f 6d 6d 6f 6e 2e 74 63  malloc_common.tc
0260: 6c 0a 0a 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70  l..unset -nocomp
0270: 6c 61 69 6e 20 3a 3a 66 64 20 3a 3a 64 61 74 61  lain ::fd ::data
0280: 0a 73 65 74 20 3a 3a 66 64 20 5b 6f 70 65 6e 20  .set ::fd [open 
0290: 24 3a 3a 63 6d 64 6c 69 6e 65 61 72 67 28 49 4e  $::cmdlinearg(IN
02a0: 46 4f 5f 53 43 52 49 50 54 29 5d 0a 73 65 74 20  FO_SCRIPT)].set 
02b0: 3a 3a 64 61 74 61 20 5b 72 65 61 64 20 24 3a 3a  ::data [read $::
02c0: 66 64 5d 0a 63 6c 6f 73 65 20 24 3a 3a 66 64 0a  fd].close $::fd.
02d0: 0a 64 6f 5f 6d 61 6c 6c 6f 63 5f 74 65 73 74 20  .do_malloc_test 
02e0: 31 20 2d 74 63 6c 70 72 65 70 20 7b 0a 20 20 73  1 -tclprep {.  s
02f0: 65 74 20 62 79 74 65 73 20 5b 66 69 6c 65 20 73  et bytes [file s
0300: 69 7a 65 20 24 3a 3a 63 6d 64 6c 69 6e 65 61 72  ize $::cmdlinear
0310: 67 28 49 4e 46 4f 5f 53 43 52 49 50 54 29 5d 0a  g(INFO_SCRIPT)].
0320: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
0330: 43 52 45 41 54 45 20 54 41 42 4c 45 20 62 6c 6f  CREATE TABLE blo
0340: 62 73 28 6b 2c 20 76 20 42 4c 4f 42 29 3b 0a 20  bs(k, v BLOB);. 
0350: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 62     INSERT INTO b
0360: 6c 6f 62 73 20 56 41 4c 55 45 53 28 31 2c 20 7a  lobs VALUES(1, z
0370: 65 72 6f 62 6c 6f 62 28 24 3a 3a 62 79 74 65 73  eroblob($::bytes
0380: 29 29 3b 0a 20 20 7d 0a 7d 20 2d 74 63 6c 62 6f  ));.  }.} -tclbo
0390: 64 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c 6f  dy {.  set ::blo
03a0: 62 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20 62  b [db incrblob b
03b0: 6c 6f 62 73 20 76 20 31 5d 0a 20 20 66 63 6f 6e  lobs v 1].  fcon
03c0: 66 69 67 75 72 65 20 24 3a 3a 62 6c 6f 62 20 2d  figure $::blob -
03d0: 74 72 61 6e 73 6c 61 74 69 6f 6e 20 62 69 6e 61  translation bina
03e0: 72 79 0a 20 20 73 65 74 20 72 63 20 5b 63 61 74  ry.  set rc [cat
03f0: 63 68 20 7b 70 75 74 73 20 2d 6e 6f 6e 65 77 6c  ch {puts -nonewl
0400: 69 6e 65 20 24 3a 3a 62 6c 6f 62 20 24 3a 3a 64  ine $::blob $::d
0410: 61 74 61 7d 5d 0a 20 20 69 66 20 7b 24 72 63 7d  ata}].  if {$rc}
0420: 20 7b 20 65 72 72 6f 72 20 22 6f 75 74 20 6f 66   { error "out of
0430: 20 6d 65 6d 6f 72 79 22 20 7d 0a 7d 20 0a 0a 64   memory" }.} ..d
0440: 6f 5f 6d 61 6c 6c 6f 63 5f 74 65 73 74 20 32 20  o_malloc_test 2 
0450: 2d 74 63 6c 70 72 65 70 20 7b 0a 20 20 65 78 65  -tclprep {.  exe
0460: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
0470: 45 20 54 41 42 4c 45 20 62 6c 6f 62 73 28 6b 2c  E TABLE blobs(k,
0480: 20 76 20 42 4c 4f 42 29 3b 0a 20 20 20 20 49 4e   v BLOB);.    IN
0490: 53 45 52 54 20 49 4e 54 4f 20 62 6c 6f 62 73 20  SERT INTO blobs 
04a0: 56 41 4c 55 45 53 28 31 2c 20 24 3a 3a 64 61 74  VALUES(1, $::dat
04b0: 61 29 3b 0a 20 20 7d 0a 7d 20 2d 74 63 6c 62 6f  a);.  }.} -tclbo
04c0: 64 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c 6f  dy {.  set ::blo
04d0: 62 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20 62  b [db incrblob b
04e0: 6c 6f 62 73 20 76 20 31 5d 0a 20 20 73 65 74 20  lobs v 1].  set 
04f0: 72 63 20 5b 63 61 74 63 68 20 7b 73 65 74 20 3a  rc [catch {set :
0500: 3a 72 20 5b 72 65 61 64 20 24 3a 3a 62 6c 6f 62  :r [read $::blob
0510: 5d 7d 5d 0a 20 20 69 66 20 7b 24 72 63 7d 20 7b  ]}].  if {$rc} {
0520: 20 0a 20 20 20 20 65 72 72 6f 72 20 22 6f 75 74   .    error "out
0530: 20 6f 66 20 6d 65 6d 6f 72 79 22 20 0a 20 20 7d   of memory" .  }
0540: 20 65 6c 73 65 69 66 20 7b 24 3a 3a 72 20 6e 65   elseif {$::r ne
0550: 20 24 3a 3a 64 61 74 61 7d 20 7b 0a 20 20 20 20   $::data} {.    
0560: 65 72 72 6f 72 20 22 42 61 64 20 64 61 74 61 20  error "Bad data 
0570: 72 65 61 64 2e 2e 2e 22 0a 20 20 7d 0a 7d 0a 0a  read...".  }.}..
0580: 64 6f 5f 6d 61 6c 6c 6f 63 5f 74 65 73 74 20 33  do_malloc_test 3
0590: 20 2d 74 63 6c 70 72 65 70 20 7b 0a 20 20 65 78   -tclprep {.  ex
05a0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
05b0: 54 45 20 54 41 42 4c 45 20 62 6c 6f 62 73 28 6b  TE TABLE blobs(k
05c0: 2c 20 76 20 42 4c 4f 42 29 3b 0a 20 20 20 20 49  , v BLOB);.    I
05d0: 4e 53 45 52 54 20 49 4e 54 4f 20 62 6c 6f 62 73  NSERT INTO blobs
05e0: 20 56 41 4c 55 45 53 28 31 2c 20 24 3a 3a 64 61   VALUES(1, $::da
05f0: 74 61 29 3b 0a 20 20 7d 0a 7d 20 2d 74 63 6c 62  ta);.  }.} -tclb
0600: 6f 64 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c  ody {.  set ::bl
0610: 6f 62 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20  ob [db incrblob 
0620: 62 6c 6f 62 73 20 76 20 31 5d 0a 20 20 73 65 74  blobs v 1].  set
0630: 20 72 63 20 5b 63 61 74 63 68 20 7b 73 65 74 20   rc [catch {set 
0640: 3a 3a 72 20 5b 72 65 61 64 20 24 3a 3a 62 6c 6f  ::r [read $::blo
0650: 62 5d 7d 5d 0a 20 20 69 66 20 7b 24 72 63 7d 20  b]}].  if {$rc} 
0660: 7b 20 0a 20 20 20 20 65 72 72 6f 72 20 22 6f 75  { .    error "ou
0670: 74 20 6f 66 20 6d 65 6d 6f 72 79 22 20 0a 20 20  t of memory" .  
0680: 7d 20 65 6c 73 65 69 66 20 7b 24 3a 3a 72 20 6e  } elseif {$::r n
0690: 65 20 24 3a 3a 64 61 74 61 7d 20 7b 0a 20 20 20  e $::data} {.   
06a0: 20 65 72 72 6f 72 20 22 42 61 64 20 64 61 74 61   error "Bad data
06b0: 20 72 65 61 64 2e 2e 2e 22 0a 20 20 7d 0a 20 20   read...".  }.  
06c0: 73 65 74 20 72 63 20 5b 63 61 74 63 68 20 7b 63  set rc [catch {c
06d0: 6c 6f 73 65 20 24 3a 3a 62 6c 6f 62 7d 5d 0a 20  lose $::blob}]. 
06e0: 20 69 66 20 7b 24 72 63 7d 20 7b 20 0a 20 20 20   if {$rc} { .   
06f0: 20 65 72 72 6f 72 20 22 6f 75 74 20 6f 66 20 6d   error "out of m
0700: 65 6d 6f 72 79 22 20 0a 20 20 7d 0a 7d 0a 0a 64  emory" .  }.}..d
0710: 6f 5f 69 6f 65 72 72 5f 74 65 73 74 20 69 6e 63  o_ioerr_test inc
0720: 72 62 6c 6f 62 5f 65 72 72 2d 34 20 2d 63 6b 73  rblob_err-4 -cks
0730: 75 6d 20 31 20 2d 73 71 6c 70 72 65 70 20 7b 0a  um 1 -sqlprep {.
0740: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 62    CREATE TABLE b
0750: 6c 6f 62 73 28 6b 2c 20 76 20 42 4c 4f 42 29 3b  lobs(k, v BLOB);
0760: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 62  .  INSERT INTO b
0770: 6c 6f 62 73 20 56 41 4c 55 45 53 28 31 2c 20 24  lobs VALUES(1, $
0780: 3a 3a 64 61 74 61 29 3b 0a 7d 20 2d 74 63 6c 62  ::data);.} -tclb
0790: 6f 64 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c  ody {.  set ::bl
07a0: 6f 62 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20  ob [db incrblob 
07b0: 62 6c 6f 62 73 20 76 20 31 5d 0a 20 20 72 65 61  blobs v 1].  rea
07c0: 64 20 24 3a 3a 62 6c 6f 62 0a 7d 0a 0a 64 6f 5f  d $::blob.}..do_
07d0: 69 6f 65 72 72 5f 74 65 73 74 20 69 6e 63 72 62  ioerr_test incrb
07e0: 6c 6f 62 5f 65 72 72 2d 35 20 2d 63 6b 73 75 6d  lob_err-5 -cksum
07f0: 20 31 20 2d 73 71 6c 70 72 65 70 20 7b 0a 20 20   1 -sqlprep {.  
0800: 43 52 45 41 54 45 20 54 41 42 4c 45 20 62 6c 6f  CREATE TABLE blo
0810: 62 73 28 6b 2c 20 76 20 42 4c 4f 42 29 3b 0a 20  bs(k, v BLOB);. 
0820: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 62 6c 6f   INSERT INTO blo
0830: 62 73 20 56 41 4c 55 45 53 28 31 2c 20 7a 65 72  bs VALUES(1, zer
0840: 6f 62 6c 6f 62 28 6c 65 6e 67 74 68 28 43 41 53  oblob(length(CAS
0850: 54 28 24 3a 3a 64 61 74 61 20 41 53 20 42 4c 4f  T($::data AS BLO
0860: 42 29 29 29 29 3b 0a 7d 20 2d 74 63 6c 62 6f 64  B))));.} -tclbod
0870: 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c 6f 62  y {.  set ::blob
0880: 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20 62 6c   [db incrblob bl
0890: 6f 62 73 20 76 20 31 5d 0a 20 20 66 63 6f 6e 66  obs v 1].  fconf
08a0: 69 67 75 72 65 20 24 3a 3a 62 6c 6f 62 20 2d 74  igure $::blob -t
08b0: 72 61 6e 73 6c 61 74 69 6f 6e 20 62 69 6e 61 72  ranslation binar
08c0: 79 0a 20 20 70 75 74 73 20 2d 6e 6f 6e 65 77 6c  y.  puts -nonewl
08d0: 69 6e 65 20 24 3a 3a 62 6c 6f 62 20 24 3a 3a 64  ine $::blob $::d
08e0: 61 74 61 0a 20 20 63 6c 6f 73 65 20 24 3a 3a 62  ata.  close $::b
08f0: 6c 6f 62 0a 7d 0a 0a 64 6f 5f 69 6f 65 72 72 5f  lob.}..do_ioerr_
0900: 74 65 73 74 20 69 6e 63 72 62 6c 6f 62 5f 65 72  test incrblob_er
0910: 72 2d 36 20 2d 63 6b 73 75 6d 20 31 20 2d 73 71  r-6 -cksum 1 -sq
0920: 6c 70 72 65 70 20 7b 0a 20 20 43 52 45 41 54 45  lprep {.  CREATE
0930: 20 54 41 42 4c 45 20 62 6c 6f 62 73 28 6b 2c 20   TABLE blobs(k, 
0940: 76 20 42 4c 4f 42 29 3b 0a 20 20 49 4e 53 45 52  v BLOB);.  INSER
0950: 54 20 49 4e 54 4f 20 62 6c 6f 62 73 20 56 41 4c  T INTO blobs VAL
0960: 55 45 53 28 31 2c 20 24 3a 3a 64 61 74 61 20 7c  UES(1, $::data |
0970: 7c 20 24 3a 3a 64 61 74 61 20 7c 7c 20 24 3a 3a  | $::data || $::
0980: 64 61 74 61 29 3b 0a 7d 20 2d 74 63 6c 62 6f 64  data);.} -tclbod
0990: 79 20 7b 0a 20 20 73 65 74 20 3a 3a 62 6c 6f 62  y {.  set ::blob
09a0: 20 5b 64 62 20 69 6e 63 72 62 6c 6f 62 20 62 6c   [db incrblob bl
09b0: 6f 62 73 20 76 20 31 5d 0a 20 20 66 63 6f 6e 66  obs v 1].  fconf
09c0: 69 67 75 72 65 20 24 3a 3a 62 6c 6f 62 20 2d 74  igure $::blob -t
09d0: 72 61 6e 73 6c 61 74 69 6f 6e 20 62 69 6e 61 72  ranslation binar
09e0: 79 0a 20 20 73 65 65 6b 20 24 3a 3a 62 6c 6f 62  y.  seek $::blob
09f0: 20 2d 32 30 20 65 6e 64 0a 20 20 70 75 74 73 20   -20 end.  puts 
0a00: 2d 6e 6f 6e 65 77 6c 69 6e 65 20 24 3a 3a 62 6c  -nonewline $::bl
0a10: 6f 62 20 22 31 32 33 34 35 36 37 38 39 30 30 39  ob "123456789009
0a20: 38 37 36 35 34 33 32 31 22 0a 20 20 63 6c 6f 73  87654321".  clos
0a30: 65 20 24 3a 3a 62 6c 6f 62 0a 7d 0a 0a 64 6f 5f  e $::blob.}..do_
0a40: 69 6f 65 72 72 5f 74 65 73 74 20 69 6e 63 72 62  ioerr_test incrb
0a50: 6c 6f 62 5f 65 72 72 2d 37 20 2d 63 6b 73 75 6d  lob_err-7 -cksum
0a60: 20 31 20 2d 73 71 6c 70 72 65 70 20 7b 0a 20 20   1 -sqlprep {.  
0a70: 50 52 41 47 4d 41 20 61 75 74 6f 5f 76 61 63 75  PRAGMA auto_vacu
0a80: 75 6d 20 3d 20 31 3b 0a 20 20 43 52 45 41 54 45  um = 1;.  CREATE
0a90: 20 54 41 42 4c 45 20 62 6c 6f 62 73 28 6b 20 49   TABLE blobs(k I
0aa0: 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b  NTEGER PRIMARY K
0ab0: 45 59 2c 20 76 20 42 4c 4f 42 29 3b 0a 20 20 49  EY, v BLOB);.  I
0ac0: 4e 53 45 52 54 20 49 4e 54 4f 20 62 6c 6f 62 73  NSERT INTO blobs
0ad0: 20 56 41 4c 55 45 53 28 31 2c 20 7a 65 72 6f 62   VALUES(1, zerob
0ae0: 6c 6f 62 28 35 30 30 20 2a 20 31 30 32 30 29 29  lob(500 * 1020))
0af0: 3b 0a 7d 20 2d 74 63 6c 62 6f 64 79 20 7b 0a 20  ;.} -tclbody {. 
0b00: 20 23 20 52 65 61 64 20 73 6f 6d 65 20 64 61 74   # Read some dat
0b10: 61 20 66 72 6f 6d 20 74 68 65 20 65 6e 64 20 6f  a from the end o
0b20: 66 20 74 68 65 20 6c 61 72 67 65 20 62 6c 6f 62  f the large blob
0b30: 20 69 6e 73 65 72 74 65 64 20 69 6e 74 6f 20 74   inserted into t
0b40: 61 62 6c 65 20 0a 20 20 23 20 22 62 6c 6f 62 73  able .  # "blobs
0b50: 22 2e 20 54 68 69 73 20 66 6f 72 63 65 73 20 74  ". This forces t
0b60: 68 65 20 49 4f 20 65 72 72 6f 72 20 74 6f 20 6f  he IO error to o
0b70: 63 63 75 72 20 77 68 69 6c 65 20 72 65 61 64 69  ccur while readi
0b80: 6e 67 20 61 20 70 6f 69 6e 74 65 72 0a 20 20 23  ng a pointer.  #
0b90: 20 6d 61 70 20 70 61 67 65 20 66 6f 72 20 74 68   map page for th
0ba0: 65 20 70 75 72 70 6f 73 65 73 20 6f 66 20 73 65  e purposes of se
0bb0: 65 6b 69 6e 67 20 74 6f 20 74 68 65 20 65 6e 64  eking to the end
0bc0: 20 6f 66 20 74 68 65 20 62 6c 6f 62 2e 0a 20 20   of the blob..  
0bd0: 23 0a 20 20 73 71 6c 69 74 65 33 20 64 62 32 20  #.  sqlite3 db2 
0be0: 74 65 73 74 2e 64 62 0a 20 20 73 65 74 20 3a 3a  test.db.  set ::
0bf0: 62 6c 6f 62 20 5b 64 62 32 20 69 6e 63 72 62 6c  blob [db2 incrbl
0c00: 6f 62 20 62 6c 6f 62 73 20 76 20 31 5d 0a 20 20  ob blobs v 1].  
0c10: 73 71 6c 69 74 65 33 5f 62 6c 6f 62 5f 72 65 61  sqlite3_blob_rea
0c20: 64 20 24 3a 3a 62 6c 6f 62 20 5b 65 78 70 72 20  d $::blob [expr 
0c30: 35 30 30 2a 31 30 32 30 2d 32 30 5d 20 32 30 0a  500*1020-20] 20.
0c40: 20 20 63 6c 6f 73 65 20 24 3a 3a 62 6c 6f 62 0a    close $::blob.
0c50: 7d 0a 63 61 74 63 68 20 7b 64 62 32 20 63 6c 6f  }.catch {db2 clo
0c60: 73 65 7d 0a 0a 64 6f 5f 69 6f 65 72 72 5f 74 65  se}..do_ioerr_te
0c70: 73 74 20 69 6e 63 72 62 6c 6f 62 5f 65 72 72 2d  st incrblob_err-
0c80: 38 20 2d 63 6b 73 75 6d 20 31 20 2d 73 71 6c 70  8 -cksum 1 -sqlp
0c90: 72 65 70 20 7b 0a 20 20 50 52 41 47 4d 41 20 61  rep {.  PRAGMA a
0ca0: 75 74 6f 5f 76 61 63 75 75 6d 20 3d 20 31 3b 0a  uto_vacuum = 1;.
0cb0: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 62    CREATE TABLE b
0cc0: 6c 6f 62 73 28 6b 20 49 4e 54 45 47 45 52 20 50  lobs(k INTEGER P
0cd0: 52 49 4d 41 52 59 20 4b 45 59 2c 20 76 20 42 4c  RIMARY KEY, v BL
0ce0: 4f 42 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e  OB);.  INSERT IN
0cf0: 54 4f 20 62 6c 6f 62 73 20 56 41 4c 55 45 53 28  TO blobs VALUES(
0d00: 31 2c 20 7a 65 72 6f 62 6c 6f 62 28 35 30 30 20  1, zeroblob(500 
0d10: 2a 20 31 30 32 30 29 29 3b 0a 7d 20 2d 74 63 6c  * 1020));.} -tcl
0d20: 62 6f 64 79 20 7b 0a 20 20 23 20 52 65 61 64 20  body {.  # Read 
0d30: 73 6f 6d 65 20 64 61 74 61 20 66 72 6f 6d 20 74  some data from t
0d40: 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20 6c 61  he end of the la
0d50: 72 67 65 20 62 6c 6f 62 20 69 6e 73 65 72 74 65  rge blob inserte
0d60: 64 20 69 6e 74 6f 20 74 61 62 6c 65 20 0a 20 20  d into table .  
0d70: 23 20 22 62 6c 6f 62 73 22 2e 20 54 68 69 73 20  # "blobs". This 
0d80: 66 6f 72 63 65 73 20 74 68 65 20 49 4f 20 65 72  forces the IO er
0d90: 72 6f 72 20 74 6f 20 6f 63 63 75 72 20 77 68 69  ror to occur whi
0da0: 6c 65 20 72 65 61 64 69 6e 67 20 61 20 70 6f 69  le reading a poi
0db0: 6e 74 65 72 0a 20 20 23 20 6d 61 70 20 70 61 67  nter.  # map pag
0dc0: 65 20 66 6f 72 20 74 68 65 20 70 75 72 70 6f 73  e for the purpos
0dd0: 65 73 20 6f 66 20 73 65 65 6b 69 6e 67 20 74 6f  es of seeking to
0de0: 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20   the end of the 
0df0: 62 6c 6f 62 2e 0a 20 20 23 0a 20 20 73 71 6c 69  blob..  #.  sqli
0e00: 74 65 33 20 64 62 32 20 74 65 73 74 2e 64 62 0a  te3 db2 test.db.
0e10: 20 20 73 65 74 20 3a 3a 62 6c 6f 62 20 5b 64 62    set ::blob [db
0e20: 32 20 69 6e 63 72 62 6c 6f 62 20 62 6c 6f 62 73  2 incrblob blobs
0e30: 20 76 20 31 5d 0a 20 20 73 71 6c 69 74 65 33 5f   v 1].  sqlite3_
0e40: 62 6c 6f 62 5f 77 72 69 74 65 20 24 3a 3a 62 6c  blob_write $::bl
0e50: 6f 62 20 5b 65 78 70 72 20 35 30 30 2a 31 30 32  ob [expr 500*102
0e60: 30 2d 32 30 5d 20 31 32 33 34 35 36 37 38 39 30  0-20] 1234567890
0e70: 30 39 38 37 36 35 34 33 32 31 0a 20 20 63 6c 6f  0987654321.  clo
0e80: 73 65 20 24 3a 3a 62 6c 6f 62 0a 7d 0a 0a 63 61  se $::blob.}..ca
0e90: 74 63 68 20 7b 64 62 32 20 63 6c 6f 73 65 7d 0a  tch {db2 close}.
0ea0: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a           .finish_test.