/ Hex Artifact Content
Login

Artifact 73149851b3aff14fc6db478e58f9083a66422cf5:


0000: 23 20 32 30 31 30 20 4d 61 72 63 68 20 31 30 0a  # 2010 March 10.
0010: 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64  #.# The author d
0020: 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67  isclaims copyrig
0030: 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63  ht to this sourc
0040: 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63  e code.  In plac
0050: 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e  e of.# a legal n
0060: 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73 20 61  otice, here is a
0070: 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20   blessing:.#.#  
0080: 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f    May you do goo
0090: 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a  d and not evil..
00a0: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e  #    May you fin
00b0: 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f  d forgiveness fo
00c0: 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66  r yourself and f
00d0: 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23  orgive others..#
00e0: 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72      May you shar
00f0: 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20  e freely, never 
0100: 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e  taking more than
0110: 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 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 2a 0a 23 0a 23 20 54 65 73 74 73 20  *****.#.# Tests 
0170: 66 6f 72 20 74 68 65 20 73 71 6c 69 74 65 33 5f  for the sqlite3_
0180: 64 62 5f 73 74 61 74 75 73 28 29 20 66 75 6e 63  db_status() func
0190: 74 69 6f 6e 0a 23 0a 0a 73 65 74 20 74 65 73 74  tion.#..set test
01a0: 64 69 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d  dir [file dirnam
01b0: 65 20 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65  e $argv0].source
01c0: 20 24 74 65 73 74 64 69 72 2f 74 65 73 74 65 72   $testdir/tester
01d0: 2e 74 63 6c 0a 73 65 74 20 74 65 73 74 70 72 65  .tcl.set testpre
01e0: 66 69 78 20 64 62 73 74 61 74 75 73 0a 0a 69 66  fix dbstatus..if
01f0: 63 61 70 61 62 6c 65 20 21 63 6f 6d 70 6f 75 6e  capable !compoun
0200: 64 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74 65 73  d {.  finish_tes
0210: 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 23 20  t.  return.}..# 
0220: 4d 65 6d 6f 72 79 20 73 74 61 74 69 73 74 69 63  Memory statistic
0230: 73 20 6d 75 73 74 20 62 65 20 65 6e 61 62 6c 65  s must be enable
0240: 64 20 66 6f 72 20 74 68 69 73 20 74 65 73 74 2e  d for this test.
0250: 0a 64 62 20 63 6c 6f 73 65 0a 73 71 6c 69 74 65  .db close.sqlite
0260: 33 5f 73 68 75 74 64 6f 77 6e 0a 73 71 6c 69 74  3_shutdown.sqlit
0270: 65 33 5f 63 6f 6e 66 69 67 5f 6d 65 6d 73 74 61  e3_config_memsta
0280: 74 75 73 20 31 0a 73 71 6c 69 74 65 33 5f 63 6f  tus 1.sqlite3_co
0290: 6e 66 69 67 5f 75 72 69 20 31 0a 73 71 6c 69 74  nfig_uri 1.sqlit
02a0: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 0a 73 71  e3_initialize.sq
02b0: 6c 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62  lite3 db test.db
02c0: 0a 0a 0a 23 20 4d 61 6b 65 20 73 75 72 65 20 73  ...# Make sure s
02d0: 71 6c 69 74 65 33 5f 64 62 5f 63 6f 6e 66 69 67  qlite3_db_config
02e0: 28 29 20 61 6e 64 20 73 71 6c 69 74 65 33 5f 64  () and sqlite3_d
02f0: 62 5f 73 74 61 74 75 73 20 61 72 65 20 77 6f 72  b_status are wor
0300: 6b 69 6e 67 2e 0a 23 0a 75 6e 73 65 74 20 2d 6e  king..#.unset -n
0310: 6f 63 6f 6d 70 6c 61 69 6e 20 50 41 47 45 53 5a  ocomplain PAGESZ
0320: 0a 75 6e 73 65 74 20 2d 6e 6f 63 6f 6d 70 6c 61  .unset -nocompla
0330: 69 6e 20 42 41 53 45 53 5a 0a 64 6f 5f 74 65 73  in BASESZ.do_tes
0340: 74 20 64 62 73 74 61 74 75 73 2d 31 2e 31 20 7b  t dbstatus-1.1 {
0350: 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 71  .  db close.  sq
0360: 6c 69 74 65 33 20 64 62 20 3a 6d 65 6d 6f 72 79  lite3 db :memory
0370: 3a 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a 20 20  :.  db eval {.  
0380: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0390: 31 28 78 29 3b 0a 20 20 7d 0a 20 20 73 65 74 20  1(x);.  }.  set 
03a0: 73 7a 31 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c  sz1 [lindex [sql
03b0: 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 20 64  ite3_db_status d
03c0: 62 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55  b SQLITE_DBSTATU
03d0: 53 5f 43 41 43 48 45 5f 55 53 45 44 20 30 5d 20  S_CACHE_USED 0] 
03e0: 31 5d 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a 20  1].  db eval {. 
03f0: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
0400: 74 32 28 79 29 3b 0a 20 20 7d 0a 20 20 73 65 74  t2(y);.  }.  set
0410: 20 73 7a 32 20 5b 6c 69 6e 64 65 78 20 5b 73 71   sz2 [lindex [sq
0420: 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 20  lite3_db_status 
0430: 64 62 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54  db SQLITE_DBSTAT
0440: 55 53 5f 43 41 43 48 45 5f 55 53 45 44 20 30 5d  US_CACHE_USED 0]
0450: 20 31 5d 0a 20 20 73 65 74 20 3a 3a 50 41 47 45   1].  set ::PAGE
0460: 53 5a 20 5b 65 78 70 72 20 7b 24 73 7a 32 2d 24  SZ [expr {$sz2-$
0470: 73 7a 31 7d 5d 0a 20 20 73 65 74 20 3a 3a 42 41  sz1}].  set ::BA
0480: 53 45 53 5a 20 5b 65 78 70 72 20 7b 24 73 7a 31  SESZ [expr {$sz1
0490: 2d 24 3a 3a 50 41 47 45 53 5a 7d 5d 0a 20 20 65  -$::PAGESZ}].  e
04a0: 78 70 72 20 7b 24 3a 3a 50 41 47 45 53 5a 3e 31  xpr {$::PAGESZ>1
04b0: 30 32 34 20 26 26 20 24 3a 3a 50 41 47 45 53 5a  024 && $::PAGESZ
04c0: 3c 31 33 30 30 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f  <1300}.} {1}.do_
04d0: 74 65 73 74 20 64 62 73 74 61 74 75 73 2d 31 2e  test dbstatus-1.
04e0: 32 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a  2 {.  db eval {.
04f0: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
0500: 74 31 20 56 41 4c 55 45 53 28 7a 65 72 6f 62 6c  t1 VALUES(zerobl
0510: 6f 62 28 39 30 30 30 29 29 3b 0a 20 20 7d 0a 20  ob(9000));.  }. 
0520: 20 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 33   lindex [sqlite3
0530: 5f 64 62 5f 73 74 61 74 75 73 20 64 62 20 53 51  _db_status db SQ
0540: 4c 49 54 45 5f 44 42 53 54 41 54 55 53 5f 43 41  LITE_DBSTATUS_CA
0550: 43 48 45 5f 55 53 45 44 20 30 5d 20 31 0a 7d 20  CHE_USED 0] 1.} 
0560: 5b 65 78 70 72 20 7b 24 42 41 53 45 53 5a 20 2b  [expr {$BASESZ +
0570: 20 31 30 2a 24 50 41 47 45 53 5a 7d 5d 0a 0a 0a   10*$PAGESZ}]...
0580: 70 72 6f 63 20 6c 6f 6f 6b 61 73 69 64 65 20 7b  proc lookaside {
0590: 64 62 7d 20 7b 0a 20 20 65 78 70 72 20 7b 20 24  db} {.  expr { $
05a0: 3a 3a 6c 6f 6f 6b 61 73 69 64 65 5f 62 75 66 66  ::lookaside_buff
05b0: 65 72 5f 73 69 7a 65 20 2a 0a 20 20 20 20 5b 6c  er_size *.    [l
05c0: 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64  index [sqlite3_d
05d0: 62 5f 73 74 61 74 75 73 20 24 64 62 20 53 51 4c  b_status $db SQL
05e0: 49 54 45 5f 44 42 53 54 41 54 55 53 5f 4c 4f 4f  ITE_DBSTATUS_LOO
05f0: 4b 41 53 49 44 45 5f 55 53 45 44 20 30 5d 20 31  KASIDE_USED 0] 1
0600: 5d 0a 20 20 7d 0a 7d 0a 0a 69 66 63 61 70 61 62  ].  }.}..ifcapab
0610: 6c 65 20 73 74 61 74 34 7c 7c 73 74 61 74 33 20  le stat4||stat3 
0620: 7b 0a 20 20 73 65 74 20 53 54 41 54 33 20 31 0a  {.  set STAT3 1.
0630: 7d 20 65 6c 73 65 20 7b 0a 20 20 73 65 74 20 53  } else {.  set S
0640: 54 41 54 33 20 30 0a 7d 0a 0a 23 2d 2d 2d 2d 2d  TAT3 0.}..#-----
0650: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0660: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0670: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0680: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0690: 2d 2d 2d 2d 2d 2d 0a 23 20 52 75 6e 20 74 68 65  ------.# Run the
06a0: 20 64 62 73 74 61 74 75 73 2d 32 20 61 6e 64 20   dbstatus-2 and 
06b0: 64 62 73 74 61 74 75 73 2d 33 20 74 65 73 74 73  dbstatus-3 tests
06c0: 20 77 69 74 68 20 73 65 76 65 72 61 6c 20 6f 66   with several of
06d0: 20 64 69 66 66 65 72 65 6e 74 0a 23 20 6c 6f 6f   different.# loo
06e0: 6b 61 73 69 64 65 20 62 75 66 66 65 72 20 73 69  kaside buffer si
06f0: 7a 65 73 2e 0a 23 0a 66 6f 72 65 61 63 68 20 3a  zes..#.foreach :
0700: 3a 6c 6f 6f 6b 61 73 69 64 65 5f 62 75 66 66 65  :lookaside_buffe
0710: 72 5f 73 69 7a 65 20 7b 30 20 36 34 20 31 32 30  r_size {0 64 120
0720: 7d 20 7b 0a 20 20 69 66 63 61 70 61 62 6c 65 20  } {.  ifcapable 
0730: 6d 61 6c 6c 6f 63 5f 75 73 61 62 6c 65 5f 73 69  malloc_usable_si
0740: 7a 65 20 62 72 65 61 6b 0a 0a 20 20 23 20 44 6f  ze break..  # Do
0750: 20 6e 6f 74 20 72 75 6e 20 61 6e 79 20 6f 66 20   not run any of 
0760: 74 68 65 73 65 20 74 65 73 74 73 20 69 66 20 74  these tests if t
0770: 68 65 72 65 20 69 73 20 53 51 4c 20 63 6f 6e 66  here is SQL conf
0780: 69 67 75 72 65 64 20 74 6f 20 72 75 6e 0a 20 20  igured to run.  
0790: 23 20 61 73 20 70 61 72 74 20 6f 66 20 74 68 65  # as part of the
07a0: 20 5b 73 71 6c 69 74 65 33 5d 20 63 6f 6d 6d 61   [sqlite3] comma
07b0: 6e 64 2e 20 54 68 69 73 20 70 72 65 76 65 6e 74  nd. This prevent
07c0: 73 20 74 68 65 20 73 63 72 69 70 74 20 66 72 6f  s the script fro
07d0: 6d 0a 20 20 23 20 63 6f 6e 66 69 67 75 72 69 6e  m.  # configurin
07e0: 67 20 74 68 65 20 73 69 7a 65 20 6f 66 20 74 68  g the size of th
07f0: 65 20 6c 6f 6f 6b 61 73 69 64 65 20 62 75 66 66  e lookaside buff
0800: 65 72 20 61 66 74 65 72 20 5b 73 71 6c 69 74 65  er after [sqlite
0810: 33 5d 20 68 61 73 0a 20 20 23 20 72 65 74 75 72  3] has.  # retur
0820: 6e 65 64 2e 0a 20 20 69 66 20 7b 5b 70 72 65 73  ned..  if {[pres
0830: 71 6c 5d 20 21 3d 20 22 22 7d 20 62 72 65 61 6b  ql] != ""} break
0840: 0a 0a 20 20 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..  #-----------
0850: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0860: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0870: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0880: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20  --------------. 
0890: 20 23 20 54 65 73 74 73 20 66 6f 72 20 53 51 4c   # Tests for SQL
08a0: 49 54 45 5f 44 42 53 54 41 54 55 53 5f 53 43 48  ITE_DBSTATUS_SCH
08b0: 45 4d 41 5f 55 53 45 44 2e 0a 20 20 23 0a 20 20  EMA_USED..  #.  
08c0: 23 20 45 61 63 68 20 74 65 73 74 20 69 6e 20 74  # Each test in t
08d0: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 62 6c 6f  he following blo
08e0: 63 6b 20 77 6f 72 6b 73 20 61 73 20 66 6f 6c 6c  ck works as foll
08f0: 6f 77 73 2e 20 45 61 63 68 20 74 65 73 74 20 75  ows. Each test u
0900: 73 65 73 20 61 0a 20 20 23 20 64 69 66 66 65 72  ses a.  # differ
0910: 65 6e 74 20 64 61 74 61 62 61 73 65 20 73 63 68  ent database sch
0920: 65 6d 61 2e 0a 20 20 23 0a 20 20 23 20 20 20 31  ema..  #.  #   1
0930: 2e 20 4f 70 65 6e 20 61 20 63 6f 6e 6e 65 63 74  . Open a connect
0940: 69 6f 6e 20 74 6f 20 61 6e 20 65 6d 70 74 79 20  ion to an empty 
0950: 64 61 74 61 62 61 73 65 2e 20 44 69 73 61 62 6c  database. Disabl
0960: 65 20 73 74 61 74 65 6d 65 6e 74 20 63 61 63 68  e statement cach
0970: 69 6e 67 2e 0a 20 20 23 0a 20 20 23 20 20 20 32  ing..  #.  #   2
0980: 2e 20 45 78 65 63 75 74 65 20 74 68 65 20 53 51  . Execute the SQ
0990: 4c 20 74 6f 20 63 72 65 61 74 65 20 74 68 65 20  L to create the 
09a0: 64 61 74 61 62 61 73 65 20 73 63 68 65 6d 61 2e  database schema.
09b0: 20 4d 65 61 73 75 72 65 20 74 68 65 20 74 6f 74   Measure the tot
09c0: 61 6c 20 0a 20 20 23 20 20 20 20 20 20 68 65 61  al .  #      hea
09d0: 70 20 61 6e 64 20 6c 6f 6f 6b 61 73 69 64 65 20  p and lookaside 
09e0: 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 65 64  memory allocated
09f0: 20 62 79 20 53 51 4c 69 74 65 2c 20 61 6e 64 20   by SQLite, and 
0a00: 74 68 65 20 6d 65 6d 6f 72 79 20 0a 20 20 23 20  the memory .  # 
0a10: 20 20 20 20 20 61 6c 6c 6f 63 61 74 65 64 20 66       allocated f
0a20: 6f 72 20 74 68 65 20 64 61 74 61 62 61 73 65 20  or the database 
0a30: 73 63 68 65 6d 61 20 61 63 63 6f 72 64 69 6e 67  schema according
0a40: 20 74 6f 20 73 71 6c 69 74 65 33 5f 64 62 5f 73   to sqlite3_db_s
0a50: 74 61 74 75 73 28 29 2e 0a 20 20 23 0a 20 20 23  tatus()..  #.  #
0a60: 20 20 20 33 2e 20 44 72 6f 70 20 61 6c 6c 20 74     3. Drop all t
0a70: 61 62 6c 65 73 20 69 6e 20 74 68 65 20 64 61 74  ables in the dat
0a80: 61 62 61 73 65 20 73 63 68 65 6d 61 2e 20 4d 65  abase schema. Me
0a90: 61 73 75 72 65 20 74 68 65 20 74 6f 74 61 6c 20  asure the total 
0aa0: 6d 65 6d 6f 72 79 20 0a 20 20 23 20 20 20 20 20  memory .  #     
0ab0: 20 61 6e 64 20 74 68 65 20 73 63 68 65 6d 61 20   and the schema 
0ac0: 6d 65 6d 6f 72 79 20 61 67 61 69 6e 2e 0a 20 20  memory again..  
0ad0: 23 0a 20 20 23 20 20 20 34 2e 20 52 65 70 65 61  #.  #   4. Repea
0ae0: 74 20 73 74 65 70 20 32 2e 0a 20 20 23 0a 20 20  t step 2..  #.  
0af0: 23 20 20 20 35 2e 20 52 65 70 65 61 74 20 73 74  #   5. Repeat st
0b00: 65 70 20 33 2e 0a 20 20 23 0a 20 20 23 20 54 68  ep 3..  #.  # Th
0b10: 65 6e 20 74 65 73 74 20 74 68 61 74 3a 0a 20 20  en test that:.  
0b20: 23 0a 20 20 23 20 20 20 61 29 20 54 68 65 20 64  #.  #   a) The d
0b30: 69 66 66 65 72 65 6e 63 65 20 69 6e 20 73 63 68  ifference in sch
0b40: 65 6d 61 20 6d 65 6d 6f 72 79 20 71 75 61 6e 74  ema memory quant
0b50: 69 74 69 65 73 20 69 6e 20 73 74 65 70 73 20 32  ities in steps 2
0b60: 20 61 6e 64 20 33 20 69 73 20 74 68 65 0a 20 20   and 3 is the.  
0b70: 23 20 20 20 20 20 20 73 61 6d 65 20 61 73 20 74  #      same as t
0b80: 68 65 20 64 69 66 66 65 72 65 6e 63 65 20 69 6e  he difference in
0b90: 20 74 6f 74 61 6c 20 6d 65 6d 6f 72 79 20 69 6e   total memory in
0ba0: 20 73 74 65 70 73 20 32 20 61 6e 64 20 33 2e 0a   steps 2 and 3..
0bb0: 20 20 23 0a 20 20 23 20 20 20 62 29 20 53 74 65    #.  #   b) Ste
0bc0: 70 20 34 20 72 65 70 6f 72 74 73 20 74 68 65 20  p 4 reports the 
0bd0: 73 61 6d 65 20 61 6d 6f 75 6e 74 20 6f 66 20 73  same amount of s
0be0: 63 68 65 6d 61 20 61 6e 64 20 74 6f 74 61 6c 20  chema and total 
0bf0: 6d 65 6d 6f 72 79 20 75 73 65 64 20 61 73 0a 20  memory used as. 
0c00: 20 23 20 20 20 20 20 20 69 6e 20 73 74 65 70 20   #      in step 
0c10: 32 2e 0a 20 20 23 0a 20 20 23 20 20 20 63 29 20  2..  #.  #   c) 
0c20: 53 74 65 70 20 35 20 72 65 70 6f 72 74 73 20 74  Step 5 reports t
0c30: 68 65 20 73 61 6d 65 20 61 6d 6f 75 6e 74 20 6f  he same amount o
0c40: 66 20 73 63 68 65 6d 61 20 61 6e 64 20 74 6f 74  f schema and tot
0c50: 61 6c 20 6d 65 6d 6f 72 79 20 75 73 65 64 20 61  al memory used a
0c60: 73 0a 20 20 23 20 20 20 20 20 20 69 6e 20 73 74  s.  #      in st
0c70: 65 70 20 33 2e 0a 20 20 23 0a 20 20 66 6f 72 65  ep 3..  #.  fore
0c80: 61 63 68 20 7b 74 6e 20 73 63 68 65 6d 61 7d 20  ach {tn schema} 
0c90: 7b 20 0a 20 20 20 20 31 20 7b 20 43 52 45 41 54  { .    1 { CREAT
0ca0: 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62 29  E TABLE t1(a, b)
0cb0: 20 7d 0a 20 20 20 20 32 20 7b 20 43 52 45 41 54   }.    2 { CREAT
0cc0: 45 20 54 41 42 4c 45 20 74 31 28 61 20 50 52 49  E TABLE t1(a PRI
0cd0: 4d 41 52 59 20 4b 45 59 2c 20 62 20 52 45 46 45  MARY KEY, b REFE
0ce0: 52 45 4e 43 45 53 20 74 31 2c 20 63 20 55 4e 49  RENCES t1, c UNI
0cf0: 51 55 45 29 20 7d 0a 20 20 20 20 33 20 7b 0a 20  QUE) }.    3 {. 
0d00: 20 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c       CREATE TABL
0d10: 45 20 74 31 28 61 2c 20 62 29 3b 0a 20 20 20 20  E t1(a, b);.    
0d20: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69    CREATE INDEX i
0d30: 31 20 4f 4e 20 74 31 28 61 2c 20 62 29 3b 0a 20  1 ON t1(a, b);. 
0d40: 20 20 20 7d 0a 20 20 20 20 34 20 7b 0a 20 20 20     }.    4 {.   
0d50: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
0d60: 74 31 28 61 2c 20 62 29 3b 0a 20 20 20 20 20 20  t1(a, b);.      
0d70: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
0d80: 63 2c 20 64 29 3b 0a 20 20 20 20 20 20 43 52 45  c, d);.      CRE
0d90: 41 54 45 20 54 52 49 47 47 45 52 20 41 46 54 45  ATE TRIGGER AFTE
0da0: 52 20 49 4e 53 45 52 54 20 4f 4e 20 74 31 20 42  R INSERT ON t1 B
0db0: 45 47 49 4e 0a 20 20 20 20 20 20 20 20 49 4e 53  EGIN.        INS
0dc0: 45 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55  ERT INTO t2 VALU
0dd0: 45 53 28 6e 65 77 2e 61 2c 20 6e 65 77 2e 62 29  ES(new.a, new.b)
0de0: 3b 0a 20 20 20 20 20 20 20 20 53 45 4c 45 43 54  ;.        SELECT
0df0: 20 2a 20 46 52 4f 4d 20 74 31 2c 20 74 32 20 57   * FROM t1, t2 W
0e00: 48 45 52 45 20 61 3d 63 20 41 4e 44 20 62 3d 64  HERE a=c AND b=d
0e10: 20 47 52 4f 55 50 20 42 59 20 62 20 48 41 56 49   GROUP BY b HAVI
0e20: 4e 47 20 61 3e 35 20 4f 52 44 45 52 20 42 59 20  NG a>5 ORDER BY 
0e30: 61 3b 0a 20 20 20 20 20 20 45 4e 44 3b 0a 20 20  a;.      END;.  
0e40: 20 20 7d 0a 20 20 20 20 35 20 7b 0a 20 20 20 20    }.    5 {.    
0e50: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0e60: 31 28 61 2c 20 62 29 3b 0a 20 20 20 20 20 20 43  1(a, b);.      C
0e70: 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 63  REATE TABLE t2(c
0e80: 2c 20 64 29 3b 0a 20 20 20 20 20 20 43 52 45 41  , d);.      CREA
0e90: 54 45 20 56 49 45 57 20 76 31 20 41 53 20 53 45  TE VIEW v1 AS SE
0ea0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 20 55  LECT * FROM t1 U
0eb0: 4e 49 4f 4e 20 53 45 4c 45 43 54 20 2a 20 46 52  NION SELECT * FR
0ec0: 4f 4d 20 74 32 3b 0a 20 20 20 20 7d 0a 20 20 20  OM t2;.    }.   
0ed0: 20 36 6b 20 7b 0a 20 20 20 20 20 20 43 52 45 41   6k {.      CREA
0ee0: 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62  TE TABLE t1(a, b
0ef0: 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  );.      CREATE 
0f00: 49 4e 44 45 58 20 69 31 20 4f 4e 20 74 31 28 61  INDEX i1 ON t1(a
0f10: 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45 20  );.      CREATE 
0f20: 49 4e 44 45 58 20 69 32 20 4f 4e 20 74 31 28 61  INDEX i2 ON t1(a
0f30: 2c 62 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54  ,b);.      CREAT
0f40: 45 20 49 4e 44 45 58 20 69 33 20 4f 4e 20 74 31  E INDEX i3 ON t1
0f50: 28 62 2c 62 29 3b 0a 20 20 20 20 20 20 49 4e 53  (b,b);.      INS
0f60: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
0f70: 45 53 28 72 61 6e 64 6f 6d 62 6c 6f 62 28 32 30  ES(randomblob(20
0f80: 29 2c 20 72 61 6e 64 6f 6d 62 6c 6f 62 28 32 35  ), randomblob(25
0f90: 29 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54  ));.      INSERT
0fa0: 20 49 4e 54 4f 20 74 31 20 53 45 4c 45 43 54 20   INTO t1 SELECT 
0fb0: 72 61 6e 64 6f 6d 62 6c 6f 62 28 32 30 29 2c 20  randomblob(20), 
0fc0: 72 61 6e 64 6f 6d 62 6c 6f 62 28 32 35 29 20 46  randomblob(25) F
0fd0: 52 4f 4d 20 74 31 3b 0a 20 20 20 20 20 20 49 4e  ROM t1;.      IN
0fe0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 53 45 4c  SERT INTO t1 SEL
0ff0: 45 43 54 20 72 61 6e 64 6f 6d 62 6c 6f 62 28 32  ECT randomblob(2
1000: 30 29 2c 20 72 61 6e 64 6f 6d 62 6c 6f 62 28 32  0), randomblob(2
1010: 35 29 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20  5) FROM t1;.    
1020: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
1030: 20 53 45 4c 45 43 54 20 72 61 6e 64 6f 6d 62 6c   SELECT randombl
1040: 6f 62 28 32 30 29 2c 20 72 61 6e 64 6f 6d 62 6c  ob(20), randombl
1050: 6f 62 28 32 35 29 20 46 52 4f 4d 20 74 31 3b 0a  ob(25) FROM t1;.
1060: 20 20 20 20 20 20 41 4e 41 4c 59 5a 45 3b 0a 20        ANALYZE;. 
1070: 20 20 20 7d 0a 20 20 20 20 37 20 7b 0a 20 20 20     }.    7 {.   
1080: 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20     CREATE TABLE 
1090: 74 31 28 61 2c 20 62 29 3b 0a 20 20 20 20 20 20  t1(a, b);.      
10a0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32 28  CREATE TABLE t2(
10b0: 63 2c 20 64 29 3b 0a 20 20 20 20 20 20 43 52 45  c, d);.      CRE
10c0: 41 54 45 20 56 49 45 57 20 76 31 20 41 53 20 0a  ATE VIEW v1 AS .
10d0: 20 20 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a          SELECT *
10e0: 20 46 52 4f 4d 20 74 31 20 0a 20 20 20 20 20 20   FROM t1 .      
10f0: 20 20 55 4e 49 4f 4e 20 0a 20 20 20 20 20 20 20    UNION .       
1100: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
1110: 32 0a 20 20 20 20 20 20 20 20 55 4e 49 4f 4e 20  2.        UNION 
1120: 41 4c 4c 0a 20 20 20 20 20 20 20 20 53 45 4c 45  ALL.        SELE
1130: 43 54 20 63 7c 7c 62 2c 20 64 7c 7c 61 20 46 52  CT c||b, d||a FR
1140: 4f 4d 20 74 32 20 4c 45 46 54 20 4f 55 54 45 52  OM t2 LEFT OUTER
1150: 20 4a 4f 49 4e 20 74 31 20 47 52 4f 55 50 20 42   JOIN t1 GROUP B
1160: 59 20 63 2c 20 64 0a 20 20 20 20 20 20 20 20 4f  Y c, d.        O
1170: 52 44 45 52 20 42 59 20 31 2c 20 32 0a 20 20 20  RDER BY 1, 2.   
1180: 20 20 20 3b 0a 20 20 20 20 20 20 43 52 45 41 54     ;.      CREAT
1190: 45 20 54 52 49 47 47 45 52 20 74 72 31 20 49 4e  E TRIGGER tr1 IN
11a0: 53 54 45 41 44 20 4f 46 20 49 4e 53 45 52 54 20  STEAD OF INSERT 
11b0: 4f 4e 20 76 31 20 42 45 47 49 4e 0a 20 20 20 20  ON v1 BEGIN.    
11c0: 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f      SELECT * FRO
11d0: 4d 20 76 31 3b 0a 20 20 20 20 20 20 20 20 55 50  M v1;.        UP
11e0: 44 41 54 45 20 74 31 20 53 45 54 20 61 3d 35 2c  DATE t1 SET a=5,
11f0: 20 62 3d 28 53 45 4c 45 43 54 20 63 20 46 52 4f   b=(SELECT c FRO
1200: 4d 20 74 32 29 3b 0a 20 20 20 20 20 20 45 4e 44  M t2);.      END
1210: 3b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a  ;.      SELECT *
1220: 20 46 52 4f 4d 20 76 31 3b 0a 20 20 20 20 7d 0a   FROM v1;.    }.
1230: 20 20 20 20 38 78 20 7b 0a 20 20 20 20 20 20 43      8x {.      C
1240: 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61  REATE TABLE t1(a
1250: 2c 20 62 2c 20 55 4e 49 51 55 45 28 61 2c 20 62  , b, UNIQUE(a, b
1260: 29 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54 45  ));.      CREATE
1270: 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45 20 74   VIRTUAL TABLE t
1280: 32 20 55 53 49 4e 47 20 65 63 68 6f 28 74 31 29  2 USING echo(t1)
1290: 3b 0a 20 20 20 20 7d 0a 20 20 7d 20 7b 0a 20 20  ;.    }.  } {.  
12a0: 20 20 73 65 74 20 74 6e 20 22 24 3a 3a 6c 6f 6f    set tn "$::loo
12b0: 6b 61 73 69 64 65 5f 62 75 66 66 65 72 5f 73 69  kaside_buffer_si
12c0: 7a 65 2d 24 74 6e 22 0a 20 20 0a 20 20 20 20 23  ze-$tn".  .    #
12d0: 20 53 74 65 70 20 31 2e 0a 20 20 20 20 64 62 20   Step 1..    db 
12e0: 63 6c 6f 73 65 0a 20 20 20 20 66 6f 72 63 65 64  close.    forced
12f0: 65 6c 65 74 65 20 74 65 73 74 2e 64 62 0a 20 20  elete test.db.  
1300: 20 20 73 71 6c 69 74 65 33 20 64 62 20 74 65 73    sqlite3 db tes
1310: 74 2e 64 62 0a 20 20 20 20 73 71 6c 69 74 65 33  t.db.    sqlite3
1320: 5f 64 62 5f 63 6f 6e 66 69 67 5f 6c 6f 6f 6b 61  _db_config_looka
1330: 73 69 64 65 20 64 62 20 30 20 24 3a 3a 6c 6f 6f  side db 0 $::loo
1340: 6b 61 73 69 64 65 5f 62 75 66 66 65 72 5f 73 69  kaside_buffer_si
1350: 7a 65 20 35 30 30 0a 20 20 20 20 64 62 20 63 61  ze 500.    db ca
1360: 63 68 65 20 73 69 7a 65 20 30 0a 0a 20 20 20 20  che size 0..    
1370: 63 61 74 63 68 20 7b 20 72 65 67 69 73 74 65 72  catch { register
1380: 5f 65 63 68 6f 5f 6d 6f 64 75 6c 65 20 64 62 20  _echo_module db 
1390: 7d 0a 20 20 20 20 69 66 63 61 70 61 62 6c 65 20  }.    ifcapable 
13a0: 21 76 74 61 62 20 7b 20 69 66 20 7b 5b 73 74 72  !vtab { if {[str
13b0: 69 6e 67 20 6d 61 74 63 68 20 2a 78 20 24 74 6e  ing match *x $tn
13c0: 5d 7d 20 63 6f 6e 74 69 6e 75 65 20 7d 0a 20 20  ]} continue }.  
13d0: 0a 20 20 20 20 23 20 53 74 65 70 20 32 2e 0a 20  .    # Step 2.. 
13e0: 20 20 20 65 78 65 63 73 71 6c 20 24 73 63 68 65     execsql $sche
13f0: 6d 61 0a 20 20 20 20 73 65 74 20 6e 41 6c 6c 6f  ma.    set nAllo
1400: 63 31 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c  c1  [lindex [sql
1410: 69 74 65 33 5f 73 74 61 74 75 73 20 53 51 4c 49  ite3_status SQLI
1420: 54 45 5f 53 54 41 54 55 53 5f 4d 45 4d 4f 52 59  TE_STATUS_MEMORY
1430: 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20  _USED 0] 1].    
1440: 69 6e 63 72 20 6e 41 6c 6c 6f 63 31 20 5b 6c 6f  incr nAlloc1 [lo
1450: 6f 6b 61 73 69 64 65 20 64 62 5d 0a 20 20 20 20  okaside db].    
1460: 73 65 74 20 6e 53 63 68 65 6d 61 31 20 5b 6c 69  set nSchema1 [li
1470: 6e 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64 62  ndex [sqlite3_db
1480: 5f 73 74 61 74 75 73 20 64 62 20 53 51 4c 49 54  _status db SQLIT
1490: 45 5f 44 42 53 54 41 54 55 53 5f 53 43 48 45 4d  E_DBSTATUS_SCHEM
14a0: 41 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 0a  A_USED 0] 1].  .
14b0: 20 20 20 20 23 20 53 74 65 70 20 33 2e 0a 20 20      # Step 3..  
14c0: 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65    drop_all_table
14d0: 73 0a 20 20 20 20 73 65 74 20 6e 41 6c 6c 6f 63  s.    set nAlloc
14e0: 32 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69  2  [lindex [sqli
14f0: 74 65 33 5f 73 74 61 74 75 73 20 53 51 4c 49 54  te3_status SQLIT
1500: 45 5f 53 54 41 54 55 53 5f 4d 45 4d 4f 52 59 5f  E_STATUS_MEMORY_
1510: 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 69  USED 0] 1].    i
1520: 6e 63 72 20 6e 41 6c 6c 6f 63 32 20 5b 6c 6f 6f  ncr nAlloc2 [loo
1530: 6b 61 73 69 64 65 20 64 62 5d 0a 20 20 20 20 73  kaside db].    s
1540: 65 74 20 6e 53 63 68 65 6d 61 32 20 5b 6c 69 6e  et nSchema2 [lin
1550: 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64 62 5f  dex [sqlite3_db_
1560: 73 74 61 74 75 73 20 64 62 20 53 51 4c 49 54 45  status db SQLITE
1570: 5f 44 42 53 54 41 54 55 53 5f 53 43 48 45 4d 41  _DBSTATUS_SCHEMA
1580: 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 0a 20  _USED 0] 1].  . 
1590: 20 20 20 23 20 53 74 65 70 20 34 2e 0a 20 20 20     # Step 4..   
15a0: 20 65 78 65 63 73 71 6c 20 24 73 63 68 65 6d 61   execsql $schema
15b0: 0a 20 20 20 20 73 65 74 20 6e 41 6c 6c 6f 63 33  .    set nAlloc3
15c0: 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74    [lindex [sqlit
15d0: 65 33 5f 73 74 61 74 75 73 20 53 51 4c 49 54 45  e3_status SQLITE
15e0: 5f 53 54 41 54 55 53 5f 4d 45 4d 4f 52 59 5f 55  _STATUS_MEMORY_U
15f0: 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 69 6e  SED 0] 1].    in
1600: 63 72 20 6e 41 6c 6c 6f 63 33 20 5b 6c 6f 6f 6b  cr nAlloc3 [look
1610: 61 73 69 64 65 20 64 62 5d 0a 20 20 20 20 73 65  aside db].    se
1620: 74 20 6e 53 63 68 65 6d 61 33 20 5b 6c 69 6e 64  t nSchema3 [lind
1630: 65 78 20 5b 73 71 6c 69 74 65 33 5f 64 62 5f 73  ex [sqlite3_db_s
1640: 74 61 74 75 73 20 64 62 20 53 51 4c 49 54 45 5f  tatus db SQLITE_
1650: 44 42 53 54 41 54 55 53 5f 53 43 48 45 4d 41 5f  DBSTATUS_SCHEMA_
1660: 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 0a  USED 0] 1].    .
1670: 20 20 20 20 23 20 53 74 65 70 20 35 2e 0a 20 20      # Step 5..  
1680: 20 20 64 72 6f 70 5f 61 6c 6c 5f 74 61 62 6c 65    drop_all_table
1690: 73 0a 20 20 20 20 73 65 74 20 6e 41 6c 6c 6f 63  s.    set nAlloc
16a0: 34 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69  4  [lindex [sqli
16b0: 74 65 33 5f 73 74 61 74 75 73 20 53 51 4c 49 54  te3_status SQLIT
16c0: 45 5f 53 54 41 54 55 53 5f 4d 45 4d 4f 52 59 5f  E_STATUS_MEMORY_
16d0: 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 69  USED 0] 1].    i
16e0: 6e 63 72 20 6e 41 6c 6c 6f 63 34 20 5b 6c 6f 6f  ncr nAlloc4 [loo
16f0: 6b 61 73 69 64 65 20 64 62 5d 0a 20 20 20 20 73  kaside db].    s
1700: 65 74 20 6e 53 63 68 65 6d 61 34 20 5b 6c 69 6e  et nSchema4 [lin
1710: 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64 62 5f  dex [sqlite3_db_
1720: 73 74 61 74 75 73 20 64 62 20 53 51 4c 49 54 45  status db SQLITE
1730: 5f 44 42 53 54 41 54 55 53 5f 53 43 48 45 4d 41  _DBSTATUS_SCHEMA
1740: 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20  _USED 0] 1].    
1750: 73 65 74 20 6e 46 72 65 65 20 5b 65 78 70 72 20  set nFree [expr 
1760: 7b 24 6e 41 6c 6c 6f 63 31 2d 24 6e 41 6c 6c 6f  {$nAlloc1-$nAllo
1770: 63 32 7d 5d 0a 20 20 20 20 0a 20 20 20 20 23 20  c2}].    .    # 
1780: 54 65 73 74 73 20 66 6f 72 20 77 68 69 63 68 20  Tests for which 
1790: 74 68 65 20 74 65 73 74 20 6e 61 6d 65 20 65 6e  the test name en
17a0: 64 73 20 69 6e 20 61 6e 20 22 6b 22 20 72 65 70  ds in an "k" rep
17b0: 6f 72 74 20 73 6c 69 67 68 74 6c 79 20 6c 65 73  ort slightly les
17c0: 73 0a 20 20 20 20 23 20 6d 65 6d 6f 72 79 20 74  s.    # memory t
17d0: 68 61 6e 20 69 73 20 61 63 74 75 61 6c 6c 79 20  han is actually 
17e0: 66 72 65 65 64 20 77 68 65 6e 20 61 6c 6c 20 73  freed when all s
17f0: 63 68 65 6d 61 20 69 74 65 6d 73 20 61 72 65 20  chema items are 
1800: 66 69 6e 61 6c 69 7a 65 64 2e 0a 20 20 20 20 23  finalized..    #
1810: 20 54 68 69 73 20 69 73 20 62 65 63 61 75 73 65   This is because
1820: 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 65   memory allocate
1830: 64 20 62 79 20 4b 65 79 49 6e 66 6f 20 6f 62 6a  d by KeyInfo obj
1840: 65 63 74 73 20 69 73 20 6e 6f 20 6c 6f 6e 67 65  ects is no longe
1850: 72 0a 20 20 20 20 23 20 63 6f 75 6e 74 65 64 20  r.    # counted 
1860: 61 73 20 22 73 63 68 65 6d 61 20 6d 65 6d 6f 72  as "schema memor
1870: 79 22 2e 0a 20 20 20 20 23 0a 20 20 20 20 23 20  y"..    #.    # 
1880: 54 65 73 74 73 20 66 6f 72 20 77 68 69 63 68 20  Tests for which 
1890: 74 68 65 20 74 65 73 74 20 6e 61 6d 65 20 65 6e  the test name en
18a0: 64 73 20 69 6e 20 61 6e 20 22 78 22 20 72 65 70  ds in an "x" rep
18b0: 6f 72 74 20 73 6c 69 67 68 74 6c 79 20 6c 65 73  ort slightly les
18c0: 73 0a 20 20 20 20 23 20 6d 65 6d 6f 72 79 20 74  s.    # memory t
18d0: 68 61 6e 20 69 73 20 61 63 74 75 61 6c 6c 79 20  han is actually 
18e0: 66 72 65 65 64 20 77 68 65 6e 20 61 6c 6c 20 73  freed when all s
18f0: 63 68 65 6d 61 20 69 74 65 6d 73 20 61 72 65 20  chema items are 
1900: 66 69 6e 61 6c 69 7a 65 64 2e 0a 20 20 20 20 23  finalized..    #
1910: 20 54 68 69 73 20 69 73 20 62 65 63 61 75 73 65   This is because
1920: 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 65   memory allocate
1930: 64 20 62 79 20 76 69 72 74 75 61 6c 20 74 61 62  d by virtual tab
1940: 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  le implementatio
1950: 6e 73 0a 20 20 20 20 23 20 66 6f 72 20 61 6e 79  ns.    # for any
1960: 20 72 65 61 73 6f 6e 20 69 73 20 6e 6f 74 20 63   reason is not c
1970: 6f 75 6e 74 65 64 20 61 73 20 22 73 63 68 65 6d  ounted as "schem
1980: 61 20 6d 65 6d 6f 72 79 22 2e 0a 20 20 20 20 23  a memory"..    #
1990: 0a 20 20 20 20 23 20 41 64 64 69 74 69 6f 6e 61  .    # Additiona
19a0: 6c 6c 79 2c 20 69 6e 20 61 75 74 6f 2d 76 61 63  lly, in auto-vac
19b0: 75 75 6d 20 6d 6f 64 65 2c 20 64 72 6f 70 70 69  uum mode, droppi
19c0: 6e 67 20 74 61 62 6c 65 73 20 61 6e 64 20 69 6e  ng tables and in
19d0: 64 65 78 65 73 20 63 61 75 73 65 73 0a 20 20 20  dexes causes.   
19e0: 20 23 20 74 68 65 20 70 61 67 65 2d 63 61 63 68   # the page-cach
19f0: 65 20 74 6f 20 73 68 72 69 6e 6b 2e 20 53 6f 20  e to shrink. So 
1a00: 74 68 65 20 61 6d 6f 75 6e 74 20 6f 66 20 6d 65  the amount of me
1a10: 6d 6f 72 79 20 66 72 65 65 64 20 69 73 20 61 6c  mory freed is al
1a20: 77 61 79 73 0a 20 20 20 20 23 20 6d 75 63 68 20  ways.    # much 
1a30: 67 72 65 61 74 65 72 20 74 68 61 6e 20 6a 75 73  greater than jus
1a40: 74 20 74 68 61 74 20 72 65 70 6f 72 74 65 64 20  t that reported 
1a50: 62 79 20 44 42 53 54 41 54 55 53 5f 53 43 48 45  by DBSTATUS_SCHE
1a60: 4d 41 5f 55 53 45 44 20 69 6e 20 74 68 69 73 0a  MA_USED in this.
1a70: 20 20 20 20 23 20 63 61 73 65 2e 0a 20 20 20 20      # case..    
1a80: 23 0a 20 20 20 20 23 20 53 6f 6d 65 20 6f 66 20  #.    # Some of 
1a90: 74 68 65 20 6d 65 6d 6f 72 79 20 75 73 65 64 20  the memory used 
1aa0: 66 6f 72 20 73 71 6c 69 74 65 5f 73 74 61 74 34  for sqlite_stat4
1ab0: 20 69 73 20 75 6e 61 63 63 6f 75 6e 74 65 64 20   is unaccounted 
1ac0: 66 6f 72 20 62 79 0a 20 20 20 20 23 20 64 62 73  for by.    # dbs
1ad0: 74 61 74 75 73 2e 0a 20 20 20 20 23 0a 20 20 20  tatus..    #.   
1ae0: 20 23 20 46 69 6e 61 6c 6c 79 2c 20 6f 6e 20 6f   # Finally, on o
1af0: 73 78 20 74 68 65 20 65 73 74 69 6d 61 74 65 20  sx the estimate 
1b00: 6f 66 20 6d 65 6d 6f 72 79 20 75 73 65 64 20 62  of memory used b
1b10: 79 20 74 68 65 20 73 63 68 65 6d 61 20 6d 61 79  y the schema may
1b20: 20 62 65 0a 20 20 20 20 23 20 73 6c 69 67 68 74   be.    # slight
1b30: 6c 79 20 6c 6f 77 2e 20 0a 20 20 20 20 23 0a 20  ly low. .    #. 
1b40: 20 20 20 69 66 20 7b 5b 73 74 72 69 6e 67 20 6d     if {[string m
1b50: 61 74 63 68 20 2a 6b 20 24 74 6e 5d 0a 20 20 20  atch *k $tn].   
1b60: 20 20 20 20 20 20 7c 7c 20 5b 73 74 72 69 6e 67        || [string
1b70: 20 6d 61 74 63 68 20 2a 78 20 24 74 6e 5d 20 7c   match *x $tn] |
1b80: 7c 20 24 41 55 54 4f 56 41 43 55 55 4d 0a 20 20  | $AUTOVACUUM.  
1b90: 20 20 20 20 20 20 20 7c 7c 20 28 5b 73 74 72 69         || ([stri
1ba0: 6e 67 20 6d 61 74 63 68 20 2a 79 20 24 74 6e 5d  ng match *y $tn]
1bb0: 20 26 26 20 24 53 54 41 54 33 29 0a 20 20 20 20   && $STAT3).    
1bc0: 20 20 20 20 20 7c 7c 20 28 24 3a 3a 74 63 6c 5f       || ($::tcl_
1bd0: 70 6c 61 74 66 6f 72 6d 28 6f 73 29 20 3d 3d 20  platform(os) == 
1be0: 22 44 61 72 77 69 6e 22 29 0a 20 20 20 20 7d 20  "Darwin").    } 
1bf0: 7b 0a 20 20 20 20 20 20 64 6f 5f 74 65 73 74 20  {.      do_test 
1c00: 64 62 73 74 61 74 75 73 2d 32 2e 24 74 6e 2e 61  dbstatus-2.$tn.a
1c10: 78 20 7b 20 65 78 70 72 20 7b 28 24 6e 53 63 68  x { expr {($nSch
1c20: 65 6d 61 31 2d 24 6e 53 63 68 65 6d 61 32 29 3c  ema1-$nSchema2)<
1c30: 3d 24 6e 46 72 65 65 7d 20 7d 20 31 0a 20 20 20  =$nFree} } 1.   
1c40: 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 20 20   } else {.      
1c50: 64 6f 5f 74 65 73 74 20 64 62 73 74 61 74 75 73  do_test dbstatus
1c60: 2d 32 2e 24 74 6e 2e 61 20 7b 20 65 78 70 72 20  -2.$tn.a { expr 
1c70: 7b 24 6e 53 63 68 65 6d 61 31 2d 24 6e 53 63 68  {$nSchema1-$nSch
1c80: 65 6d 61 32 7d 20 7d 20 24 6e 46 72 65 65 0a 20  ema2} } $nFree. 
1c90: 20 20 20 7d 0a 20 20 0a 20 20 20 20 64 6f 5f 74     }.  .    do_t
1ca0: 65 73 74 20 64 62 73 74 61 74 75 73 2d 32 2e 24  est dbstatus-2.$
1cb0: 74 6e 2e 62 20 7b 20 6c 69 73 74 20 24 6e 41 6c  tn.b { list $nAl
1cc0: 6c 6f 63 31 20 24 6e 53 63 68 65 6d 61 31 20 7d  loc1 $nSchema1 }
1cd0: 20 22 24 6e 41 6c 6c 6f 63 33 20 24 6e 53 63 68   "$nAlloc3 $nSch
1ce0: 65 6d 61 33 22 0a 20 20 20 20 64 6f 5f 74 65 73  ema3".    do_tes
1cf0: 74 20 64 62 73 74 61 74 75 73 2d 32 2e 24 74 6e  t dbstatus-2.$tn
1d00: 2e 63 20 7b 20 6c 69 73 74 20 24 6e 41 6c 6c 6f  .c { list $nAllo
1d10: 63 32 20 24 6e 53 63 68 65 6d 61 32 20 7d 20 22  c2 $nSchema2 } "
1d20: 24 6e 41 6c 6c 6f 63 34 20 24 6e 53 63 68 65 6d  $nAlloc4 $nSchem
1d30: 61 34 22 0a 20 20 7d 0a 20 20 0a 20 20 23 2d 2d  a4".  }.  .  #--
1d40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1d50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1d60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1d70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1d80: 2d 2d 2d 2d 2d 2d 2d 0a 20 20 23 20 54 65 73 74  -------.  # Test
1d90: 73 20 66 6f 72 20 53 51 4c 49 54 45 5f 44 42 53  s for SQLITE_DBS
1da0: 54 41 54 55 53 5f 53 54 4d 54 5f 55 53 45 44 2e  TATUS_STMT_USED.
1db0: 0a 20 20 23 0a 20 20 23 20 45 61 63 68 20 74 65  .  #.  # Each te
1dc0: 73 74 20 69 6e 20 74 68 65 20 66 6f 6c 6c 6f 77  st in the follow
1dd0: 69 6e 67 20 62 6c 6f 63 6b 20 77 6f 72 6b 73 20  ing block works 
1de0: 61 73 20 66 6f 6c 6c 6f 77 73 2e 20 45 61 63 68  as follows. Each
1df0: 20 74 65 73 74 20 75 73 65 73 20 61 0a 20 20 23   test uses a.  #
1e00: 20 64 69 66 66 65 72 65 6e 74 20 64 61 74 61 62   different datab
1e10: 61 73 65 20 73 63 68 65 6d 61 2e 0a 20 20 23 0a  ase schema..  #.
1e20: 20 20 23 20 20 20 31 2e 20 4f 70 65 6e 20 61 20    #   1. Open a 
1e30: 63 6f 6e 6e 65 63 74 69 6f 6e 20 74 6f 20 61 6e  connection to an
1e40: 20 65 6d 70 74 79 20 64 61 74 61 62 61 73 65 2e   empty database.
1e50: 20 49 6e 69 74 69 61 6c 69 7a 65 64 20 74 68 65   Initialized the
1e60: 20 64 61 74 61 62 61 73 65 0a 20 20 23 20 20 20   database.  #   
1e70: 20 20 20 73 63 68 65 6d 61 2e 0a 20 20 23 0a 20     schema..  #. 
1e80: 20 23 20 20 20 32 2e 20 50 72 65 70 61 72 65 20   #   2. Prepare 
1e90: 61 20 62 75 6e 63 68 20 6f 66 20 53 51 4c 20 73  a bunch of SQL s
1ea0: 74 61 74 65 6d 65 6e 74 73 2e 20 4d 65 61 73 75  tatements. Measu
1eb0: 72 65 20 74 68 65 20 74 6f 74 61 6c 20 68 65 61  re the total hea
1ec0: 70 20 61 6e 64 20 0a 20 20 23 20 20 20 20 20 20  p and .  #      
1ed0: 6c 6f 6f 6b 61 73 69 64 65 20 6d 65 6d 6f 72 79  lookaside memory
1ee0: 20 61 6c 6c 6f 63 61 74 65 64 20 62 79 20 53 51   allocated by SQ
1ef0: 4c 69 74 65 2c 20 61 6e 64 20 74 68 65 20 6d 65  Lite, and the me
1f00: 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 65 64 20 0a  mory allocated .
1f10: 20 20 23 20 20 20 20 20 20 66 6f 72 20 74 68 65    #      for the
1f20: 20 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d   prepared statem
1f30: 65 6e 74 73 20 61 63 63 6f 72 64 69 6e 67 20 74  ents according t
1f40: 6f 20 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61  o sqlite3_db_sta
1f50: 74 75 73 28 29 2e 0a 20 20 23 0a 20 20 23 20 20  tus()..  #.  #  
1f60: 20 33 2e 20 46 69 6e 61 6c 69 7a 65 20 61 6c 6c   3. Finalize all
1f70: 20 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d   prepared statem
1f80: 65 6e 74 73 2e 20 4d 65 61 73 75 72 65 20 74 68  ents. Measure th
1f90: 65 20 74 6f 74 61 6c 20 6d 65 6d 6f 72 79 20 0a  e total memory .
1fa0: 20 20 23 20 20 20 20 20 20 61 6e 64 20 74 68 65    #      and the
1fb0: 20 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d   prepared statem
1fc0: 65 6e 74 20 6d 65 6d 6f 72 79 20 61 67 61 69 6e  ent memory again
1fd0: 2e 0a 20 20 23 0a 20 20 23 20 20 20 34 2e 20 52  ..  #.  #   4. R
1fe0: 65 70 65 61 74 20 73 74 65 70 20 32 2e 0a 20 20  epeat step 2..  
1ff0: 23 0a 20 20 23 20 20 20 35 2e 20 52 65 70 65 61  #.  #   5. Repea
2000: 74 20 73 74 65 70 20 33 2e 0a 20 20 23 0a 20 20  t step 3..  #.  
2010: 23 20 54 68 65 6e 20 74 65 73 74 20 74 68 61 74  # Then test that
2020: 3a 0a 20 20 23 0a 20 20 23 20 20 20 61 29 20 54  :.  #.  #   a) T
2030: 68 65 20 64 69 66 66 65 72 65 6e 63 65 20 69 6e  he difference in
2040: 20 73 63 68 65 6d 61 20 6d 65 6d 6f 72 79 20 71   schema memory q
2050: 75 61 6e 74 69 74 69 65 73 20 69 6e 20 73 74 65  uantities in ste
2060: 70 73 20 32 20 61 6e 64 20 33 20 69 73 20 74 68  ps 2 and 3 is th
2070: 65 0a 20 20 23 20 20 20 20 20 20 73 61 6d 65 20  e.  #      same 
2080: 61 73 20 74 68 65 20 64 69 66 66 65 72 65 6e 63  as the differenc
2090: 65 20 69 6e 20 74 6f 74 61 6c 20 6d 65 6d 6f 72  e in total memor
20a0: 79 20 69 6e 20 73 74 65 70 73 20 32 20 61 6e 64  y in steps 2 and
20b0: 20 33 2e 0a 20 20 23 0a 20 20 23 20 20 20 62 29   3..  #.  #   b)
20c0: 20 53 74 65 70 20 34 20 72 65 70 6f 72 74 73 20   Step 4 reports 
20d0: 74 68 65 20 73 61 6d 65 20 61 6d 6f 75 6e 74 20  the same amount 
20e0: 6f 66 20 73 63 68 65 6d 61 20 61 6e 64 20 74 6f  of schema and to
20f0: 74 61 6c 20 6d 65 6d 6f 72 79 20 75 73 65 64 20  tal memory used 
2100: 61 73 0a 20 20 23 20 20 20 20 20 20 69 6e 20 73  as.  #      in s
2110: 74 65 70 20 32 2e 0a 20 20 23 0a 20 20 23 20 20  tep 2..  #.  #  
2120: 20 63 29 20 53 74 65 70 20 35 20 72 65 70 6f 72   c) Step 5 repor
2130: 74 73 20 74 68 65 20 73 61 6d 65 20 61 6d 6f 75  ts the same amou
2140: 6e 74 20 6f 66 20 73 63 68 65 6d 61 20 61 6e 64  nt of schema and
2150: 20 74 6f 74 61 6c 20 6d 65 6d 6f 72 79 20 75 73   total memory us
2160: 65 64 20 61 73 0a 20 20 23 20 20 20 20 20 20 69  ed as.  #      i
2170: 6e 20 73 74 65 70 20 33 2e 0a 20 20 23 0a 20 20  n step 3..  #.  
2180: 66 6f 72 65 61 63 68 20 7b 74 6e 20 73 63 68 65  foreach {tn sche
2190: 6d 61 20 73 74 61 74 65 6d 65 6e 74 73 7d 20 7b  ma statements} {
21a0: 20 0a 20 20 20 20 31 20 7b 20 43 52 45 41 54 45   .    1 { CREATE
21b0: 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62 29 20   TABLE t1(a, b) 
21c0: 7d 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54  } {.      SELECT
21d0: 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20   * FROM t1;.    
21e0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
21f0: 20 56 41 4c 55 45 53 28 31 2c 20 32 29 3b 0a 20   VALUES(1, 2);. 
2200: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
2210: 20 74 31 20 53 45 4c 45 43 54 20 2a 20 46 52 4f   t1 SELECT * FRO
2220: 4d 20 74 31 3b 0a 20 20 20 20 20 20 55 50 44 41  M t1;.      UPDA
2230: 54 45 20 74 31 20 53 45 54 20 61 3d 35 3b 0a 20  TE t1 SET a=5;. 
2240: 20 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d       DELETE FROM
2250: 20 74 31 3b 0a 20 20 20 20 7d 0a 20 20 20 20 32   t1;.    }.    2
2260: 20 7b 0a 20 20 20 20 20 20 50 52 41 47 4d 41 20   {.      PRAGMA 
2270: 72 65 63 75 72 73 69 76 65 5f 74 72 69 67 67 65  recursive_trigge
2280: 72 73 20 3d 20 31 3b 0a 20 20 20 20 20 20 43 52  rs = 1;.      CR
2290: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c  EATE TABLE t1(a,
22a0: 20 62 29 3b 0a 20 20 20 20 20 20 43 52 45 41 54   b);.      CREAT
22b0: 45 20 54 52 49 47 47 45 52 20 74 72 31 20 41 46  E TRIGGER tr1 AF
22c0: 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 74 31  TER INSERT ON t1
22d0: 20 57 48 45 4e 20 28 6e 65 77 2e 61 3e 30 29 20   WHEN (new.a>0) 
22e0: 42 45 47 49 4e 0a 20 20 20 20 20 20 20 20 49 4e  BEGIN.        IN
22f0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
2300: 55 45 53 28 6e 65 77 2e 61 2d 31 2c 20 6e 65 77  UES(new.a-1, new
2310: 2e 62 29 3b 0a 20 20 20 20 20 20 45 4e 44 3b 0a  .b);.      END;.
2320: 20 20 20 20 7d 20 7b 0a 20 20 20 20 20 20 49 4e      } {.      IN
2330: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
2340: 55 45 53 28 35 2c 20 27 78 27 29 3b 0a 20 20 20  UES(5, 'x');.   
2350: 20 7d 20 0a 20 20 20 20 33 20 7b 0a 20 20 20 20   } .    3 {.    
2360: 20 20 50 52 41 47 4d 41 20 72 65 63 75 72 73 69    PRAGMA recursi
2370: 76 65 5f 74 72 69 67 67 65 72 73 20 3d 20 31 3b  ve_triggers = 1;
2380: 0a 20 20 20 20 20 20 43 52 45 41 54 45 20 54 41  .      CREATE TA
2390: 42 4c 45 20 74 31 28 61 2c 20 62 29 3b 0a 20 20  BLE t1(a, b);.  
23a0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
23b0: 20 74 32 28 61 2c 20 62 29 3b 0a 20 20 20 20 20   t2(a, b);.     
23c0: 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20   CREATE TRIGGER 
23d0: 74 72 31 20 41 46 54 45 52 20 49 4e 53 45 52 54  tr1 AFTER INSERT
23e0: 20 4f 4e 20 74 31 20 57 48 45 4e 20 28 6e 65 77   ON t1 WHEN (new
23f0: 2e 61 3e 30 29 20 42 45 47 49 4e 0a 20 20 20 20  .a>0) BEGIN.    
2400: 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20      INSERT INTO 
2410: 74 32 20 56 41 4c 55 45 53 28 6e 65 77 2e 61 2d  t2 VALUES(new.a-
2420: 31 2c 20 6e 65 77 2e 62 29 3b 0a 20 20 20 20 20  1, new.b);.     
2430: 20 45 4e 44 3b 0a 20 20 20 20 20 20 43 52 45 41   END;.      CREA
2440: 54 45 20 54 52 49 47 47 45 52 20 74 72 32 20 41  TE TRIGGER tr2 A
2450: 46 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 74  FTER INSERT ON t
2460: 31 20 57 48 45 4e 20 28 6e 65 77 2e 61 3e 30 29  1 WHEN (new.a>0)
2470: 20 42 45 47 49 4e 0a 20 20 20 20 20 20 20 20 49   BEGIN.        I
2480: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
2490: 4c 55 45 53 28 6e 65 77 2e 61 2d 31 2c 20 6e 65  LUES(new.a-1, ne
24a0: 77 2e 62 29 3b 0a 20 20 20 20 20 20 45 4e 44 3b  w.b);.      END;
24b0: 0a 20 20 20 20 7d 20 7b 0a 20 20 20 20 20 20 49  .    } {.      I
24c0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
24d0: 4c 55 45 53 28 31 30 2c 20 27 78 27 29 3b 0a 20  LUES(10, 'x');. 
24e0: 20 20 20 7d 20 0a 20 20 20 20 34 20 7b 0a 20 20     } .    4 {.  
24f0: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
2500: 20 74 31 28 61 2c 20 62 29 3b 0a 20 20 20 20 7d   t1(a, b);.    }
2510: 20 7b 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20   {.      SELECT 
2520: 63 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 74 31  count(*) FROM t1
2530: 20 57 48 45 52 45 20 75 70 70 65 72 28 61 29 3d   WHERE upper(a)=
2540: 27 41 42 43 27 3b 0a 20 20 20 20 7d 0a 20 20 20  'ABC';.    }.   
2550: 20 35 78 20 7b 0a 20 20 20 20 20 20 43 52 45 41   5x {.      CREA
2560: 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62  TE TABLE t1(a, b
2570: 20 55 4e 49 51 55 45 29 3b 0a 20 20 20 20 20 20   UNIQUE);.      
2580: 43 52 45 41 54 45 20 56 49 52 54 55 41 4c 20 54  CREATE VIRTUAL T
2590: 41 42 4c 45 20 74 32 20 55 53 49 4e 47 20 65 63  ABLE t2 USING ec
25a0: 68 6f 28 74 31 29 3b 0a 20 20 20 20 7d 20 7b 0a  ho(t1);.    } {.
25b0: 20 20 20 20 20 20 53 45 4c 45 43 54 20 63 6f 75        SELECT cou
25c0: 6e 74 28 2a 29 20 46 52 4f 4d 20 74 32 3b 0a 20  nt(*) FROM t2;. 
25d0: 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52       SELECT * FR
25e0: 4f 4d 20 74 32 20 57 48 45 52 45 20 62 3e 35 3b  OM t2 WHERE b>5;
25f0: 0a 20 20 20 20 20 20 53 45 4c 45 43 54 20 2a 20  .      SELECT * 
2600: 46 52 4f 4d 20 74 32 20 57 48 45 52 45 20 62 3d  FROM t2 WHERE b=
2610: 27 61 62 63 64 65 66 67 27 3b 0a 20 20 20 20 7d  'abcdefg';.    }
2620: 0a 20 20 7d 20 7b 0a 20 20 20 20 73 65 74 20 74  .  } {.    set t
2630: 6e 20 22 24 3a 3a 6c 6f 6f 6b 61 73 69 64 65 5f  n "$::lookaside_
2640: 62 75 66 66 65 72 5f 73 69 7a 65 2d 24 74 6e 22  buffer_size-$tn"
2650: 0a 0a 20 20 20 20 23 20 53 74 65 70 20 31 2e 0a  ..    # Step 1..
2660: 20 20 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 20      db close.   
2670: 20 66 6f 72 63 65 64 65 6c 65 74 65 20 74 65 73   forcedelete tes
2680: 74 2e 64 62 0a 20 20 20 20 73 71 6c 69 74 65 33  t.db.    sqlite3
2690: 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 20 20   db test.db.    
26a0: 73 71 6c 69 74 65 33 5f 64 62 5f 63 6f 6e 66 69  sqlite3_db_confi
26b0: 67 5f 6c 6f 6f 6b 61 73 69 64 65 20 64 62 20 30  g_lookaside db 0
26c0: 20 24 3a 3a 6c 6f 6f 6b 61 73 69 64 65 5f 62 75   $::lookaside_bu
26d0: 66 66 65 72 5f 73 69 7a 65 20 35 30 30 0a 20 20  ffer_size 500.  
26e0: 20 20 64 62 20 63 61 63 68 65 20 73 69 7a 65 20    db cache size 
26f0: 31 30 30 30 0a 0a 20 20 20 20 63 61 74 63 68 20  1000..    catch 
2700: 7b 20 72 65 67 69 73 74 65 72 5f 65 63 68 6f 5f  { register_echo_
2710: 6d 6f 64 75 6c 65 20 64 62 20 7d 0a 20 20 20 20  module db }.    
2720: 69 66 63 61 70 61 62 6c 65 20 21 76 74 61 62 20  ifcapable !vtab 
2730: 7b 20 69 66 20 7b 5b 73 74 72 69 6e 67 20 6d 61  { if {[string ma
2740: 74 63 68 20 2a 78 20 24 74 6e 5d 7d 20 63 6f 6e  tch *x $tn]} con
2750: 74 69 6e 75 65 20 7d 0a 20 20 0a 20 20 20 20 65  tinue }.  .    e
2760: 78 65 63 73 71 6c 20 24 73 63 68 65 6d 61 0a 20  xecsql $schema. 
2770: 20 20 20 64 62 20 63 61 63 68 65 20 66 6c 75 73     db cache flus
2780: 68 0a 20 20 0a 20 20 20 20 23 20 53 74 65 70 20  h.  .    # Step 
2790: 32 2e 0a 20 20 20 20 65 78 65 63 73 71 6c 20 24  2..    execsql $
27a0: 73 74 61 74 65 6d 65 6e 74 73 0a 20 20 20 20 73  statements.    s
27b0: 65 74 20 6e 41 6c 6c 6f 63 31 20 20 5b 6c 69 6e  et nAlloc1  [lin
27c0: 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 73 74 61  dex [sqlite3_sta
27d0: 74 75 73 20 53 51 4c 49 54 45 5f 53 54 41 54 55  tus SQLITE_STATU
27e0: 53 5f 4d 45 4d 4f 52 59 5f 55 53 45 44 20 30 5d  S_MEMORY_USED 0]
27f0: 20 31 5d 0a 20 20 20 20 69 6e 63 72 20 6e 41 6c   1].    incr nAl
2800: 6c 6f 63 31 20 5b 6c 6f 6f 6b 61 73 69 64 65 20  loc1 [lookaside 
2810: 64 62 5d 0a 20 20 20 20 73 65 74 20 6e 53 74 6d  db].    set nStm
2820: 74 31 20 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71  t1   [lindex [sq
2830: 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73 20  lite3_db_status 
2840: 64 62 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54  db SQLITE_DBSTAT
2850: 55 53 5f 53 54 4d 54 5f 55 53 45 44 20 30 5d 20  US_STMT_USED 0] 
2860: 31 5d 0a 20 20 20 20 65 78 65 63 73 71 6c 20 24  1].    execsql $
2870: 73 74 61 74 65 6d 65 6e 74 73 0a 20 20 0a 20 20  statements.  .  
2880: 20 20 23 20 53 74 65 70 20 33 2e 0a 20 20 20 20    # Step 3..    
2890: 64 62 20 63 61 63 68 65 20 66 6c 75 73 68 0a 20  db cache flush. 
28a0: 20 20 20 73 65 74 20 6e 41 6c 6c 6f 63 32 20 20     set nAlloc2  
28b0: 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 33  [lindex [sqlite3
28c0: 5f 73 74 61 74 75 73 20 53 51 4c 49 54 45 5f 53  _status SQLITE_S
28d0: 54 41 54 55 53 5f 4d 45 4d 4f 52 59 5f 55 53 45  TATUS_MEMORY_USE
28e0: 44 20 30 5d 20 31 5d 0a 20 20 20 20 69 6e 63 72  D 0] 1].    incr
28f0: 20 6e 41 6c 6c 6f 63 32 20 5b 6c 6f 6f 6b 61 73   nAlloc2 [lookas
2900: 69 64 65 20 64 62 5d 0a 20 20 20 20 73 65 74 20  ide db].    set 
2910: 6e 53 74 6d 74 32 20 20 20 5b 6c 69 6e 64 65 78  nStmt2   [lindex
2920: 20 5b 73 71 6c 69 74 65 33 5f 64 62 5f 73 74 61   [sqlite3_db_sta
2930: 74 75 73 20 64 62 20 53 51 4c 49 54 45 5f 44 42  tus db SQLITE_DB
2940: 53 54 41 54 55 53 5f 53 54 4d 54 5f 55 53 45 44  STATUS_STMT_USED
2950: 20 30 5d 20 31 5d 0a 20 20 20 20 0a 20 20 20 20   0] 1].    .    
2960: 23 20 53 74 65 70 20 33 2e 0a 20 20 20 20 65 78  # Step 3..    ex
2970: 65 63 73 71 6c 20 24 73 74 61 74 65 6d 65 6e 74  ecsql $statement
2980: 73 0a 20 20 20 20 73 65 74 20 6e 41 6c 6c 6f 63  s.    set nAlloc
2990: 33 20 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69  3  [lindex [sqli
29a0: 74 65 33 5f 73 74 61 74 75 73 20 53 51 4c 49 54  te3_status SQLIT
29b0: 45 5f 53 54 41 54 55 53 5f 4d 45 4d 4f 52 59 5f  E_STATUS_MEMORY_
29c0: 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 69  USED 0] 1].    i
29d0: 6e 63 72 20 6e 41 6c 6c 6f 63 33 20 5b 6c 6f 6f  ncr nAlloc3 [loo
29e0: 6b 61 73 69 64 65 20 64 62 5d 0a 20 20 20 20 73  kaside db].    s
29f0: 65 74 20 6e 53 74 6d 74 33 20 20 20 5b 6c 69 6e  et nStmt3   [lin
2a00: 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64 62 5f  dex [sqlite3_db_
2a10: 73 74 61 74 75 73 20 64 62 20 53 51 4c 49 54 45  status db SQLITE
2a20: 5f 44 42 53 54 41 54 55 53 5f 53 54 4d 54 5f 55  _DBSTATUS_STMT_U
2a30: 53 45 44 20 30 5d 20 31 5d 0a 20 20 20 20 65 78  SED 0] 1].    ex
2a40: 65 63 73 71 6c 20 24 73 74 61 74 65 6d 65 6e 74  ecsql $statement
2a50: 73 0a 20 20 0a 20 20 20 20 23 20 53 74 65 70 20  s.  .    # Step 
2a60: 34 2e 0a 20 20 20 20 64 62 20 63 61 63 68 65 20  4..    db cache 
2a70: 66 6c 75 73 68 0a 20 20 20 20 73 65 74 20 6e 41  flush.    set nA
2a80: 6c 6c 6f 63 34 20 20 5b 6c 69 6e 64 65 78 20 5b  lloc4  [lindex [
2a90: 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 20 53  sqlite3_status S
2aa0: 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 45 4d  QLITE_STATUS_MEM
2ab0: 4f 52 59 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20  ORY_USED 0] 1]. 
2ac0: 20 20 20 69 6e 63 72 20 6e 41 6c 6c 6f 63 34 20     incr nAlloc4 
2ad0: 5b 6c 6f 6f 6b 61 73 69 64 65 20 64 62 5d 0a 20  [lookaside db]. 
2ae0: 20 20 20 73 65 74 20 6e 53 74 6d 74 34 20 5b 6c     set nStmt4 [l
2af0: 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 33 5f 64  index [sqlite3_d
2b00: 62 5f 73 74 61 74 75 73 20 64 62 20 53 51 4c 49  b_status db SQLI
2b10: 54 45 5f 44 42 53 54 41 54 55 53 5f 53 54 4d 54  TE_DBSTATUS_STMT
2b20: 5f 55 53 45 44 20 30 5d 20 31 5d 0a 20 20 0a 20  _USED 0] 1].  . 
2b30: 20 20 20 73 65 74 20 6e 46 72 65 65 20 5b 65 78     set nFree [ex
2b40: 70 72 20 7b 24 6e 41 6c 6c 6f 63 31 2d 24 6e 41  pr {$nAlloc1-$nA
2b50: 6c 6c 6f 63 32 7d 5d 0a 0a 20 20 20 20 64 6f 5f  lloc2}]..    do_
2b60: 74 65 73 74 20 64 62 73 74 61 74 75 73 2d 33 2e  test dbstatus-3.
2b70: 24 74 6e 2e 61 20 7b 20 65 78 70 72 20 24 6e 53  $tn.a { expr $nS
2b80: 74 6d 74 32 20 7d 20 7b 30 7d 0a 0a 20 20 20 20  tmt2 } {0}..    
2b90: 23 20 54 65 73 74 73 20 66 6f 72 20 77 68 69 63  # Tests for whic
2ba0: 68 20 74 68 65 20 74 65 73 74 20 6e 61 6d 65 20  h the test name 
2bb0: 65 6e 64 73 20 69 6e 20 61 6e 20 22 78 22 20 72  ends in an "x" r
2bc0: 65 70 6f 72 74 20 73 6c 69 67 68 74 6c 79 20 6c  eport slightly l
2bd0: 65 73 73 0a 20 20 20 20 23 20 6d 65 6d 6f 72 79  ess.    # memory
2be0: 20 74 68 61 6e 20 69 73 20 61 63 74 75 61 6c 6c   than is actuall
2bf0: 79 20 66 72 65 65 64 20 77 68 65 6e 20 61 6c 6c  y freed when all
2c00: 20 73 74 61 74 65 6d 65 6e 74 73 20 61 72 65 20   statements are 
2c10: 66 69 6e 61 6c 69 7a 65 64 2e 0a 20 20 20 20 23  finalized..    #
2c20: 20 54 68 69 73 20 69 73 20 62 65 63 61 75 73 65   This is because
2c30: 20 61 20 73 6d 61 6c 6c 20 61 6d 6f 75 6e 74 20   a small amount 
2c40: 6f 66 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61  of memory alloca
2c50: 74 65 64 20 62 79 20 61 20 76 69 72 74 75 61 6c  ted by a virtual
2c60: 20 74 61 62 6c 65 0a 20 20 20 20 23 20 69 6d 70   table.    # imp
2c70: 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 75 73 69 6e  lementation usin
2c80: 67 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74  g sqlite3_mprint
2c90: 66 28 29 20 69 73 20 74 65 63 68 6e 69 63 61 6c  f() is technical
2ca0: 6c 79 20 63 6f 6e 73 69 64 65 72 65 64 0a 20 20  ly considered.  
2cb0: 20 20 23 20 65 78 74 65 72 6e 61 6c 20 61 6e 64    # external and
2cc0: 20 73 6f 20 69 73 20 6e 6f 74 20 63 6f 75 6e 74   so is not count
2cd0: 65 64 20 61 73 20 22 73 74 61 74 65 6d 65 6e 74  ed as "statement
2ce0: 20 6d 65 6d 6f 72 79 22 2e 0a 20 20 20 20 23 0a   memory"..    #.
2cf0: 23 70 75 74 73 20 22 24 6e 53 74 6d 74 31 20 24  #puts "$nStmt1 $
2d00: 6e 46 72 65 65 22 0a 20 20 20 20 69 66 20 7b 5b  nFree".    if {[
2d10: 73 74 72 69 6e 67 20 6d 61 74 63 68 20 2a 78 20  string match *x 
2d20: 24 74 6e 5d 7d 20 7b 0a 20 20 20 20 20 20 64 6f  $tn]} {.      do
2d30: 5f 74 65 73 74 20 64 62 73 74 61 74 75 73 2d 33  _test dbstatus-3
2d40: 2e 24 74 6e 2e 62 78 20 7b 20 65 78 70 72 20 24  .$tn.bx { expr $
2d50: 6e 53 74 6d 74 31 3c 3d 24 6e 46 72 65 65 20 7d  nStmt1<=$nFree }
2d60: 20 20 7b 31 7d 0a 20 20 20 20 7d 20 65 6c 73 65    {1}.    } else
2d70: 20 7b 0a 20 20 20 20 20 20 64 6f 5f 74 65 73 74   {.      do_test
2d80: 20 64 62 73 74 61 74 75 73 2d 33 2e 24 74 6e 2e   dbstatus-3.$tn.
2d90: 62 20 7b 20 65 78 70 72 20 24 6e 53 74 6d 74 31  b { expr $nStmt1
2da0: 3d 3d 24 6e 46 72 65 65 20 7d 20 7b 31 7d 0a 20  ==$nFree } {1}. 
2db0: 20 20 20 7d 0a 0a 20 20 20 20 64 6f 5f 74 65 73     }..    do_tes
2dc0: 74 20 64 62 73 74 61 74 75 73 2d 33 2e 24 74 6e  t dbstatus-3.$tn
2dd0: 2e 63 20 7b 20 6c 69 73 74 20 24 6e 41 6c 6c 6f  .c { list $nAllo
2de0: 63 31 20 24 6e 53 74 6d 74 31 20 7d 20 5b 6c 69  c1 $nStmt1 } [li
2df0: 73 74 20 24 6e 41 6c 6c 6f 63 33 20 24 6e 53 74  st $nAlloc3 $nSt
2e00: 6d 74 33 5d 0a 20 20 20 20 64 6f 5f 74 65 73 74  mt3].    do_test
2e10: 20 64 62 73 74 61 74 75 73 2d 33 2e 24 74 6e 2e   dbstatus-3.$tn.
2e20: 64 20 7b 20 6c 69 73 74 20 24 6e 41 6c 6c 6f 63  d { list $nAlloc
2e30: 32 20 24 6e 53 74 6d 74 32 20 7d 20 5b 6c 69 73  2 $nStmt2 } [lis
2e40: 74 20 24 6e 41 6c 6c 6f 63 34 20 24 6e 53 74 6d  t $nAlloc4 $nStm
2e50: 74 34 5d 0a 20 20 7d 0a 7d 0a 0a 23 2d 2d 2d 2d  t4].  }.}..#----
2e60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2e90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
2ea0: 2d 2d 2d 2d 2d 0a 23 20 54 68 65 20 66 6f 6c 6c  -----.# The foll
2eb0: 6f 77 69 6e 67 20 74 65 73 74 73 20 66 6f 63 75  owing tests focu
2ec0: 73 20 6f 6e 20 44 42 53 54 41 54 55 53 5f 43 41  s on DBSTATUS_CA
2ed0: 43 48 45 5f 55 53 45 44 5f 53 48 41 52 45 44 0a  CHE_USED_SHARED.
2ee0: 23 0a 69 66 63 61 70 61 62 6c 65 20 73 68 61 72  #.ifcapable shar
2ef0: 65 64 5f 63 61 63 68 65 20 7b 0a 20 20 69 66 20  ed_cache {.  if 
2f00: 7b 5b 70 65 72 6d 75 74 61 74 69 6f 6e 5d 3d 3d  {[permutation]==
2f10: 22 6d 65 6d 73 79 73 33 22 0a 20 20 20 20 20 20  "memsys3".      
2f20: 7c 7c 20 5b 70 65 72 6d 75 74 61 74 69 6f 6e 5d  || [permutation]
2f30: 3d 3d 22 6d 65 6d 73 79 73 35 22 0a 20 20 20 20  =="memsys5".    
2f40: 20 20 7c 7c 20 24 3a 3a 74 63 6c 5f 70 6c 61 74    || $::tcl_plat
2f50: 66 6f 72 6d 28 6f 73 29 3d 3d 22 4c 69 6e 75 78  form(os)=="Linux
2f60: 22 7d 20 7b 0a 20 20 20 20 70 72 6f 63 20 64 6f  "} {.    proc do
2f70: 5f 63 61 63 68 65 75 73 65 64 5f 74 65 73 74 20  _cacheused_test 
2f80: 7b 74 6e 20 64 62 20 72 65 73 7d 20 7b 0a 20 20  {tn db res} {.  
2f90: 20 20 20 20 73 65 74 20 63 75 20 5b 73 71 6c 69      set cu [sqli
2fa0: 74 65 33 5f 64 62 5f 73 74 61 74 75 73 20 24 64  te3_db_status $d
2fb0: 62 20 53 51 4c 49 54 45 5f 44 42 53 54 41 54 55  b SQLITE_DBSTATU
2fc0: 53 5f 43 41 43 48 45 5f 55 53 45 44 20 30 5d 0a  S_CACHE_USED 0].
2fd0: 20 20 20 20 20 20 73 65 74 20 70 63 75 20 5b 73        set pcu [s
2fe0: 71 6c 69 74 65 33 5f 64 62 5f 73 74 61 74 75 73  qlite3_db_status
2ff0: 20 24 64 62 20 53 51 4c 49 54 45 5f 44 42 53 54   $db SQLITE_DBST
3000: 41 54 55 53 5f 43 41 43 48 45 5f 55 53 45 44 5f  ATUS_CACHE_USED_
3010: 53 48 41 52 45 44 20 30 5d 0a 20 20 20 20 20 20  SHARED 0].      
3020: 73 65 74 20 63 75 20 5b 6c 69 6e 64 65 78 20 24  set cu [lindex $
3030: 63 75 20 31 5d 0a 20 20 20 20 20 20 73 65 74 20  cu 1].      set 
3040: 70 63 75 20 5b 6c 69 6e 64 65 78 20 24 70 63 75  pcu [lindex $pcu
3050: 20 31 5d 0a 20 20 20 20 20 20 75 70 6c 65 76 65   1].      upleve
3060: 6c 20 5b 6c 69 73 74 20 64 6f 5f 74 65 73 74 20  l [list do_test 
3070: 24 74 6e 20 5b 6c 69 73 74 20 6c 69 73 74 20 24  $tn [list list $
3080: 63 75 20 24 70 63 75 5d 20 22 23 2f 24 72 65 73  cu $pcu] "#/$res
3090: 2f 22 5d 0a 20 20 20 20 7d 0a 20 20 20 20 72 65  /"].    }.    re
30a0: 73 65 74 5f 64 62 0a 20 20 20 20 73 71 6c 69 74  set_db.    sqlit
30b0: 65 33 20 64 62 20 66 69 6c 65 3a 74 65 73 74 2e  e3 db file:test.
30c0: 64 62 3f 63 61 63 68 65 3d 73 68 61 72 65 64 0a  db?cache=shared.
30d0: 20 20 0a 20 20 20 20 64 6f 5f 65 78 65 63 73 71    .    do_execsq
30e0: 6c 5f 74 65 73 74 20 34 2e 30 20 7b 0a 20 20 20  l_test 4.0 {.   
30f0: 20 20 20 50 52 41 47 4d 41 20 61 75 74 6f 5f 76     PRAGMA auto_v
3100: 61 63 75 75 6d 3d 4e 4f 4e 45 3b 0a 20 20 20 20  acuum=NONE;.    
3110: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
3120: 31 28 61 2c 20 62 2c 20 63 29 3b 0a 20 20 20 20  1(a, b, c);.    
3130: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
3140: 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33 29   VALUES(1, 2, 3)
3150: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64 6f 5f 63  ;.    }.    do_c
3160: 61 63 68 65 75 73 65 64 5f 74 65 73 74 20 34 2e  acheused_test 4.
3170: 30 2e 31 20 64 62 20 7b 20 34 35 36 38 20 34 35  0.1 db { 4568 45
3180: 36 38 20 7d 0a 20 20 20 20 64 6f 5f 65 78 65 63  68 }.    do_exec
3190: 73 71 6c 5f 74 65 73 74 20 34 2e 31 20 7b 0a 20  sql_test 4.1 {. 
31a0: 20 20 20 20 20 43 52 45 41 54 45 20 54 45 4d 50       CREATE TEMP
31b0: 20 54 41 42 4c 45 20 74 74 28 61 2c 20 62 2c 20   TABLE tt(a, b, 
31c0: 63 29 3b 0a 20 20 20 20 20 20 49 4e 53 45 52 54  c);.      INSERT
31d0: 20 49 4e 54 4f 20 74 74 20 56 41 4c 55 45 53 28   INTO tt VALUES(
31e0: 31 2c 20 32 2c 20 33 29 3b 0a 20 20 20 20 7d 0a  1, 2, 3);.    }.
31f0: 20 20 20 20 64 6f 5f 63 61 63 68 65 75 73 65 64      do_cacheused
3200: 5f 74 65 73 74 20 34 2e 31 2e 31 20 64 62 20 7b  _test 4.1.1 db {
3210: 20 39 30 30 30 20 39 30 30 30 20 7d 0a 20 20 0a   9000 9000 }.  .
3220: 20 20 20 20 73 71 6c 69 74 65 33 20 64 62 32 20      sqlite3 db2 
3230: 66 69 6c 65 3a 74 65 73 74 2e 64 62 3f 63 61 63  file:test.db?cac
3240: 68 65 3d 73 68 61 72 65 64 0a 20 20 20 20 64 6f  he=shared.    do
3250: 5f 63 61 63 68 65 75 73 65 64 5f 74 65 73 74 20  _cacheused_test 
3260: 34 2e 32 2e 31 20 64 62 32 20 7b 20 34 35 36 38  4.2.1 db2 { 4568
3270: 20 32 32 38 34 20 7d 0a 20 20 20 20 64 6f 5f 63   2284 }.    do_c
3280: 61 63 68 65 75 73 65 64 5f 74 65 73 74 20 34 2e  acheused_test 4.
3290: 32 2e 32 20 64 62 20 7b 20 39 30 30 30 20 36 37  2.2 db { 9000 67
32a0: 31 36 20 7d 0a 20 20 20 20 64 62 20 63 6c 6f 73  16 }.    db clos
32b0: 65 0a 20 20 20 20 64 6f 5f 63 61 63 68 65 75 73  e.    do_cacheus
32c0: 65 64 5f 74 65 73 74 20 34 2e 32 2e 33 20 64 62  ed_test 4.2.3 db
32d0: 32 20 7b 20 34 35 36 38 20 34 35 36 38 20 7d 0a  2 { 4568 4568 }.
32e0: 20 20 20 20 73 71 6c 69 74 65 33 20 64 62 20 66      sqlite3 db f
32f0: 69 6c 65 3a 74 65 73 74 2e 64 62 3f 63 61 63 68  ile:test.db?cach
3300: 65 3d 73 68 61 72 65 64 0a 20 20 20 20 64 6f 5f  e=shared.    do_
3310: 63 61 63 68 65 75 73 65 64 5f 74 65 73 74 20 34  cacheused_test 4
3320: 2e 32 2e 34 20 64 62 32 20 7b 20 34 35 36 38 20  .2.4 db2 { 4568 
3330: 32 32 38 34 20 7d 0a 20 20 20 20 64 62 32 20 63  2284 }.    db2 c
3340: 6c 6f 73 65 0a 20 20 7d 0a 7d 0a 0a 66 69 6e 69  lose.  }.}..fini
3350: 73 68 5f 74 65 73 74 0a                          sh_test.