/ Hex Artifact Content
Login

Artifact 1e811e5598ca22cfa2482cf4699ddd069200c78e:


0000: 23 20 32 30 30 38 20 4a 75 6e 65 20 32 31 0a 23  # 2008 June 21.#
0010: 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64 69  .# The author di
0020: 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68  sclaims copyrigh
0030: 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65  t to this source
0040: 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65   code.  In place
0050: 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f   of.# a legal no
0060: 74 69 63 65 2c 20 68 65 72 65 20 69 73 20 61 20  tice, here is a 
0070: 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20  blessing:.#.#   
0080: 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64   May you do good
0090: 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23   and not evil..#
00a0: 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64      May you find
00b0: 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72   forgiveness for
00c0: 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f   yourself and fo
00d0: 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20  rgive others..# 
00e0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
00f0: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0100: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0110: 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a  you give..#.#***
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 0a 23 0a 23 20 24 49 64 3a 20 70 65  ****.#.# $Id: pe
0170: 72 6d 75 74 61 74 69 6f 6e 73 2e 74 65 73 74 2c  rmutations.test,
0180: 76 20 31 2e 35 30 20 32 30 30 39 2f 30 35 2f 31  v 1.50 2009/05/1
0190: 33 20 31 34 3a 34 36 3a 31 30 20 64 61 6e 69 65  3 14:46:10 danie
01a0: 6c 6b 31 39 37 37 20 45 78 70 20 24 0a 0a 73 65  lk1977 Exp $..se
01b0: 74 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65 20  t testdir [file 
01c0: 64 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a  dirname $argv0].
01d0: 73 6f 75 72 63 65 20 24 74 65 73 74 64 69 72 2f  source $testdir/
01e0: 74 65 73 74 65 72 2e 74 63 6c 0a 0a 23 20 41 72  tester.tcl..# Ar
01f0: 67 75 6d 65 6e 74 20 70 72 6f 63 65 73 73 69 6e  gument processin
0200: 67 2e 0a 23 0a 23 70 75 74 73 20 22 50 45 52 4d  g..#.#puts "PERM
0210: 2d 44 45 42 55 47 3a 20 61 72 67 76 3d 24 61 72  -DEBUG: argv=$ar
0220: 67 76 22 0a 6e 61 6d 65 73 70 61 63 65 20 65 76  gv".namespace ev
0230: 61 6c 20 3a 3a 70 65 72 6d 20 7b 0a 20 20 76 61  al ::perm {.  va
0240: 72 69 61 62 6c 65 20 74 65 73 74 6d 6f 64 65 20  riable testmode 
0250: 5b 6c 69 6e 64 65 78 20 24 3a 3a 61 72 67 76 20  [lindex $::argv 
0260: 30 5d 0a 20 20 76 61 72 69 61 62 6c 65 20 74 65  0].  variable te
0270: 73 74 66 69 6c 65 20 5b 6c 69 6e 64 65 78 20 24  stfile [lindex $
0280: 3a 3a 61 72 67 76 20 31 5d 0a 7d 0a 73 65 74 20  ::argv 1].}.set 
0290: 61 72 67 76 20 5b 6c 72 61 6e 67 65 20 24 61 72  argv [lrange $ar
02a0: 67 76 20 32 20 65 6e 64 5d 0a 23 70 75 74 73 20  gv 2 end].#puts 
02b0: 22 50 45 52 4d 2d 44 45 42 55 47 3a 20 74 65 73  "PERM-DEBUG: tes
02c0: 74 6d 6f 64 65 3d 24 3a 3a 70 65 72 6d 3a 3a 74  tmode=$::perm::t
02d0: 65 73 74 6d 6f 64 65 20 74 73 74 66 69 6c 65 3d  estmode tstfile=
02e0: 24 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 66 69 6c  $::perm::testfil
02f0: 65 22 0a 0a 73 65 74 20 3a 3a 70 65 72 6d 75 74  e"..set ::permut
0300: 61 74 69 6f 6e 73 5f 70 72 65 73 71 6c 20 22 22  ations_presql ""
0310: 0a 73 65 74 20 3a 3a 70 65 72 6d 75 74 61 74 69  .set ::permutati
0320: 6f 6e 73 5f 74 65 73 74 5f 70 72 65 66 69 78 20  ons_test_prefix 
0330: 22 22 0a 0a 69 66 20 7b 24 3a 3a 70 65 72 6d 3a  ""..if {$::perm:
0340: 3a 74 65 73 74 6d 6f 64 65 20 65 71 20 22 76 65  :testmode eq "ve
0350: 72 79 71 75 69 63 6b 22 7d 20 7b 0a 20 20 73 65  ryquick"} {.  se
0360: 74 20 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f  t ::perm::testmo
0370: 64 65 20 5b 6c 69 73 74 20 70 65 72 73 69 73 74  de [list persist
0380: 65 6e 74 5f 6a 6f 75 72 6e 61 6c 20 6e 6f 5f 6a  ent_journal no_j
0390: 6f 75 72 6e 61 6c 5d 0a 20 20 73 65 74 20 49 53  ournal].  set IS
03a0: 51 55 49 43 4b 20 31 0a 7d 0a 69 66 20 7b 24 3a  QUICK 1.}.if {$:
03b0: 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f 64 65 20  :perm::testmode 
03c0: 65 71 20 22 71 75 69 63 6b 22 7d 20 7b 0a 20 20  eq "quick"} {.  
03d0: 73 65 74 20 3a 3a 70 65 72 6d 3a 3a 74 65 73 74  set ::perm::test
03e0: 6d 6f 64 65 20 5b 6c 69 73 74 20 70 65 72 73 69  mode [list persi
03f0: 73 74 65 6e 74 5f 6a 6f 75 72 6e 61 6c 20 6e 6f  stent_journal no
0400: 5f 6a 6f 75 72 6e 61 6c 20 61 75 74 6f 76 61 63  _journal autovac
0410: 75 75 6d 5f 69 6f 65 72 72 5d 0a 20 20 73 65 74  uum_ioerr].  set
0420: 20 49 53 51 55 49 43 4b 20 31 0a 7d 0a 69 66 20   ISQUICK 1.}.if 
0430: 7b 24 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f  {$::perm::testmo
0440: 64 65 20 65 71 20 22 61 6c 6c 22 20 7c 7c 20 24  de eq "all" || $
0450: 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f 64 65  ::perm::testmode
0460: 20 65 71 20 22 22 7d 20 7b 0a 20 20 73 65 74 20   eq ""} {.  set 
0470: 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f 64 65  ::perm::testmode
0480: 20 7b 0a 20 20 20 20 6d 65 6d 73 75 62 73 79 73   {.    memsubsys
0490: 31 20 6d 65 6d 73 75 62 73 79 73 32 20 73 69 6e  1 memsubsys2 sin
04a0: 67 6c 65 74 68 72 65 61 64 20 6d 75 6c 74 69 74  glethread multit
04b0: 68 72 65 61 64 20 6f 6e 65 66 69 6c 65 20 75 74  hread onefile ut
04c0: 66 31 36 20 65 78 63 6c 75 73 69 76 65 0a 20 20  f16 exclusive.  
04d0: 20 20 70 65 72 73 69 73 74 65 6e 74 5f 6a 6f 75    persistent_jou
04e0: 72 6e 61 6c 20 70 65 72 73 69 73 74 65 6e 74 5f  rnal persistent_
04f0: 6a 6f 75 72 6e 61 6c 5f 65 72 72 6f 72 20 6e 6f  journal_error no
0500: 5f 6a 6f 75 72 6e 61 6c 20 6e 6f 5f 6a 6f 75 72  _journal no_jour
0510: 6e 61 6c 5f 65 72 72 6f 72 0a 20 20 20 20 61 75  nal_error.    au
0520: 74 6f 76 61 63 75 75 6d 5f 69 6f 65 72 72 20 6e  tovacuum_ioerr n
0530: 6f 5f 6d 75 74 65 78 5f 74 72 79 20 66 75 6c 6c  o_mutex_try full
0540: 6d 75 74 65 78 20 6a 6f 75 72 6e 61 6c 74 65 73  mutex journaltes
0550: 74 20 69 6e 6d 65 6d 6f 72 79 5f 6a 6f 75 72 6e  t inmemory_journ
0560: 61 6c 0a 20 20 20 20 70 63 61 63 68 65 30 20 70  al.    pcache0 p
0570: 63 61 63 68 65 31 30 20 70 63 61 63 68 65 35 30  cache10 pcache50
0580: 20 70 63 61 63 68 65 39 30 20 70 63 61 63 68 65   pcache90 pcache
0590: 31 30 30 0a 20 20 7d 0a 7d 0a 69 66 20 7b 24 3a  100.  }.}.if {$:
05a0: 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f 64 65 20  :perm::testmode 
05b0: 65 71 20 22 74 61 72 67 65 74 73 22 7d 20 7b 20  eq "targets"} { 
05c0: 0a 20 20 70 75 74 73 20 22 22 0a 20 20 70 75 74  .  puts "".  put
05d0: 73 20 2d 6e 6f 6e 65 77 6c 69 6e 65 20 22 76 65  s -nonewline "ve
05e0: 72 79 71 75 69 63 6b 20 20 20 20 20 20 20 20 20  ryquick         
05f0: 20 20 20 22 0a 20 20 70 75 74 73 20 22 53 61 6d     ".  puts "Sam
0600: 65 20 61 73 20 70 65 72 73 69 73 74 65 6e 74 5f  e as persistent_
0610: 6a 6f 75 72 6e 61 6c 20 61 6e 64 20 6e 6f 5f 6a  journal and no_j
0620: 6f 75 72 6e 61 6c 22 0a 20 20 70 75 74 73 20 2d  ournal".  puts -
0630: 6e 6f 6e 65 77 6c 69 6e 65 20 22 71 75 69 63 6b  nonewline "quick
0640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0650: 22 0a 20 20 70 75 74 73 20 22 53 61 6d 65 20 61  ".  puts "Same a
0660: 73 20 70 65 72 73 69 73 74 65 6e 74 5f 6a 6f 75  s persistent_jou
0670: 72 6e 61 6c 2c 20 6e 6f 5f 6a 6f 75 72 6e 61 6c  rnal, no_journal
0680: 20 61 6e 64 20 61 75 74 6f 76 61 63 75 75 6d 5f   and autovacuum_
0690: 69 6f 65 72 72 22 0a 20 20 70 75 74 73 20 2d 6e  ioerr".  puts -n
06a0: 6f 6e 65 77 6c 69 6e 65 20 22 61 6c 6c 20 20 20  onewline "all   
06b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
06c0: 0a 20 20 70 75 74 73 20 22 45 76 65 72 79 74 68  .  puts "Everyth
06d0: 69 6e 67 20 65 78 63 65 70 74 20 61 75 74 6f 76  ing except autov
06e0: 61 63 75 75 6d 5f 63 72 61 73 68 22 0a 7d 0a 23  acuum_crash".}.#
06f0: 70 75 74 73 20 22 50 45 52 4d 2d 44 45 42 55 47  puts "PERM-DEBUG
0700: 3a 20 74 65 73 74 6d 6f 64 65 3d 24 3a 3a 70 65  : testmode=$::pe
0710: 72 6d 3a 3a 74 65 73 74 6d 6f 64 65 22 0a 0a 73  rm::testmode"..s
0720: 65 74 20 45 58 43 4c 55 44 45 20 7b 0a 20 20 61  et EXCLUDE {.  a
0730: 6c 6c 2e 74 65 73 74 20 20 20 20 20 20 20 20 20  ll.test         
0740: 20 20 20 20 20 20 20 20 20 69 6e 32 2e 74 65 73           in2.tes
0750: 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t               
0760: 20 20 20 6f 6e 65 66 69 6c 65 2e 74 65 73 74 0a     onefile.test.
0770: 20 20 61 73 79 6e 63 32 2e 74 65 73 74 20 20 20    async2.test   
0780: 20 20 20 20 20 20 20 20 20 20 20 20 69 6e 63 72              incr
0790: 76 61 63 75 75 6d 5f 69 6f 65 72 72 2e 74 65 73  vacuum_ioerr.tes
07a0: 74 20 20 20 20 20 70 65 72 6d 75 74 61 74 69 6f  t     permutatio
07b0: 6e 73 2e 74 65 73 74 0a 20 20 61 73 79 6e 63 2e  ns.test.  async.
07c0: 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20  test            
07d0: 20 20 20 20 6a 72 6e 6c 6d 6f 64 65 32 2e 74 65      jrnlmode2.te
07e0: 73 74 20 20 20 20 20 20 20 20 20 20 20 20 71 75  st            qu
07f0: 69 63 6b 2e 74 65 73 74 0a 20 20 61 75 74 6f 76  ick.test.  autov
0800: 61 63 75 75 6d 5f 63 72 61 73 68 2e 74 65 73 74  acuum_crash.test
0810: 20 20 20 20 20 6a 72 6e 6c 6d 6f 64 65 33 2e 74       jrnlmode3.t
0820: 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20 73  est            s
0830: 68 61 72 65 64 5f 65 72 72 2e 74 65 73 74 0a 20  hared_err.test. 
0840: 20 61 75 74 6f 76 61 63 75 75 6d 5f 69 6f 65 72   autovacuum_ioer
0850: 72 2e 74 65 73 74 20 20 20 20 20 6a 72 6e 6c 6d  r.test     jrnlm
0860: 6f 64 65 34 2e 74 65 73 74 20 20 20 20 20 20 20  ode4.test       
0870: 20 20 20 20 20 73 6f 61 6b 2e 74 65 73 74 0a 20       soak.test. 
0880: 20 62 74 72 65 65 38 2e 74 65 73 74 20 20 20 20   btree8.test    
0890: 20 20 20 20 20 20 20 20 20 20 20 6c 6f 61 64 65             loade
08a0: 78 74 2e 74 65 73 74 20 20 20 20 20 20 20 20 20  xt.test         
08b0: 20 20 20 20 20 73 70 65 65 64 31 70 2e 74 65 73       speed1p.tes
08c0: 74 0a 20 20 63 6f 72 72 75 70 74 2e 74 65 73 74  t.  corrupt.test
08d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6d 61                ma
08e0: 6c 6c 6f 63 32 2e 74 65 73 74 20 20 20 20 20 20  lloc2.test      
08f0: 20 20 20 20 20 20 20 20 73 70 65 65 64 31 2e 74          speed1.t
0900: 65 73 74 0a 20 20 63 72 61 73 68 32 2e 74 65 73  est.  crash2.tes
0910: 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t               
0920: 6d 61 6c 6c 6f 63 33 2e 74 65 73 74 20 20 20 20  malloc3.test    
0930: 20 20 20 20 20 20 20 20 20 20 73 70 65 65 64 32            speed2
0940: 2e 74 65 73 74 0a 20 20 63 72 61 73 68 33 2e 74  .test.  crash3.t
0950: 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20 20  est             
0960: 20 20 6d 61 6c 6c 6f 63 34 2e 74 65 73 74 20 20    malloc4.test  
0970: 20 20 20 20 20 20 20 20 20 20 20 20 73 70 65 65              spee
0980: 64 33 2e 74 65 73 74 0a 20 20 63 72 61 73 68 34  d3.test.  crash4
0990: 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20  .test           
09a0: 20 20 20 20 6d 61 6c 6c 6f 63 41 6c 6c 2e 74 65      mallocAll.te
09b0: 73 74 20 20 20 20 20 20 20 20 20 20 20 20 73 70  st            sp
09c0: 65 65 64 34 70 2e 74 65 73 74 0a 20 20 63 72 61  eed4p.test.  cra
09d0: 73 68 36 2e 74 65 73 74 20 20 20 20 20 20 20 20  sh6.test        
09e0: 20 20 20 20 20 20 20 6d 61 6c 6c 6f 63 2e 74 65         malloc.te
09f0: 73 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20  st              
0a00: 20 73 70 65 65 64 34 2e 74 65 73 74 0a 20 20 63   speed4.test.  c
0a10: 72 61 73 68 37 2e 74 65 73 74 20 20 20 20 20 20  rash7.test      
0a20: 20 20 20 20 20 20 20 20 20 6d 65 6d 6c 65 61 6b           memleak
0a30: 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20  .test           
0a40: 20 20 20 73 71 6c 6c 69 6d 69 74 73 31 2e 74 65     sqllimits1.te
0a50: 73 74 0a 20 20 63 72 61 73 68 2e 74 65 73 74 20  st.  crash.test 
0a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6d                 m
0a70: 65 6d 73 75 62 73 79 73 31 2e 74 65 73 74 20 20  emsubsys1.test  
0a80: 20 20 20 20 20 20 20 20 20 74 68 72 65 61 64 30           thread0
0a90: 30 31 2e 74 65 73 74 0a 20 20 65 78 63 6c 75 73  01.test.  exclus
0aa0: 69 76 65 33 2e 74 65 73 74 20 20 20 20 20 20 20  ive3.test       
0ab0: 20 20 20 20 6d 65 6d 73 75 62 73 79 73 32 2e 74      memsubsys2.t
0ac0: 65 73 74 20 20 20 20 20 20 20 20 20 20 20 74 68  est           th
0ad0: 72 65 61 64 30 30 32 2e 74 65 73 74 0a 20 20 66  read002.test.  f
0ae0: 74 73 33 2e 74 65 73 74 20 20 20 20 20 20 20 20  ts3.test        
0af0: 20 20 20 20 20 20 20 20 20 6d 69 73 63 37 2e 74           misc7.t
0b00: 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20 20  est             
0b10: 20 20 20 75 74 66 31 36 2e 74 65 73 74 0a 20 20     utf16.test.  
0b20: 66 75 7a 7a 5f 6d 61 6c 6c 6f 63 2e 74 65 73 74  fuzz_malloc.test
0b30: 20 20 20 20 20 20 20 20 20 20 6d 69 73 75 73 65            misuse
0b40: 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20  .test           
0b50: 20 20 20 20 76 65 72 79 71 75 69 63 6b 2e 74 65      veryquick.te
0b60: 73 74 0a 20 20 66 75 7a 7a 2e 74 65 73 74 20 20  st.  fuzz.test  
0b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6d                 m
0b80: 75 74 65 78 32 2e 74 65 73 74 20 20 20 20 20 20  utex2.test      
0b90: 20 20 20 20 20 20 20 20 20 76 74 61 62 5f 65 72           vtab_er
0ba0: 72 2e 74 65 73 74 0a 20 20 6c 6f 6f 6b 61 73 69  r.test.  lookasi
0bb0: 64 65 2e 74 65 73 74 20 20 20 20 20 20 20 20 20  de.test         
0bc0: 20 20 20 66 75 7a 7a 33 2e 74 65 73 74 20 20 20     fuzz3.test   
0bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 61 76               sav
0be0: 65 70 6f 69 6e 74 34 2e 74 65 73 74 0a 20 20 73  epoint4.test.  s
0bf0: 61 76 65 70 6f 69 6e 74 36 2e 74 65 73 74 0a 7d  avepoint6.test.}
0c00: 0a 73 65 74 20 41 4c 4c 54 45 53 54 53 20 5b 6c  .set ALLTESTS [l
0c10: 69 73 74 5d 0a 66 6f 72 65 61 63 68 20 66 69 6c  ist].foreach fil
0c20: 65 6e 61 6d 65 20 5b 67 6c 6f 62 20 24 74 65 73  ename [glob $tes
0c30: 74 64 69 72 2f 2a 2e 74 65 73 74 5d 20 7b 0a 20  tdir/*.test] {. 
0c40: 20 73 65 74 20 66 69 6c 65 6e 61 6d 65 20 5b 66   set filename [f
0c50: 69 6c 65 20 74 61 69 6c 20 24 66 69 6c 65 6e 61  ile tail $filena
0c60: 6d 65 5d 0a 20 20 69 66 20 7b 5b 6c 73 65 61 72  me].  if {[lsear
0c70: 63 68 20 24 45 58 43 4c 55 44 45 20 24 66 69 6c  ch $EXCLUDE $fil
0c80: 65 6e 61 6d 65 5d 20 3c 20 30 7d 20 7b 20 6c 61  ename] < 0} { la
0c90: 70 70 65 6e 64 20 41 4c 4c 54 45 53 54 53 20 24  ppend ALLTESTS $
0ca0: 66 69 6c 65 6e 61 6d 65 20 7d 0a 7d 0a 73 65 74  filename }.}.set
0cb0: 20 41 4c 4c 54 45 53 54 53 20 5b 6c 73 6f 72 74   ALLTESTS [lsort
0cc0: 20 24 41 4c 4c 54 45 53 54 53 5d 0a 0a 72 65 6e   $ALLTESTS]..ren
0cd0: 61 6d 65 20 66 69 6e 69 73 68 5f 74 65 73 74 20  ame finish_test 
0ce0: 72 65 61 6c 6c 79 5f 66 69 6e 69 73 68 5f 74 65  really_finish_te
0cf0: 73 74 32 0a 70 72 6f 63 20 66 69 6e 69 73 68 5f  st2.proc finish_
0d00: 74 65 73 74 20 7b 7d 20 7b 7d 0a 0a 72 65 6e 61  test {} {}..rena
0d10: 6d 65 20 64 6f 5f 74 65 73 74 20 72 65 61 6c 6c  me do_test reall
0d20: 79 5f 64 6f 5f 74 65 73 74 0a 0a 70 72 6f 63 20  y_do_test..proc 
0d30: 64 6f 5f 74 65 73 74 20 7b 6e 61 6d 65 20 61 72  do_test {name ar
0d40: 67 73 7d 20 7b 0a 20 20 65 76 61 6c 20 72 65 61  gs} {.  eval rea
0d50: 6c 6c 79 5f 64 6f 5f 74 65 73 74 20 5b 6c 69 73  lly_do_test [lis
0d60: 74 20 22 70 65 72 6d 2d 24 3a 3a 70 65 72 6d 75  t "perm-$::permu
0d70: 74 61 74 69 6f 6e 73 5f 74 65 73 74 5f 70 72 65  tations_test_pre
0d80: 66 69 78 2e 24 6e 61 6d 65 22 5d 20 24 61 72 67  fix.$name"] $arg
0d90: 73 0a 7d 0a 0a 23 20 4f 76 65 72 6c 6f 61 64 20  s.}..# Overload 
0da0: 74 68 65 20 5b 73 71 6c 69 74 65 33 5d 20 63 6f  the [sqlite3] co
0db0: 6d 6d 61 6e 64 0a 72 65 6e 61 6d 65 20 73 71 6c  mmand.rename sql
0dc0: 69 74 65 33 20 72 65 61 6c 6c 79 5f 73 71 6c 69  ite3 really_sqli
0dd0: 74 65 33 0a 70 72 6f 63 20 73 71 6c 69 74 65 33  te3.proc sqlite3
0de0: 20 7b 61 72 67 73 7d 20 7b 0a 20 20 73 65 74 20   {args} {.  set 
0df0: 72 20 5b 65 76 61 6c 20 72 65 61 6c 6c 79 5f 73  r [eval really_s
0e00: 71 6c 69 74 65 33 20 24 61 72 67 73 5d 0a 20 20  qlite3 $args].  
0e10: 69 66 20 7b 20 5b 6c 6c 65 6e 67 74 68 20 24 61  if { [llength $a
0e20: 72 67 73 5d 20 3d 3d 20 32 20 26 26 20 24 3a 3a  rgs] == 2 && $::
0e30: 70 65 72 6d 75 74 61 74 69 6f 6e 73 5f 70 72 65  permutations_pre
0e40: 73 71 6c 20 6e 65 20 22 22 20 7d 20 7b 0a 20 20  sql ne "" } {.  
0e50: 20 20 5b 6c 69 6e 64 65 78 20 24 61 72 67 73 20    [lindex $args 
0e60: 30 5d 20 65 76 61 6c 20 24 3a 3a 70 65 72 6d 75  0] eval $::permu
0e70: 74 61 74 69 6f 6e 73 5f 70 72 65 73 71 6c 0a 20  tations_presql. 
0e80: 20 7d 0a 20 20 73 65 74 20 72 0a 7d 0a 0a 23 20   }.  set r.}..# 
0e90: 72 75 6e 5f 74 65 73 74 73 20 4f 50 54 49 4f 4e  run_tests OPTION
0ea0: 53 0a 23 0a 23 20 77 68 65 72 65 20 61 76 61 69  S.#.# where avai
0eb0: 6c 61 62 6c 65 20 6f 70 74 69 6f 6e 73 20 61 72  lable options ar
0ec0: 65 3a 20 20 0a 23 0a 23 20 20 20 20 20 20 20 2d  e:  .#.#       -
0ed0: 69 6e 69 74 69 61 6c 69 7a 65 20 20 53 43 52 49  initialize  SCRI
0ee0: 50 54 20 20 20 20 20 20 20 20 20 20 20 20 20 20  PT              
0ef0: 20 20 20 28 64 65 66 61 75 6c 74 20 22 22 29 0a     (default "").
0f00: 23 20 20 20 20 20 20 20 2d 73 68 75 74 64 6f 77  #       -shutdow
0f10: 6e 20 20 20 20 53 43 52 49 50 54 20 20 20 20 20  n    SCRIPT     
0f20: 20 20 20 20 20 20 20 20 20 20 20 20 28 64 65 66              (def
0f30: 61 75 6c 74 20 22 22 29 0a 23 20 20 20 20 20 20  ault "").#      
0f40: 20 2d 69 6e 63 6c 75 64 65 20 20 20 20 20 4c 49   -include     LI
0f50: 53 54 2d 4f 46 2d 46 49 4c 45 53 20 20 20 20 20  ST-OF-FILES     
0f60: 20 20 20 20 20 28 64 65 66 61 75 6c 74 20 24 3a       (default $:
0f70: 3a 41 4c 4c 54 45 53 54 53 29 0a 23 20 20 20 20  :ALLTESTS).#    
0f80: 20 20 20 2d 65 78 63 6c 75 64 65 20 20 20 20 20     -exclude     
0f90: 4c 49 53 54 2d 4f 46 2d 46 49 4c 45 53 20 20 20  LIST-OF-FILES   
0fa0: 20 20 20 20 20 20 20 28 64 65 66 61 75 6c 74 20         (default 
0fb0: 22 22 29 0a 23 20 20 20 20 20 20 20 2d 70 72 65  "").#       -pre
0fc0: 73 71 6c 20 20 20 20 20 20 53 51 4c 20 20 20 20  sql      SQL    
0fd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0fe0: 28 64 65 66 61 75 6c 74 20 22 22 29 0a 23 20 20  (default "").#  
0ff0: 20 20 20 20 20 2d 64 65 73 63 72 69 70 74 69 6f       -descriptio
1000: 6e 20 54 49 54 4c 45 20 20 20 20 20 20 20 20 20  n TITLE         
1010: 20 20 20 20 20 20 20 20 20 28 64 65 66 61 75 6c           (defaul
1020: 74 20 22 22 29 0a 23 0a 70 72 6f 63 20 72 75 6e  t "").#.proc run
1030: 5f 74 65 73 74 73 20 7b 6e 61 6d 65 20 61 72 67  _tests {name arg
1040: 73 7d 20 7b 0a 20 20 73 65 74 20 3a 3a 70 65 72  s} {.  set ::per
1050: 6d 75 74 61 74 69 6f 6e 73 5f 74 65 73 74 5f 70  mutations_test_p
1060: 72 65 66 69 78 20 24 6e 61 6d 65 0a 20 20 73 65  refix $name.  se
1070: 74 20 6f 70 74 69 6f 6e 73 28 2d 73 68 75 74 64  t options(-shutd
1080: 6f 77 6e 29 20 22 22 0a 20 20 73 65 74 20 6f 70  own) "".  set op
1090: 74 69 6f 6e 73 28 2d 69 6e 69 74 69 61 6c 69 7a  tions(-initializ
10a0: 65 29 20 22 22 0a 20 20 73 65 74 20 6f 70 74 69  e) "".  set opti
10b0: 6f 6e 73 28 2d 65 78 63 6c 75 64 65 29 20 22 22  ons(-exclude) ""
10c0: 0a 20 20 73 65 74 20 6f 70 74 69 6f 6e 73 28 2d  .  set options(-
10d0: 69 6e 63 6c 75 64 65 29 20 24 3a 3a 41 4c 4c 54  include) $::ALLT
10e0: 45 53 54 53 0a 20 20 73 65 74 20 6f 70 74 69 6f  ESTS.  set optio
10f0: 6e 73 28 2d 70 72 65 73 71 6c 29 20 22 22 0a 20  ns(-presql) "". 
1100: 20 73 65 74 20 6f 70 74 69 6f 6e 73 28 2d 64 65   set options(-de
1110: 73 63 72 69 70 74 69 6f 6e 29 20 22 6e 6f 20 64  scription) "no d
1120: 65 73 63 72 69 70 74 69 6f 6e 20 73 75 70 70 6c  escription suppl
1130: 69 65 64 20 28 66 69 78 6d 65 29 22 0a 20 20 61  ied (fixme)".  a
1140: 72 72 61 79 20 73 65 74 20 6f 70 74 69 6f 6e 73  rray set options
1150: 20 24 61 72 67 73 0a 20 20 23 70 75 74 73 20 22   $args.  #puts "
1160: 50 45 52 4d 2d 44 45 42 55 47 3a 20 6e 61 6d 65  PERM-DEBUG: name
1170: 3d 24 6e 61 6d 65 20 74 65 73 74 66 69 6c 65 3d  =$name testfile=
1180: 24 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 66 69 6c  $::perm::testfil
1190: 65 22 0a 20 20 23 70 75 74 73 20 22 50 45 52 4d  e".  #puts "PERM
11a0: 2d 44 45 42 55 47 3a 20 5b 61 72 72 61 79 20 67  -DEBUG: [array g
11b0: 65 74 20 6f 70 74 69 6f 6e 73 5d 22 0a 0a 20 20  et options]"..  
11c0: 69 66 20 7b 24 3a 3a 70 65 72 6d 3a 3a 74 65 73  if {$::perm::tes
11d0: 74 6d 6f 64 65 20 65 71 20 22 74 61 72 67 65 74  tmode eq "target
11e0: 73 22 7d 20 7b 0a 20 20 20 20 70 75 74 73 20 5b  s"} {.    puts [
11f0: 66 6f 72 6d 61 74 20 22 25 20 2d 32 30 73 20 25  format "% -20s %
1200: 73 22 20 24 6e 61 6d 65 20 5b 73 74 72 69 6e 67  s" $name [string
1210: 20 74 72 69 6d 20 24 6f 70 74 69 6f 6e 73 28 2d   trim $options(-
1220: 64 65 73 63 72 69 70 74 69 6f 6e 29 5d 5d 0a 20  description)]]. 
1230: 20 20 20 72 65 74 75 72 6e 0a 20 20 7d 0a 20 20     return.  }.  
1240: 69 66 20 7b 24 3a 3a 70 65 72 6d 3a 3a 74 65 73  if {$::perm::tes
1250: 74 6d 6f 64 65 20 6e 65 20 22 22 20 26 26 20 5b  tmode ne "" && [
1260: 6c 73 65 61 72 63 68 20 24 3a 3a 70 65 72 6d 3a  lsearch $::perm:
1270: 3a 74 65 73 74 6d 6f 64 65 20 24 6e 61 6d 65 5d  :testmode $name]
1280: 3c 30 7d 20 7b 0a 20 20 20 20 70 75 74 73 20 22  <0} {.    puts "
1290: 73 6b 69 70 70 69 6e 67 20 70 65 72 6d 75 74 61  skipping permuta
12a0: 74 69 6f 6e 20 74 65 73 74 20 24 6e 61 6d 65 2e  tion test $name.
12b0: 2e 2e 22 0a 20 20 20 20 72 65 74 75 72 6e 0a 20  ..".    return. 
12c0: 20 7d 0a 0a 20 20 75 70 6c 65 76 65 6c 20 24 6f   }..  uplevel $o
12d0: 70 74 69 6f 6e 73 28 2d 69 6e 69 74 69 61 6c 69  ptions(-initiali
12e0: 7a 65 29 0a 20 20 73 65 74 20 3a 3a 70 65 72 6d  ze).  set ::perm
12f0: 75 74 61 74 69 6f 6e 73 5f 70 72 65 73 71 6c 20  utations_presql 
1300: 24 6f 70 74 69 6f 6e 73 28 2d 70 72 65 73 71 6c  $options(-presql
1310: 29 0a 0a 20 20 66 6f 72 65 61 63 68 20 66 69 6c  )..  foreach fil
1320: 65 20 5b 6c 73 6f 72 74 20 24 6f 70 74 69 6f 6e  e [lsort $option
1330: 73 28 2d 69 6e 63 6c 75 64 65 29 5d 20 7b 0a 20  s(-include)] {. 
1340: 20 20 20 69 66 20 7b 5b 6c 73 65 61 72 63 68 20     if {[lsearch 
1350: 24 6f 70 74 69 6f 6e 73 28 2d 65 78 63 6c 75 64  $options(-exclud
1360: 65 29 20 24 66 69 6c 65 5d 20 3c 20 30 20 26 26  e) $file] < 0 &&
1370: 0a 20 20 20 20 20 20 20 28 20 24 3a 3a 70 65 72  .       ( $::per
1380: 6d 3a 3a 74 65 73 74 66 69 6c 65 20 65 71 20 22  m::testfile eq "
1390: 22 20 7c 7c 0a 20 20 20 20 20 20 20 20 20 24 3a  " ||.         $:
13a0: 3a 70 65 72 6d 3a 3a 74 65 73 74 66 69 6c 65 20  :perm::testfile 
13b0: 65 71 20 24 66 69 6c 65 20 7c 7c 0a 20 20 20 20  eq $file ||.    
13c0: 20 20 20 20 22 24 3a 3a 70 65 72 6d 3a 3a 74 65      "$::perm::te
13d0: 73 74 66 69 6c 65 2e 74 65 73 74 22 20 65 71 20  stfile.test" eq 
13e0: 24 66 69 6c 65 20 29 0a 20 20 20 20 7d 20 7b 0a  $file ).    } {.
13f0: 20 20 20 20 20 20 73 65 74 20 3a 3a 70 65 72 6d        set ::perm
1400: 3a 3a 73 68 61 72 65 64 5f 63 61 63 68 65 5f 73  ::shared_cache_s
1410: 65 74 74 69 6e 67 20 5b 73 68 61 72 65 64 5f 63  etting [shared_c
1420: 61 63 68 65 5f 73 65 74 74 69 6e 67 5d 0a 20 20  ache_setting].  
1430: 20 20 20 20 75 70 6c 65 76 65 6c 20 73 6f 75 72      uplevel sour
1440: 63 65 20 24 3a 3a 74 65 73 74 64 69 72 2f 24 66  ce $::testdir/$f
1450: 69 6c 65 0a 20 20 20 20 20 20 69 66 20 7b 24 3a  ile.      if {$:
1460: 3a 70 65 72 6d 3a 3a 73 68 61 72 65 64 5f 63 61  :perm::shared_ca
1470: 63 68 65 5f 73 65 74 74 69 6e 67 20 6e 65 20 5b  che_setting ne [
1480: 73 68 61 72 65 64 5f 63 61 63 68 65 5f 73 65 74  shared_cache_set
1490: 74 69 6e 67 5d 7d 20 7b 0a 20 20 20 20 20 20 20  ting]} {.       
14a0: 20 65 72 72 6f 72 20 22 46 69 6c 65 20 24 3a 3a   error "File $::
14b0: 74 65 73 74 64 69 72 2f 24 66 69 6c 65 20 63 68  testdir/$file ch
14c0: 61 6e 67 65 64 20 74 68 65 20 73 68 61 72 65 64  anged the shared
14d0: 20 63 61 63 68 65 20 73 65 74 74 69 6e 67 20 66   cache setting f
14e0: 72 6f 6d 20 24 3a 3a 70 65 72 6d 3a 3a 73 68 61  rom $::perm::sha
14f0: 72 65 64 5f 63 61 63 68 65 5f 73 65 74 74 69 6e  red_cache_settin
1500: 67 20 74 6f 20 5b 73 68 61 72 65 64 5f 63 61 63  g to [shared_cac
1510: 68 65 5f 73 65 74 74 69 6e 67 5d 22 0a 20 20 20  he_setting]".   
1520: 20 20 20 7d 0a 20 20 20 20 7d 20 65 6c 73 65 20     }.    } else 
1530: 7b 0a 20 20 20 20 20 20 23 20 70 75 74 73 20 22  {.      # puts "
1540: 73 6b 69 70 70 69 6e 67 20 66 69 6c 65 20 24 66  skipping file $f
1550: 69 6c 65 22 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a  ile".    }.  }..
1560: 20 20 75 70 6c 65 76 65 6c 20 24 6f 70 74 69 6f    uplevel $optio
1570: 6e 73 28 2d 73 68 75 74 64 6f 77 6e 29 0a 20 20  ns(-shutdown).  
1580: 73 65 74 20 3a 3a 70 65 72 6d 75 74 61 74 69 6f  set ::permutatio
1590: 6e 73 5f 74 65 73 74 5f 70 72 65 66 69 78 20 22  ns_test_prefix "
15a0: 22 0a 7d 0a 0a 70 72 6f 63 20 73 68 61 72 65 64  ".}..proc shared
15b0: 5f 63 61 63 68 65 5f 73 65 74 74 69 6e 67 20 7b  _cache_setting {
15c0: 7d 20 7b 0a 20 20 73 65 74 20 72 65 74 20 30 0a  } {.  set ret 0.
15d0: 20 20 63 61 74 63 68 20 7b 0a 20 20 20 20 73 65    catch {.    se
15e0: 74 20 72 65 74 20 5b 73 71 6c 69 74 65 33 5f 65  t ret [sqlite3_e
15f0: 6e 61 62 6c 65 5f 73 68 61 72 65 64 5f 63 61 63  nable_shared_cac
1600: 68 65 5d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  he].  }.  return
1610: 20 24 72 65 74 0a 7d 0a 0a 23 23 23 23 23 23 23   $ret.}..#######
1620: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1630: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1640: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1650: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
1660: 23 23 23 23 23 23 0a 23 20 53 74 61 72 74 20 6f  ######.# Start o
1670: 66 20 74 65 73 74 73 0a 0a 23 20 52 75 6e 20 73  f tests..# Run s
1680: 6f 6d 65 20 74 65 73 74 73 20 75 73 69 6e 67 20  ome tests using 
1690: 70 72 65 2d 61 6c 6c 6f 63 61 74 65 64 20 70 61  pre-allocated pa
16a0: 67 65 20 61 6e 64 20 73 63 72 61 74 63 68 20 62  ge and scratch b
16b0: 6c 6f 63 6b 73 2e 0a 23 0a 72 75 6e 5f 74 65 73  locks..#.run_tes
16c0: 74 73 20 22 6d 65 6d 73 75 62 73 79 73 31 22 20  ts "memsubsys1" 
16d0: 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b 0a 20  -description {. 
16e0: 20 54 65 73 74 73 20 75 73 69 6e 67 20 70 72 65   Tests using pre
16f0: 2d 61 6c 6c 6f 63 61 74 65 64 20 70 61 67 65 20  -allocated page 
1700: 61 6e 64 20 73 63 72 61 74 63 68 20 62 6c 6f 63  and scratch bloc
1710: 6b 73 0a 7d 20 2d 65 78 63 6c 75 64 65 20 7b 0a  ks.} -exclude {.
1720: 20 20 69 6f 65 72 72 35 2e 74 65 73 74 0a 20 20    ioerr5.test.  
1730: 6d 61 6c 6c 6f 63 35 2e 74 65 73 74 0a 7d 20 2d  malloc5.test.} -
1740: 69 6e 69 74 69 61 6c 69 7a 65 20 7b 0a 20 20 63  initialize {.  c
1750: 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a  atch {db close}.
1760: 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f    sqlite3_shutdo
1770: 77 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e  wn.  sqlite3_con
1780: 66 69 67 5f 70 61 67 65 63 61 63 68 65 20 34 30  fig_pagecache 40
1790: 39 36 20 32 34 0a 20 20 73 71 6c 69 74 65 33 5f  96 24.  sqlite3_
17a0: 63 6f 6e 66 69 67 5f 73 63 72 61 74 63 68 20 32  config_scratch 2
17b0: 35 30 30 30 20 31 0a 20 20 73 71 6c 69 74 65 33  5000 1.  sqlite3
17c0: 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 61 75  _initialize.  au
17d0: 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66  toinstall_test_f
17e0: 75 6e 63 74 69 6f 6e 73 0a 7d 20 2d 73 68 75 74  unctions.} -shut
17f0: 64 6f 77 6e 20 7b 0a 20 20 63 61 74 63 68 20 7b  down {.  catch {
1800: 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69  db close}.  sqli
1810: 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73  te3_shutdown.  s
1820: 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 70 61  qlite3_config_pa
1830: 67 65 63 61 63 68 65 20 30 20 30 0a 20 20 73 71  gecache 0 0.  sq
1840: 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 73 63 72  lite3_config_scr
1850: 61 74 63 68 20 30 20 30 0a 20 20 73 71 6c 69 74  atch 0 0.  sqlit
1860: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20  e3_initialize.  
1870: 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74  autoinstall_test
1880: 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 0a 0a 23 20  _functions.}..# 
1890: 52 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20 75  Run some tests u
18a0: 73 69 6e 67 20 70 72 65 2d 61 6c 6c 6f 63 61 74  sing pre-allocat
18b0: 65 64 20 70 61 67 65 20 61 6e 64 20 73 63 72 61  ed page and scra
18c0: 74 63 68 20 62 6c 6f 63 6b 73 2e 20 54 68 69 73  tch blocks. This
18d0: 20 74 69 6d 65 0a 23 20 74 68 65 20 61 6c 6c 6f   time.# the allo
18e0: 63 61 74 69 6f 6e 73 20 61 72 65 20 74 6f 6f 20  cations are too 
18f0: 73 6d 61 6c 6c 20 74 6f 20 75 73 65 20 69 6e 20  small to use in 
1900: 6d 6f 73 74 20 63 61 73 65 73 2e 0a 23 0a 23 20  most cases..#.# 
1910: 42 6f 74 68 20 69 6f 65 72 72 35 2e 74 65 73 74  Both ioerr5.test
1920: 20 61 6e 64 20 6d 61 6c 6c 6f 63 35 2e 74 65 73   and malloc5.tes
1930: 74 20 61 72 65 20 65 78 63 6c 75 64 65 64 20 62  t are excluded b
1940: 65 63 61 75 73 65 20 74 68 65 79 20 74 65 73 74  ecause they test
1950: 20 74 68 65 0a 23 20 73 71 6c 69 74 65 33 5f 73   the.# sqlite3_s
1960: 6f 66 74 5f 68 65 61 70 5f 6c 69 6d 69 74 28 29  oft_heap_limit()
1970: 20 61 6e 64 20 73 71 6c 69 74 65 33 5f 72 65 6c   and sqlite3_rel
1980: 65 61 73 65 5f 6d 65 6d 6f 72 79 28 29 20 66 75  ease_memory() fu
1990: 6e 63 74 69 6f 6e 61 6c 69 74 79 2e 0a 23 20 54  nctionality..# T
19a0: 68 69 73 20 66 75 6e 63 74 69 6f 6e 61 6c 69 74  his functionalit
19b0: 79 20 69 73 20 64 69 73 61 62 6c 65 64 20 69 66  y is disabled if
19c0: 20 61 20 70 72 65 2d 61 6c 6c 6f 63 61 74 65 64   a pre-allocated
19d0: 20 70 61 67 65 20 62 6c 6f 63 6b 20 69 73 20 70   page block is p
19e0: 72 6f 76 69 64 65 64 2e 0a 23 0a 72 75 6e 5f 74  rovided..#.run_t
19f0: 65 73 74 73 20 22 6d 65 6d 73 75 62 73 79 73 32  ests "memsubsys2
1a00: 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b  " -description {
1a10: 0a 20 20 54 65 73 74 73 20 75 73 69 6e 67 20 73  .  Tests using s
1a20: 6d 61 6c 6c 20 70 72 65 2d 61 6c 6c 6f 63 61 74  mall pre-allocat
1a30: 65 64 20 70 61 67 65 20 61 6e 64 20 73 63 72 61  ed page and scra
1a40: 74 63 68 20 62 6c 6f 63 6b 73 0a 7d 20 2d 65 78  tch blocks.} -ex
1a50: 63 6c 75 64 65 20 7b 0a 20 20 69 6f 65 72 72 35  clude {.  ioerr5
1a60: 2e 74 65 73 74 0a 20 20 6d 61 6c 6c 6f 63 35 2e  .test.  malloc5.
1a70: 74 65 73 74 0a 7d 20 2d 69 6e 69 74 69 61 6c 69  test.} -initiali
1a80: 7a 65 20 7b 0a 20 20 63 61 74 63 68 20 7b 64 62  ze {.  catch {db
1a90: 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69 74 65   close}.  sqlite
1aa0: 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73 71 6c  3_shutdown.  sql
1ab0: 69 74 65 33 5f 63 6f 6e 66 69 67 5f 70 61 67 65  ite3_config_page
1ac0: 63 61 63 68 65 20 35 31 32 20 35 0a 20 20 73 71  cache 512 5.  sq
1ad0: 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 73 63 72  lite3_config_scr
1ae0: 61 74 63 68 20 31 30 30 30 20 31 0a 20 20 73 71  atch 1000 1.  sq
1af0: 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65  lite3_initialize
1b00: 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74  .  autoinstall_t
1b10: 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20  est_functions.} 
1b20: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 63 61  -shutdown {.  ca
1b30: 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20  tch {db close}. 
1b40: 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77   sqlite3_shutdow
1b50: 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66  n.  sqlite3_conf
1b60: 69 67 5f 70 61 67 65 63 61 63 68 65 20 30 20 30  ig_pagecache 0 0
1b70: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69  .  sqlite3_confi
1b80: 67 5f 73 63 72 61 74 63 68 20 30 20 30 0a 20 20  g_scratch 0 0.  
1b90: 73 71 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69  sqlite3_initiali
1ba0: 7a 65 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c  ze.  autoinstall
1bb0: 5f 74 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a  _test_functions.
1bc0: 7d 0a 0a 23 20 52 75 6e 20 61 6c 6c 20 74 65 73  }..# Run all tes
1bd0: 74 73 20 77 69 74 68 20 74 68 65 20 6c 6f 6f 6b  ts with the look
1be0: 61 73 69 64 65 20 61 6c 6c 6f 63 61 74 6f 72 20  aside allocator 
1bf0: 64 69 73 61 62 6c 65 64 2e 0a 23 0a 72 75 6e 5f  disabled..#.run_
1c00: 74 65 73 74 73 20 22 6e 6f 6c 6f 6f 6b 61 73 69  tests "nolookasi
1c10: 64 65 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e  de" -description
1c20: 20 7b 0a 20 20 4f 4f 4d 20 74 65 73 74 73 20 77   {.  OOM tests w
1c30: 69 74 68 20 6c 6f 6f 6b 61 73 69 64 65 20 64 69  ith lookaside di
1c40: 73 61 62 6c 65 64 0a 7d 20 2d 69 6e 69 74 69 61  sabled.} -initia
1c50: 6c 69 7a 65 20 7b 0a 20 20 63 61 74 63 68 20 7b  lize {.  catch {
1c60: 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69  db close}.  sqli
1c70: 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73  te3_shutdown.  s
1c80: 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 6c 6f  qlite3_config_lo
1c90: 6f 6b 61 73 69 64 65 20 30 20 30 0a 20 20 73 71  okaside 0 0.  sq
1ca0: 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65  lite3_initialize
1cb0: 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74  .  autoinstall_t
1cc0: 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20  est_functions.} 
1cd0: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 63 61  -shutdown {.  ca
1ce0: 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20  tch {db close}. 
1cf0: 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77   sqlite3_shutdow
1d00: 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66  n.  sqlite3_conf
1d10: 69 67 5f 6c 6f 6f 6b 61 73 69 64 65 20 31 30 30  ig_lookaside 100
1d20: 20 35 30 30 0a 20 20 73 71 6c 69 74 65 33 5f 69   500.  sqlite3_i
1d30: 6e 69 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f  nitialize.  auto
1d40: 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e  install_test_fun
1d50: 63 74 69 6f 6e 73 0a 7d 0a 0a 23 20 52 75 6e 20  ctions.}..# Run 
1d60: 73 6f 6d 65 20 74 65 73 74 73 20 69 6e 20 53 51  some tests in SQ
1d70: 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 53 49 4e 47  LITE_CONFIG_SING
1d80: 4c 45 54 48 52 45 41 44 20 6d 6f 64 65 2e 0a 23  LETHREAD mode..#
1d90: 0a 72 75 6e 5f 74 65 73 74 73 20 22 73 69 6e 67  .run_tests "sing
1da0: 6c 65 74 68 72 65 61 64 22 20 2d 64 65 73 63 72  lethread" -descr
1db0: 69 70 74 69 6f 6e 20 7b 0a 20 20 54 65 73 74 73  iption {.  Tests
1dc0: 20 72 75 6e 20 69 6e 20 53 51 4c 49 54 45 5f 43   run in SQLITE_C
1dd0: 4f 4e 46 49 47 5f 53 49 4e 47 4c 45 54 48 52 45  ONFIG_SINGLETHRE
1de0: 41 44 20 6d 6f 64 65 0a 7d 20 2d 69 6e 69 74 69  AD mode.} -initi
1df0: 61 6c 69 7a 65 20 7b 0a 20 20 63 61 74 63 68 20  alize {.  catch 
1e00: 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c  {db close}.  sql
1e10: 69 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20  ite3_shutdown.  
1e20: 63 61 74 63 68 20 7b 73 71 6c 69 74 65 33 5f 63  catch {sqlite3_c
1e30: 6f 6e 66 69 67 20 73 69 6e 67 6c 65 74 68 72 65  onfig singlethre
1e40: 61 64 7d 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e  ad}.  sqlite3_in
1e50: 69 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f 69  itialize.  autoi
1e60: 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e 63  nstall_test_func
1e70: 74 69 6f 6e 73 0a 7d 20 2d 69 6e 63 6c 75 64 65  tions.} -include
1e80: 20 7b 0a 20 20 64 65 6c 65 74 65 2e 74 65 73 74   {.  delete.test
1e90: 20 20 20 64 65 6c 65 74 65 32 2e 74 65 73 74 20     delete2.test 
1ea0: 20 69 6e 73 65 72 74 2e 74 65 73 74 20 20 72 6f   insert.test  ro
1eb0: 6c 6c 62 61 63 6b 2e 74 65 73 74 20 20 73 65 6c  llback.test  sel
1ec0: 65 63 74 31 2e 74 65 73 74 0a 20 20 73 65 6c 65  ect1.test.  sele
1ed0: 63 74 32 2e 74 65 73 74 20 20 74 72 61 6e 73 2e  ct2.test  trans.
1ee0: 74 65 73 74 20 20 20 20 75 70 64 61 74 65 2e 74  test    update.t
1ef0: 65 73 74 20 20 76 61 63 75 75 6d 2e 74 65 73 74  est  vacuum.test
1f00: 20 20 20 20 74 79 70 65 73 2e 74 65 73 74 0a 20      types.test. 
1f10: 20 74 79 70 65 73 32 2e 74 65 73 74 20 20 20 74   types2.test   t
1f20: 79 70 65 73 33 2e 74 65 73 74 0a 7d 20 2d 73 68  ypes3.test.} -sh
1f30: 75 74 64 6f 77 6e 20 7b 0a 20 20 63 61 74 63 68  utdown {.  catch
1f40: 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71   {db close}.  sq
1f50: 6c 69 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20  lite3_shutdown. 
1f60: 20 63 61 74 63 68 20 7b 73 71 6c 69 74 65 33 5f   catch {sqlite3_
1f70: 63 6f 6e 66 69 67 20 73 65 72 69 61 6c 69 7a 65  config serialize
1f80: 64 7d 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 69  d}.  sqlite3_ini
1f90: 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f 69 6e  tialize.  autoin
1fa0: 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e 63 74  stall_test_funct
1fb0: 69 6f 6e 73 0a 7d 0a 0a 72 75 6e 5f 74 65 73 74  ions.}..run_test
1fc0: 73 20 22 6e 6f 6d 75 74 65 78 22 20 2d 64 65 73  s "nomutex" -des
1fd0: 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20 54 65 73  cription {.  Tes
1fe0: 74 73 20 72 75 6e 20 77 69 74 68 20 74 68 65 20  ts run with the 
1ff0: 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 4d 55 4c 54  SQLITE_OPEN_MULT
2000: 49 54 48 52 45 41 44 45 44 20 66 6c 61 67 20 70  ITHREADED flag p
2010: 61 73 73 65 64 20 74 6f 20 73 71 6c 69 74 65 33  assed to sqlite3
2020: 5f 6f 70 65 6e 28 29 2e 0a 7d 20 2d 69 6e 69 74  _open()..} -init
2030: 69 61 6c 69 7a 65 20 7b 0a 20 20 72 65 6e 61 6d  ialize {.  renam
2040: 65 20 73 71 6c 69 74 65 33 20 73 71 6c 69 74 65  e sqlite3 sqlite
2050: 33 5f 6e 6f 6d 75 74 65 78 0a 20 20 70 72 6f 63  3_nomutex.  proc
2060: 20 73 71 6c 69 74 65 33 20 7b 61 72 67 73 7d 20   sqlite3 {args} 
2070: 7b 0a 20 20 20 20 69 66 20 7b 5b 73 74 72 69 6e  {.    if {[strin
2080: 67 20 72 61 6e 67 65 20 5b 6c 69 6e 64 65 78 20  g range [lindex 
2090: 24 61 72 67 73 20 30 5d 20 30 20 30 5d 20 6e 65  $args 0] 0 0] ne
20a0: 20 22 2d 22 7d 20 7b 0a 20 20 20 20 20 20 6c 61   "-"} {.      la
20b0: 70 70 65 6e 64 20 61 72 67 73 20 2d 66 75 6c 6c  ppend args -full
20c0: 6d 75 74 65 78 20 30 20 2d 6e 6f 6d 75 74 65 78  mutex 0 -nomutex
20d0: 20 31 0a 20 20 20 20 7d 0a 20 20 20 20 75 70 6c   1.    }.    upl
20e0: 65 76 65 6c 20 5b 63 6f 6e 63 61 74 20 73 71 6c  evel [concat sql
20f0: 69 74 65 33 5f 6e 6f 6d 75 74 65 78 20 24 61 72  ite3_nomutex $ar
2100: 67 73 5d 0a 20 20 7d 0a 7d 20 2d 69 6e 63 6c 75  gs].  }.} -inclu
2110: 64 65 20 7b 0a 20 20 64 65 6c 65 74 65 2e 74 65  de {.  delete.te
2120: 73 74 20 20 20 64 65 6c 65 74 65 32 2e 74 65 73  st   delete2.tes
2130: 74 20 20 69 6e 73 65 72 74 2e 74 65 73 74 20 20  t  insert.test  
2140: 72 6f 6c 6c 62 61 63 6b 2e 74 65 73 74 20 20 73  rollback.test  s
2150: 65 6c 65 63 74 31 2e 74 65 73 74 0a 20 20 73 65  elect1.test.  se
2160: 6c 65 63 74 32 2e 74 65 73 74 20 20 74 72 61 6e  lect2.test  tran
2170: 73 2e 74 65 73 74 20 20 20 20 75 70 64 61 74 65  s.test    update
2180: 2e 74 65 73 74 20 20 76 61 63 75 75 6d 2e 74 65  .test  vacuum.te
2190: 73 74 20 20 20 20 74 79 70 65 73 2e 74 65 73 74  st    types.test
21a0: 0a 20 20 74 79 70 65 73 32 2e 74 65 73 74 20 20  .  types2.test  
21b0: 20 74 79 70 65 73 33 2e 74 65 73 74 0a 7d 20 2d   types3.test.} -
21c0: 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 72 65 6e  shutdown {.  ren
21d0: 61 6d 65 20 73 71 6c 69 74 65 33 20 7b 7d 0a 20  ame sqlite3 {}. 
21e0: 20 72 65 6e 61 6d 65 20 73 71 6c 69 74 65 33 5f   rename sqlite3_
21f0: 6e 6f 6d 75 74 65 78 20 73 71 6c 69 74 65 33 0a  nomutex sqlite3.
2200: 7d 0a 0a 23 20 52 75 6e 20 73 6f 6d 65 20 74 65  }..# Run some te
2210: 73 74 73 20 69 6e 20 53 51 4c 49 54 45 5f 43 4f  sts in SQLITE_CO
2220: 4e 46 49 47 5f 4d 55 4c 54 49 54 48 52 45 41 44  NFIG_MULTITHREAD
2230: 20 6d 6f 64 65 2e 0a 23 0a 72 75 6e 5f 74 65 73   mode..#.run_tes
2240: 74 73 20 22 6d 75 6c 74 69 74 68 72 65 61 64 22  ts "multithread"
2250: 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b 0a   -description {.
2260: 20 20 54 65 73 74 73 20 72 75 6e 20 69 6e 20 53    Tests run in S
2270: 51 4c 49 54 45 5f 43 4f 4e 46 49 47 5f 4d 55 4c  QLITE_CONFIG_MUL
2280: 54 49 54 48 52 45 41 44 20 6d 6f 64 65 0a 7d 20  TITHREAD mode.} 
2290: 2d 69 6e 69 74 69 61 6c 69 7a 65 20 7b 0a 20 20  -initialize {.  
22a0: 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d  catch {db close}
22b0: 0a 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64  .  sqlite3_shutd
22c0: 6f 77 6e 0a 20 20 63 61 74 63 68 20 7b 73 71 6c  own.  catch {sql
22d0: 69 74 65 33 5f 63 6f 6e 66 69 67 20 6d 75 6c 74  ite3_config mult
22e0: 69 74 68 72 65 61 64 7d 0a 20 20 73 71 6c 69 74  ithread}.  sqlit
22f0: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20  e3_initialize.  
2300: 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74  autoinstall_test
2310: 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20 2d 69 6e  _functions.} -in
2320: 63 6c 75 64 65 20 7b 0a 20 20 64 65 6c 65 74 65  clude {.  delete
2330: 2e 74 65 73 74 20 20 20 64 65 6c 65 74 65 32 2e  .test   delete2.
2340: 74 65 73 74 20 20 69 6e 73 65 72 74 2e 74 65 73  test  insert.tes
2350: 74 20 20 72 6f 6c 6c 62 61 63 6b 2e 74 65 73 74  t  rollback.test
2360: 20 20 73 65 6c 65 63 74 31 2e 74 65 73 74 0a 20    select1.test. 
2370: 20 73 65 6c 65 63 74 32 2e 74 65 73 74 20 20 74   select2.test  t
2380: 72 61 6e 73 2e 74 65 73 74 20 20 20 20 75 70 64  rans.test    upd
2390: 61 74 65 2e 74 65 73 74 20 20 76 61 63 75 75 6d  ate.test  vacuum
23a0: 2e 74 65 73 74 20 20 20 20 74 79 70 65 73 2e 74  .test    types.t
23b0: 65 73 74 0a 20 20 74 79 70 65 73 32 2e 74 65 73  est.  types2.tes
23c0: 74 20 20 20 74 79 70 65 73 33 2e 74 65 73 74 0a  t   types3.test.
23d0: 7d 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20  } -shutdown {.  
23e0: 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d  catch {db close}
23f0: 0a 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64  .  sqlite3_shutd
2400: 6f 77 6e 0a 20 20 63 61 74 63 68 20 7b 73 71 6c  own.  catch {sql
2410: 69 74 65 33 5f 63 6f 6e 66 69 67 20 73 65 72 69  ite3_config seri
2420: 61 6c 69 7a 65 64 7d 0a 20 20 73 71 6c 69 74 65  alized}.  sqlite
2430: 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 61  3_initialize.  a
2440: 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f  utoinstall_test_
2450: 66 75 6e 63 74 69 6f 6e 73 0a 7d 0a 0a 23 20 52  functions.}..# R
2460: 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20 69 6e  un some tests in
2470: 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 46 55 4c   SQLITE_OPEN_FUL
2480: 4c 4d 55 54 45 58 20 6d 6f 64 65 2e 0a 23 0a 72  LMUTEX mode..#.r
2490: 75 6e 5f 74 65 73 74 73 20 22 66 75 6c 6c 6d 75  un_tests "fullmu
24a0: 74 65 78 22 20 2d 64 65 73 63 72 69 70 74 69 6f  tex" -descriptio
24b0: 6e 20 7b 0a 20 20 54 65 73 74 73 20 72 75 6e 20  n {.  Tests run 
24c0: 69 6e 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 46  in SQLITE_OPEN_F
24d0: 55 4c 4c 4d 55 54 45 58 20 6d 6f 64 65 0a 7d 20  ULLMUTEX mode.} 
24e0: 2d 69 6e 69 74 69 61 6c 69 7a 65 20 7b 0a 20 20  -initialize {.  
24f0: 72 65 6e 61 6d 65 20 73 71 6c 69 74 65 33 20 73  rename sqlite3 s
2500: 71 6c 69 74 65 33 5f 66 75 6c 6c 6d 75 74 65 78  qlite3_fullmutex
2510: 0a 20 20 70 72 6f 63 20 73 71 6c 69 74 65 33 20  .  proc sqlite3 
2520: 7b 61 72 67 73 7d 20 7b 0a 20 20 20 20 69 66 20  {args} {.    if 
2530: 7b 5b 73 74 72 69 6e 67 20 72 61 6e 67 65 20 5b  {[string range [
2540: 6c 69 6e 64 65 78 20 24 61 72 67 73 20 30 5d 20  lindex $args 0] 
2550: 30 20 30 5d 20 6e 65 20 22 2d 22 7d 20 7b 0a 20  0 0] ne "-"} {. 
2560: 20 20 20 20 20 6c 61 70 70 65 6e 64 20 61 72 67       lappend arg
2570: 73 20 2d 6e 6f 6d 75 74 65 78 20 30 20 2d 66 75  s -nomutex 0 -fu
2580: 6c 6c 6d 75 74 65 78 20 31 0a 20 20 20 20 7d 0a  llmutex 1.    }.
2590: 20 20 20 20 75 70 6c 65 76 65 6c 20 5b 63 6f 6e      uplevel [con
25a0: 63 61 74 20 73 71 6c 69 74 65 33 5f 66 75 6c 6c  cat sqlite3_full
25b0: 6d 75 74 65 78 20 24 61 72 67 73 5d 0a 20 20 7d  mutex $args].  }
25c0: 0a 7d 20 2d 69 6e 63 6c 75 64 65 20 7b 0a 20 20  .} -include {.  
25d0: 64 65 6c 65 74 65 2e 74 65 73 74 20 20 20 64 65  delete.test   de
25e0: 6c 65 74 65 32 2e 74 65 73 74 20 20 69 6e 73 65  lete2.test  inse
25f0: 72 74 2e 74 65 73 74 20 20 72 6f 6c 6c 62 61 63  rt.test  rollbac
2600: 6b 2e 74 65 73 74 20 20 73 65 6c 65 63 74 31 2e  k.test  select1.
2610: 74 65 73 74 0a 20 20 73 65 6c 65 63 74 32 2e 74  test.  select2.t
2620: 65 73 74 20 20 74 72 61 6e 73 2e 74 65 73 74 20  est  trans.test 
2630: 20 20 20 75 70 64 61 74 65 2e 74 65 73 74 20 20     update.test  
2640: 76 61 63 75 75 6d 2e 74 65 73 74 20 20 20 20 74  vacuum.test    t
2650: 79 70 65 73 2e 74 65 73 74 0a 20 20 74 79 70 65  ypes.test.  type
2660: 73 32 2e 74 65 73 74 20 20 20 74 79 70 65 73 33  s2.test   types3
2670: 2e 74 65 73 74 0a 7d 20 2d 73 68 75 74 64 6f 77  .test.} -shutdow
2680: 6e 20 7b 0a 20 20 72 65 6e 61 6d 65 20 73 71 6c  n {.  rename sql
2690: 69 74 65 33 20 7b 7d 0a 20 20 72 65 6e 61 6d 65  ite3 {}.  rename
26a0: 20 73 71 6c 69 74 65 33 5f 66 75 6c 6c 6d 75 74   sqlite3_fullmut
26b0: 65 78 20 73 71 6c 69 74 65 33 0a 7d 0a 0a 23 20  ex sqlite3.}..# 
26c0: 52 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20 75  Run some tests u
26d0: 73 69 6e 67 20 74 68 65 20 22 6f 6e 65 66 69 6c  sing the "onefil
26e0: 65 22 20 64 65 6d 6f 2e 0a 23 0a 72 75 6e 5f 74  e" demo..#.run_t
26f0: 65 73 74 73 20 22 6f 6e 65 66 69 6c 65 22 20 2d  ests "onefile" -
2700: 64 65 73 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20  description {.  
2710: 52 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20 75  Run some tests u
2720: 73 69 6e 67 20 74 68 65 20 22 74 65 73 74 5f 6f  sing the "test_o
2730: 6e 65 66 69 6c 65 2e 63 22 20 64 65 6d 6f 0a 7d  nefile.c" demo.}
2740: 20 2d 69 6e 69 74 69 61 6c 69 7a 65 20 7b 0a 20   -initialize {. 
2750: 20 72 65 6e 61 6d 65 20 73 71 6c 69 74 65 33 20   rename sqlite3 
2760: 73 71 6c 69 74 65 33 5f 6f 6e 65 66 69 6c 65 0a  sqlite3_onefile.
2770: 20 20 70 72 6f 63 20 73 71 6c 69 74 65 33 20 7b    proc sqlite3 {
2780: 61 72 67 73 7d 20 7b 0a 20 20 20 20 69 66 20 7b  args} {.    if {
2790: 5b 73 74 72 69 6e 67 20 72 61 6e 67 65 20 5b 6c  [string range [l
27a0: 69 6e 64 65 78 20 24 61 72 67 73 20 30 5d 20 30  index $args 0] 0
27b0: 20 30 5d 20 6e 65 20 22 2d 22 7d 20 7b 0a 20 20   0] ne "-"} {.  
27c0: 20 20 20 20 6c 61 70 70 65 6e 64 20 61 72 67 73      lappend args
27d0: 20 2d 76 66 73 20 66 73 0a 20 20 20 20 7d 0a 20   -vfs fs.    }. 
27e0: 20 20 20 75 70 6c 65 76 65 6c 20 5b 63 6f 6e 63     uplevel [conc
27f0: 61 74 20 73 71 6c 69 74 65 33 5f 6f 6e 65 66 69  at sqlite3_onefi
2800: 6c 65 20 24 61 72 67 73 5d 0a 20 20 7d 0a 7d 20  le $args].  }.} 
2810: 2d 69 6e 63 6c 75 64 65 20 7b 0a 20 20 63 6f 6e  -include {.  con
2820: 66 6c 69 63 74 2e 74 65 73 74 20 20 69 6e 73 65  flict.test  inse
2830: 72 74 2e 74 65 73 74 20 20 20 69 6e 73 65 72 74  rt.test   insert
2840: 32 2e 74 65 73 74 20 20 69 6e 73 65 72 74 33 2e  2.test  insert3.
2850: 74 65 73 74 0a 20 20 72 6f 6c 6c 62 61 63 6b 2e  test.  rollback.
2860: 74 65 73 74 20 20 73 65 6c 65 63 74 31 2e 74 65  test  select1.te
2870: 73 74 20 20 73 65 6c 65 63 74 32 2e 74 65 73 74  st  select2.test
2880: 20 20 73 65 6c 65 63 74 33 2e 74 65 73 74 0a 7d    select3.test.}
2890: 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 72   -shutdown {.  r
28a0: 65 6e 61 6d 65 20 73 71 6c 69 74 65 33 20 7b 7d  ename sqlite3 {}
28b0: 0a 20 20 72 65 6e 61 6d 65 20 73 71 6c 69 74 65  .  rename sqlite
28c0: 33 5f 6f 6e 65 66 69 6c 65 20 73 71 6c 69 74 65  3_onefile sqlite
28d0: 33 0a 7d 0a 0a 23 20 52 75 6e 20 73 6f 6d 65 20  3.}..# Run some 
28e0: 74 65 73 74 73 20 75 73 69 6e 67 20 55 54 46 2d  tests using UTF-
28f0: 31 36 20 64 61 74 61 62 61 73 65 73 2e 0a 23 0a  16 databases..#.
2900: 72 75 6e 5f 74 65 73 74 73 20 22 75 74 66 31 36  run_tests "utf16
2910: 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b  " -description {
2920: 0a 20 20 52 75 6e 20 74 65 73 74 73 20 75 73 69  .  Run tests usi
2930: 6e 67 20 55 54 46 2d 31 36 20 64 61 74 61 62 61  ng UTF-16 databa
2940: 73 65 73 0a 7d 20 2d 70 72 65 73 71 6c 20 7b 0a  ses.} -presql {.
2950: 20 20 70 72 61 67 6d 61 20 65 6e 63 6f 64 69 6e    pragma encodin
2960: 67 20 3d 20 27 55 54 46 2d 31 36 27 0a 7d 20 2d  g = 'UTF-16'.} -
2970: 69 6e 63 6c 75 64 65 20 7b 0a 20 20 20 20 61 6c  include {.    al
2980: 74 65 72 2e 74 65 73 74 20 61 6c 74 65 72 33 2e  ter.test alter3.
2990: 74 65 73 74 0a 20 20 20 20 61 75 74 68 2e 74 65  test.    auth.te
29a0: 73 74 20 62 69 6e 64 2e 74 65 73 74 20 62 6c 6f  st bind.test blo
29b0: 62 2e 74 65 73 74 20 63 61 70 69 32 2e 74 65 73  b.test capi2.tes
29c0: 74 20 63 61 70 69 33 2e 74 65 73 74 20 63 6f 6c  t capi3.test col
29d0: 6c 61 74 65 31 2e 74 65 73 74 0a 20 20 20 20 63  late1.test.    c
29e0: 6f 6c 6c 61 74 65 32 2e 74 65 73 74 20 63 6f 6c  ollate2.test col
29f0: 6c 61 74 65 33 2e 74 65 73 74 20 63 6f 6c 6c 61  late3.test colla
2a00: 74 65 34 2e 74 65 73 74 20 63 6f 6c 6c 61 74 65  te4.test collate
2a10: 35 2e 74 65 73 74 20 63 6f 6c 6c 61 74 65 36 2e  5.test collate6.
2a20: 74 65 73 74 0a 20 20 20 20 63 6f 6e 66 6c 69 63  test.    conflic
2a30: 74 2e 74 65 73 74 20 64 61 74 65 2e 74 65 73 74  t.test date.test
2a40: 20 64 65 6c 65 74 65 2e 74 65 73 74 20 65 78 70   delete.test exp
2a50: 72 2e 74 65 73 74 20 66 6b 65 79 31 2e 74 65 73  r.test fkey1.tes
2a60: 74 20 66 75 6e 63 2e 74 65 73 74 0a 20 20 20 20  t func.test.    
2a70: 68 6f 6f 6b 2e 74 65 73 74 20 69 6e 64 65 78 2e  hook.test index.
2a80: 74 65 73 74 20 69 6e 73 65 72 74 32 2e 74 65 73  test insert2.tes
2a90: 74 20 69 6e 73 65 72 74 2e 74 65 73 74 20 69 6e  t insert.test in
2aa0: 74 65 72 72 75 70 74 2e 74 65 73 74 20 69 6e 2e  terrupt.test in.
2ab0: 74 65 73 74 0a 20 20 20 20 69 6e 74 70 6b 65 79  test.    intpkey
2ac0: 2e 74 65 73 74 20 69 6f 65 72 72 2e 74 65 73 74  .test ioerr.test
2ad0: 20 6a 6f 69 6e 32 2e 74 65 73 74 20 6a 6f 69 6e   join2.test join
2ae0: 2e 74 65 73 74 20 6c 61 73 74 69 6e 73 65 72 74  .test lastinsert
2af0: 2e 74 65 73 74 0a 20 20 20 20 6c 61 73 74 73 74  .test.    lastst
2b00: 6d 74 63 68 61 6e 67 65 73 2e 74 65 73 74 20 6c  mtchanges.test l
2b10: 69 6d 69 74 2e 74 65 73 74 20 6c 6f 63 6b 32 2e  imit.test lock2.
2b20: 74 65 73 74 20 6c 6f 63 6b 2e 74 65 73 74 20 6d  test lock.test m
2b30: 61 69 6e 2e 74 65 73 74 20 0a 20 20 20 20 6d 65  ain.test .    me
2b40: 6d 64 62 2e 74 65 73 74 20 6d 69 6e 6d 61 78 2e  mdb.test minmax.
2b50: 74 65 73 74 20 6d 69 73 63 31 2e 74 65 73 74 20  test misc1.test 
2b60: 6d 69 73 63 32 2e 74 65 73 74 20 6d 69 73 63 33  misc2.test misc3
2b70: 2e 74 65 73 74 20 6e 6f 74 6e 75 6c 6c 2e 74 65  .test notnull.te
2b80: 73 74 0a 20 20 20 20 6e 75 6c 6c 2e 74 65 73 74  st.    null.test
2b90: 20 70 72 6f 67 72 65 73 73 2e 74 65 73 74 20 71   progress.test q
2ba0: 75 6f 74 65 2e 74 65 73 74 20 72 6f 77 69 64 2e  uote.test rowid.
2bb0: 74 65 73 74 20 73 65 6c 65 63 74 31 2e 74 65 73  test select1.tes
2bc0: 74 20 73 65 6c 65 63 74 32 2e 74 65 73 74 0a 20  t select2.test. 
2bd0: 20 20 20 73 65 6c 65 63 74 33 2e 74 65 73 74 20     select3.test 
2be0: 73 65 6c 65 63 74 34 2e 74 65 73 74 20 73 65 6c  select4.test sel
2bf0: 65 63 74 35 2e 74 65 73 74 20 73 65 6c 65 63 74  ect5.test select
2c00: 36 2e 74 65 73 74 20 73 6f 72 74 2e 74 65 73 74  6.test sort.test
2c10: 20 0a 20 20 20 20 73 75 62 73 65 6c 65 63 74 2e   .    subselect.
2c20: 74 65 73 74 20 74 61 62 6c 65 61 70 69 2e 74 65  test tableapi.te
2c30: 73 74 20 74 61 62 6c 65 2e 74 65 73 74 20 74 65  st table.test te
2c40: 6d 70 74 61 62 6c 65 2e 74 65 73 74 0a 20 20 20  mptable.test.   
2c50: 20 74 72 61 63 65 2e 74 65 73 74 20 74 72 69 67   trace.test trig
2c60: 67 65 72 31 2e 74 65 73 74 20 74 72 69 67 67 65  ger1.test trigge
2c70: 72 32 2e 74 65 73 74 20 74 72 69 67 67 65 72 33  r2.test trigger3
2c80: 2e 74 65 73 74 0a 20 20 20 20 74 72 69 67 67 65  .test.    trigge
2c90: 72 34 2e 74 65 73 74 20 74 79 70 65 73 32 2e 74  r4.test types2.t
2ca0: 65 73 74 20 74 79 70 65 73 2e 74 65 73 74 20 75  est types.test u
2cb0: 6e 69 71 75 65 2e 74 65 73 74 20 75 70 64 61 74  nique.test updat
2cc0: 65 2e 74 65 73 74 0a 20 20 20 20 76 61 63 75 75  e.test.    vacuu
2cd0: 6d 2e 74 65 73 74 20 76 69 65 77 2e 74 65 73 74  m.test view.test
2ce0: 20 77 68 65 72 65 2e 74 65 73 74 0a 7d 0a 0a 23   where.test.}..#
2cf0: 20 52 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20   Run some tests 
2d00: 69 6e 20 65 78 63 6c 75 73 69 76 65 20 6c 6f 63  in exclusive loc
2d10: 6b 69 6e 67 20 6d 6f 64 65 2e 0a 23 0a 72 75 6e  king mode..#.run
2d20: 5f 74 65 73 74 73 20 22 65 78 63 6c 75 73 69 76  _tests "exclusiv
2d30: 65 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20  e" -description 
2d40: 7b 0a 20 20 52 75 6e 20 74 65 73 74 73 20 69 6e  {.  Run tests in
2d50: 20 65 78 63 6c 75 73 69 76 65 20 6c 6f 63 6b 69   exclusive locki
2d60: 6e 67 20 6d 6f 64 65 2e 0a 7d 20 2d 70 72 65 73  ng mode..} -pres
2d70: 71 6c 20 7b 0a 20 20 70 72 61 67 6d 61 20 6c 6f  ql {.  pragma lo
2d80: 63 6b 69 6e 67 5f 6d 6f 64 65 20 3d 20 27 65 78  cking_mode = 'ex
2d90: 63 6c 75 73 69 76 65 27 0a 7d 20 2d 69 6e 63 6c  clusive'.} -incl
2da0: 75 64 65 20 7b 0a 20 20 72 6f 6c 6c 62 61 63 6b  ude {.  rollback
2db0: 2e 74 65 73 74 20 73 65 6c 65 63 74 31 2e 74 65  .test select1.te
2dc0: 73 74 20 73 65 6c 65 63 74 32 2e 74 65 73 74 20  st select2.test 
2dd0: 0a 20 20 6d 61 6c 6c 6f 63 2e 74 65 73 74 20 69  .  malloc.test i
2de0: 6f 65 72 72 2e 74 65 73 74 0a 7d 20 0a 0a 23 20  oerr.test.} ..# 
2df0: 52 75 6e 20 73 6f 6d 65 20 74 65 73 74 73 20 69  Run some tests i
2e00: 6e 20 65 78 63 6c 75 73 69 76 65 20 6c 6f 63 6b  n exclusive lock
2e10: 69 6e 67 20 6d 6f 64 65 20 77 69 74 68 20 74 72  ing mode with tr
2e20: 75 6e 63 61 74 65 64 20 6a 6f 75 72 6e 61 6c 73  uncated journals
2e30: 2e 0a 23 0a 72 75 6e 5f 74 65 73 74 73 20 22 65  ..#.run_tests "e
2e40: 78 63 6c 75 73 69 76 65 2d 74 72 75 6e 63 61 74  xclusive-truncat
2e50: 65 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20  e" -description 
2e60: 7b 0a 20 20 52 75 6e 20 74 65 73 74 73 20 69 6e  {.  Run tests in
2e70: 20 65 78 63 6c 75 73 69 76 65 20 6c 6f 63 6b 69   exclusive locki
2e80: 6e 67 20 6d 6f 64 65 20 61 6e 64 20 74 72 75 6e  ng mode and trun
2e90: 63 61 74 65 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64  cate journal mod
2ea0: 65 2e 0a 7d 20 2d 70 72 65 73 71 6c 20 7b 0a 20  e..} -presql {. 
2eb0: 20 70 72 61 67 6d 61 20 6c 6f 63 6b 69 6e 67 5f   pragma locking_
2ec0: 6d 6f 64 65 20 3d 20 27 65 78 63 6c 75 73 69 76  mode = 'exclusiv
2ed0: 65 27 3b 0a 20 20 70 72 61 67 6d 61 20 6a 6f 75  e';.  pragma jou
2ee0: 72 6e 61 6c 5f 6d 6f 64 65 20 3d 20 54 52 55 4e  rnal_mode = TRUN
2ef0: 43 41 54 45 3b 0a 7d 20 2d 69 6e 63 6c 75 64 65  CATE;.} -include
2f00: 20 7b 0a 20 20 64 65 6c 65 74 65 2e 74 65 73 74   {.  delete.test
2f10: 20 64 65 6c 65 74 65 32 2e 74 65 73 74 20 69 6e   delete2.test in
2f20: 73 65 72 74 2e 74 65 73 74 20 72 6f 6c 6c 62 61  sert.test rollba
2f30: 63 6b 2e 74 65 73 74 20 73 65 6c 65 63 74 31 2e  ck.test select1.
2f40: 74 65 73 74 0a 20 20 73 65 6c 65 63 74 32 2e 74  test.  select2.t
2f50: 65 73 74 20 75 70 64 61 74 65 2e 74 65 73 74 20  est update.test 
2f60: 6d 61 6c 6c 6f 63 2e 74 65 73 74 20 69 6f 65 72  malloc.test ioer
2f70: 72 2e 74 65 73 74 0a 7d 20 0a 0a 23 20 52 75 6e  r.test.} ..# Run
2f80: 20 73 6f 6d 65 20 74 65 73 74 73 20 69 6e 20 70   some tests in p
2f90: 65 72 73 69 73 74 65 6e 74 20 6a 6f 75 72 6e 61  ersistent journa
2fa0: 6c 20 6d 6f 64 65 2e 0a 23 0a 72 75 6e 5f 74 65  l mode..#.run_te
2fb0: 73 74 73 20 22 70 65 72 73 69 73 74 65 6e 74 5f  sts "persistent_
2fc0: 6a 6f 75 72 6e 61 6c 22 20 2d 64 65 73 63 72 69  journal" -descri
2fd0: 70 74 69 6f 6e 20 7b 0a 20 20 52 75 6e 20 74 65  ption {.  Run te
2fe0: 73 74 73 20 69 6e 20 70 65 72 73 69 73 74 65 6e  sts in persisten
2ff0: 74 2d 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65 2e 0a  t-journal mode..
3000: 7d 20 2d 70 72 65 73 71 6c 20 7b 0a 20 20 70 72  } -presql {.  pr
3010: 61 67 6d 61 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64  agma journal_mod
3020: 65 20 3d 20 70 65 72 73 69 73 74 0a 7d 20 2d 69  e = persist.} -i
3030: 6e 63 6c 75 64 65 20 7b 0a 20 20 64 65 6c 65 74  nclude {.  delet
3040: 65 2e 74 65 73 74 20 64 65 6c 65 74 65 32 2e 74  e.test delete2.t
3050: 65 73 74 20 69 6e 73 65 72 74 2e 74 65 73 74 20  est insert.test 
3060: 72 6f 6c 6c 62 61 63 6b 2e 74 65 73 74 20 73 65  rollback.test se
3070: 6c 65 63 74 31 2e 74 65 73 74 0a 20 20 73 65 6c  lect1.test.  sel
3080: 65 63 74 32 2e 74 65 73 74 20 74 72 61 6e 73 2e  ect2.test trans.
3090: 74 65 73 74 20 75 70 64 61 74 65 2e 74 65 73 74  test update.test
30a0: 20 76 61 63 75 75 6d 2e 74 65 73 74 20 0a 7d 0a   vacuum.test .}.
30b0: 0a 23 20 52 75 6e 20 73 6f 6d 65 20 74 65 73 74  .# Run some test
30c0: 73 20 69 6e 20 74 72 75 6e 63 61 74 69 6e 67 20  s in truncating 
30d0: 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65 2e 0a 23 0a  journal mode..#.
30e0: 72 75 6e 5f 74 65 73 74 73 20 22 74 72 75 6e 63  run_tests "trunc
30f0: 61 74 65 5f 6a 6f 75 72 6e 61 6c 22 20 2d 64 65  ate_journal" -de
3100: 73 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20 52 75  scription {.  Ru
3110: 6e 20 74 65 73 74 73 20 69 6e 20 70 65 72 73 69  n tests in persi
3120: 73 74 65 6e 74 2d 6a 6f 75 72 6e 61 6c 20 6d 6f  stent-journal mo
3130: 64 65 2e 0a 7d 20 2d 70 72 65 73 71 6c 20 7b 0a  de..} -presql {.
3140: 20 20 70 72 61 67 6d 61 20 6a 6f 75 72 6e 61 6c    pragma journal
3150: 5f 6d 6f 64 65 20 3d 20 74 72 75 6e 63 61 74 65  _mode = truncate
3160: 0a 7d 20 2d 69 6e 63 6c 75 64 65 20 7b 0a 20 20  .} -include {.  
3170: 64 65 6c 65 74 65 2e 74 65 73 74 20 64 65 6c 65  delete.test dele
3180: 74 65 32 2e 74 65 73 74 20 69 6e 73 65 72 74 2e  te2.test insert.
3190: 74 65 73 74 20 72 6f 6c 6c 62 61 63 6b 2e 74 65  test rollback.te
31a0: 73 74 20 73 65 6c 65 63 74 31 2e 74 65 73 74 0a  st select1.test.
31b0: 20 20 73 65 6c 65 63 74 32 2e 74 65 73 74 20 74    select2.test t
31c0: 72 61 6e 73 2e 74 65 73 74 20 75 70 64 61 74 65  rans.test update
31d0: 2e 74 65 73 74 20 76 61 63 75 75 6d 2e 74 65 73  .test vacuum.tes
31e0: 74 20 0a 20 20 6d 61 6c 6c 6f 63 2e 74 65 73 74  t .  malloc.test
31f0: 20 69 6f 65 72 72 2e 74 65 73 74 0a 7d 0a 0a 23   ioerr.test.}..#
3200: 20 52 75 6e 20 73 6f 6d 65 20 65 72 72 6f 72 20   Run some error 
3210: 74 65 73 74 73 20 69 6e 20 70 65 72 73 69 73 74  tests in persist
3220: 65 6e 74 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65  ent journal mode
3230: 2e 0a 23 0a 72 75 6e 5f 74 65 73 74 73 20 22 70  ..#.run_tests "p
3240: 65 72 73 69 73 74 65 6e 74 5f 6a 6f 75 72 6e 61  ersistent_journa
3250: 6c 5f 65 72 72 6f 72 22 20 2d 64 65 73 63 72 69  l_error" -descri
3260: 70 74 69 6f 6e 20 7b 0a 20 20 52 75 6e 20 6d 61  ption {.  Run ma
3270: 6c 6c 6f 63 2e 74 65 73 74 20 61 6e 64 20 69 6f  lloc.test and io
3280: 65 72 72 2e 74 65 73 74 20 69 6e 20 70 65 72 73  err.test in pers
3290: 69 73 74 65 6e 74 2d 6a 6f 75 72 6e 61 6c 20 6d  istent-journal m
32a0: 6f 64 65 2e 0a 7d 20 2d 70 72 65 73 71 6c 20 7b  ode..} -presql {
32b0: 0a 20 20 70 72 61 67 6d 61 20 6a 6f 75 72 6e 61  .  pragma journa
32c0: 6c 5f 6d 6f 64 65 20 3d 20 70 65 72 73 69 73 74  l_mode = persist
32d0: 0a 7d 20 2d 69 6e 63 6c 75 64 65 20 7b 0a 20 20  .} -include {.  
32e0: 6d 61 6c 6c 6f 63 2e 74 65 73 74 20 69 6f 65 72  malloc.test ioer
32f0: 72 2e 74 65 73 74 0a 7d 0a 0a 23 20 52 75 6e 20  r.test.}..# Run 
3300: 73 6f 6d 65 20 74 65 73 74 73 20 69 6e 20 6e 6f  some tests in no
3310: 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65 2e 0a 23   journal mode..#
3320: 0a 72 75 6e 5f 74 65 73 74 73 20 22 6e 6f 5f 6a  .run_tests "no_j
3330: 6f 75 72 6e 61 6c 22 20 2d 64 65 73 63 72 69 70  ournal" -descrip
3340: 74 69 6f 6e 20 7b 0a 20 20 52 75 6e 20 74 65 73  tion {.  Run tes
3350: 74 73 20 69 6e 20 6e 6f 2d 6a 6f 75 72 6e 61 6c  ts in no-journal
3360: 20 6d 6f 64 65 2e 0a 7d 20 2d 70 72 65 73 71 6c   mode..} -presql
3370: 20 7b 0a 20 20 70 72 61 67 6d 61 20 6a 6f 75 72   {.  pragma jour
3380: 6e 61 6c 5f 6d 6f 64 65 20 3d 20 70 65 72 73 69  nal_mode = persi
3390: 73 74 0a 7d 20 2d 69 6e 63 6c 75 64 65 20 7b 0a  st.} -include {.
33a0: 20 20 64 65 6c 65 74 65 2e 74 65 73 74 20 64 65    delete.test de
33b0: 6c 65 74 65 32 2e 74 65 73 74 20 69 6e 73 65 72  lete2.test inser
33c0: 74 2e 74 65 73 74 20 72 6f 6c 6c 62 61 63 6b 2e  t.test rollback.
33d0: 74 65 73 74 20 73 65 6c 65 63 74 31 2e 74 65 73  test select1.tes
33e0: 74 0a 20 20 73 65 6c 65 63 74 32 2e 74 65 73 74  t.  select2.test
33f0: 20 74 72 61 6e 73 2e 74 65 73 74 20 75 70 64 61   trans.test upda
3400: 74 65 2e 74 65 73 74 20 76 61 63 75 75 6d 2e 74  te.test vacuum.t
3410: 65 73 74 20 0a 7d 0a 0a 23 20 52 75 6e 20 73 6f  est .}..# Run so
3420: 6d 65 20 65 72 72 6f 72 20 74 65 73 74 73 20 69  me error tests i
3430: 6e 20 6e 6f 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64  n no journal mod
3440: 65 2e 0a 23 0a 72 75 6e 5f 74 65 73 74 73 20 22  e..#.run_tests "
3450: 6e 6f 5f 6a 6f 75 72 6e 61 6c 5f 65 72 72 6f 72  no_journal_error
3460: 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b  " -description {
3470: 0a 20 20 52 75 6e 20 6d 61 6c 6c 6f 63 2e 74 65  .  Run malloc.te
3480: 73 74 20 61 6e 64 20 69 6f 65 72 72 2e 74 65 73  st and ioerr.tes
3490: 74 20 69 6e 20 6e 6f 2d 6a 6f 75 72 6e 61 6c 20  t in no-journal 
34a0: 6d 6f 64 65 2e 0a 7d 20 2d 70 72 65 73 71 6c 20  mode..} -presql 
34b0: 7b 0a 20 20 70 72 61 67 6d 61 20 6a 6f 75 72 6e  {.  pragma journ
34c0: 61 6c 5f 6d 6f 64 65 20 3d 20 70 65 72 73 69 73  al_mode = persis
34d0: 74 0a 7d 20 2d 69 6e 63 6c 75 64 65 20 7b 0a 20  t.} -include {. 
34e0: 20 6d 61 6c 6c 6f 63 2e 74 65 73 74 20 69 6f 65   malloc.test ioe
34f0: 72 72 2e 74 65 73 74 0a 7d 0a 0a 23 20 52 75 6e  rr.test.}..# Run
3500: 20 73 6f 6d 65 20 63 72 61 73 68 2d 74 65 73 74   some crash-test
3510: 73 20 69 6e 20 61 75 74 6f 76 61 63 75 75 6d 20  s in autovacuum 
3520: 6d 6f 64 65 2e 0a 23 0a 72 75 6e 5f 74 65 73 74  mode..#.run_test
3530: 73 20 22 61 75 74 6f 76 61 63 75 75 6d 5f 63 72  s "autovacuum_cr
3540: 61 73 68 22 20 2d 64 65 73 63 72 69 70 74 69 6f  ash" -descriptio
3550: 6e 20 7b 0a 20 20 52 75 6e 20 63 72 61 73 68 2e  n {.  Run crash.
3560: 74 65 73 74 20 69 6e 20 61 75 74 6f 76 61 63 75  test in autovacu
3570: 75 6d 20 6d 6f 64 65 2e 0a 7d 20 2d 70 72 65 73  um mode..} -pres
3580: 71 6c 20 7b 0a 20 20 70 72 61 67 6d 61 20 61 75  ql {.  pragma au
3590: 74 6f 5f 76 61 63 75 75 6d 20 3d 20 31 0a 7d 20  to_vacuum = 1.} 
35a0: 2d 69 6e 63 6c 75 64 65 20 63 72 61 73 68 2e 74  -include crash.t
35b0: 65 73 74 0a 0a 23 20 52 75 6e 20 73 6f 6d 65 20  est..# Run some 
35c0: 69 6f 65 72 72 2d 74 65 73 74 73 20 69 6e 20 61  ioerr-tests in a
35d0: 75 74 6f 76 61 63 75 75 6d 20 6d 6f 64 65 2e 0a  utovacuum mode..
35e0: 23 0a 72 75 6e 5f 74 65 73 74 73 20 22 61 75 74  #.run_tests "aut
35f0: 6f 76 61 63 75 75 6d 5f 69 6f 65 72 72 22 20 2d  ovacuum_ioerr" -
3600: 64 65 73 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20  description {.  
3610: 52 75 6e 20 69 6f 65 72 72 2e 74 65 73 74 20 69  Run ioerr.test i
3620: 6e 20 61 75 74 6f 76 61 63 75 75 6d 20 6d 6f 64  n autovacuum mod
3630: 65 2e 0a 7d 20 2d 70 72 65 73 71 6c 20 7b 0a 20  e..} -presql {. 
3640: 20 70 72 61 67 6d 61 20 61 75 74 6f 5f 76 61 63   pragma auto_vac
3650: 75 75 6d 20 3d 20 31 0a 7d 20 2d 69 6e 63 6c 75  uum = 1.} -inclu
3660: 64 65 20 69 6f 65 72 72 2e 74 65 73 74 0a 0a 23  de ioerr.test..#
3670: 20 52 75 6e 20 74 65 73 74 73 20 77 69 74 68 20   Run tests with 
3680: 61 6e 20 69 6e 2d 6d 65 6d 6f 72 79 20 6a 6f 75  an in-memory jou
3690: 72 6e 61 6c 2e 0a 23 0a 72 75 6e 5f 74 65 73 74  rnal..#.run_test
36a0: 73 20 22 69 6e 6d 65 6d 6f 72 79 5f 6a 6f 75 72  s "inmemory_jour
36b0: 6e 61 6c 22 20 2d 64 65 73 63 72 69 70 74 69 6f  nal" -descriptio
36c0: 6e 20 7b 0a 20 20 52 75 6e 20 74 65 73 74 73 20  n {.  Run tests 
36d0: 77 69 74 68 20 61 6e 20 69 6e 2d 6d 65 6d 6f 72  with an in-memor
36e0: 79 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 2e 0a  y journal file..
36f0: 7d 20 2d 70 72 65 73 71 6c 20 7b 0a 20 20 70 72  } -presql {.  pr
3700: 61 67 6d 61 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64  agma journal_mod
3710: 65 20 3d 20 27 6d 65 6d 6f 72 79 27 0a 7d 20 2d  e = 'memory'.} -
3720: 65 78 63 6c 75 64 65 20 7b 0a 20 20 23 20 45 78  exclude {.  # Ex
3730: 63 6c 75 64 65 20 61 6c 6c 20 74 65 73 74 73 20  clude all tests 
3740: 74 68 61 74 20 73 69 6d 75 6c 61 74 65 20 49 4f  that simulate IO
3750: 20 65 72 72 6f 72 73 2e 0a 20 20 61 75 74 6f 76   errors..  autov
3760: 61 63 75 75 6d 5f 69 6f 65 72 72 32 2e 74 65 73  acuum_ioerr2.tes
3770: 74 20 69 6e 63 72 76 61 63 75 75 6d 5f 69 6f 65  t incrvacuum_ioe
3780: 72 72 2e 74 65 73 74 20 69 6f 65 72 72 2e 74 65  rr.test ioerr.te
3790: 73 74 0a 20 20 69 6f 65 72 72 2e 74 65 73 74 20  st.  ioerr.test 
37a0: 69 6f 65 72 72 32 2e 74 65 73 74 20 69 6f 65 72  ioerr2.test ioer
37b0: 72 33 2e 74 65 73 74 20 69 6f 65 72 72 34 2e 74  r3.test ioerr4.t
37c0: 65 73 74 20 69 6f 65 72 72 35 2e 74 65 73 74 0a  est ioerr5.test.
37d0: 20 20 76 61 63 75 75 6d 33 2e 74 65 73 74 20 69    vacuum3.test i
37e0: 6e 63 72 62 6c 6f 62 5f 65 72 72 2e 74 65 73 74  ncrblob_err.test
37f0: 20 64 69 73 6b 66 75 6c 6c 2e 74 65 73 74 20 62   diskfull.test b
3800: 61 63 6b 75 70 5f 69 6f 65 72 72 2e 74 65 73 74  ackup_ioerr.test
3810: 0a 0a 20 20 23 20 45 78 63 6c 75 64 65 20 74 65  ..  # Exclude te
3820: 73 74 20 73 63 72 69 70 74 73 20 74 68 61 74 20  st scripts that 
3830: 75 73 65 20 74 63 6c 20 49 4f 20 74 6f 20 61 63  use tcl IO to ac
3840: 63 65 73 73 20 6a 6f 75 72 6e 61 6c 20 66 69 6c  cess journal fil
3850: 65 73 20 6f 72 20 63 6f 75 6e 74 0a 20 20 23 20  es or count.  # 
3860: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 66 73  the number of fs
3870: 79 6e 63 28 29 20 63 61 6c 6c 73 2e 0a 20 20 70  ync() calls..  p
3880: 61 67 65 72 2e 74 65 73 74 20 65 78 63 6c 75 73  ager.test exclus
3890: 69 76 65 2e 74 65 73 74 20 6a 72 6e 6c 6d 6f 64  ive.test jrnlmod
38a0: 65 2e 74 65 73 74 20 73 79 6e 63 2e 74 65 73 74  e.test sync.test
38b0: 20 6d 69 73 63 31 2e 74 65 73 74 20 0a 20 20 6a   misc1.test .  j
38c0: 6f 75 72 6e 61 6c 31 2e 74 65 73 74 20 63 6f 6e  ournal1.test con
38d0: 66 6c 69 63 74 2e 74 65 73 74 20 63 72 61 73 68  flict.test crash
38e0: 38 2e 74 65 73 74 20 74 6b 74 33 34 35 37 2e 74  8.test tkt3457.t
38f0: 65 73 74 20 69 6f 2e 74 65 73 74 0a 7d 0a 0a 69  est io.test.}..i
3900: 66 63 61 70 61 62 6c 65 20 6d 65 6d 33 20 7b 0a  fcapable mem3 {.
3910: 20 20 72 75 6e 5f 74 65 73 74 73 20 22 6d 65 6d    run_tests "mem
3920: 73 79 73 33 22 20 2d 64 65 73 63 72 69 70 74 69  sys3" -descripti
3930: 6f 6e 20 7b 0a 20 20 20 20 52 75 6e 20 74 65 73  on {.    Run tes
3940: 74 73 20 75 73 69 6e 67 20 74 68 65 20 61 6c 6c  ts using the all
3950: 6f 63 61 74 6f 72 20 69 6e 20 6d 65 6d 33 2e 63  ocator in mem3.c
3960: 2e 0a 20 20 7d 20 2d 65 78 63 6c 75 64 65 20 7b  ..  } -exclude {
3970: 0a 20 20 20 20 61 75 74 6f 76 61 63 75 75 6d 2e  .    autovacuum.
3980: 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20 64  test           d
3990: 65 6c 65 74 65 33 2e 74 65 73 74 20 20 20 20 20  elete3.test     
39a0: 20 20 20 20 20 20 20 20 20 6d 61 6e 79 64 62 2e           manydb.
39b0: 74 65 73 74 0a 20 20 20 20 62 69 67 72 6f 77 2e  test.    bigrow.
39c0: 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20  test            
39d0: 20 20 20 69 6e 63 72 62 6c 6f 62 32 2e 74 65 73     incrblob2.tes
39e0: 74 20 20 20 20 20 20 20 20 20 20 20 20 6d 65 6d  t            mem
39f0: 64 62 2e 74 65 73 74 0a 20 20 20 20 62 69 74 76  db.test.    bitv
3a00: 65 63 2e 74 65 73 74 20 20 20 20 20 20 20 20 20  ec.test         
3a10: 20 20 20 20 20 20 69 6e 64 65 78 32 2e 74 65 73        index2.tes
3a20: 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t               
3a30: 6d 65 6d 73 75 62 73 79 73 31 2e 74 65 73 74 0a  memsubsys1.test.
3a40: 20 20 20 20 63 61 70 69 33 63 2e 74 65 73 74 20      capi3c.test 
3a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69 6f                io
3a60: 65 72 72 2e 74 65 73 74 20 20 20 20 20 20 20 20  err.test        
3a70: 20 20 20 20 20 20 20 20 6d 65 6d 73 75 62 73 79          memsubsy
3a80: 73 32 2e 74 65 73 74 0a 20 20 20 20 63 61 70 69  s2.test.    capi
3a90: 33 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20  3.test          
3aa0: 20 20 20 20 20 20 6a 6f 69 6e 33 2e 74 65 73 74        join3.test
3ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3ac0: 70 61 67 65 73 69 7a 65 2e 74 65 73 74 0a 20 20  pagesize.test.  
3ad0: 20 20 63 6f 6c 6c 61 74 65 35 2e 74 65 73 74 20    collate5.test 
3ae0: 20 20 20 20 20 20 20 20 20 20 20 20 6c 69 6d 69              limi
3af0: 74 2e 74 65 73 74 0a 20 20 7d 20 2d 69 6e 69 74  t.test.  } -init
3b00: 69 61 6c 69 7a 65 20 7b 0a 20 20 20 20 63 61 74  ialize {.    cat
3b10: 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20  ch {db close}.  
3b20: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 5f    sqlite3_reset_
3b30: 61 75 74 6f 5f 65 78 74 65 6e 73 69 6f 6e 0a 20  auto_extension. 
3b40: 20 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64     sqlite3_shutd
3b50: 6f 77 6e 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  own.    sqlite3_
3b60: 63 6f 6e 66 69 67 5f 68 65 61 70 20 32 35 30 30  config_heap 2500
3b70: 30 30 30 30 20 30 0a 20 20 20 20 73 71 6c 69 74  0000 0.    sqlit
3b80: 65 33 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b 61 73  e3_config_lookas
3b90: 69 64 65 20 30 20 30 0a 20 20 20 20 69 6e 73 74  ide 0 0.    inst
3ba0: 61 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75 6c 74  all_malloc_fault
3bb0: 73 69 6d 20 31 20 0a 20 20 20 20 73 71 6c 69 74  sim 1 .    sqlit
3bc0: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20  e3_initialize.  
3bd0: 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65    autoinstall_te
3be0: 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20 20 7d  st_functions.  }
3bf0: 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 20   -shutdown {.   
3c00: 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65   catch {db close
3c10: 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 68  }.    sqlite3_sh
3c20: 75 74 64 6f 77 6e 0a 20 20 20 20 73 71 6c 69 74  utdown.    sqlit
3c30: 65 33 5f 63 6f 6e 66 69 67 5f 68 65 61 70 20 30  e3_config_heap 0
3c40: 20 30 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 63   0.    sqlite3_c
3c50: 6f 6e 66 69 67 5f 6c 6f 6f 6b 61 73 69 64 65 20  onfig_lookaside 
3c60: 31 30 30 20 35 30 30 0a 20 20 20 20 69 6e 73 74  100 500.    inst
3c70: 61 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75 6c 74  all_malloc_fault
3c80: 73 69 6d 20 31 20 0a 20 20 20 20 73 71 6c 69 74  sim 1 .    sqlit
3c90: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20  e3_initialize.  
3ca0: 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65    autoinstall_te
3cb0: 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20 20 7d  st_functions.  }
3cc0: 0a 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 6d 65  .}..ifcapable me
3cd0: 6d 35 20 7b 0a 20 20 72 75 6e 5f 74 65 73 74 73  m5 {.  run_tests
3ce0: 20 22 6d 65 6d 73 79 73 35 22 20 2d 64 65 73 63   "memsys5" -desc
3cf0: 72 69 70 74 69 6f 6e 20 7b 0a 20 20 20 20 52 75  ription {.    Ru
3d00: 6e 20 74 65 73 74 73 20 75 73 69 6e 67 20 74 68  n tests using th
3d10: 65 20 61 6c 6c 6f 63 61 74 6f 72 20 69 6e 20 6d  e allocator in m
3d20: 65 6d 35 2e 63 2e 0a 20 20 7d 20 2d 65 78 63 6c  em5.c..  } -excl
3d30: 75 64 65 20 7b 0a 20 20 20 20 61 75 74 6f 76 61  ude {.    autova
3d40: 63 75 75 6d 2e 74 65 73 74 20 20 20 20 20 20 20  cuum.test       
3d50: 20 20 20 20 64 65 6c 65 74 65 33 2e 74 65 73 74      delete3.test
3d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6d 61                ma
3d70: 6e 79 64 62 2e 74 65 73 74 0a 20 20 20 20 62 69  nydb.test.    bi
3d80: 67 72 6f 77 2e 74 65 73 74 20 20 20 20 20 20 20  grow.test       
3d90: 20 20 20 20 20 20 20 20 69 6e 63 72 62 6c 6f 62          incrblob
3da0: 32 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20  2.test          
3db0: 20 20 6d 65 6d 64 62 2e 74 65 73 74 0a 20 20 20    memdb.test.   
3dc0: 20 62 69 74 76 65 63 2e 74 65 73 74 20 20 20 20   bitvec.test    
3dd0: 20 20 20 20 20 20 20 20 20 20 20 69 6e 64 65 78             index
3de0: 32 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20  2.test          
3df0: 20 20 20 20 20 6d 65 6d 73 75 62 73 79 73 31 2e       memsubsys1.
3e00: 74 65 73 74 0a 20 20 20 20 63 61 70 69 33 63 2e  test.    capi3c.
3e10: 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20  test            
3e20: 20 20 20 69 6f 65 72 72 2e 74 65 73 74 20 20 20     ioerr.test   
3e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 6d 65 6d               mem
3e40: 73 75 62 73 79 73 32 2e 74 65 73 74 0a 20 20 20  subsys2.test.   
3e50: 20 63 61 70 69 33 2e 74 65 73 74 20 20 20 20 20   capi3.test     
3e60: 20 20 20 20 20 20 20 20 20 20 20 6a 6f 69 6e 33             join3
3e70: 2e 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20  .test           
3e80: 20 20 20 20 20 70 61 67 65 73 69 7a 65 2e 74 65       pagesize.te
3e90: 73 74 0a 20 20 20 20 63 6f 6c 6c 61 74 65 35 2e  st.    collate5.
3ea0: 74 65 73 74 20 20 20 20 20 20 20 20 20 20 20 20  test            
3eb0: 20 6c 69 6d 69 74 2e 74 65 73 74 20 20 20 20 20   limit.test     
3ec0: 20 20 20 20 20 20 20 20 20 20 20 7a 65 72 6f 62             zerob
3ed0: 6c 6f 62 2e 74 65 73 74 0a 20 20 7d 20 2d 69 6e  lob.test.  } -in
3ee0: 69 74 69 61 6c 69 7a 65 20 7b 0a 20 20 20 20 63  itialize {.    c
3ef0: 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a  atch {db close}.
3f00: 20 20 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74      sqlite3_shut
3f10: 64 6f 77 6e 0a 20 20 20 20 73 71 6c 69 74 65 33  down.    sqlite3
3f20: 5f 63 6f 6e 66 69 67 5f 68 65 61 70 20 32 35 30  _config_heap 250
3f30: 30 30 30 30 30 20 36 34 0a 20 20 20 20 73 71 6c  00000 64.    sql
3f40: 69 74 65 33 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b  ite3_config_look
3f50: 61 73 69 64 65 20 30 20 30 0a 20 20 20 20 69 6e  aside 0 0.    in
3f60: 73 74 61 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75  stall_malloc_fau
3f70: 6c 74 73 69 6d 20 31 20 0a 20 20 20 20 73 71 6c  ltsim 1 .    sql
3f80: 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a  ite3_initialize.
3f90: 20 20 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f      autoinstall_
3fa0: 74 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20  test_functions. 
3fb0: 20 7d 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20   } -shutdown {. 
3fc0: 20 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f     catch {db clo
3fd0: 73 65 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  se}.    sqlite3_
3fe0: 73 68 75 74 64 6f 77 6e 0a 20 20 20 20 73 71 6c  shutdown.    sql
3ff0: 69 74 65 33 5f 63 6f 6e 66 69 67 5f 68 65 61 70  ite3_config_heap
4000: 20 30 20 30 0a 20 20 20 20 73 71 6c 69 74 65 33   0 0.    sqlite3
4010: 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b 61 73 69 64  _config_lookasid
4020: 65 20 31 30 30 20 35 30 30 0a 20 20 20 20 69 6e  e 100 500.    in
4030: 73 74 61 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75  stall_malloc_fau
4040: 6c 74 73 69 6d 20 31 20 0a 20 20 20 20 73 71 6c  ltsim 1 .    sql
4050: 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a  ite3_initialize.
4060: 20 20 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f      autoinstall_
4070: 74 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20  test_functions. 
4080: 20 7d 0a 0a 20 20 72 75 6e 5f 74 65 73 74 73 20   }..  run_tests 
4090: 22 6d 65 6d 73 79 73 35 2d 32 22 20 2d 64 65 73  "memsys5-2" -des
40a0: 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20 20 20 52  cription {.    R
40b0: 75 6e 20 74 65 73 74 73 20 75 73 69 6e 67 20 74  un tests using t
40c0: 68 65 20 61 6c 6c 6f 63 61 74 6f 72 20 69 6e 20  he allocator in 
40d0: 6d 65 6d 35 2e 63 20 69 6e 20 61 20 64 69 66 66  mem5.c in a diff
40e0: 65 72 65 6e 74 20 63 6f 6e 66 69 67 75 72 61 74  erent configurat
40f0: 69 6f 6e 2e 0a 20 20 7d 20 2d 69 6e 63 6c 75 64  ion..  } -includ
4100: 65 20 7b 0a 20 20 20 20 73 65 6c 65 63 74 31 2e  e {.    select1.
4110: 74 65 73 74 20 0a 20 20 7d 20 2d 69 6e 69 74 69  test .  } -initi
4120: 61 6c 69 7a 65 20 7b 0a 20 20 20 20 63 61 74 63  alize {.    catc
4130: 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 20  h {db close}.   
4140: 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77   sqlite3_shutdow
4150: 6e 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 63 6f  n.    sqlite3_co
4160: 6e 66 69 67 5f 68 65 61 70 20 34 30 30 30 30 30  nfig_heap 400000
4170: 30 30 20 31 36 0a 20 20 20 20 73 71 6c 69 74 65  00 16.    sqlite
4180: 33 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b 61 73 69  3_config_lookasi
4190: 64 65 20 30 20 30 0a 20 20 20 20 69 6e 73 74 61  de 0 0.    insta
41a0: 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75 6c 74 73  ll_malloc_faults
41b0: 69 6d 20 31 20 0a 20 20 20 20 73 71 6c 69 74 65  im 1 .    sqlite
41c0: 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 20  3_initialize.   
41d0: 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73   autoinstall_tes
41e0: 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20 20 7d 20  t_functions.  } 
41f0: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 20 20  -shutdown {.    
4200: 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d  catch {db close}
4210: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 68 75  .    sqlite3_shu
4220: 74 64 6f 77 6e 0a 20 20 20 20 73 71 6c 69 74 65  tdown.    sqlite
4230: 33 5f 63 6f 6e 66 69 67 5f 68 65 61 70 20 30 20  3_config_heap 0 
4240: 30 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 63 6f  0.    sqlite3_co
4250: 6e 66 69 67 5f 6c 6f 6f 6b 61 73 69 64 65 20 31  nfig_lookaside 1
4260: 30 30 20 35 30 30 0a 20 20 20 20 69 6e 73 74 61  00 500.    insta
4270: 6c 6c 5f 6d 61 6c 6c 6f 63 5f 66 61 75 6c 74 73  ll_malloc_faults
4280: 69 6d 20 31 20 0a 20 20 20 20 73 71 6c 69 74 65  im 1 .    sqlite
4290: 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 20  3_initialize.   
42a0: 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73   autoinstall_tes
42b0: 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20 20 7d 0a  t_functions.  }.
42c0: 7d 0a 0a 69 66 63 61 70 61 62 6c 65 20 74 68 72  }..ifcapable thr
42d0: 65 61 64 73 61 66 65 20 7b 0a 20 20 72 75 6e 5f  eadsafe {.  run_
42e0: 74 65 73 74 73 20 22 6e 6f 5f 6d 75 74 65 78 5f  tests "no_mutex_
42f0: 74 72 79 22 20 2d 64 65 73 63 72 69 70 74 69 6f  try" -descriptio
4300: 6e 20 7b 0a 20 20 20 20 20 54 68 65 20 73 71 6c  n {.     The sql
4310: 69 74 65 33 5f 6d 75 74 65 78 5f 74 72 79 28 29  ite3_mutex_try()
4320: 20 69 6e 74 65 72 66 61 63 65 20 61 6c 77 61 79   interface alway
4330: 73 20 66 61 69 6c 73 0a 20 20 7d 20 2d 65 78 63  s fails.  } -exc
4340: 6c 75 64 65 20 5b 63 6f 6e 63 61 74 20 24 45 58  lude [concat $EX
4350: 43 4c 55 44 45 20 6d 75 74 65 78 31 2e 74 65 73  CLUDE mutex1.tes
4360: 74 20 6d 75 74 65 78 32 2e 74 65 73 74 5d 20 5c  t mutex2.test] \
4370: 0a 20 20 2d 69 6e 69 74 69 61 6c 69 7a 65 20 7b  .  -initialize {
4380: 0a 20 20 20 20 63 61 74 63 68 20 7b 64 62 20 63  .    catch {db c
4390: 6c 6f 73 65 7d 0a 20 20 20 20 73 71 6c 69 74 65  lose}.    sqlite
43a0: 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 20 20 69  3_shutdown.    i
43b0: 6e 73 74 61 6c 6c 5f 6d 75 74 65 78 5f 63 6f 75  nstall_mutex_cou
43c0: 6e 74 65 72 73 20 31 0a 20 20 20 20 73 65 74 20  nters 1.    set 
43d0: 3a 3a 64 69 73 61 62 6c 65 5f 6d 75 74 65 78 5f  ::disable_mutex_
43e0: 74 72 79 20 31 0a 20 20 20 20 73 71 6c 69 74 65  try 1.    sqlite
43f0: 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 20  3_initialize.   
4400: 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73   autoinstall_tes
4410: 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 20 20 7d 20  t_functions.  } 
4420: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 20 20  -shutdown {.    
4430: 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d  catch {db close}
4440: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 68 75  .    sqlite3_shu
4450: 74 64 6f 77 6e 0a 20 20 20 20 69 6e 73 74 61 6c  tdown.    instal
4460: 6c 5f 6d 75 74 65 78 5f 63 6f 75 6e 74 65 72 73  l_mutex_counters
4470: 20 30 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 69   0.    sqlite3_i
4480: 6e 69 74 69 61 6c 69 7a 65 0a 20 20 20 20 61 75  nitialize.    au
4490: 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66  toinstall_test_f
44a0: 75 6e 63 74 69 6f 6e 73 0a 20 20 7d 0a 7d 0a 0a  unctions.  }.}..
44b0: 23 20 72 75 6e 5f 74 65 73 74 73 20 22 63 72 61  # run_tests "cra
44c0: 73 68 5f 73 61 66 65 5f 61 70 70 65 6e 64 22 20  sh_safe_append" 
44d0: 2d 64 65 73 63 72 69 70 74 69 6f 6e 20 7b 0a 23  -description {.#
44e0: 20 20 20 52 75 6e 20 63 72 61 73 68 2e 74 65 73     Run crash.tes
44f0: 74 20 77 69 74 68 20 70 65 72 73 69 73 74 65 6e  t with persisten
4500: 74 20 6a 6f 75 72 6e 61 6c 73 20 6f 6e 20 61 20  t journals on a 
4510: 53 41 46 45 5f 41 50 50 45 4e 44 20 66 69 6c 65  SAFE_APPEND file
4520: 2d 73 79 73 74 65 6d 2e 0a 23 20 7d 20 2d 69 6e  -system..# } -in
4530: 69 74 69 61 6c 69 7a 65 20 7b 0a 23 20 20 20 72  itialize {.#   r
4540: 65 6e 61 6d 65 20 63 72 61 73 68 73 71 6c 20 73  ename crashsql s
4550: 61 5f 63 72 61 73 68 73 71 6c 0a 23 20 20 20 70  a_crashsql.#   p
4560: 72 6f 63 20 63 72 61 73 68 73 71 6c 20 7b 61 72  roc crashsql {ar
4570: 67 73 7d 20 7b 0a 23 20 20 20 20 20 73 65 74 20  gs} {.#     set 
4580: 6f 70 74 69 6f 6e 73 20 5b 6c 72 61 6e 67 65 20  options [lrange 
4590: 24 61 72 67 73 20 30 20 5b 65 78 70 72 20 7b 5b  $args 0 [expr {[
45a0: 6c 6c 65 6e 67 74 68 20 24 61 72 67 73 5d 2d 32  llength $args]-2
45b0: 7d 5d 5d 0a 23 20 20 20 20 20 6c 61 70 70 65 6e  }]].#     lappen
45c0: 64 20 6f 70 74 69 6f 6e 73 20 2d 63 68 61 72 20  d options -char 
45d0: 73 61 66 65 5f 61 70 70 65 6e 64 0a 23 20 20 20  safe_append.#   
45e0: 20 20 73 65 74 20 73 71 6c 20 5b 6c 69 6e 64 65    set sql [linde
45f0: 78 20 24 61 72 67 73 20 65 6e 64 5d 0a 23 20 20  x $args end].#  
4600: 20 20 20 6c 61 70 70 65 6e 64 20 6f 70 74 69 6f     lappend optio
4610: 6e 73 20 22 0a 23 20 20 20 20 20 20 20 50 52 41  ns ".#       PRA
4620: 47 4d 41 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65  GMA journal_mode
4630: 3d 70 65 72 73 69 73 74 65 6e 74 3b 0a 23 20 20  =persistent;.#  
4640: 20 20 20 20 20 24 73 71 6c 0a 23 20 20 20 20 20       $sql.#     
4650: 22 0a 23 20 20 20 20 20 73 65 74 20 66 64 20 5b  ".#     set fd [
4660: 6f 70 65 6e 20 74 65 73 74 2e 64 62 2d 6a 6f 75  open test.db-jou
4670: 72 6e 61 6c 20 77 5d 0a 23 20 20 20 20 20 70 75  rnal w].#     pu
4680: 74 73 20 24 66 64 20 5b 73 74 72 69 6e 67 20 72  ts $fd [string r
4690: 65 70 65 61 74 20 31 32 33 34 35 36 37 38 39 30  epeat 1234567890
46a0: 20 31 30 30 30 30 30 5d 0a 23 20 20 20 20 20 63   100000].#     c
46b0: 6c 6f 73 65 20 24 66 64 0a 23 20 20 20 20 20 65  lose $fd.#     e
46c0: 76 61 6c 20 73 61 5f 63 72 61 73 68 73 71 6c 20  val sa_crashsql 
46d0: 24 6f 70 74 69 6f 6e 73 0a 23 20 20 20 7d 0a 23  $options.#   }.#
46e0: 20 7d 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 23   } -shutdown {.#
46f0: 20 20 20 72 65 6e 61 6d 65 20 63 72 61 73 68 73     rename crashs
4700: 71 6c 20 7b 7d 0a 23 20 20 20 72 65 6e 61 6d 65  ql {}.#   rename
4710: 20 73 61 5f 63 72 61 73 68 73 71 6c 20 63 72 61   sa_crashsql cra
4720: 73 68 73 71 6c 0a 23 20 7d 20 2d 69 6e 63 6c 75  shsql.# } -inclu
4730: 64 65 20 63 72 61 73 68 2e 74 65 73 74 0a 0a 72  de crash.test..r
4740: 75 6e 5f 74 65 73 74 73 20 22 73 61 66 65 5f 61  un_tests "safe_a
4750: 70 70 65 6e 64 22 20 2d 64 65 73 63 72 69 70 74  ppend" -descript
4760: 69 6f 6e 20 7b 0a 20 20 52 75 6e 20 73 6f 6d 65  ion {.  Run some
4770: 20 74 65 73 74 73 20 6f 6e 20 61 20 53 41 46 45   tests on a SAFE
4780: 5f 41 50 50 45 4e 44 20 66 69 6c 65 2d 73 79 73  _APPEND file-sys
4790: 74 65 6d 2e 0a 7d 20 2d 69 6e 69 74 69 61 6c 69  tem..} -initiali
47a0: 7a 65 20 7b 0a 20 20 72 65 6e 61 6d 65 20 73 71  ze {.  rename sq
47b0: 6c 69 74 65 33 20 73 71 6c 69 74 65 33 5f 73 61  lite3 sqlite3_sa
47c0: 66 65 61 70 70 65 6e 64 0a 20 20 70 72 6f 63 20  feappend.  proc 
47d0: 73 71 6c 69 74 65 33 20 7b 61 72 67 73 7d 20 7b  sqlite3 {args} {
47e0: 0a 20 20 20 20 69 66 20 7b 5b 73 74 72 69 6e 67  .    if {[string
47f0: 20 72 61 6e 67 65 20 5b 6c 69 6e 64 65 78 20 24   range [lindex $
4800: 61 72 67 73 20 30 5d 20 30 20 30 5d 20 6e 65 20  args 0] 0 0] ne 
4810: 22 2d 22 7d 20 7b 0a 20 20 20 20 20 20 6c 61 70  "-"} {.      lap
4820: 70 65 6e 64 20 61 72 67 73 20 2d 76 66 73 20 64  pend args -vfs d
4830: 65 76 73 79 6d 0a 20 20 20 20 7d 0a 20 20 20 20  evsym.    }.    
4840: 75 70 6c 65 76 65 6c 20 5b 63 6f 6e 63 61 74 20  uplevel [concat 
4850: 73 71 6c 69 74 65 33 5f 73 61 66 65 61 70 70 65  sqlite3_safeappe
4860: 6e 64 20 24 61 72 67 73 5d 0a 20 20 7d 0a 20 20  nd $args].  }.  
4870: 73 71 6c 69 74 65 33 5f 73 69 6d 75 6c 61 74 65  sqlite3_simulate
4880: 5f 64 65 76 69 63 65 20 2d 63 68 61 72 20 73 61  _device -char sa
4890: 66 65 5f 61 70 70 65 6e 64 0a 7d 20 2d 73 68 75  fe_append.} -shu
48a0: 74 64 6f 77 6e 20 7b 0a 20 20 72 65 6e 61 6d 65  tdown {.  rename
48b0: 20 73 71 6c 69 74 65 33 20 7b 7d 0a 20 20 72 65   sqlite3 {}.  re
48c0: 6e 61 6d 65 20 73 71 6c 69 74 65 33 5f 73 68 75  name sqlite3_shu
48d0: 74 64 6f 77 6e 20 73 71 6c 69 74 65 33 0a 7d 20  tdown sqlite3.} 
48e0: 2d 69 6e 63 6c 75 64 65 20 5b 6c 73 6f 72 74 20  -include [lsort 
48f0: 5b 63 6f 6e 63 61 74 20 73 68 61 72 65 64 5f 65  [concat shared_e
4900: 72 72 2e 74 65 73 74 20 24 41 4c 4c 54 45 53 54  rr.test $ALLTEST
4910: 53 5d 5d 20 5c 0a 20 20 2d 65 78 63 6c 75 64 65  S]] \.  -exclude
4920: 20 61 73 79 6e 63 33 2e 74 65 73 74 0a 0a 23 20   async3.test..# 
4930: 54 68 65 20 73 65 74 20 6f 66 20 74 65 73 74 73  The set of tests
4940: 20 74 6f 20 72 75 6e 20 6f 6e 20 74 68 65 20 61   to run on the a
4950: 6c 74 65 72 6e 61 74 69 76 65 2d 70 63 61 63 68  lternative-pcach
4960: 65 0a 73 65 74 20 70 65 72 6d 2d 61 6c 74 2d 70  e.set perm-alt-p
4970: 63 61 63 68 65 2d 74 65 73 74 73 65 74 20 7b 0a  cache-testset {.
4980: 20 20 61 73 79 6e 63 2e 74 65 73 74 0a 20 20 61    async.test.  a
4990: 74 74 61 63 68 2e 74 65 73 74 0a 20 20 64 65 6c  ttach.test.  del
49a0: 65 74 65 2e 74 65 73 74 20 64 65 6c 65 74 65 32  ete.test delete2
49b0: 2e 74 65 73 74 0a 20 20 69 6e 64 65 78 2e 74 65  .test.  index.te
49c0: 73 74 0a 20 20 69 6e 73 65 72 74 2e 74 65 73 74  st.  insert.test
49d0: 20 69 6e 73 65 72 74 32 2e 74 65 73 74 0a 20 20   insert2.test.  
49e0: 6a 6f 69 6e 2e 74 65 73 74 20 6a 6f 69 6e 32 2e  join.test join2.
49f0: 74 65 73 74 0a 20 20 72 6f 6c 6c 62 61 63 6b 2e  test.  rollback.
4a00: 74 65 73 74 0a 20 20 73 65 6c 65 63 74 31 2e 74  test.  select1.t
4a10: 65 73 74 20 73 65 6c 65 63 74 32 2e 74 65 73 74  est select2.test
4a20: 0a 20 20 74 72 61 6e 73 2e 74 65 73 74 0a 20 20  .  trans.test.  
4a30: 75 70 64 61 74 65 2e 74 65 73 74 0a 7d 0a 0a 72  update.test.}..r
4a40: 75 6e 5f 74 65 73 74 73 20 22 70 63 61 63 68 65  un_tests "pcache
4a50: 30 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20  0" -description 
4a60: 7b 0a 20 20 41 6c 74 65 72 6e 61 74 69 76 65 20  {.  Alternative 
4a70: 70 63 61 63 68 65 20 69 6d 70 6c 65 6d 65 6e 74  pcache implement
4a80: 61 74 69 6f 6e 20 77 69 74 68 6f 75 74 20 72 61  ation without ra
4a90: 6e 64 6f 6d 20 64 69 73 63 61 72 64 0a 7d 20 2d  ndom discard.} -
4aa0: 69 6e 69 74 69 61 6c 69 7a 65 20 7b 0a 20 20 63  initialize {.  c
4ab0: 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a  atch {db close}.
4ac0: 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f    sqlite3_shutdo
4ad0: 77 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e  wn.  sqlite3_con
4ae0: 66 69 67 5f 61 6c 74 5f 70 63 61 63 68 65 20 31  fig_alt_pcache 1
4af0: 20 30 20 31 0a 20 20 73 71 6c 69 74 65 33 5f 69   0 1.  sqlite3_i
4b00: 6e 69 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f  nitialize.  auto
4b10: 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e  install_test_fun
4b20: 63 74 69 6f 6e 73 0a 7d 20 2d 73 68 75 74 64 6f  ctions.} -shutdo
4b30: 77 6e 20 7b 0a 20 20 63 61 74 63 68 20 7b 64 62  wn {.  catch {db
4b40: 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69 74 65   close}.  sqlite
4b50: 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73 71 6c  3_shutdown.  sql
4b60: 69 74 65 33 5f 63 6f 6e 66 69 67 5f 61 6c 74 5f  ite3_config_alt_
4b70: 70 63 61 63 68 65 20 30 20 30 20 30 0a 20 20 73  pcache 0 0 0.  s
4b80: 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 6c 6f  qlite3_config_lo
4b90: 6f 6b 61 73 69 64 65 20 31 30 30 20 35 30 30 0a  okaside 100 500.
4ba0: 20 20 69 6e 73 74 61 6c 6c 5f 6d 61 6c 6c 6f 63    install_malloc
4bb0: 5f 66 61 75 6c 74 73 69 6d 20 31 20 0a 20 20 73  _faultsim 1 .  s
4bc0: 71 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a  qlite3_initializ
4bd0: 65 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f  e.  autoinstall_
4be0: 74 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d  test_functions.}
4bf0: 20 2d 69 6e 63 6c 75 64 65 20 24 7b 70 65 72 6d   -include ${perm
4c00: 2d 61 6c 74 2d 70 63 61 63 68 65 2d 74 65 73 74  -alt-pcache-test
4c10: 73 65 74 7d 0a 0a 72 75 6e 5f 74 65 73 74 73 20  set}..run_tests 
4c20: 22 70 63 61 63 68 65 31 30 22 20 2d 64 65 73 63  "pcache10" -desc
4c30: 72 69 70 74 69 6f 6e 20 7b 0a 20 20 41 6c 74 65  ription {.  Alte
4c40: 72 6e 61 74 69 76 65 20 70 63 61 63 68 65 20 69  rnative pcache i
4c50: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 77 69  mplementation wi
4c60: 74 68 6f 75 74 20 31 30 25 20 72 61 6e 64 6f 6d  thout 10% random
4c70: 20 64 69 73 63 61 72 64 0a 7d 20 2d 69 6e 69 74   discard.} -init
4c80: 69 61 6c 69 7a 65 20 7b 0a 20 20 63 61 74 63 68  ialize {.  catch
4c90: 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71   {db close}.  sq
4ca0: 6c 69 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20  lite3_shutdown. 
4cb0: 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f   sqlite3_config_
4cc0: 61 6c 74 5f 70 63 61 63 68 65 20 31 20 35 30 20  alt_pcache 1 50 
4cd0: 31 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 69 74  1.  sqlite3_init
4ce0: 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f 69 6e 73  ialize.  autoins
4cf0: 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e 63 74 69  tall_test_functi
4d00: 6f 6e 73 0a 7d 20 2d 73 68 75 74 64 6f 77 6e 20  ons.} -shutdown 
4d10: 7b 0a 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c  {.  catch {db cl
4d20: 6f 73 65 7d 0a 20 20 73 71 6c 69 74 65 33 5f 73  ose}.  sqlite3_s
4d30: 68 75 74 64 6f 77 6e 0a 20 20 73 71 6c 69 74 65  hutdown.  sqlite
4d40: 33 5f 63 6f 6e 66 69 67 5f 61 6c 74 5f 70 63 61  3_config_alt_pca
4d50: 63 68 65 20 30 20 30 20 30 0a 20 20 73 71 6c 69  che 0 0 0.  sqli
4d60: 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20  te3_initialize. 
4d70: 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73   autoinstall_tes
4d80: 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20 2d 69  t_functions.} -i
4d90: 6e 63 6c 75 64 65 20 24 7b 70 65 72 6d 2d 61 6c  nclude ${perm-al
4da0: 74 2d 70 63 61 63 68 65 2d 74 65 73 74 73 65 74  t-pcache-testset
4db0: 7d 0a 0a 72 75 6e 5f 74 65 73 74 73 20 22 70 63  }..run_tests "pc
4dc0: 61 63 68 65 35 30 22 20 2d 64 65 73 63 72 69 70  ache50" -descrip
4dd0: 74 69 6f 6e 20 7b 0a 20 20 41 6c 74 65 72 6e 61  tion {.  Alterna
4de0: 74 69 76 65 20 70 63 61 63 68 65 20 69 6d 70 6c  tive pcache impl
4df0: 65 6d 65 6e 74 61 74 69 6f 6e 20 77 69 74 68 6f  ementation witho
4e00: 75 74 20 35 30 25 20 72 61 6e 64 6f 6d 20 64 69  ut 50% random di
4e10: 73 63 61 72 64 0a 7d 20 2d 69 6e 69 74 69 61 6c  scard.} -initial
4e20: 69 7a 65 20 7b 0a 20 20 63 61 74 63 68 20 7b 64  ize {.  catch {d
4e30: 62 20 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69 74  b close}.  sqlit
4e40: 65 33 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73 71  e3_shutdown.  sq
4e50: 6c 69 74 65 33 5f 63 6f 6e 66 69 67 5f 61 6c 74  lite3_config_alt
4e60: 5f 70 63 61 63 68 65 20 31 20 35 30 20 31 0a 20  _pcache 1 50 1. 
4e70: 20 73 71 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c   sqlite3_initial
4e80: 69 7a 65 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c  ize.  autoinstal
4e90: 6c 5f 74 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73  l_test_functions
4ea0: 0a 7d 20 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20  .} -shutdown {. 
4eb0: 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f 73 65   catch {db close
4ec0: 7d 0a 20 20 73 71 6c 69 74 65 33 5f 73 68 75 74  }.  sqlite3_shut
4ed0: 64 6f 77 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63  down.  sqlite3_c
4ee0: 6f 6e 66 69 67 5f 61 6c 74 5f 70 63 61 63 68 65  onfig_alt_pcache
4ef0: 20 30 20 30 20 30 0a 20 20 73 71 6c 69 74 65 33   0 0 0.  sqlite3
4f00: 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 20 20 61 75  _initialize.  au
4f10: 74 6f 69 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66  toinstall_test_f
4f20: 75 6e 63 74 69 6f 6e 73 0a 7d 20 2d 69 6e 63 6c  unctions.} -incl
4f30: 75 64 65 20 24 7b 70 65 72 6d 2d 61 6c 74 2d 70  ude ${perm-alt-p
4f40: 63 61 63 68 65 2d 74 65 73 74 73 65 74 7d 0a 0a  cache-testset}..
4f50: 72 75 6e 5f 74 65 73 74 73 20 22 70 63 61 63 68  run_tests "pcach
4f60: 65 39 30 22 20 2d 64 65 73 63 72 69 70 74 69 6f  e90" -descriptio
4f70: 6e 20 7b 0a 20 20 41 6c 74 65 72 6e 61 74 69 76  n {.  Alternativ
4f80: 65 20 70 63 61 63 68 65 20 69 6d 70 6c 65 6d 65  e pcache impleme
4f90: 6e 74 61 74 69 6f 6e 20 77 69 74 68 6f 75 74 20  ntation without 
4fa0: 39 30 25 20 72 61 6e 64 6f 6d 20 64 69 73 63 61  90% random disca
4fb0: 72 64 0a 7d 20 2d 69 6e 69 74 69 61 6c 69 7a 65  rd.} -initialize
4fc0: 20 7b 0a 20 20 63 61 74 63 68 20 7b 64 62 20 63   {.  catch {db c
4fd0: 6c 6f 73 65 7d 0a 20 20 73 71 6c 69 74 65 33 5f  lose}.  sqlite3_
4fe0: 73 68 75 74 64 6f 77 6e 0a 20 20 73 71 6c 69 74  shutdown.  sqlit
4ff0: 65 33 5f 63 6f 6e 66 69 67 5f 61 6c 74 5f 70 63  e3_config_alt_pc
5000: 61 63 68 65 20 31 20 35 30 20 31 0a 20 20 73 71  ache 1 50 1.  sq
5010: 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65  lite3_initialize
5020: 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74  .  autoinstall_t
5030: 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20  est_functions.} 
5040: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 63 61  -shutdown {.  ca
5050: 74 63 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20  tch {db close}. 
5060: 20 73 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77   sqlite3_shutdow
5070: 6e 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66  n.  sqlite3_conf
5080: 69 67 5f 61 6c 74 5f 70 63 61 63 68 65 20 30 20  ig_alt_pcache 0 
5090: 30 20 30 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e  0 0.  sqlite3_in
50a0: 69 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f 69  itialize.  autoi
50b0: 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e 63  nstall_test_func
50c0: 74 69 6f 6e 73 0a 7d 20 2d 69 6e 63 6c 75 64 65  tions.} -include
50d0: 20 24 7b 70 65 72 6d 2d 61 6c 74 2d 70 63 61 63   ${perm-alt-pcac
50e0: 68 65 2d 74 65 73 74 73 65 74 7d 0a 0a 72 75 6e  he-testset}..run
50f0: 5f 74 65 73 74 73 20 22 70 63 61 63 68 65 31 30  _tests "pcache10
5100: 30 22 20 2d 64 65 73 63 72 69 70 74 69 6f 6e 20  0" -description 
5110: 7b 0a 20 20 41 6c 74 65 72 6e 61 74 69 76 65 20  {.  Alternative 
5120: 70 63 61 63 68 65 20 69 6d 70 6c 65 6d 65 6e 74  pcache implement
5130: 61 74 69 6f 6e 20 74 68 61 74 20 61 6c 77 61 79  ation that alway
5140: 73 20 64 69 73 63 61 72 64 73 20 77 68 65 6e 20  s discards when 
5150: 75 6e 70 69 6e 6e 69 6e 67 0a 7d 20 2d 69 6e 69  unpinning.} -ini
5160: 74 69 61 6c 69 7a 65 20 7b 0a 20 20 63 61 74 63  tialize {.  catc
5170: 68 20 7b 64 62 20 63 6c 6f 73 65 7d 0a 20 20 73  h {db close}.  s
5180: 71 6c 69 74 65 33 5f 73 68 75 74 64 6f 77 6e 0a  qlite3_shutdown.
5190: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 66 69 67    sqlite3_config
51a0: 5f 61 6c 74 5f 70 63 61 63 68 65 20 31 20 31 30  _alt_pcache 1 10
51b0: 30 20 31 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e  0 1.  sqlite3_in
51c0: 69 74 69 61 6c 69 7a 65 0a 20 20 61 75 74 6f 69  itialize.  autoi
51d0: 6e 73 74 61 6c 6c 5f 74 65 73 74 5f 66 75 6e 63  nstall_test_func
51e0: 74 69 6f 6e 73 0a 7d 20 2d 73 68 75 74 64 6f 77  tions.} -shutdow
51f0: 6e 20 7b 0a 20 20 63 61 74 63 68 20 7b 64 62 20  n {.  catch {db 
5200: 63 6c 6f 73 65 7d 0a 20 20 73 71 6c 69 74 65 33  close}.  sqlite3
5210: 5f 73 68 75 74 64 6f 77 6e 0a 20 20 73 71 6c 69  _shutdown.  sqli
5220: 74 65 33 5f 63 6f 6e 66 69 67 5f 61 6c 74 5f 70  te3_config_alt_p
5230: 63 61 63 68 65 20 30 20 30 20 30 0a 20 20 73 71  cache 0 0 0.  sq
5240: 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65  lite3_initialize
5250: 0a 20 20 61 75 74 6f 69 6e 73 74 61 6c 6c 5f 74  .  autoinstall_t
5260: 65 73 74 5f 66 75 6e 63 74 69 6f 6e 73 0a 7d 20  est_functions.} 
5270: 2d 69 6e 63 6c 75 64 65 20 24 7b 70 65 72 6d 2d  -include ${perm-
5280: 61 6c 74 2d 70 63 61 63 68 65 2d 74 65 73 74 73  alt-pcache-tests
5290: 65 74 7d 0a 0a 72 75 6e 5f 74 65 73 74 73 20 22  et}..run_tests "
52a0: 6a 6f 75 72 6e 61 6c 74 65 73 74 22 20 2d 64 65  journaltest" -de
52b0: 73 63 72 69 70 74 69 6f 6e 20 7b 0a 20 20 43 68  scription {.  Ch
52c0: 65 63 6b 20 74 68 61 74 20 70 61 67 65 73 20 61  eck that pages a
52d0: 72 65 20 73 79 6e 63 65 64 20 62 65 66 6f 72 65  re synced before
52e0: 20 62 65 69 6e 67 20 77 72 69 74 74 65 6e 20 28   being written (
52f0: 74 65 73 74 5f 6a 6f 75 72 6e 61 6c 2e 63 29 2e  test_journal.c).
5300: 0a 7d 20 2d 69 6e 69 74 69 61 6c 69 7a 65 20 7b  .} -initialize {
5310: 0a 20 20 73 65 74 20 49 53 51 55 49 43 4b 20 31  .  set ISQUICK 1
5320: 0a 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c 6f  .  catch {db clo
5330: 73 65 7d 0a 20 20 72 65 67 69 73 74 65 72 5f 6a  se}.  register_j
5340: 74 5f 76 66 73 20 2d 64 65 66 61 75 6c 74 20 22  t_vfs -default "
5350: 22 0a 20 20 23 73 71 6c 69 74 65 33 5f 69 6e 73  ".  #sqlite3_ins
5360: 74 76 66 73 20 62 69 6e 61 72 79 6c 6f 67 20 2d  tvfs binarylog -
5370: 64 65 66 61 75 6c 74 20 62 69 6e 61 72 79 6c 6f  default binarylo
5380: 67 20 6f 73 74 72 61 63 65 2e 62 69 6e 0a 7d 20  g ostrace.bin.} 
5390: 2d 73 68 75 74 64 6f 77 6e 20 7b 0a 20 20 23 73  -shutdown {.  #s
53a0: 71 6c 69 74 65 33 5f 69 6e 73 74 76 66 73 20 64  qlite3_instvfs d
53b0: 65 73 74 72 6f 79 20 62 69 6e 61 72 79 6c 6f 67  estroy binarylog
53c0: 0a 20 20 75 6e 72 65 67 69 73 74 65 72 5f 6a 74  .  unregister_jt
53d0: 5f 76 66 73 0a 7d 20 2d 69 6e 63 6c 75 64 65 20  _vfs.} -include 
53e0: 5b 63 6f 6e 63 61 74 20 24 3a 3a 41 4c 4c 54 45  [concat $::ALLTE
53f0: 53 54 53 20 73 61 76 65 70 6f 69 6e 74 36 2e 74  STS savepoint6.t
5400: 65 73 74 0a 5d 20 2d 65 78 63 6c 75 64 65 20 7b  est.] -exclude {
5410: 0a 20 20 69 6e 63 72 76 61 63 75 75 6d 2e 74 65  .  incrvacuum.te
5420: 73 74 0a 20 20 69 6f 65 72 72 2e 74 65 73 74 0a  st.  ioerr.test.
5430: 20 20 63 6f 72 72 75 70 74 34 2e 74 65 73 74 20    corrupt4.test 
5440: 0a 20 20 69 6f 2e 74 65 73 74 20 0a 20 20 63 72  .  io.test .  cr
5450: 61 73 68 38 2e 74 65 73 74 20 0a 20 20 61 73 79  ash8.test .  asy
5460: 6e 63 34 2e 74 65 73 74 20 0a 7d 0a 0a 23 20 45  nc4.test .}..# E
5470: 6e 64 20 6f 66 20 74 65 73 74 73 0a 23 23 23 23  nd of tests.####
5480: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
5490: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
54a0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
54b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
54c0: 23 23 23 23 23 23 23 23 23 0a 0a 69 66 20 7b 24  #########..if {$
54d0: 3a 3a 70 65 72 6d 3a 3a 74 65 73 74 6d 6f 64 65  ::perm::testmode
54e0: 20 65 71 20 22 74 61 72 67 65 74 73 22 7d 20 7b   eq "targets"} {
54f0: 20 70 75 74 73 20 22 22 20 3b 20 65 78 69 74 20   puts "" ; exit 
5500: 7d 0a 0a 23 20 52 65 73 74 6f 72 65 20 74 68 65  }..# Restore the
5510: 20 5b 73 71 6c 69 74 65 33 5d 20 63 6f 6d 6d 61   [sqlite3] comma
5520: 6e 64 2e 0a 23 0a 72 65 6e 61 6d 65 20 73 71 6c  nd..#.rename sql
5530: 69 74 65 33 20 7b 7d 0a 72 65 6e 61 6d 65 20 72  ite3 {}.rename r
5540: 65 61 6c 6c 79 5f 73 71 6c 69 74 65 33 20 73 71  eally_sqlite3 sq
5550: 6c 69 74 65 33 0a 0a 23 20 52 65 73 74 6f 72 65  lite3..# Restore
5560: 20 74 68 65 20 5b 66 69 6e 69 73 68 5f 74 65 73   the [finish_tes
5570: 74 5d 20 63 6f 6d 6d 61 6e 64 2e 0a 23 0a 72 65  t] command..#.re
5580: 6e 61 6d 65 20 66 69 6e 69 73 68 5f 74 65 73 74  name finish_test
5590: 20 22 22 0a 72 65 6e 61 6d 65 20 72 65 61 6c 6c   "".rename reall
55a0: 79 5f 66 69 6e 69 73 68 5f 74 65 73 74 32 20 66  y_finish_test2 f
55b0: 69 6e 69 73 68 5f 74 65 73 74 0a 0a 23 20 52 65  inish_test..# Re
55c0: 73 74 6f 72 65 20 74 68 65 20 5b 64 6f 5f 74 65  store the [do_te
55d0: 73 74 5d 20 63 6f 6d 6d 61 6e 64 2e 0a 23 0a 72  st] command..#.r
55e0: 65 6e 61 6d 65 20 64 6f 5f 74 65 73 74 20 22 22  ename do_test ""
55f0: 0a 72 65 6e 61 6d 65 20 72 65 61 6c 6c 79 5f 64  .rename really_d
5600: 6f 5f 74 65 73 74 20 64 6f 5f 74 65 73 74 0a 0a  o_test do_test..
5610: 66 69 6e 69 73 68 5f 74 65 73 74 0a              finish_test.