/ Hex Artifact Content
Login

Artifact 1d3862c25017cf01ef6d0db682bc7ca87ab43387:


0000: 23 20 32 30 30 37 20 41 75 67 75 73 74 20 32 31  # 2007 August 21
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 23 20 54 68 65 20 66  ******.#.# The f
0170: 6f 63 75 73 20 6f 66 20 74 68 69 73 20 66 69 6c  ocus of this fil
0180: 65 20 69 73 20 74 65 73 74 69 6e 67 20 73 6f 6d  e is testing som
0190: 65 20 73 70 65 63 69 66 69 63 20 63 68 61 72 61  e specific chara
01a0: 63 74 65 72 69 73 74 69 63 73 20 6f 66 20 74 68  cteristics of th
01b0: 65 20 0a 23 20 49 4f 20 74 72 61 66 66 69 63 20  e .# IO traffic 
01c0: 67 65 6e 65 72 61 74 65 64 20 62 79 20 53 51 4c  generated by SQL
01d0: 69 74 65 20 28 6d 61 6b 69 6e 67 20 73 75 72 65  ite (making sure
01e0: 20 53 51 4c 69 74 65 20 69 73 20 6e 6f 74 20 77   SQLite is not w
01f0: 72 69 74 69 6e 67 20 6f 75 74 0a 23 20 6d 6f 72  riting out.# mor
0200: 65 20 64 61 74 61 62 61 73 65 20 70 61 67 65 73  e database pages
0210: 20 74 68 61 6e 20 69 74 20 68 61 73 20 74 6f 2c   than it has to,
0220: 20 73 74 75 66 66 20 6c 69 6b 65 20 74 68 61 74   stuff like that
0230: 29 2e 0a 23 0a 0a 73 65 74 20 74 65 73 74 64 69  )..#..set testdi
0240: 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20  r [file dirname 
0250: 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24  $argv0].source $
0260: 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74  testdir/tester.t
0270: 63 6c 0a 0a 64 62 20 63 6c 6f 73 65 0a 73 71 6c  cl..db close.sql
0280: 69 74 65 33 5f 73 69 6d 75 6c 61 74 65 5f 64 65  ite3_simulate_de
0290: 76 69 63 65 0a 73 71 6c 69 74 65 33 20 64 62 20  vice.sqlite3 db 
02a0: 74 65 73 74 2e 64 62 20 2d 76 66 73 20 64 65 76  test.db -vfs dev
02b0: 73 79 6d 0a 0a 23 20 54 65 73 74 20 73 75 6d 6d  sym..# Test summ
02c0: 61 72 79 3a 0a 23 0a 23 20 69 6f 2d 31 2e 2a 20  ary:.#.# io-1.* 
02d0: 2d 20 20 54 65 73 74 20 74 68 61 74 20 71 75 69  -  Test that qui
02e0: 63 6b 2d 62 61 6c 61 6e 63 65 20 64 6f 65 73 20  ck-balance does 
02f0: 6e 6f 74 20 6a 6f 75 72 6e 61 6c 20 70 61 67 65  not journal page
0300: 73 20 75 6e 6e 65 63 65 73 73 61 72 69 6c 79 2e  s unnecessarily.
0310: 0a 23 0a 23 20 69 6f 2d 32 2e 2a 20 2d 20 20 54  .#.# io-2.* -  T
0320: 65 73 74 20 74 68 65 20 22 61 74 6f 6d 69 63 2d  est the "atomic-
0330: 77 72 69 74 65 20 6f 70 74 69 6d 69 7a 61 74 69  write optimizati
0340: 6f 6e 22 2e 0a 23 0a 23 20 69 6f 2d 33 2e 2a 20  on"..#.# io-3.* 
0350: 2d 20 20 54 65 73 74 20 74 68 65 20 49 4f 20 74  -  Test the IO t
0360: 72 61 66 66 69 63 20 65 6e 68 61 6e 63 65 6d 65  raffic enhanceme
0370: 6e 74 73 20 74 72 69 67 67 65 72 65 64 20 77 68  nts triggered wh
0380: 65 6e 20 74 68 65 20 0a 23 20 20 20 20 20 20 20  en the .#       
0390: 20 20 20 20 49 4f 43 41 50 5f 53 45 51 55 45 4e      IOCAP_SEQUEN
03a0: 54 49 41 4c 20 64 65 76 69 63 65 20 63 61 70 61  TIAL device capa
03b0: 62 69 6c 69 74 79 20 66 6c 61 67 20 69 73 20 73  bility flag is s
03c0: 65 74 20 28 6e 6f 20 0a 23 20 20 20 20 20 20 20  et (no .#       
03d0: 20 20 20 20 66 73 79 6e 63 28 29 20 63 61 6c 6c      fsync() call
03e0: 73 20 6f 6e 20 74 68 65 20 6a 6f 75 72 6e 61 6c  s on the journal
03f0: 20 66 69 6c 65 29 2e 0a 23 0a 23 20 69 6f 2d 34   file)..#.# io-4
0400: 2e 2a 20 2d 20 20 54 65 73 74 20 74 68 65 20 49  .* -  Test the I
0410: 4f 20 74 72 61 66 66 69 63 20 65 6e 68 61 6e 63  O traffic enhanc
0420: 65 6d 65 6e 74 73 20 74 72 69 67 67 65 72 65 64  ements triggered
0430: 20 77 68 65 6e 20 74 68 65 20 0a 23 20 20 20 20   when the .#    
0440: 20 20 20 20 20 20 20 49 4f 43 41 50 5f 53 41 46         IOCAP_SAF
0450: 45 5f 41 50 50 45 4e 44 20 64 65 76 69 63 65 20  E_APPEND device 
0460: 63 61 70 61 62 69 6c 69 74 79 20 66 6c 61 67 20  capability flag 
0470: 69 73 20 73 65 74 20 28 66 65 77 65 72 20 0a 23  is set (fewer .#
0480: 20 20 20 20 20 20 20 20 20 20 20 66 73 79 6e 63             fsync
0490: 28 29 20 63 61 6c 6c 73 20 6f 6e 20 74 68 65 20  () calls on the 
04a0: 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 2c 20 6e 6f  journal file, no
04b0: 20 6e 65 65 64 20 74 6f 20 73 65 74 20 6e 52 65   need to set nRe
04c0: 63 0a 23 20 20 20 20 20 20 20 20 20 20 20 66 69  c.#           fi
04d0: 65 6c 64 20 69 6e 20 74 68 65 20 73 69 6e 67 6c  eld in the singl
04e0: 65 20 6a 6f 75 72 6e 61 6c 20 68 65 61 64 65 72  e journal header
04f0: 29 2e 0a 23 0a 23 20 69 6f 2d 35 2e 2a 20 2d 20  )..#.# io-5.* - 
0500: 20 54 65 73 74 20 74 68 61 74 20 74 68 65 20 64   Test that the d
0510: 65 66 61 75 6c 74 20 70 61 67 65 20 73 69 7a 65  efault page size
0520: 20 69 73 20 73 65 6c 65 63 74 65 64 20 61 6e 64   is selected and
0530: 20 75 73 65 64 20 0a 23 20 20 20 20 20 20 20 20   used .#        
0540: 20 20 20 63 6f 72 72 65 63 74 6c 79 2e 0a 23 20     correctly..# 
0550: 20 20 20 20 20 20 20 20 20 20 0a 0a 73 65 74 20            ..set 
0560: 3a 3a 6e 57 72 69 74 65 20 30 0a 70 72 6f 63 20  ::nWrite 0.proc 
0570: 6e 57 72 69 74 65 20 7b 64 62 7d 20 7b 0a 20 20  nWrite {db} {.  
0580: 73 65 74 20 62 74 20 5b 62 74 72 65 65 5f 66 72  set bt [btree_fr
0590: 6f 6d 5f 64 62 20 24 64 62 5d 0a 20 20 64 62 5f  om_db $db].  db_
05a0: 65 6e 74 65 72 20 24 64 62 0a 20 20 61 72 72 61  enter $db.  arra
05b0: 79 20 73 65 74 20 73 74 61 74 73 20 5b 62 74 72  y set stats [btr
05c0: 65 65 5f 70 61 67 65 72 5f 73 74 61 74 73 20 24  ee_pager_stats $
05d0: 62 74 5d 0a 20 20 64 62 5f 6c 65 61 76 65 20 24  bt].  db_leave $
05e0: 64 62 0a 20 20 73 65 74 20 72 65 73 20 5b 65 78  db.  set res [ex
05f0: 70 72 20 24 73 74 61 74 73 28 77 72 69 74 65 29  pr $stats(write)
0600: 20 2d 20 24 3a 3a 6e 57 72 69 74 65 5d 0a 20 20   - $::nWrite].  
0610: 73 65 74 20 3a 3a 6e 57 72 69 74 65 20 24 73 74  set ::nWrite $st
0620: 61 74 73 28 77 72 69 74 65 29 0a 20 20 73 65 74  ats(write).  set
0630: 20 72 65 73 0a 7d 0a 0a 73 65 74 20 3a 3a 6e 53   res.}..set ::nS
0640: 79 6e 63 20 30 0a 70 72 6f 63 20 6e 53 79 6e 63  ync 0.proc nSync
0650: 20 7b 7d 20 7b 0a 20 20 73 65 74 20 72 65 73 20   {} {.  set res 
0660: 5b 65 78 70 72 20 7b 24 3a 3a 73 71 6c 69 74 65  [expr {$::sqlite
0670: 5f 73 79 6e 63 5f 63 6f 75 6e 74 20 2d 20 24 3a  _sync_count - $:
0680: 3a 6e 53 79 6e 63 7d 5d 0a 20 20 73 65 74 20 3a  :nSync}].  set :
0690: 3a 6e 53 79 6e 63 20 24 3a 3a 73 71 6c 69 74 65  :nSync $::sqlite
06a0: 5f 73 79 6e 63 5f 63 6f 75 6e 74 0a 20 20 73 65  _sync_count.  se
06b0: 74 20 72 65 73 0a 7d 0a 0a 64 6f 5f 74 65 73 74  t res.}..do_test
06c0: 20 69 6f 2d 31 2e 31 20 7b 0a 20 20 65 78 65 63   io-1.1 {.  exec
06d0: 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41  sql {.    PRAGMA
06e0: 20 61 75 74 6f 5f 76 61 63 75 75 6d 20 3d 20 4f   auto_vacuum = O
06f0: 46 46 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 70  FF;.    PRAGMA p
0700: 61 67 65 5f 73 69 7a 65 20 3d 20 31 30 32 34 3b  age_size = 1024;
0710: 0a 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c  .    CREATE TABL
0720: 45 20 61 62 63 28 61 2c 62 29 3b 0a 20 20 7d 0a  E abc(a,b);.  }.
0730: 20 20 6e 57 72 69 74 65 20 64 62 0a 7d 20 7b 32    nWrite db.} {2
0740: 7d 0a 0a 23 20 49 6e 73 65 72 74 20 69 6e 74 6f  }..# Insert into
0750: 20 74 68 65 20 74 61 62 6c 65 20 34 20 72 65 63   the table 4 rec
0760: 6f 72 64 73 20 6f 66 20 61 70 72 6f 78 69 6d 61  ords of aproxima
0770: 74 65 6c 79 20 32 34 30 20 62 79 74 65 73 20 65  tely 240 bytes e
0780: 61 63 68 2e 0a 23 20 54 68 69 73 20 73 68 6f 75  ach..# This shou
0790: 6c 64 20 63 6f 6d 70 6c 65 74 65 6c 79 20 66 69  ld completely fi
07a0: 6c 6c 20 74 68 65 20 72 6f 6f 74 2d 70 61 67 65  ll the root-page
07b0: 20 6f 66 20 74 68 65 20 74 61 62 6c 65 2e 20 45   of the table. E
07c0: 61 63 68 0a 23 20 49 4e 53 45 52 54 20 63 61 75  ach.# INSERT cau
07d0: 73 65 73 20 32 20 64 62 20 70 61 67 65 73 20 74  ses 2 db pages t
07e0: 6f 20 62 65 20 77 72 69 74 74 65 6e 20 2d 20 74  o be written - t
07f0: 68 65 20 72 6f 6f 74 2d 70 61 67 65 20 6f 66 20  he root-page of 
0800: 22 61 62 63 22 0a 23 20 61 6e 64 20 70 61 67 65  "abc".# and page
0810: 20 31 20 28 64 62 20 63 68 61 6e 67 65 2d 63 6f   1 (db change-co
0820: 75 6e 74 65 72 20 70 61 67 65 29 2e 0a 64 6f 5f  unter page)..do_
0830: 74 65 73 74 20 69 6f 2d 31 2e 32 20 7b 0a 20 20  test io-1.2 {.  
0840: 73 65 74 20 72 65 74 20 5b 6c 69 73 74 5d 0a 20  set ret [list]. 
0850: 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52   execsql { INSER
0860: 54 20 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45  T INTO abc VALUE
0870: 53 28 31 2c 72 61 6e 64 73 74 72 28 32 33 30 2c  S(1,randstr(230,
0880: 32 33 30 29 29 3b 20 7d 0a 20 20 6c 61 70 70 65  230)); }.  lappe
0890: 6e 64 20 72 65 74 20 5b 6e 57 72 69 74 65 20 64  nd ret [nWrite d
08a0: 62 5d 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 49  b].  execsql { I
08b0: 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 56  NSERT INTO abc V
08c0: 41 4c 55 45 53 28 32 2c 72 61 6e 64 73 74 72 28  ALUES(2,randstr(
08d0: 32 33 30 2c 32 33 30 29 29 3b 20 7d 0a 20 20 6c  230,230)); }.  l
08e0: 61 70 70 65 6e 64 20 72 65 74 20 5b 6e 57 72 69  append ret [nWri
08f0: 74 65 20 64 62 5d 0a 20 20 65 78 65 63 73 71 6c  te db].  execsql
0900: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61   { INSERT INTO a
0910: 62 63 20 56 41 4c 55 45 53 28 33 2c 72 61 6e 64  bc VALUES(3,rand
0920: 73 74 72 28 32 33 30 2c 32 33 30 29 29 3b 20 7d  str(230,230)); }
0930: 0a 20 20 6c 61 70 70 65 6e 64 20 72 65 74 20 5b  .  lappend ret [
0940: 6e 57 72 69 74 65 20 64 62 5d 0a 20 20 65 78 65  nWrite db].  exe
0950: 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e  csql { INSERT IN
0960: 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28 34 2c  TO abc VALUES(4,
0970: 72 61 6e 64 73 74 72 28 32 33 30 2c 32 33 30 29  randstr(230,230)
0980: 29 3b 20 7d 0a 20 20 6c 61 70 70 65 6e 64 20 72  ); }.  lappend r
0990: 65 74 20 5b 6e 57 72 69 74 65 20 64 62 5d 0a 7d  et [nWrite db].}
09a0: 20 7b 32 20 32 20 32 20 32 7d 0a 0a 23 20 49 6e   {2 2 2 2}..# In
09b0: 73 65 72 74 20 61 6e 6f 74 68 65 72 20 32 34 30  sert another 240
09c0: 20 62 79 74 65 20 72 65 63 6f 72 64 2e 20 54 68   byte record. Th
09d0: 69 73 20 63 61 75 73 65 73 20 74 77 6f 20 6c 65  is causes two le
09e0: 61 66 20 70 61 67 65 73 0a 23 20 74 6f 20 62 65  af pages.# to be
09f0: 20 61 64 64 65 64 20 74 6f 20 74 68 65 20 72 6f   added to the ro
0a00: 6f 74 20 70 61 67 65 20 6f 66 20 61 62 63 2e 20  ot page of abc. 
0a10: 34 20 70 61 67 65 73 20 69 6e 20 74 6f 74 61 6c  4 pages in total
0a20: 0a 23 20 61 72 65 20 77 72 69 74 74 65 6e 20 74  .# are written t
0a30: 6f 20 74 68 65 20 64 62 20 66 69 6c 65 20 2d 20  o the db file - 
0a40: 74 68 65 20 74 77 6f 20 6c 65 61 66 20 70 61 67  the two leaf pag
0a50: 65 73 2c 20 74 68 65 20 72 6f 6f 74 0a 23 20 6f  es, the root.# o
0a60: 66 20 61 62 63 20 61 6e 64 20 74 68 65 20 63 68  f abc and the ch
0a70: 61 6e 67 65 2d 63 6f 75 6e 74 65 72 20 70 61 67  ange-counter pag
0a80: 65 2e 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 31 2e  e..do_test io-1.
0a90: 33 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  3 {.  execsql { 
0aa0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20  INSERT INTO abc 
0ab0: 56 41 4c 55 45 53 28 35 2c 72 61 6e 64 73 74 72  VALUES(5,randstr
0ac0: 28 32 33 30 2c 32 33 30 29 29 3b 20 7d 0a 20 20  (230,230)); }.  
0ad0: 6e 57 72 69 74 65 20 64 62 0a 7d 20 7b 34 7d 0a  nWrite db.} {4}.
0ae0: 0a 23 20 49 6e 73 65 72 74 20 61 6e 6f 74 68 65  .# Insert anothe
0af0: 72 20 33 20 32 34 30 20 62 79 74 65 20 72 65 63  r 3 240 byte rec
0b00: 6f 72 64 73 2e 20 41 66 74 65 72 20 74 68 69 73  ords. After this
0b10: 2c 20 74 68 65 20 74 72 65 65 20 63 6f 6e 73 69  , the tree consi
0b20: 73 74 73 20 6f 66 20 0a 23 20 74 68 65 20 72 6f  sts of .# the ro
0b30: 6f 74 2d 6e 6f 64 65 2c 20 77 68 69 63 68 20 69  ot-node, which i
0b40: 73 20 63 6c 6f 73 65 20 74 6f 20 65 6d 70 74 79  s close to empty
0b50: 2c 20 61 6e 64 20 74 77 6f 20 6c 65 61 66 20 70  , and two leaf p
0b60: 61 67 65 73 2c 20 62 6f 74 68 20 6f 66 20 0a 23  ages, both of .#
0b70: 20 77 68 69 63 68 20 61 72 65 20 66 75 6c 6c 2e   which are full.
0b80: 20 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 31 2e 34   .do_test io-1.4
0b90: 20 7b 0a 20 20 73 65 74 20 72 65 74 20 5b 6c 69   {.  set ret [li
0ba0: 73 74 5d 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  st].  execsql { 
0bb0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20  INSERT INTO abc 
0bc0: 56 41 4c 55 45 53 28 36 2c 72 61 6e 64 73 74 72  VALUES(6,randstr
0bd0: 28 32 33 30 2c 32 33 30 29 29 3b 20 7d 0a 20 20  (230,230)); }.  
0be0: 6c 61 70 70 65 6e 64 20 72 65 74 20 5b 6e 57 72  lappend ret [nWr
0bf0: 69 74 65 20 64 62 5d 0a 20 20 65 78 65 63 73 71  ite db].  execsq
0c00: 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  l { INSERT INTO 
0c10: 61 62 63 20 56 41 4c 55 45 53 28 37 2c 72 61 6e  abc VALUES(7,ran
0c20: 64 73 74 72 28 32 33 30 2c 32 33 30 29 29 3b 20  dstr(230,230)); 
0c30: 7d 0a 20 20 6c 61 70 70 65 6e 64 20 72 65 74 20  }.  lappend ret 
0c40: 5b 6e 57 72 69 74 65 20 64 62 5d 0a 20 20 65 78  [nWrite db].  ex
0c50: 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49  ecsql { INSERT I
0c60: 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28 38  NTO abc VALUES(8
0c70: 2c 72 61 6e 64 73 74 72 28 32 33 30 2c 32 33 30  ,randstr(230,230
0c80: 29 29 3b 20 7d 0a 20 20 6c 61 70 70 65 6e 64 20  )); }.  lappend 
0c90: 72 65 74 20 5b 6e 57 72 69 74 65 20 64 62 5d 0a  ret [nWrite db].
0ca0: 7d 20 7b 32 20 32 20 32 7d 0a 0a 23 20 54 68 69  } {2 2 2}..# Thi
0cb0: 73 20 69 6e 73 65 72 74 20 73 68 6f 75 6c 64 20  s insert should 
0cc0: 75 73 65 20 74 68 65 20 71 75 69 63 6b 2d 62 61  use the quick-ba
0cd0: 6c 61 6e 63 65 20 74 72 69 63 6b 20 74 6f 20 61  lance trick to a
0ce0: 64 64 20 61 20 74 68 69 72 64 20 6c 65 61 66 0a  dd a third leaf.
0cf0: 23 20 74 6f 20 74 68 65 20 62 2d 74 72 65 65 20  # to the b-tree 
0d00: 75 73 65 64 20 74 6f 20 73 74 6f 72 65 20 74 61  used to store ta
0d10: 62 6c 65 20 61 62 63 2e 20 49 74 20 73 68 6f 75  ble abc. It shou
0d20: 6c 64 20 6f 6e 6c 79 20 62 65 20 6e 65 63 65 73  ld only be neces
0d30: 73 61 72 79 20 74 6f 0a 23 20 77 72 69 74 65 20  sary to.# write 
0d40: 74 6f 20 33 20 70 61 67 65 73 20 74 6f 20 64 6f  to 3 pages to do
0d50: 20 74 68 69 73 3a 20 74 68 65 20 63 68 61 6e 67   this: the chang
0d60: 65 2d 63 6f 75 6e 74 65 72 2c 20 74 68 65 20 72  e-counter, the r
0d70: 6f 6f 74 2d 70 61 67 65 20 61 6e 64 0a 23 20 74  oot-page and.# t
0d80: 68 65 20 6e 65 77 20 6c 65 61 66 20 70 61 67 65  he new leaf page
0d90: 2e 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 31 2e 35  ..do_test io-1.5
0da0: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 49   {.  execsql { I
0db0: 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 56  NSERT INTO abc V
0dc0: 41 4c 55 45 53 28 39 2c 72 61 6e 64 73 74 72 28  ALUES(9,randstr(
0dd0: 32 33 30 2c 32 33 30 29 29 3b 20 7d 0a 20 20 6e  230,230)); }.  n
0de0: 57 72 69 74 65 20 64 62 0a 7d 20 7b 33 7d 0a 0a  Write db.} {3}..
0df0: 69 66 63 61 70 61 62 6c 65 20 61 74 6f 6d 69 63  ifcapable atomic
0e00: 77 72 69 74 65 20 7b 0a 0a 23 2d 2d 2d 2d 2d 2d  write {..#------
0e10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0e50: 0a 23 20 54 65 73 74 20 63 61 73 65 73 20 69 6f  .# Test cases io
0e60: 2d 32 2e 2a 20 74 65 73 74 20 74 68 65 20 61 74  -2.* test the at
0e70: 6f 6d 69 63 2d 77 72 69 74 65 20 6f 70 74 69 6d  omic-write optim
0e80: 69 7a 61 74 69 6f 6e 2e 0a 23 0a 64 6f 5f 74 65  ization..#.do_te
0e90: 73 74 20 69 6f 2d 32 2e 31 20 7b 0a 20 20 65 78  st io-2.1 {.  ex
0ea0: 65 63 73 71 6c 20 7b 20 44 45 4c 45 54 45 20 46  ecsql { DELETE F
0eb0: 52 4f 4d 20 61 62 63 3b 20 56 41 43 55 55 4d 3b  ROM abc; VACUUM;
0ec0: 20 7d 0a 7d 20 7b 7d 0a 0a 23 20 43 6c 65 61 72   }.} {}..# Clear
0ed0: 20 74 68 65 20 77 72 69 74 65 20 61 6e 64 20 73   the write and s
0ee0: 79 6e 63 20 63 6f 75 6e 74 73 2e 0a 6e 57 72 69  ync counts..nWri
0ef0: 74 65 20 64 62 20 3b 20 6e 53 79 6e 63 0a 0a 23  te db ; nSync..#
0f00: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 49   The following I
0f10: 4e 53 45 52 54 20 75 70 64 61 74 65 73 20 32 20  NSERT updates 2 
0f20: 70 61 67 65 73 20 61 6e 64 20 72 65 71 75 69 72  pages and requir
0f30: 65 73 20 34 20 63 61 6c 6c 73 20 74 6f 20 66 73  es 4 calls to fs
0f40: 79 6e 63 28 29 3a 0a 23 0a 23 20 20 20 31 29 20  ync():.#.#   1) 
0f50: 54 68 65 20 64 69 72 65 63 74 6f 72 79 20 69 6e  The directory in
0f60: 20 77 68 69 63 68 20 74 68 65 20 6a 6f 75 72 6e   which the journ
0f70: 61 6c 20 66 69 6c 65 20 69 73 20 63 72 65 61 74  al file is creat
0f80: 65 64 2c 0a 23 20 20 20 32 29 20 54 68 65 20 6a  ed,.#   2) The j
0f90: 6f 75 72 6e 61 6c 20 66 69 6c 65 20 28 74 6f 20  ournal file (to 
0fa0: 73 79 6e 63 20 74 68 65 20 70 61 67 65 20 64 61  sync the page da
0fb0: 74 61 29 2c 0a 23 20 20 20 33 29 20 54 68 65 20  ta),.#   3) The 
0fc0: 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20 28 74 6f  journal file (to
0fd0: 20 73 79 6e 63 20 74 68 65 20 6a 6f 75 72 6e 61   sync the journa
0fe0: 6c 20 66 69 6c 65 20 68 65 61 64 65 72 29 2c 0a  l file header),.
0ff0: 23 20 20 20 34 29 20 54 68 65 20 64 61 74 61 62  #   4) The datab
1000: 61 73 65 20 66 69 6c 65 2e 0a 23 0a 64 6f 5f 74  ase file..#.do_t
1010: 65 73 74 20 69 6f 2d 32 2e 32 20 7b 0a 20 20 65  est io-2.2 {.  e
1020: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
1030: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
1040: 31 2c 20 32 29 20 7d 0a 20 20 6c 69 73 74 20 5b  1, 2) }.  list [
1050: 6e 57 72 69 74 65 20 64 62 5d 20 5b 6e 53 79 6e  nWrite db] [nSyn
1060: 63 5d 0a 7d 20 7b 32 20 34 7d 0a 0a 23 20 53 65  c].} {2 4}..# Se
1070: 74 20 74 68 65 20 64 65 76 69 63 65 2d 63 68 61  t the device-cha
1080: 72 61 63 74 65 72 69 73 74 69 63 20 6d 61 73 6b  racteristic mask
1090: 20 74 6f 20 69 6e 63 6c 75 64 65 20 74 68 65 20   to include the 
10a0: 53 51 4c 49 54 45 5f 49 4f 43 41 50 5f 41 54 4f  SQLITE_IOCAP_ATO
10b0: 4d 49 43 2c 0a 23 20 74 68 65 6e 20 64 6f 20 61  MIC,.# then do a
10c0: 6e 6f 74 68 65 72 20 49 4e 53 45 52 54 20 73 69  nother INSERT si
10d0: 6d 69 6c 61 72 20 74 6f 20 74 68 65 20 6f 6e 65  milar to the one
10e0: 20 69 6e 20 69 6f 2d 32 2e 32 2e 20 54 68 69 73   in io-2.2. This
10f0: 20 73 68 6f 75 6c 64 0a 23 20 6f 6e 6c 79 20 77   should.# only w
1100: 72 69 74 65 20 31 20 70 61 67 65 20 61 6e 64 20  rite 1 page and 
1110: 72 65 71 75 69 72 65 20 61 20 73 69 6e 67 6c 65  require a single
1120: 20 66 73 79 6e 63 28 29 2e 0a 23 20 0a 23 20 54   fsync()..# .# T
1130: 68 65 20 73 69 6e 67 6c 65 20 66 73 79 6e 63 28  he single fsync(
1140: 29 20 69 73 20 74 68 65 20 64 61 74 61 62 61 73  ) is the databas
1150: 65 20 66 69 6c 65 2e 20 4f 6e 6c 79 20 6f 6e 65  e file. Only one
1160: 20 70 61 67 65 20 69 73 20 72 65 70 6f 72 74 65   page is reporte
1170: 64 20 61 73 0a 23 20 77 72 69 74 74 65 6e 20 62  d as.# written b
1180: 65 63 61 75 73 65 20 70 61 67 65 20 31 20 2d 20  ecause page 1 - 
1190: 74 68 65 20 63 68 61 6e 67 65 2d 63 6f 75 6e 74  the change-count
11a0: 65 72 20 70 61 67 65 20 2d 20 69 73 20 77 72 69  er page - is wri
11b0: 74 74 65 6e 20 75 73 69 6e 67 0a 23 20 61 6e 20  tten using.# an 
11c0: 6f 75 74 2d 6f 66 2d 62 61 6e 64 20 6d 65 74 68  out-of-band meth
11d0: 6f 64 20 74 68 61 74 20 62 79 70 61 73 73 65 73  od that bypasses
11e0: 20 74 68 65 20 77 72 69 74 65 20 63 6f 75 6e 74   the write count
11f0: 65 72 2e 0a 23 0a 23 20 55 50 44 41 54 45 3a 20  er..#.# UPDATE: 
1200: 41 73 20 6f 66 20 5b 30 35 66 39 38 64 34 65 65  As of [05f98d4ee
1210: 63 5d 20 28 61 64 64 69 6e 67 20 53 51 4c 49 54  c] (adding SQLIT
1220: 45 5f 44 42 53 54 41 54 55 53 5f 43 41 43 48 45  E_DBSTATUS_CACHE
1230: 5f 57 52 49 54 45 29 2c 20 74 68 65 0a 23 20 73  _WRITE), the.# s
1240: 65 63 6f 6e 64 20 77 72 69 74 65 20 69 73 20 61  econd write is a
1250: 6c 73 6f 20 63 6f 75 6e 74 65 64 2e 20 53 6f 20  lso counted. So 
1260: 74 68 69 73 20 6e 6f 77 20 72 65 70 6f 72 74 73  this now reports
1270: 20 74 77 6f 20 77 72 69 74 65 73 20 61 6e 64 20   two writes and 
1280: 61 0a 23 20 73 69 6e 67 6c 65 20 66 73 79 6e 63  a.# single fsync
1290: 2e 0a 23 0a 73 71 6c 69 74 65 33 5f 73 69 6d 75  ..#.sqlite3_simu
12a0: 6c 61 74 65 5f 64 65 76 69 63 65 20 2d 63 68 61  late_device -cha
12b0: 72 20 61 74 6f 6d 69 63 0a 64 6f 5f 74 65 73 74  r atomic.do_test
12c0: 20 69 6f 2d 32 2e 33 20 7b 0a 20 20 65 78 65 63   io-2.3 {.  exec
12d0: 73 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54  sql { INSERT INT
12e0: 4f 20 61 62 63 20 56 41 4c 55 45 53 28 33 2c 20  O abc VALUES(3, 
12f0: 34 29 20 7d 0a 20 20 6c 69 73 74 20 5b 6e 57 72  4) }.  list [nWr
1300: 69 74 65 20 64 62 5d 20 5b 6e 53 79 6e 63 5d 0a  ite db] [nSync].
1310: 7d 20 7b 32 20 31 7d 0a 0a 23 20 54 65 73 74 20  } {2 1}..# Test 
1320: 74 68 61 74 20 74 68 65 20 6a 6f 75 72 6e 61 6c  that the journal
1330: 20 66 69 6c 65 20 69 73 20 6e 6f 74 20 63 72 65   file is not cre
1340: 61 74 65 64 20 61 6e 64 20 74 68 65 20 63 68 61  ated and the cha
1350: 6e 67 65 2d 63 6f 75 6e 74 65 72 20 69 73 0a 23  nge-counter is.#
1360: 20 75 70 64 61 74 65 64 20 77 68 65 6e 20 74 68   updated when th
1370: 65 20 61 74 6f 6d 69 63 2d 77 72 69 74 65 20 6f  e atomic-write o
1380: 70 74 69 6d 69 7a 61 74 69 6f 6e 20 69 73 20 75  ptimization is u
1390: 73 65 64 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 69  sed..#.do_test i
13a0: 6f 2d 32 2e 34 2e 31 20 7b 0a 20 20 65 78 65 63  o-2.4.1 {.  exec
13b0: 73 71 6c 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b  sql {.    BEGIN;
13c0: 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  .    INSERT INTO
13d0: 20 61 62 63 20 56 41 4c 55 45 53 28 35 2c 20 36   abc VALUES(5, 6
13e0: 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33  );.  }.  sqlite3
13f0: 20 64 62 32 20 74 65 73 74 2e 64 62 20 2d 76 66   db2 test.db -vf
1400: 73 20 64 65 76 73 79 6d 0a 20 20 65 78 65 63 73  s devsym.  execs
1410: 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  ql { SELECT * FR
1420: 4f 4d 20 61 62 63 20 7d 20 64 62 32 0a 7d 20 7b  OM abc } db2.} {
1430: 31 20 32 20 33 20 34 7d 0a 64 6f 5f 74 65 73 74  1 2 3 4}.do_test
1440: 20 69 6f 2d 32 2e 34 2e 32 20 7b 0a 20 20 66 69   io-2.4.2 {.  fi
1450: 6c 65 20 65 78 69 73 74 73 20 74 65 73 74 2e 64  le exists test.d
1460: 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20 7b 30 7d 0a  b-journal.} {0}.
1470: 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 34 2e 33  do_test io-2.4.3
1480: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 43   {.  execsql { C
1490: 4f 4d 4d 49 54 20 7d 0a 20 20 65 78 65 63 73 71  OMMIT }.  execsq
14a0: 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  l { SELECT * FRO
14b0: 4d 20 61 62 63 20 7d 20 64 62 32 0a 7d 20 7b 31  M abc } db2.} {1
14c0: 20 32 20 33 20 34 20 35 20 36 7d 0a 64 62 32 20   2 3 4 5 6}.db2 
14d0: 63 6c 6f 73 65 0a 0a 23 20 54 65 73 74 20 74 68  close..# Test th
14e0: 61 74 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66  at the journal f
14f0: 69 6c 65 20 69 73 20 63 72 65 61 74 65 64 20 61  ile is created a
1500: 6e 64 20 73 79 6e 63 28 29 64 20 69 66 20 74 68  nd sync()d if th
1510: 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 0a 23 20  e transaction.# 
1520: 6d 6f 64 69 66 69 65 73 20 6d 6f 72 65 20 74 68  modifies more th
1530: 61 6e 20 6f 6e 65 20 64 61 74 61 62 61 73 65 20  an one database 
1540: 70 61 67 65 2c 20 65 76 65 6e 20 69 66 20 74 68  page, even if th
1550: 65 20 49 4f 43 41 50 5f 41 54 4f 4d 49 43 20 66  e IOCAP_ATOMIC f
1560: 6c 61 67 0a 23 20 69 73 20 73 65 74 2e 0a 23 0a  lag.# is set..#.
1570: 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 35 2e 31  do_test io-2.5.1
1580: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 43   {.  execsql { C
1590: 52 45 41 54 45 20 54 41 42 4c 45 20 64 65 66 28  REATE TABLE def(
15a0: 64 2c 20 65 29 20 7d 0a 20 20 6e 57 72 69 74 65  d, e) }.  nWrite
15b0: 20 64 62 20 3b 20 6e 53 79 6e 63 0a 20 20 65 78   db ; nSync.  ex
15c0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 42 45 47 49  ecsql {.    BEGI
15d0: 4e 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  N;.    INSERT IN
15e0: 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28 37 2c  TO abc VALUES(7,
15f0: 20 38 29 3b 0a 20 20 7d 0a 20 20 66 69 6c 65 20   8);.  }.  file 
1600: 65 78 69 73 74 73 20 74 65 73 74 2e 64 62 2d 6a  exists test.db-j
1610: 6f 75 72 6e 61 6c 0a 7d 20 7b 30 7d 0a 64 6f 5f  ournal.} {0}.do_
1620: 74 65 73 74 20 69 6f 2d 32 2e 35 2e 32 20 7b 0a  test io-2.5.2 {.
1630: 20 20 65 78 65 63 73 71 6c 20 7b 20 49 4e 53 45    execsql { INSE
1640: 52 54 20 49 4e 54 4f 20 64 65 66 20 56 41 4c 55  RT INTO def VALU
1650: 45 53 28 27 61 27 2c 20 27 62 27 29 3b 20 7d 0a  ES('a', 'b'); }.
1660: 20 20 66 69 6c 65 20 65 78 69 73 74 73 20 74 65    file exists te
1670: 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20  st.db-journal.} 
1680: 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32  {1}.do_test io-2
1690: 2e 35 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  .5.3 {.  execsql
16a0: 20 7b 20 43 4f 4d 4d 49 54 20 7d 0a 20 20 6c 69   { COMMIT }.  li
16b0: 73 74 20 5b 6e 57 72 69 74 65 20 64 62 5d 20 5b  st [nWrite db] [
16c0: 6e 53 79 6e 63 5d 0a 7d 20 7b 33 20 34 7d 0a 0a  nSync].} {3 4}..
16d0: 23 20 54 65 73 74 20 74 68 61 74 20 74 68 65 20  # Test that the 
16e0: 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20 69 73 20  journal file is 
16f0: 63 72 65 61 74 65 64 20 61 6e 64 20 73 79 6e 63  created and sync
1700: 28 29 64 20 69 66 20 74 68 65 20 74 72 61 6e 73  ()d if the trans
1710: 61 63 74 69 6f 6e 0a 23 20 6d 6f 64 69 66 69 65  action.# modifie
1720: 73 20 61 20 73 69 6e 67 6c 65 20 64 61 74 61 62  s a single datab
1730: 61 73 65 20 70 61 67 65 20 61 6e 64 20 61 6c 73  ase page and als
1740: 6f 20 61 70 70 65 6e 64 73 20 61 20 70 61 67 65  o appends a page
1750: 20 74 6f 20 74 68 65 20 66 69 6c 65 2e 0a 23 20   to the file..# 
1760: 49 6e 74 65 72 6e 61 6c 6c 79 2c 20 74 68 69 73  Internally, this
1770: 20 63 61 73 65 20 69 73 20 68 61 6e 64 6c 65 64   case is handled
1780: 20 64 69 66 66 65 72 65 6e 74 6c 79 20 74 6f 20   differently to 
1790: 74 68 65 20 6f 6e 65 20 61 62 6f 76 65 2e 20 54  the one above. T
17a0: 68 65 0a 23 20 6a 6f 75 72 6e 61 6c 20 66 69 6c  he.# journal fil
17b0: 65 20 69 73 20 6e 6f 74 20 61 63 74 75 61 6c 6c  e is not actuall
17c0: 79 20 63 72 65 61 74 65 64 20 75 6e 74 69 6c 20  y created until 
17d0: 74 68 65 20 27 43 4f 4d 4d 49 54 27 20 73 74 61  the 'COMMIT' sta
17e0: 74 65 6d 65 6e 74 0a 23 20 69 73 20 65 78 65 63  tement.# is exec
17f0: 75 74 65 64 2e 0a 23 0a 23 20 43 68 61 6e 67 65  uted..#.# Change
1800: 64 20 32 30 31 30 2d 30 33 2d 32 37 3a 20 20 54  d 2010-03-27:  T
1810: 68 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20 64  he size of the d
1820: 61 74 61 62 61 73 65 20 69 73 20 6e 6f 77 20 73  atabase is now s
1830: 74 6f 72 65 64 20 69 6e 20 0a 23 20 62 79 74 65  tored in .# byte
1840: 73 20 32 38 2e 2e 33 31 20 61 6e 64 20 73 6f 20  s 28..31 and so 
1850: 77 68 65 6e 20 61 20 70 61 67 65 20 69 73 20 61  when a page is a
1860: 64 64 65 64 20 74 6f 20 74 68 65 20 64 61 74 61  dded to the data
1870: 62 61 73 65 2c 20 70 61 67 65 20 31 0a 23 20 69  base, page 1.# i
1880: 73 20 69 6d 6d 65 64 69 61 74 65 6c 79 20 6d 6f  s immediately mo
1890: 64 69 66 69 65 64 20 61 6e 64 20 74 68 65 20 6a  dified and the j
18a0: 6f 75 72 6e 61 6c 20 66 69 6c 65 20 69 6d 6d 65  ournal file imme
18b0: 64 69 61 74 65 6c 79 20 63 6f 6d 65 73 20 69 6e  diately comes in
18c0: 74 6f 0a 23 20 65 78 69 73 74 65 6e 63 65 2e 20  to.# existence. 
18d0: 20 54 6f 20 66 69 78 20 74 68 69 73 20 74 65 73   To fix this tes
18e0: 74 2c 20 74 68 65 20 42 45 47 49 4e 20 69 73 20  t, the BEGIN is 
18f0: 63 68 61 6e 67 65 64 20 69 6e 74 6f 20 61 20 61  changed into a a
1900: 0a 23 20 42 45 47 49 4e 20 49 4d 4d 45 44 49 41  .# BEGIN IMMEDIA
1910: 54 45 20 61 6e 64 20 74 68 65 20 49 4e 53 45 52  TE and the INSER
1920: 54 20 69 73 20 6f 6d 69 74 74 65 64 2e 0a 23 0a  T is omitted..#.
1930: 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 36 2e 31  do_test io-2.6.1
1940: 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20   {.  execsql {. 
1950: 20 20 20 42 45 47 49 4e 20 49 4d 4d 45 44 49 41     BEGIN IMMEDIA
1960: 54 45 3b 0a 20 20 20 20 2d 2d 20 49 4e 53 45 52  TE;.    -- INSER
1970: 54 20 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45  T INTO abc VALUE
1980: 53 28 39 2c 20 72 61 6e 64 73 74 72 28 31 30 30  S(9, randstr(100
1990: 30 2c 31 30 30 30 29 29 3b 0a 20 20 7d 0a 20 20  0,1000));.  }.  
19a0: 66 69 6c 65 20 65 78 69 73 74 73 20 74 65 73 74  file exists test
19b0: 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20 7b 30  .db-journal.} {0
19c0: 7d 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 36  }.do_test io-2.6
19d0: 2e 32 20 7b 0a 20 20 23 20 43 72 65 61 74 65 20  .2 {.  # Create 
19e0: 61 20 66 69 6c 65 20 61 74 20 22 74 65 73 74 2e  a file at "test.
19f0: 64 62 2d 6a 6f 75 72 6e 61 6c 22 2e 20 54 68 69  db-journal". Thi
1a00: 73 20 77 69 6c 6c 20 70 72 65 76 65 6e 74 20 53  s will prevent S
1a10: 51 4c 69 74 65 20 66 72 6f 6d 0a 20 20 23 20 6f  QLite from.  # o
1a20: 70 65 6e 69 6e 67 20 74 68 65 20 6a 6f 75 72 6e  pening the journ
1a30: 61 6c 20 66 6f 72 20 65 78 63 6c 75 73 69 76 65  al for exclusive
1a40: 20 61 63 63 65 73 73 2e 20 41 73 20 61 20 72 65   access. As a re
1a50: 73 75 6c 74 2c 20 74 68 65 20 43 4f 4d 4d 49 54  sult, the COMMIT
1a60: 0a 20 20 23 20 73 68 6f 75 6c 64 20 66 61 69 6c  .  # should fail
1a70: 20 77 69 74 68 20 53 51 4c 49 54 45 5f 43 41 4e   with SQLITE_CAN
1a80: 54 4f 50 45 4e 20 61 6e 64 20 74 68 65 20 74 72  TOPEN and the tr
1a90: 61 6e 73 61 63 74 69 6f 6e 20 72 6f 6c 6c 65 64  ansaction rolled
1aa0: 20 62 61 63 6b 2e 0a 20 20 23 0a 20 20 66 69 6c   back..  #.  fil
1ab0: 65 20 6d 6b 64 69 72 20 74 65 73 74 2e 64 62 2d  e mkdir test.db-
1ac0: 6a 6f 75 72 6e 61 6c 0a 20 20 63 61 74 63 68 73  journal.  catchs
1ad0: 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54 20  ql {.    INSERT 
1ae0: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
1af0: 39 2c 20 72 61 6e 64 73 74 72 28 31 30 30 30 2c  9, randstr(1000,
1b00: 31 30 30 30 29 29 3b 0a 20 20 20 20 43 4f 4d 4d  1000));.    COMM
1b10: 49 54 0a 20 20 7d 0a 7d 20 7b 31 20 7b 75 6e 61  IT.  }.} {1 {una
1b20: 62 6c 65 20 74 6f 20 6f 70 65 6e 20 64 61 74 61  ble to open data
1b30: 62 61 73 65 20 66 69 6c 65 7d 7d 0a 64 6f 5f 74  base file}}.do_t
1b40: 65 73 74 20 69 6f 2d 32 2e 36 2e 33 20 7b 0a 20  est io-2.6.3 {. 
1b50: 20 66 6f 72 63 65 64 65 6c 65 74 65 20 74 65 73   forcedelete tes
1b60: 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 20 20 63  t.db-journal.  c
1b70: 61 74 63 68 73 71 6c 20 7b 20 43 4f 4d 4d 49 54  atchsql { COMMIT
1b80: 20 7d 0a 7d 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74   }.} {0 {}}.do_t
1b90: 65 73 74 20 69 6f 2d 32 2e 36 2e 34 20 7b 0a 20  est io-2.6.4 {. 
1ba0: 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43   execsql { SELEC
1bb0: 54 20 2a 20 46 52 4f 4d 20 61 62 63 20 7d 0a 7d  T * FROM abc }.}
1bc0: 20 7b 31 20 32 20 33 20 34 20 35 20 36 20 37 20   {1 2 3 4 5 6 7 
1bd0: 38 7d 0a 0a 23 20 54 65 73 74 20 74 68 61 74 20  8}..# Test that 
1be0: 69 66 20 74 68 65 20 64 61 74 61 62 61 73 65 20  if the database 
1bf0: 6d 6f 64 69 66 69 63 61 74 69 6f 6e 20 69 73 20  modification is 
1c00: 70 61 72 74 20 6f 66 20 6d 75 6c 74 69 2d 66 69  part of multi-fi
1c10: 6c 65 20 63 6f 6d 6d 69 74 2c 0a 23 20 74 68 65  le commit,.# the
1c20: 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20 69 73   journal file is
1c30: 20 61 6c 77 61 79 73 20 63 72 65 61 74 65 64 2e   always created.
1c40: 20 49 6e 20 74 68 69 73 20 63 61 73 65 2c 20 74   In this case, t
1c50: 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 0a  he journal file.
1c60: 23 20 69 73 20 63 72 65 61 74 65 64 20 64 75 72  # is created dur
1c70: 69 6e 67 20 65 78 65 63 75 74 69 6f 6e 20 6f 66  ing execution of
1c80: 20 74 68 65 20 43 4f 4d 4d 49 54 20 73 74 61 74   the COMMIT stat
1c90: 65 6d 65 6e 74 2c 20 73 6f 20 77 65 20 68 61 76  ement, so we hav
1ca0: 65 20 74 6f 0a 23 20 75 73 65 20 74 68 65 20 73  e to.# use the s
1cb0: 61 6d 65 20 74 65 63 68 6e 69 71 75 65 20 74 6f  ame technique to
1cc0: 20 63 68 65 63 6b 20 74 68 61 74 20 69 74 20 69   check that it i
1cd0: 73 20 63 72 65 61 74 65 64 20 61 73 20 69 6e 20  s created as in 
1ce0: 74 68 65 20 61 62 6f 76 65 20 0a 23 20 62 6c 6f  the above .# blo
1cf0: 63 6b 2e 0a 66 6f 72 63 65 64 65 6c 65 74 65 20  ck..forcedelete 
1d00: 74 65 73 74 32 2e 64 62 20 74 65 73 74 32 2e 64  test2.db test2.d
1d10: 62 2d 6a 6f 75 72 6e 61 6c 0a 69 66 63 61 70 61  b-journal.ifcapa
1d20: 62 6c 65 20 61 74 74 61 63 68 20 7b 0a 20 20 64  ble attach {.  d
1d30: 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 37 2e 31 20  o_test io-2.7.1 
1d40: 7b 0a 20 20 20 20 65 78 65 63 73 71 6c 20 7b 0a  {.    execsql {.
1d50: 20 20 20 20 20 20 41 54 54 41 43 48 20 27 74 65        ATTACH 'te
1d60: 73 74 32 2e 64 62 27 20 41 53 20 61 75 78 3b 0a  st2.db' AS aux;.
1d70: 20 20 20 20 20 20 50 52 41 47 4d 41 20 61 75 78        PRAGMA aux
1d80: 2e 70 61 67 65 5f 73 69 7a 65 20 3d 20 31 30 32  .page_size = 102
1d90: 34 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  4;.      CREATE 
1da0: 54 41 42 4c 45 20 61 75 78 2e 61 62 63 32 28 61  TABLE aux.abc2(a
1db0: 2c 20 62 29 3b 0a 20 20 20 20 20 20 42 45 47 49  , b);.      BEGI
1dc0: 4e 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20  N;.      INSERT 
1dd0: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
1de0: 39 2c 20 31 30 29 3b 0a 20 20 20 20 7d 0a 20 20  9, 10);.    }.  
1df0: 20 20 66 69 6c 65 20 65 78 69 73 74 73 20 74 65    file exists te
1e00: 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 20 20  st.db-journal.  
1e10: 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20  } {0}.  do_test 
1e20: 69 6f 2d 32 2e 37 2e 32 20 7b 0a 20 20 20 20 65  io-2.7.2 {.    e
1e30: 78 65 63 73 71 6c 20 7b 20 49 4e 53 45 52 54 20  xecsql { INSERT 
1e40: 49 4e 54 4f 20 61 62 63 32 20 53 45 4c 45 43 54  INTO abc2 SELECT
1e50: 20 2a 20 46 52 4f 4d 20 61 62 63 20 7d 0a 20 20   * FROM abc }.  
1e60: 20 20 66 69 6c 65 20 65 78 69 73 74 73 20 74 65    file exists te
1e70: 73 74 32 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 20  st2.db-journal. 
1e80: 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65 73 74   } {0}.  do_test
1e90: 20 69 6f 2d 32 2e 37 2e 33 20 7b 0a 20 20 20 20   io-2.7.3 {.    
1ea0: 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45 43 54  execsql { SELECT
1eb0: 20 2a 20 46 52 4f 4d 20 61 62 63 20 55 4e 49 4f   * FROM abc UNIO
1ec0: 4e 20 41 4c 4c 20 53 45 4c 45 43 54 20 2a 20 46  N ALL SELECT * F
1ed0: 52 4f 4d 20 61 62 63 32 20 7d 0a 20 20 7d 20 7b  ROM abc2 }.  } {
1ee0: 31 20 32 20 33 20 34 20 35 20 36 20 37 20 38 20  1 2 3 4 5 6 7 8 
1ef0: 39 20 31 30 20 31 20 32 20 33 20 34 20 35 20 36  9 10 1 2 3 4 5 6
1f00: 20 37 20 38 20 39 20 31 30 7d 0a 20 20 64 6f 5f   7 8 9 10}.  do_
1f10: 74 65 73 74 20 69 6f 2d 32 2e 37 2e 34 20 7b 0a  test io-2.7.4 {.
1f20: 20 20 20 20 66 69 6c 65 20 6d 6b 64 69 72 20 74      file mkdir t
1f30: 65 73 74 32 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a  est2.db-journal.
1f40: 20 20 20 20 63 61 74 63 68 73 71 6c 20 7b 20 43      catchsql { C
1f50: 4f 4d 4d 49 54 20 7d 0a 20 20 7d 20 7b 31 20 7b  OMMIT }.  } {1 {
1f60: 75 6e 61 62 6c 65 20 74 6f 20 6f 70 65 6e 20 64  unable to open d
1f70: 61 74 61 62 61 73 65 20 66 69 6c 65 7d 7d 0a 20  atabase file}}. 
1f80: 20 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 37 2e   do_test io-2.7.
1f90: 35 20 7b 0a 20 20 20 20 66 6f 72 63 65 64 65 6c  5 {.    forcedel
1fa0: 65 74 65 20 74 65 73 74 32 2e 64 62 2d 6a 6f 75  ete test2.db-jou
1fb0: 72 6e 61 6c 0a 20 20 20 20 63 61 74 63 68 73 71  rnal.    catchsq
1fc0: 6c 20 7b 20 43 4f 4d 4d 49 54 20 7d 0a 20 20 7d  l { COMMIT }.  }
1fd0: 20 7b 31 20 7b 63 61 6e 6e 6f 74 20 63 6f 6d 6d   {1 {cannot comm
1fe0: 69 74 20 2d 20 6e 6f 20 74 72 61 6e 73 61 63 74  it - no transact
1ff0: 69 6f 6e 20 69 73 20 61 63 74 69 76 65 7d 7d 0a  ion is active}}.
2000: 20 20 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 37    do_test io-2.7
2010: 2e 36 20 7b 0a 20 20 20 20 65 78 65 63 73 71 6c  .6 {.    execsql
2020: 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d   { SELECT * FROM
2030: 20 61 62 63 20 55 4e 49 4f 4e 20 41 4c 4c 20 53   abc UNION ALL S
2040: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63  ELECT * FROM abc
2050: 32 20 7d 0a 20 20 7d 20 7b 31 20 32 20 33 20 34  2 }.  } {1 2 3 4
2060: 20 35 20 36 20 37 20 38 7d 0a 7d 0a 0a 23 20 54   5 6 7 8}.}..# T
2070: 72 79 20 61 6e 20 65 78 70 6c 69 63 69 74 20 52  ry an explicit R
2080: 4f 4c 4c 42 41 43 4b 20 62 65 66 6f 72 65 20 74  OLLBACK before t
2090: 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20  he journal file 
20a0: 69 73 20 63 72 65 61 74 65 64 2e 0a 23 0a 64 6f  is created..#.do
20b0: 5f 74 65 73 74 20 69 6f 2d 32 2e 38 2e 31 20 7b  _test io-2.8.1 {
20c0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
20d0: 20 42 45 47 49 4e 3b 0a 20 20 20 20 44 45 4c 45   BEGIN;.    DELE
20e0: 54 45 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 7d  TE FROM abc;.  }
20f0: 0a 20 20 66 69 6c 65 20 65 78 69 73 74 73 20 74  .  file exists t
2100: 65 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d  est.db-journal.}
2110: 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 69 6f 2d   {0}.do_test io-
2120: 32 2e 38 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  2.8.2 {.  execsq
2130: 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  l { SELECT * FRO
2140: 4d 20 61 62 63 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  M abc }.} {}.do_
2150: 74 65 73 74 20 69 6f 2d 32 2e 38 2e 33 20 7b 0a  test io-2.8.3 {.
2160: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
2170: 52 4f 4c 4c 42 41 43 4b 3b 0a 20 20 20 20 53 45  ROLLBACK;.    SE
2180: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b  LECT * FROM abc;
2190: 0a 20 20 7d 0a 7d 20 7b 31 20 32 20 33 20 34 20  .  }.} {1 2 3 4 
21a0: 35 20 36 20 37 20 38 7d 0a 0a 23 20 54 65 73 74  5 6 7 8}..# Test
21b0: 20 74 68 61 74 20 74 68 65 20 61 74 6f 6d 69 63   that the atomic
21c0: 20 77 72 69 74 65 20 6f 70 74 69 6d 69 73 61 74   write optimisat
21d0: 69 6f 6e 20 69 73 20 6e 6f 74 20 65 6e 61 62 6c  ion is not enabl
21e0: 65 64 20 69 66 20 74 68 65 20 73 65 63 74 6f 72  ed if the sector
21f0: 0a 23 20 73 69 7a 65 20 69 73 20 6c 61 72 67 65  .# size is large
2200: 72 20 74 68 61 6e 20 74 68 65 20 70 61 67 65 2d  r than the page-
2210: 73 69 7a 65 2e 0a 23 0a 64 6f 5f 74 65 73 74 20  size..#.do_test 
2220: 69 6f 2d 32 2e 39 2e 31 20 7b 0a 20 20 64 62 20  io-2.9.1 {.  db 
2230: 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 33 20  close.  sqlite3 
2240: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 73 71 6c  db test.db.  sql
2250: 69 74 65 33 5f 73 69 6d 75 6c 61 74 65 5f 64 65  ite3_simulate_de
2260: 76 69 63 65 20 2d 63 68 61 72 20 61 74 6f 6d 69  vice -char atomi
2270: 63 20 2d 73 65 63 74 6f 72 73 69 7a 65 20 32 30  c -sectorsize 20
2280: 34 38 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20  48.  execsql {. 
2290: 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 49 4e     BEGIN;.    IN
22a0: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 56 41  SERT INTO abc VA
22b0: 4c 55 45 53 28 39 2c 20 31 30 29 3b 0a 20 20 7d  LUES(9, 10);.  }
22c0: 0a 20 20 66 69 6c 65 20 65 78 69 73 74 73 20 74  .  file exists t
22d0: 65 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d  est.db-journal.}
22e0: 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 69 6f 2d   {1}.do_test io-
22f0: 32 2e 39 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  2.9.2 {.  execsq
2300: 6c 20 7b 20 52 4f 4c 4c 42 41 43 4b 3b 20 7d 0a  l { ROLLBACK; }.
2310: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 66 6f 72    db close.  for
2320: 63 65 64 65 6c 65 74 65 20 74 65 73 74 2e 64 62  cedelete test.db
2330: 20 74 65 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c   test.db-journal
2340: 0a 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65  .  sqlite3 db te
2350: 73 74 2e 64 62 20 2d 76 66 73 20 64 65 76 73 79  st.db -vfs devsy
2360: 6d 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  m.  execsql {.  
2370: 20 20 50 52 41 47 4d 41 20 61 75 74 6f 5f 76 61    PRAGMA auto_va
2380: 63 75 75 6d 20 3d 20 4f 46 46 3b 0a 20 20 20 20  cuum = OFF;.    
2390: 50 52 41 47 4d 41 20 70 61 67 65 5f 73 69 7a 65  PRAGMA page_size
23a0: 20 3d 20 32 30 34 38 3b 0a 20 20 20 20 43 52 45   = 2048;.    CRE
23b0: 41 54 45 20 54 41 42 4c 45 20 61 62 63 28 61 2c  ATE TABLE abc(a,
23c0: 20 62 29 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73   b);.  }.  execs
23d0: 71 6c 20 7b 0a 20 20 20 20 42 45 47 49 4e 3b 0a  ql {.    BEGIN;.
23e0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
23f0: 61 62 63 20 56 41 4c 55 45 53 28 39 2c 20 31 30  abc VALUES(9, 10
2400: 29 3b 0a 20 20 7d 0a 20 20 66 69 6c 65 20 65 78  );.  }.  file ex
2410: 69 73 74 73 20 74 65 73 74 2e 64 62 2d 6a 6f 75  ists test.db-jou
2420: 72 6e 61 6c 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65  rnal.} {0}.do_te
2430: 73 74 20 69 6f 2d 32 2e 39 2e 33 20 7b 0a 20 20  st io-2.9.3 {.  
2440: 65 78 65 63 73 71 6c 20 7b 20 43 4f 4d 4d 49 54  execsql { COMMIT
2450: 20 7d 0a 7d 20 7b 7d 0a 0a 23 20 54 65 73 74 20   }.} {}..# Test 
2460: 61 20 63 6f 75 70 6c 65 20 6f 66 20 74 68 65 20  a couple of the 
2470: 6d 6f 72 65 20 73 70 65 63 69 66 69 63 20 49 4f  more specific IO
2480: 43 41 50 5f 41 54 4f 4d 49 43 20 66 6c 61 67 73  CAP_ATOMIC flags
2490: 20 0a 23 20 28 69 2e 65 20 49 4f 43 41 50 5f 41   .# (i.e IOCAP_A
24a0: 54 4f 4d 49 43 32 4b 20 65 74 63 2e 29 2e 0a 23  TOMIC2K etc.)..#
24b0: 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 31 30  .do_test io-2.10
24c0: 2e 31 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 73  .1 {.  sqlite3_s
24d0: 69 6d 75 6c 61 74 65 5f 64 65 76 69 63 65 20 2d  imulate_device -
24e0: 63 68 61 72 20 61 74 6f 6d 69 63 31 6b 0a 20 20  char atomic1k.  
24f0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 42 45  execsql {.    BE
2500: 47 49 4e 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  GIN;.    INSERT 
2510: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
2520: 31 31 2c 20 31 32 29 3b 0a 20 20 7d 0a 20 20 66  11, 12);.  }.  f
2530: 69 6c 65 20 65 78 69 73 74 73 20 74 65 73 74 2e  ile exists test.
2540: 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20 7b 31 7d  db-journal.} {1}
2550: 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 31 30  .do_test io-2.10
2560: 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .2 {.  execsql {
2570: 20 52 4f 4c 4c 42 41 43 4b 20 7d 0a 20 20 73 71   ROLLBACK }.  sq
2580: 6c 69 74 65 33 5f 73 69 6d 75 6c 61 74 65 5f 64  lite3_simulate_d
2590: 65 76 69 63 65 20 2d 63 68 61 72 20 61 74 6f 6d  evice -char atom
25a0: 69 63 32 6b 0a 20 20 65 78 65 63 73 71 6c 20 7b  ic2k.  execsql {
25b0: 0a 20 20 20 20 42 45 47 49 4e 3b 0a 20 20 20 20  .    BEGIN;.    
25c0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20  INSERT INTO abc 
25d0: 56 41 4c 55 45 53 28 31 31 2c 20 31 32 29 3b 0a  VALUES(11, 12);.
25e0: 20 20 7d 0a 20 20 66 69 6c 65 20 65 78 69 73 74    }.  file exist
25f0: 73 20 74 65 73 74 2e 64 62 2d 6a 6f 75 72 6e 61  s test.db-journa
2600: 6c 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20  l.} {0}.do_test 
2610: 69 6f 2d 32 2e 31 30 2e 33 20 7b 0a 20 20 65 78  io-2.10.3 {.  ex
2620: 65 63 73 71 6c 20 7b 20 52 4f 4c 4c 42 41 43 4b  ecsql { ROLLBACK
2630: 20 7d 0a 7d 20 7b 7d 0a 0a 64 6f 5f 74 65 73 74   }.} {}..do_test
2640: 20 69 6f 2d 32 2e 31 31 2e 30 20 7b 0a 20 20 65   io-2.11.0 {.  e
2650: 78 65 63 73 71 6c 20 7b 20 0a 20 20 20 20 50 52  xecsql { .    PR
2660: 41 47 4d 41 20 6c 6f 63 6b 69 6e 67 5f 6d 6f 64  AGMA locking_mod
2670: 65 20 3d 20 65 78 63 6c 75 73 69 76 65 3b 0a 20  e = exclusive;. 
2680: 20 20 20 50 52 41 47 4d 41 20 6c 6f 63 6b 69 6e     PRAGMA lockin
2690: 67 5f 6d 6f 64 65 3b 0a 20 20 7d 0a 7d 20 7b 65  g_mode;.  }.} {e
26a0: 78 63 6c 75 73 69 76 65 20 65 78 63 6c 75 73 69  xclusive exclusi
26b0: 76 65 7d 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32  ve}.do_test io-2
26c0: 2e 31 31 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  .11.1 {.  execsq
26d0: 6c 20 7b 20 0a 20 20 20 20 49 4e 53 45 52 54 20  l { .    INSERT 
26e0: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
26f0: 31 31 2c 20 31 32 29 3b 0a 20 20 7d 0a 20 20 66  11, 12);.  }.  f
2700: 69 6c 65 20 65 78 69 73 74 73 20 74 65 73 74 2e  ile exists test.
2710: 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20 7b 30 7d  db-journal.} {0}
2720: 0a 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 32 2e 31  ..do_test io-2.1
2730: 31 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.2 {.  execsql 
2740: 7b 20 0a 20 20 20 20 50 52 41 47 4d 41 20 6c 6f  { .    PRAGMA lo
2750: 63 6b 69 6e 67 5f 6d 6f 64 65 20 3d 20 6e 6f 72  cking_mode = nor
2760: 6d 61 6c 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  mal;.    INSERT 
2770: 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53 28  INTO abc VALUES(
2780: 31 33 2c 20 31 34 29 3b 0a 20 20 7d 0a 20 20 66  13, 14);.  }.  f
2790: 69 6c 65 20 65 78 69 73 74 73 20 74 65 73 74 2e  ile exists test.
27a0: 64 62 2d 6a 6f 75 72 6e 61 6c 0a 7d 20 7b 30 7d  db-journal.} {0}
27b0: 0a 0a 7d 20 3b 23 20 2f 2a 20 69 66 63 61 70 61  ..} ;# /* ifcapa
27c0: 62 6c 65 20 61 74 6f 6d 69 63 77 72 69 74 65 20  ble atomicwrite 
27d0: 2a 2f 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  */..#-----------
27e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
27f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2800: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2810: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 65  -----------.# Te
2820: 73 74 20 63 61 73 65 73 20 69 6f 2d 33 2e 2a 20  st cases io-3.* 
2830: 74 65 73 74 20 74 68 65 20 49 4f 43 41 50 5f 53  test the IOCAP_S
2840: 45 51 55 45 4e 54 49 41 4c 20 6f 70 74 69 6d 69  EQUENTIAL optimi
2850: 7a 61 74 69 6f 6e 2e 0a 23 0a 73 71 6c 69 74 65  zation..#.sqlite
2860: 33 5f 73 69 6d 75 6c 61 74 65 5f 64 65 76 69 63  3_simulate_devic
2870: 65 20 2d 63 68 61 72 20 73 65 71 75 65 6e 74 69  e -char sequenti
2880: 61 6c 20 2d 73 65 63 74 6f 72 73 69 7a 65 20 30  al -sectorsize 0
2890: 0a 69 66 63 61 70 61 62 6c 65 20 70 61 67 65 72  .ifcapable pager
28a0: 5f 70 72 61 67 6d 61 73 20 7b 0a 20 20 64 6f 5f  _pragmas {.  do_
28b0: 74 65 73 74 20 69 6f 2d 33 2e 31 20 7b 0a 20 20  test io-3.1 {.  
28c0: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 20 20 66    db close.    f
28d0: 6f 72 63 65 64 65 6c 65 74 65 20 74 65 73 74 2e  orcedelete test.
28e0: 64 62 20 74 65 73 74 2e 64 62 2d 6a 6f 75 72 6e  db test.db-journ
28f0: 61 6c 0a 20 20 20 20 73 71 6c 69 74 65 33 20 64  al.    sqlite3 d
2900: 62 20 74 65 73 74 2e 64 62 20 2d 76 66 73 20 64  b test.db -vfs d
2910: 65 76 73 79 6d 0a 20 20 20 20 64 62 20 65 76 61  evsym.    db eva
2920: 6c 20 7b 0a 20 20 20 20 20 20 50 52 41 47 4d 41  l {.      PRAGMA
2930: 20 61 75 74 6f 5f 76 61 63 75 75 6d 3d 4f 46 46   auto_vacuum=OFF
2940: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 23 20 46 69  ;.    }.    # Fi
2950: 6c 65 20 73 69 7a 65 20 6d 69 67 68 74 20 62 65  le size might be
2960: 20 31 20 64 75 65 20 74 6f 20 74 68 65 20 68 61   1 due to the ha
2970: 63 6b 20 74 6f 20 77 6f 72 6b 20 61 72 6f 75 6e  ck to work aroun
2980: 64 20 74 69 63 6b 65 74 20 23 33 32 36 30 2e 0a  d ticket #3260..
2990: 20 20 20 20 23 20 53 65 61 72 63 68 20 66 6f 72      # Search for
29a0: 20 23 33 32 36 30 20 69 6e 20 6f 73 5f 75 6e 69   #3260 in os_uni
29b0: 78 2e 63 20 66 6f 72 20 61 64 64 69 74 69 6f 6e  x.c for addition
29c0: 61 6c 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2e 0a  al information..
29d0: 20 20 20 20 65 78 70 72 20 7b 5b 66 69 6c 65 20      expr {[file 
29e0: 73 69 7a 65 20 74 65 73 74 2e 64 62 5d 3e 31 7d  size test.db]>1}
29f0: 0a 20 20 7d 20 7b 30 7d 0a 20 20 64 6f 5f 74 65  .  } {0}.  do_te
2a00: 73 74 20 69 6f 2d 33 2e 32 20 7b 0a 20 20 20 20  st io-3.2 {.    
2a10: 65 78 65 63 73 71 6c 20 7b 20 43 52 45 41 54 45  execsql { CREATE
2a20: 20 54 41 42 4c 45 20 61 62 63 28 61 2c 20 62 29   TABLE abc(a, b)
2a30: 20 7d 0a 20 20 20 20 6e 53 79 6e 63 0a 20 20 20   }.    nSync.   
2a40: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
2a50: 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f   PRAGMA temp_sto
2a60: 72 65 20 3d 20 6d 65 6d 6f 72 79 3b 0a 20 20 20  re = memory;.   
2a70: 20 20 20 50 52 41 47 4d 41 20 63 61 63 68 65 5f     PRAGMA cache_
2a80: 73 69 7a 65 20 3d 20 31 30 3b 0a 20 20 20 20 20  size = 10;.     
2a90: 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 49 4e   BEGIN;.      IN
2aa0: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 56 41  SERT INTO abc VA
2ab0: 4c 55 45 53 28 27 68 65 6c 6c 6f 27 2c 20 27 77  LUES('hello', 'w
2ac0: 6f 72 6c 64 27 29 3b 0a 20 20 20 20 20 20 49 4e  orld');.      IN
2ad0: 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 53 45  SERT INTO abc SE
2ae0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b  LECT * FROM abc;
2af0: 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e  .      INSERT IN
2b00: 54 4f 20 61 62 63 20 53 45 4c 45 43 54 20 2a 20  TO abc SELECT * 
2b10: 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20 20 20  FROM abc;.      
2b20: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20  INSERT INTO abc 
2b30: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62  SELECT * FROM ab
2b40: 63 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20  c;.      INSERT 
2b50: 49 4e 54 4f 20 61 62 63 20 53 45 4c 45 43 54 20  INTO abc SELECT 
2b60: 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20  * FROM abc;.    
2b70: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62    INSERT INTO ab
2b80: 63 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  c SELECT * FROM 
2b90: 61 62 63 3b 0a 20 20 20 20 20 20 49 4e 53 45 52  abc;.      INSER
2ba0: 54 20 49 4e 54 4f 20 61 62 63 20 53 45 4c 45 43  T INTO abc SELEC
2bb0: 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20  T * FROM abc;.  
2bc0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2bd0: 61 62 63 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  abc SELECT * FRO
2be0: 4d 20 61 62 63 3b 0a 20 20 20 20 20 20 49 4e 53  M abc;.      INS
2bf0: 45 52 54 20 49 4e 54 4f 20 61 62 63 20 53 45 4c  ERT INTO abc SEL
2c00: 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a  ECT * FROM abc;.
2c10: 20 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54        INSERT INT
2c20: 4f 20 61 62 63 20 53 45 4c 45 43 54 20 2a 20 46  O abc SELECT * F
2c30: 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20 20 20 49  ROM abc;.      I
2c40: 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 53  NSERT INTO abc S
2c50: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63  ELECT * FROM abc
2c60: 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54 20 49  ;.      INSERT I
2c70: 4e 54 4f 20 61 62 63 20 53 45 4c 45 43 54 20 2a  NTO abc SELECT *
2c80: 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20 7d   FROM abc;.    }
2c90: 0a 20 20 20 20 23 20 46 69 6c 65 20 68 61 73 20  .    # File has 
2ca0: 67 72 6f 77 6e 20 2d 20 73 68 6f 77 69 6e 67 20  grown - showing 
2cb0: 74 68 65 72 65 20 77 61 73 20 61 20 63 61 63 68  there was a cach
2cc0: 65 2d 73 70 69 6c 6c 20 2d 20 62 75 74 20 74 68  e-spill - but th
2cd0: 65 72 65 20 0a 20 20 20 20 23 20 68 61 76 65 20  ere .    # have 
2ce0: 62 65 65 6e 20 6e 6f 20 63 61 6c 6c 73 20 74 6f  been no calls to
2cf0: 20 66 73 79 6e 63 28 29 2e 20 54 68 65 20 66 69   fsync(). The fi
2d00: 6c 65 20 69 73 20 70 72 6f 62 61 62 6c 79 20 61  le is probably a
2d10: 62 6f 75 74 20 33 30 4b 42 2e 0a 20 20 20 20 23  bout 30KB..    #
2d20: 20 42 75 74 20 73 6f 6d 65 20 56 46 53 20 69 6d   But some VFS im
2d30: 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 73 20 28 73  plementations (s
2d40: 79 6d 62 69 61 6e 29 20 62 75 66 66 65 72 20 77  ymbian) buffer w
2d50: 72 69 74 65 73 20 73 6f 20 74 68 65 20 61 63 74  rites so the act
2d60: 75 61 6c 0a 20 20 20 20 23 20 73 69 7a 65 20 6d  ual.    # size m
2d70: 61 79 20 62 65 20 61 20 6c 69 74 74 6c 65 20 6c  ay be a little l
2d80: 65 73 73 20 74 68 61 6e 20 74 68 61 74 2e 20 53  ess than that. S
2d90: 6f 20 74 68 69 73 20 74 65 73 74 20 63 61 73 65  o this test case
2da0: 20 6a 75 73 74 20 74 65 73 74 73 0a 20 20 20 20   just tests.    
2db0: 23 20 74 68 61 74 20 74 68 65 20 66 69 6c 65 20  # that the file 
2dc0: 69 73 20 6e 6f 77 20 67 72 65 61 74 65 72 20 74  is now greater t
2dd0: 68 61 6e 20 32 30 30 30 30 20 62 79 74 65 73 20  han 20000 bytes 
2de0: 69 6e 20 73 69 7a 65 2e 0a 20 20 20 20 6c 69 73  in size..    lis
2df0: 74 20 5b 65 78 70 72 20 5b 66 69 6c 65 20 73 69  t [expr [file si
2e00: 7a 65 20 74 65 73 74 2e 64 62 5d 3e 32 30 30 30  ze test.db]>2000
2e10: 30 5d 20 5b 6e 53 79 6e 63 5d 0a 20 20 7d 20 7b  0] [nSync].  } {
2e20: 31 20 30 7d 0a 20 20 64 6f 5f 74 65 73 74 20 69  1 0}.  do_test i
2e30: 6f 2d 33 2e 33 20 7b 0a 20 20 20 20 23 20 54 68  o-3.3 {.    # Th
2e40: 65 20 43 4f 4d 4d 49 54 20 72 65 71 75 69 72 65  e COMMIT require
2e50: 73 20 61 20 73 69 6e 67 6c 65 20 66 73 79 6e 63  s a single fsync
2e60: 28 29 20 2d 20 74 6f 20 74 68 65 20 64 61 74 61  () - to the data
2e70: 62 61 73 65 20 66 69 6c 65 2e 0a 20 20 20 20 65  base file..    e
2e80: 78 65 63 73 71 6c 20 7b 20 43 4f 4d 4d 49 54 20  xecsql { COMMIT 
2e90: 7d 0a 20 20 20 20 6c 69 73 74 20 5b 66 69 6c 65  }.    list [file
2ea0: 5f 70 61 67 65 5f 63 6f 75 6e 74 20 74 65 73 74  _page_count test
2eb0: 2e 64 62 5d 20 5b 6e 53 79 6e 63 5d 0a 20 20 7d  .db] [nSync].  }
2ec0: 20 7b 33 39 20 31 7d 0a 7d 0a 0a 23 2d 2d 2d 2d   {39 1}.}..#----
2ed0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2ee0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2ef0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2f00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2f10: 2d 2d 0a 23 20 54 65 73 74 20 63 61 73 65 73 20  --.# Test cases 
2f20: 69 6f 2d 34 2e 2a 20 74 65 73 74 20 74 68 65 20  io-4.* test the 
2f30: 49 4f 43 41 50 5f 53 41 46 45 5f 41 50 50 45 4e  IOCAP_SAFE_APPEN
2f40: 44 20 6f 70 74 69 6d 69 7a 61 74 69 6f 6e 2e 0a  D optimization..
2f50: 23 0a 73 71 6c 69 74 65 33 5f 73 69 6d 75 6c 61  #.sqlite3_simula
2f60: 74 65 5f 64 65 76 69 63 65 20 2d 63 68 61 72 20  te_device -char 
2f70: 73 61 66 65 5f 61 70 70 65 6e 64 0a 0a 23 20 57  safe_append..# W
2f80: 69 74 68 20 74 68 65 20 53 41 46 45 5f 41 50 50  ith the SAFE_APP
2f90: 45 4e 44 20 66 6c 61 67 20 73 65 74 2c 20 73 69  END flag set, si
2fa0: 6d 70 6c 65 20 74 72 61 6e 73 61 63 74 69 6f 6e  mple transaction
2fb0: 73 20 72 65 71 75 69 72 65 20 33 2c 20 72 61 74  s require 3, rat
2fc0: 68 65 72 0a 23 20 74 68 61 6e 20 34 2c 20 63 61  her.# than 4, ca
2fd0: 6c 6c 73 20 74 6f 20 66 73 79 6e 63 28 29 2e 20  lls to fsync(). 
2fe0: 54 68 65 20 66 73 79 6e 63 28 29 20 63 61 6c 6c  The fsync() call
2ff0: 73 20 61 72 65 20 6f 6e 3a 0a 23 0a 23 20 20 20  s are on:.#.#   
3000: 31 29 20 54 68 65 20 64 69 72 65 63 74 6f 72 79  1) The directory
3010: 20 69 6e 20 77 68 69 63 68 20 74 68 65 20 6a 6f   in which the jo
3020: 75 72 6e 61 6c 20 66 69 6c 65 20 69 73 20 63 72  urnal file is cr
3030: 65 61 74 65 64 2c 20 28 75 6e 69 78 20 6f 6e 6c  eated, (unix onl
3040: 79 29 0a 23 20 20 20 32 29 20 54 68 65 20 6a 6f  y).#   2) The jo
3050: 75 72 6e 61 6c 20 66 69 6c 65 20 28 74 6f 20 73  urnal file (to s
3060: 79 6e 63 20 74 68 65 20 70 61 67 65 20 64 61 74  ync the page dat
3070: 61 29 2c 0a 23 20 20 20 33 29 20 54 68 65 20 64  a),.#   3) The d
3080: 61 74 61 62 61 73 65 20 66 69 6c 65 2e 0a 23 0a  atabase file..#.
3090: 23 20 4e 6f 72 6d 61 6c 6c 79 2c 20 77 68 65 6e  # Normally, when
30a0: 20 74 68 65 20 53 41 46 45 5f 41 50 50 45 4e 44   the SAFE_APPEND
30b0: 20 66 6c 61 67 20 69 73 20 6e 6f 74 20 73 65 74   flag is not set
30c0: 2c 20 74 68 65 72 65 20 69 73 20 61 6e 6f 74 68  , there is anoth
30d0: 65 72 20 66 73 79 6e 63 28 29 0a 23 20 6f 6e 20  er fsync().# on 
30e0: 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65  the journal file
30f0: 20 62 65 74 77 65 65 6e 20 73 74 65 70 73 20 28   between steps (
3100: 32 29 20 61 6e 64 20 28 33 29 20 61 62 6f 76 65  2) and (3) above
3110: 2e 0a 23 0a 73 65 74 20 65 78 70 65 63 74 65 64  ..#.set expected
3120: 5f 73 79 6e 63 5f 63 6f 75 6e 74 20 32 0a 69 66  _sync_count 2.if
3130: 20 7b 24 3a 3a 74 63 6c 5f 70 6c 61 74 66 6f 72   {$::tcl_platfor
3140: 6d 28 70 6c 61 74 66 6f 72 6d 29 3d 3d 22 75 6e  m(platform)=="un
3150: 69 78 22 7d 20 7b 0a 20 20 69 66 63 61 70 61 62  ix"} {.  ifcapab
3160: 6c 65 20 64 69 72 73 79 6e 63 20 7b 0a 20 20 20  le dirsync {.   
3170: 20 69 6e 63 72 20 65 78 70 65 63 74 65 64 5f 73   incr expected_s
3180: 79 6e 63 5f 63 6f 75 6e 74 0a 20 20 7d 0a 7d 0a  ync_count.  }.}.
3190: 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 34 2e 31 20  .do_test io-4.1 
31a0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 44 45  {.  execsql { DE
31b0: 4c 45 54 45 20 46 52 4f 4d 20 61 62 63 20 7d 0a  LETE FROM abc }.
31c0: 20 20 6e 53 79 6e 63 0a 20 20 65 78 65 63 73 71    nSync.  execsq
31d0: 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  l { INSERT INTO 
31e0: 61 62 63 20 56 41 4c 55 45 53 28 27 61 27 2c 20  abc VALUES('a', 
31f0: 27 62 27 29 20 7d 0a 20 20 6e 53 79 6e 63 0a 7d  'b') }.  nSync.}
3200: 20 24 65 78 70 65 63 74 65 64 5f 73 79 6e 63 5f   $expected_sync_
3210: 63 6f 75 6e 74 0a 0a 23 20 57 69 74 68 20 53 41  count..# With SA
3220: 46 45 5f 41 50 50 45 4e 44 20 73 65 74 2c 20 74  FE_APPEND set, t
3230: 68 65 20 6e 52 65 63 20 66 69 65 6c 64 20 6f 66  he nRec field of
3240: 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c   the journal fil
3250: 65 20 68 65 61 64 65 72 20 73 68 6f 75 6c 64 0a  e header should.
3260: 23 20 62 65 20 73 65 74 20 74 6f 20 30 78 46 46  # be set to 0xFF
3270: 46 46 46 46 46 46 20 62 65 66 6f 72 65 20 74 68  FFFFFF before th
3280: 65 20 66 69 72 73 74 20 6a 6f 75 72 6e 61 6c 20  e first journal 
3290: 73 79 6e 63 2e 20 54 68 65 20 6e 52 65 63 20 66  sync. The nRec f
32a0: 69 65 6c 64 0a 23 20 6f 63 63 75 70 69 65 73 20  ield.# occupies 
32b0: 62 79 74 65 73 20 38 2d 31 31 20 6f 66 20 74 68  bytes 8-11 of th
32c0: 65 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 2e 0a  e journal file..
32d0: 23 0a 64 6f 5f 74 65 73 74 20 69 6f 2d 34 2e 32  #.do_test io-4.2
32e0: 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b  .1 {.  execsql {
32f0: 20 42 45 47 49 4e 20 7d 0a 20 20 65 78 65 63 73   BEGIN }.  execs
3300: 71 6c 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f  ql { INSERT INTO
3310: 20 61 62 63 20 56 41 4c 55 45 53 28 27 63 27 2c   abc VALUES('c',
3320: 20 27 64 27 29 20 7d 0a 20 20 66 69 6c 65 20 65   'd') }.  file e
3330: 78 69 73 74 73 20 74 65 73 74 2e 64 62 2d 6a 6f  xists test.db-jo
3340: 75 72 6e 61 6c 0a 7d 20 7b 31 7d 0a 69 66 20 7b  urnal.} {1}.if {
3350: 24 3a 3a 74 63 6c 5f 70 6c 61 74 66 6f 72 6d 28  $::tcl_platform(
3360: 70 6c 61 74 66 6f 72 6d 29 3d 3d 22 75 6e 69 78  platform)=="unix
3370: 22 7d 20 7b 0a 20 20 64 6f 5f 74 65 73 74 20 69  "} {.  do_test i
3380: 6f 2d 34 2e 32 2e 32 20 7b 0a 20 20 20 20 68 65  o-4.2.2 {.    he
3390: 78 69 6f 5f 72 65 61 64 20 74 65 73 74 2e 64 62  xio_read test.db
33a0: 2d 6a 6f 75 72 6e 61 6c 20 38 20 34 0a 20 20 7d  -journal 8 4.  }
33b0: 20 7b 46 46 46 46 46 46 46 46 7d 0a 7d 0a 64 6f   {FFFFFFFF}.}.do
33c0: 5f 74 65 73 74 20 69 6f 2d 34 2e 32 2e 33 20 7b  _test io-4.2.3 {
33d0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 43 4f 4d  .  execsql { COM
33e0: 4d 49 54 20 7d 0a 20 20 6e 53 79 6e 63 0a 7d 20  MIT }.  nSync.} 
33f0: 24 65 78 70 65 63 74 65 64 5f 73 79 6e 63 5f 63  $expected_sync_c
3400: 6f 75 6e 74 0a 73 71 6c 69 74 65 33 5f 73 69 6d  ount.sqlite3_sim
3410: 75 6c 61 74 65 5f 64 65 76 69 63 65 20 2d 63 68  ulate_device -ch
3420: 61 72 20 73 61 66 65 5f 61 70 70 65 6e 64 0a 0a  ar safe_append..
3430: 23 20 57 69 74 68 20 53 41 46 45 5f 41 50 50 45  # With SAFE_APPE
3440: 4e 44 20 73 65 74 2c 20 74 68 65 72 65 20 73 68  ND set, there sh
3450: 6f 75 6c 64 20 6f 6e 6c 79 20 65 76 65 72 20 62  ould only ever b
3460: 65 20 6f 6e 65 20 6a 6f 75 72 6e 61 6c 2d 68 65  e one journal-he
3470: 61 64 65 72 0a 23 20 77 72 69 74 74 65 6e 20 74  ader.# written t
3480: 6f 20 74 68 65 20 64 61 74 61 62 61 73 65 2c 20  o the database, 
3490: 65 76 65 6e 20 74 68 6f 75 67 68 20 74 68 65 20  even though the 
34a0: 73 79 6e 63 2d 6d 6f 64 65 20 69 73 20 22 66 75  sync-mode is "fu
34b0: 6c 6c 22 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 69  ll"..#.do_test i
34c0: 6f 2d 34 2e 33 2e 31 20 7b 0a 20 20 65 78 65 63  o-4.3.1 {.  exec
34d0: 73 71 6c 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  sql {.    INSERT
34e0: 20 49 4e 54 4f 20 61 62 63 20 53 45 4c 45 43 54   INTO abc SELECT
34f0: 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20   * FROM abc;.   
3500: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63   INSERT INTO abc
3510: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61   SELECT * FROM a
3520: 62 63 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  bc;.    INSERT I
3530: 4e 54 4f 20 61 62 63 20 53 45 4c 45 43 54 20 2a  NTO abc SELECT *
3540: 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20 49   FROM abc;.    I
3550: 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20 53  NSERT INTO abc S
3560: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63  ELECT * FROM abc
3570: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
3580: 4f 20 61 62 63 20 53 45 4c 45 43 54 20 2a 20 46  O abc SELECT * F
3590: 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20 49 4e 53  ROM abc;.    INS
35a0: 45 52 54 20 49 4e 54 4f 20 61 62 63 20 53 45 4c  ERT INTO abc SEL
35b0: 45 43 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a  ECT * FROM abc;.
35c0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
35d0: 61 62 63 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  abc SELECT * FRO
35e0: 4d 20 61 62 63 3b 0a 20 20 20 20 49 4e 53 45 52  M abc;.    INSER
35f0: 54 20 49 4e 54 4f 20 61 62 63 20 53 45 4c 45 43  T INTO abc SELEC
3600: 54 20 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20  T * FROM abc;.  
3610: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62    INSERT INTO ab
3620: 63 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  c SELECT * FROM 
3630: 61 62 63 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  abc;.    INSERT 
3640: 49 4e 54 4f 20 61 62 63 20 53 45 4c 45 43 54 20  INTO abc SELECT 
3650: 2a 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20 20 20  * FROM abc;.    
3660: 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63 20  INSERT INTO abc 
3670: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 61 62  SELECT * FROM ab
3680: 63 3b 0a 20 20 7d 0a 20 20 66 69 6c 65 5f 70 61  c;.  }.  file_pa
3690: 67 65 5f 63 6f 75 6e 74 20 74 65 73 74 2e 64 62  ge_count test.db
36a0: 0a 7d 20 7b 34 33 7d 0a 69 66 63 61 70 61 62 6c  .} {43}.ifcapabl
36b0: 65 20 70 61 67 65 72 5f 70 72 61 67 6d 61 73 20  e pager_pragmas 
36c0: 7b 0a 20 20 64 6f 5f 74 65 73 74 20 69 6f 2d 34  {.  do_test io-4
36d0: 2e 33 2e 32 20 7b 0a 20 20 20 20 65 78 65 63 73  .3.2 {.    execs
36e0: 71 6c 20 7b 0a 20 20 20 20 20 20 50 52 41 47 4d  ql {.      PRAGM
36f0: 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 20 3d 20  A synchronous = 
3700: 66 75 6c 6c 3b 0a 20 20 20 20 20 20 50 52 41 47  full;.      PRAG
3710: 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 20 3d 20  MA cache_size = 
3720: 31 30 3b 0a 20 20 20 20 20 20 50 52 41 47 4d 41  10;.      PRAGMA
3730: 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20   synchronous;.  
3740: 20 20 7d 0a 20 20 7d 20 7b 32 7d 0a 7d 0a 64 6f    }.  } {2}.}.do
3750: 5f 74 65 73 74 20 69 6f 2d 34 2e 33 2e 33 20 7b  _test io-4.3.3 {
3760: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
3770: 20 42 45 47 49 4e 3b 0a 20 20 20 20 55 50 44 41   BEGIN;.    UPDA
3780: 54 45 20 61 62 63 20 53 45 54 20 61 20 3d 20 27  TE abc SET a = '
3790: 78 27 3b 0a 20 20 7d 0a 20 20 66 69 6c 65 20 65  x';.  }.  file e
37a0: 78 69 73 74 73 20 74 65 73 74 2e 64 62 2d 6a 6f  xists test.db-jo
37b0: 75 72 6e 61 6c 0a 7d 20 7b 31 7d 0a 69 66 20 7b  urnal.} {1}.if {
37c0: 24 74 63 6c 5f 70 6c 61 74 66 6f 72 6d 28 70 6c  $tcl_platform(pl
37d0: 61 74 66 6f 72 6d 29 20 21 3d 20 22 73 79 6d 62  atform) != "symb
37e0: 69 61 6e 22 7d 20 7b 0a 20 20 23 20 54 68 69 73  ian"} {.  # This
37f0: 20 74 65 73 74 20 69 73 20 6e 6f 74 20 72 75 6e   test is not run
3800: 20 6f 6e 20 73 79 6d 62 69 61 6e 20 62 65 63 61   on symbian beca
3810: 75 73 65 20 74 68 65 20 66 69 6c 65 2d 62 75 66  use the file-buf
3820: 66 65 72 20 6d 61 6b 65 73 20 69 74 0a 20 20 23  fer makes it.  #
3830: 20 64 69 66 66 69 63 75 6c 74 20 74 6f 20 70 72   difficult to pr
3840: 65 64 69 63 74 20 74 68 65 20 65 78 61 63 74 20  edict the exact 
3850: 73 69 7a 65 20 6f 66 20 74 68 65 20 66 69 6c 65  size of the file
3860: 20 61 73 20 72 65 70 6f 72 74 65 64 20 62 79 20   as reported by 
3870: 0a 20 20 23 20 5b 66 69 6c 65 20 73 69 7a 65 5d  .  # [file size]
3880: 2e 0a 20 20 64 6f 5f 74 65 73 74 20 69 6f 2d 34  ..  do_test io-4
3890: 2e 33 2e 34 20 7b 0a 20 20 20 20 23 20 54 68 65  .3.4 {.    # The
38a0: 20 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e   UPDATE statemen
38b0: 74 20 69 6e 20 74 68 65 20 73 74 61 74 65 6d 65  t in the stateme
38c0: 6e 74 20 61 62 6f 76 65 20 6d 6f 64 69 66 69 65  nt above modifie
38d0: 73 20 34 31 20 70 61 67 65 73 20 0a 20 20 20 20  s 41 pages .    
38e0: 23 20 28 61 6c 6c 20 70 61 67 65 73 20 69 6e 20  # (all pages in 
38f0: 74 68 65 20 64 61 74 61 62 61 73 65 20 65 78 63  the database exc
3900: 65 70 74 20 70 61 67 65 20 31 20 61 6e 64 20 74  ept page 1 and t
3910: 68 65 20 72 6f 6f 74 20 70 61 67 65 20 6f 66 20  he root page of 
3920: 0a 20 20 20 20 23 20 61 62 63 29 2e 20 42 65 63  .    # abc). Bec
3930: 61 75 73 65 20 74 68 65 20 63 61 63 68 65 5f 73  ause the cache_s
3940: 69 7a 65 20 69 73 20 73 65 74 20 74 6f 20 31 30  ize is set to 10
3950: 2c 20 74 68 69 73 20 6d 75 73 74 20 68 61 76 65  , this must have
3960: 20 72 65 71 75 69 72 65 64 0a 20 20 20 20 23 20   required.    # 
3970: 61 74 20 6c 65 61 73 74 20 34 20 63 61 63 68 65  at least 4 cache
3980: 2d 73 70 69 6c 6c 73 2e 20 49 66 20 74 68 65 72  -spills. If ther
3990: 65 20 77 65 72 65 20 6e 6f 20 6a 6f 75 72 6e 61  e were no journa
39a0: 6c 20 68 65 61 64 65 72 73 20 77 72 69 74 74 65  l headers writte
39b0: 6e 0a 20 20 20 20 23 20 74 6f 20 74 68 65 20 6a  n.    # to the j
39c0: 6f 75 72 6e 61 6c 20 66 69 6c 65 20 61 66 74 65  ournal file afte
39d0: 72 20 74 68 65 20 63 61 63 68 65 2d 73 70 69 6c  r the cache-spil
39e0: 6c 2c 20 74 68 65 6e 20 74 68 65 20 73 69 7a 65  l, then the size
39f0: 20 6f 66 20 74 68 65 0a 20 20 20 20 23 20 6a 6f   of the.    # jo
3a00: 75 72 6e 61 6c 20 66 69 6c 65 20 69 73 20 67 69  urnal file is gi
3a10: 76 65 20 62 79 3a 0a 20 20 20 20 23 0a 20 20 20  ve by:.    #.   
3a20: 20 23 20 20 20 20 3c 6a 72 6e 6c 20 66 69 6c 65   #    <jrnl file
3a30: 20 73 69 7a 65 3e 20 3d 20 3c 6a 72 6e 6c 20 68   size> = <jrnl h
3a40: 65 61 64 65 72 20 73 69 7a 65 3e 20 2b 20 6e 50  eader size> + nP
3a50: 61 67 65 20 2a 20 28 3c 70 61 67 65 2d 73 69 7a  age * (<page-siz
3a60: 65 3e 20 2b 20 38 29 0a 20 20 20 20 23 0a 20 20  e> + 8).    #.  
3a70: 20 20 23 20 49 66 20 74 68 65 20 6a 6f 75 72 6e    # If the journ
3a80: 61 6c 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73  al file contains
3a90: 20 61 64 64 69 74 69 6f 6e 61 6c 20 68 65 61 64   additional head
3aa0: 65 72 73 2c 20 74 68 69 73 20 66 6f 72 6d 75 6c  ers, this formul
3ab0: 61 0a 20 20 20 20 23 20 77 69 6c 6c 20 6e 6f 74  a.    # will not
3ac0: 20 70 72 65 64 69 63 74 20 74 68 65 20 73 69 7a   predict the siz
3ad0: 65 20 6f 66 20 74 68 65 20 6a 6f 75 72 6e 61 6c  e of the journal
3ae0: 20 66 69 6c 65 2e 0a 20 20 20 20 23 0a 20 20 20   file..    #.   
3af0: 20 66 69 6c 65 20 73 69 7a 65 20 74 65 73 74 2e   file size test.
3b00: 64 62 2d 6a 6f 75 72 6e 61 6c 0a 20 20 7d 20 5b  db-journal.  } [
3b10: 65 78 70 72 20 35 31 32 20 2b 20 28 31 30 32 34  expr 512 + (1024
3b20: 2b 38 29 2a 34 31 5d 0a 7d 0a 0a 23 2d 2d 2d 2d  +8)*41].}..#----
3b30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3b40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3b50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3b60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3b70: 2d 2d 0a 23 20 54 65 73 74 20 63 61 73 65 73 20  --.# Test cases 
3b80: 69 6f 2d 35 2e 2a 20 74 65 73 74 20 74 68 61 74  io-5.* test that
3b90: 20 74 68 65 20 64 65 66 61 75 6c 74 20 70 61 67   the default pag
3ba0: 65 20 73 69 7a 65 20 69 73 20 73 65 6c 65 63 74  e size is select
3bb0: 65 64 20 61 6e 64 0a 23 20 75 73 65 64 20 63 6f  ed and.# used co
3bc0: 72 72 65 63 74 6c 79 2e 0a 23 0a 73 65 74 20 74  rrectly..#.set t
3bd0: 6e 20 30 0a 66 6f 72 65 61 63 68 20 7b 63 68 61  n 0.foreach {cha
3be0: 72 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  r               
3bf0: 20 20 73 65 63 74 6f 72 73 69 7a 65 20 70 67 73    sectorsize pgs
3c00: 69 7a 65 7d 20 7b 0a 20 20 20 20 20 20 20 20 20  ize} {.         
3c10: 7b 7d 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {}              
3c20: 20 20 20 20 20 20 20 35 31 32 20 20 20 20 20 20         512      
3c30: 31 30 32 34 0a 20 20 20 20 20 20 20 20 20 7b 7d  1024.         {}
3c40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c50: 20 20 20 20 31 30 32 34 20 20 20 20 20 20 31 30      1024      10
3c60: 32 34 0a 20 20 20 20 20 20 20 20 20 7b 7d 20 20  24.         {}  
3c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c80: 20 20 32 30 34 38 20 20 20 20 20 20 32 30 34 38    2048      2048
3c90: 0a 20 20 20 20 20 20 20 20 20 7b 7d 20 20 20 20  .         {}    
3ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3cb0: 38 31 39 32 20 20 20 20 20 20 38 31 39 32 0a 20  8192      8192. 
3cc0: 20 20 20 20 20 20 20 20 7b 7d 20 20 20 20 20 20          {}      
3cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 31 36 33               163
3ce0: 38 34 20 20 20 20 20 20 38 31 39 32 0a 20 20 20  84      8192.   
3cf0: 20 20 20 20 20 20 7b 61 74 6f 6d 69 63 7d 20 20        {atomic}  
3d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 35 31 32               512
3d10: 20 20 20 20 20 20 38 31 39 32 0a 20 20 20 20 20        8192.     
3d20: 20 20 20 20 7b 61 74 6f 6d 69 63 35 31 32 7d 20      {atomic512} 
3d30: 20 20 20 20 20 20 20 20 20 20 20 35 31 32 20 20             512  
3d40: 20 20 20 20 31 30 32 34 0a 20 20 20 20 20 20 20      1024.       
3d50: 20 20 7b 61 74 6f 6d 69 63 32 4b 7d 20 20 20 20    {atomic2K}    
3d60: 20 20 20 20 20 20 20 20 20 35 31 32 20 20 20 20           512    
3d70: 20 20 32 30 34 38 0a 20 20 20 20 20 20 20 20 20    2048.         
3d80: 7b 61 74 6f 6d 69 63 32 4b 7d 20 20 20 20 20 20  {atomic2K}      
3d90: 20 20 20 20 20 20 34 30 39 36 20 20 20 20 20 20        4096      
3da0: 34 30 39 36 0a 20 20 20 20 20 20 20 20 20 7b 61  4096.         {a
3db0: 74 6f 6d 69 63 32 4b 20 61 74 6f 6d 69 63 7d 20  tomic2K atomic} 
3dc0: 20 20 20 20 20 35 31 32 20 20 20 20 20 20 38 31       512      81
3dd0: 39 32 0a 20 20 20 20 20 20 20 20 20 7b 61 74 6f  92.         {ato
3de0: 6d 69 63 36 34 4b 7d 20 20 20 20 20 20 20 20 20  mic64K}         
3df0: 20 20 20 35 31 32 20 20 20 20 20 20 31 30 32 34     512      1024
3e00: 0a 7d 20 7b 0a 20 20 69 6e 63 72 20 74 6e 0a 20  .} {.  incr tn. 
3e10: 20 69 66 20 7b 24 70 67 73 69 7a 65 3e 24 3a 3a   if {$pgsize>$::
3e20: 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f  SQLITE_MAX_PAGE_
3e30: 53 49 5a 45 7d 20 63 6f 6e 74 69 6e 75 65 0a 20  SIZE} continue. 
3e40: 20 64 62 20 63 6c 6f 73 65 0a 20 20 66 6f 72 63   db close.  forc
3e50: 65 64 65 6c 65 74 65 20 74 65 73 74 2e 64 62 20  edelete test.db 
3e60: 74 65 73 74 2e 64 62 2d 6a 6f 75 72 6e 61 6c 0a  test.db-journal.
3e70: 20 20 73 71 6c 69 74 65 33 5f 73 69 6d 75 6c 61    sqlite3_simula
3e80: 74 65 5f 64 65 76 69 63 65 20 2d 63 68 61 72 20  te_device -char 
3e90: 24 63 68 61 72 20 2d 73 65 63 74 6f 72 73 69 7a  $char -sectorsiz
3ea0: 65 20 24 73 65 63 74 6f 72 73 69 7a 65 0a 20 20  e $sectorsize.  
3eb0: 73 71 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e  sqlite3 db test.
3ec0: 64 62 20 2d 76 66 73 20 64 65 76 73 79 6d 0a 20  db -vfs devsym. 
3ed0: 20 64 62 20 65 76 61 6c 20 7b 0a 20 20 20 20 50   db eval {.    P
3ee0: 52 41 47 4d 41 20 61 75 74 6f 5f 76 61 63 75 75  RAGMA auto_vacuu
3ef0: 6d 3d 4f 46 46 3b 0a 20 20 7d 0a 20 20 69 66 63  m=OFF;.  }.  ifc
3f00: 61 70 61 62 6c 65 20 21 61 74 6f 6d 69 63 77 72  apable !atomicwr
3f10: 69 74 65 20 7b 0a 20 20 20 20 69 66 20 7b 5b 72  ite {.    if {[r
3f20: 65 67 65 78 70 20 7b 5e 61 74 6f 6d 69 63 7d 20  egexp {^atomic} 
3f30: 24 63 68 61 72 5d 7d 20 63 6f 6e 74 69 6e 75 65  $char]} continue
3f40: 0a 20 20 7d 0a 20 20 64 6f 5f 74 65 73 74 20 69  .  }.  do_test i
3f50: 6f 2d 35 2e 24 74 6e 20 7b 0a 20 20 20 20 65 78  o-5.$tn {.    ex
3f60: 65 63 73 71 6c 20 7b 0a 20 20 20 20 20 20 43 52  ecsql {.      CR
3f70: 45 41 54 45 20 54 41 42 4c 45 20 61 62 63 28 61  EATE TABLE abc(a
3f80: 2c 20 62 2c 20 63 29 3b 0a 20 20 20 20 7d 0a 20  , b, c);.    }. 
3f90: 20 20 20 65 78 70 72 20 7b 5b 66 69 6c 65 20 73     expr {[file s
3fa0: 69 7a 65 20 74 65 73 74 2e 64 62 5d 2f 32 7d 0a  ize test.db]/2}.
3fb0: 0a 20 20 20 20 6c 69 73 74 20 5b 66 69 6c 65 5f  .    list [file_
3fc0: 70 61 67 65 5f 63 6f 75 6e 74 20 74 65 73 74 2e  page_count test.
3fd0: 64 62 5d 20 5b 66 69 6c 65 5f 70 61 67 65 5f 73  db] [file_page_s
3fe0: 69 7a 65 20 74 65 73 74 2e 64 62 5d 0a 20 20 7d  ize test.db].  }
3ff0: 20 5b 6c 69 73 74 20 32 20 24 70 67 73 69 7a 65   [list 2 $pgsize
4000: 5d 0a 7d 0a 0a 73 71 6c 69 74 65 33 5f 73 69 6d  ].}..sqlite3_sim
4010: 75 6c 61 74 65 5f 64 65 76 69 63 65 20 2d 63 68  ulate_device -ch
4020: 61 72 20 7b 7d 20 2d 73 65 63 74 6f 72 73 69 7a  ar {} -sectorsiz
4030: 65 20 30 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a  e 0.finish_test.