/ Hex Artifact Content
Login

Artifact aecaa46ed0618a3c338f3651ca4f10fbb4021044:


0000: 23 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64  #.#    May you d
0010: 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65  o good and not e
0020: 76 69 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f  vil..#    May yo
0030: 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65  u find forgivene
0040: 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20  ss for yourself 
0050: 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65  and forgive othe
0060: 72 73 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75  rs..#    May you
0070: 20 73 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e   share freely, n
0080: 65 76 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65  ever taking more
0090: 20 74 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a   than you give..
00a0: 23 0a 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  #.#*************
00b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
00c0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
00d0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
00e0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69  **********.# Thi
00f0: 73 20 66 69 6c 65 20 72 75 6e 73 20 61 6c 6c 20  s file runs all 
0100: 74 65 73 74 73 2e 0a 23 0a 23 20 24 49 64 3a 20  tests..#.# $Id: 
0110: 61 73 79 6e 63 2e 74 65 73 74 2c 76 20 31 2e 31  async.test,v 1.1
0120: 33 20 32 30 30 37 2f 31 31 2f 30 35 20 31 37 3a  3 2007/11/05 17:
0130: 30 31 3a 30 38 20 64 61 6e 69 65 6c 6b 31 39 37  01:08 danielk197
0140: 37 20 45 78 70 20 24 0a 0a 0a 69 66 20 7b 5b 63  7 Exp $...if {[c
0150: 61 74 63 68 20 7b 73 71 6c 69 74 65 33 61 73 79  atch {sqlite3asy
0160: 6e 63 5f 65 6e 61 62 6c 65 7d 5d 7d 20 7b 0a 20  nc_enable}]} {. 
0170: 20 23 20 54 68 65 20 61 73 79 6e 63 20 6c 6f 67   # The async log
0180: 69 63 20 69 73 20 6e 6f 74 20 62 75 69 6c 74 20  ic is not built 
0190: 69 6e 74 6f 20 74 68 69 73 20 73 79 73 74 65 6d  into this system
01a0: 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 73 65 74  .  return.}..set
01b0: 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64   testdir [file d
01c0: 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73  irname $argv0].s
01d0: 6f 75 72 63 65 20 24 74 65 73 74 64 69 72 2f 74  ource $testdir/t
01e0: 65 73 74 65 72 2e 74 63 6c 0a 72 65 6e 61 6d 65  ester.tcl.rename
01f0: 20 66 69 6e 69 73 68 5f 74 65 73 74 20 72 65 61   finish_test rea
0200: 6c 6c 79 5f 66 69 6e 69 73 68 5f 74 65 73 74 0a  lly_finish_test.
0210: 70 72 6f 63 20 66 69 6e 69 73 68 5f 74 65 73 74  proc finish_test
0220: 20 7b 7d 20 7b 0a 20 20 63 61 74 63 68 20 7b 64   {} {.  catch {d
0230: 62 20 63 6c 6f 73 65 7d 0a 20 20 63 61 74 63 68  b close}.  catch
0240: 20 7b 64 62 32 20 63 6c 6f 73 65 7d 0a 20 20 63   {db2 close}.  c
0250: 61 74 63 68 20 7b 64 62 33 20 63 6c 6f 73 65 7d  atch {db3 close}
0260: 0a 7d 0a 73 65 74 20 49 53 51 55 49 43 4b 20 31  .}.set ISQUICK 1
0270: 0a 0a 73 65 74 20 49 4e 43 4c 55 44 45 20 7b 0a  ..set INCLUDE {.
0280: 20 20 69 6e 73 65 72 74 2e 74 65 73 74 0a 20 20    insert.test.  
0290: 69 6e 73 65 72 74 32 2e 74 65 73 74 0a 20 20 69  insert2.test.  i
02a0: 6e 73 65 72 74 33 2e 74 65 73 74 0a 20 20 6c 6f  nsert3.test.  lo
02b0: 63 6b 2e 74 65 73 74 0a 20 20 6c 6f 63 6b 32 2e  ck.test.  lock2.
02c0: 74 65 73 74 0a 20 20 6c 6f 63 6b 33 2e 74 65 73  test.  lock3.tes
02d0: 74 0a 20 20 73 65 6c 65 63 74 31 2e 74 65 73 74  t.  select1.test
02e0: 0a 20 20 73 65 6c 65 63 74 32 2e 74 65 73 74 0a  .  select2.test.
02f0: 20 20 73 65 6c 65 63 74 33 2e 74 65 73 74 0a 20    select3.test. 
0300: 20 73 65 6c 65 63 74 34 2e 74 65 73 74 0a 20 20   select4.test.  
0310: 74 72 61 6e 73 2e 74 65 73 74 0a 7d 0a 0a 23 20  trans.test.}..# 
0320: 45 6e 61 62 6c 65 20 61 73 79 6e 63 68 72 6f 6e  Enable asynchron
0330: 6f 75 73 20 49 4f 2e 0a 73 71 6c 69 74 65 33 61  ous IO..sqlite3a
0340: 73 79 6e 63 5f 65 6e 61 62 6c 65 20 31 0a 0a 72  sync_enable 1..r
0350: 65 6e 61 6d 65 20 64 6f 5f 74 65 73 74 20 72 65  ename do_test re
0360: 61 6c 6c 79 5f 64 6f 5f 74 65 73 74 0a 70 72 6f  ally_do_test.pro
0370: 63 20 64 6f 5f 74 65 73 74 20 7b 6e 61 6d 65 20  c do_test {name 
0380: 61 72 67 73 7d 20 7b 0a 20 20 75 70 6c 65 76 65  args} {.  upleve
0390: 6c 20 72 65 61 6c 6c 79 5f 64 6f 5f 74 65 73 74  l really_do_test
03a0: 20 61 73 79 6e 63 5f 69 6f 2d 24 6e 61 6d 65 20   async_io-$name 
03b0: 24 61 72 67 73 0a 20 20 73 71 6c 69 74 65 33 61  $args.  sqlite3a
03c0: 73 79 6e 63 5f 73 74 61 72 74 0a 20 20 73 71 6c  sync_start.  sql
03d0: 69 74 65 33 61 73 79 6e 63 5f 68 61 6c 74 20 69  ite3async_halt i
03e0: 64 6c 65 0a 20 20 73 71 6c 69 74 65 33 61 73 79  dle.  sqlite3asy
03f0: 6e 63 5f 77 61 69 74 0a 20 20 73 71 6c 69 74 65  nc_wait.  sqlite
0400: 33 61 73 79 6e 63 5f 68 61 6c 74 20 6e 65 76 65  3async_halt neve
0410: 72 0a 7d 0a 0a 66 6f 72 65 61 63 68 20 74 65 73  r.}..foreach tes
0420: 74 66 69 6c 65 20 5b 6c 73 6f 72 74 20 2d 64 69  tfile [lsort -di
0430: 63 74 69 6f 6e 61 72 79 20 5b 67 6c 6f 62 20 24  ctionary [glob $
0440: 74 65 73 74 64 69 72 2f 2a 2e 74 65 73 74 5d 5d  testdir/*.test]]
0450: 20 7b 0a 20 20 73 65 74 20 74 61 69 6c 20 5b 66   {.  set tail [f
0460: 69 6c 65 20 74 61 69 6c 20 24 74 65 73 74 66 69  ile tail $testfi
0470: 6c 65 5d 0a 20 20 69 66 20 7b 5b 6c 73 65 61 72  le].  if {[lsear
0480: 63 68 20 2d 65 78 61 63 74 20 24 49 4e 43 4c 55  ch -exact $INCLU
0490: 44 45 20 24 74 61 69 6c 5d 3c 30 7d 20 63 6f 6e  DE $tail]<0} con
04a0: 74 69 6e 75 65 0a 20 20 73 6f 75 72 63 65 20 24  tinue.  source $
04b0: 74 65 73 74 66 69 6c 65 0a 0a 20 20 23 20 4d 61  testfile..  # Ma
04c0: 6b 65 20 73 75 72 65 20 65 76 65 72 79 74 68 69  ke sure everythi
04d0: 6e 67 20 69 73 20 66 6c 75 73 68 65 64 20 74 68  ng is flushed th
04e0: 72 6f 75 67 68 2e 20 54 68 69 73 20 69 73 20 62  rough. This is b
04f0: 65 63 61 75 73 65 20 5b 73 6f 75 72 63 65 5d 69  ecause [source]i
0500: 6e 67 20 0a 20 20 23 20 74 68 65 20 6e 65 78 74  ng .  # the next
0510: 20 74 65 73 74 20 66 69 6c 65 20 77 69 6c 6c 20   test file will 
0520: 64 65 6c 65 74 65 20 74 68 65 20 64 61 74 61 62  delete the datab
0530: 61 73 65 20 66 69 6c 65 20 6f 6e 20 64 69 73 6b  ase file on disk
0540: 20 28 75 73 69 6e 67 0a 20 20 23 20 5b 66 69 6c   (using.  # [fil
0550: 65 20 64 65 6c 65 74 65 5d 29 2e 20 49 66 20 74  e delete]). If t
0560: 68 65 20 61 73 79 6e 63 68 72 6f 6e 6f 75 73 20  he asynchronous 
0570: 62 61 63 6b 65 6e 64 20 73 74 69 6c 6c 20 68 61  backend still ha
0580: 73 20 74 68 65 20 66 69 6c 65 0a 20 20 23 20 6f  s the file.  # o
0590: 70 65 6e 2c 20 69 74 20 77 69 6c 6c 20 62 65 63  pen, it will bec
05a0: 6f 6d 65 20 63 6f 6e 66 75 73 65 64 2e 0a 20 20  ome confused..  
05b0: 23 0a 20 20 73 71 6c 69 74 65 33 61 73 79 6e 63  #.  sqlite3async
05c0: 5f 68 61 6c 74 20 69 64 6c 65 0a 20 20 73 71 6c  _halt idle.  sql
05d0: 69 74 65 33 61 73 79 6e 63 5f 73 74 61 72 74 0a  ite3async_start.
05e0: 20 20 73 71 6c 69 74 65 33 61 73 79 6e 63 5f 77    sqlite3async_w
05f0: 61 69 74 0a 20 20 73 71 6c 69 74 65 33 61 73 79  ait.  sqlite3asy
0600: 6e 63 5f 68 61 6c 74 20 6e 65 76 65 72 0a 7d 0a  nc_halt never.}.
0610: 0a 23 20 46 6c 75 73 68 20 74 68 65 20 77 72 69  .# Flush the wri
0620: 74 65 2d 71 75 65 75 65 20 61 6e 64 20 64 69 73  te-queue and dis
0630: 61 62 6c 65 20 61 73 79 6e 63 68 72 6f 6e 6f 75  able asynchronou
0640: 73 20 49 4f 2e 20 54 68 69 73 20 73 68 6f 75 6c  s IO. This shoul
0650: 64 20 65 6e 73 75 72 65 0a 23 20 61 6c 6c 20 61  d ensure.# all a
0660: 6c 6c 6f 63 61 74 65 64 20 6d 65 6d 6f 72 79 20  llocated memory 
0670: 69 73 20 63 6c 65 61 6e 65 64 20 75 70 2e 0a 73  is cleaned up..s
0680: 65 74 20 73 71 6c 69 74 65 33 61 73 79 6e 63 5f  et sqlite3async_
0690: 74 72 61 63 65 20 31 0a 73 71 6c 69 74 65 33 61  trace 1.sqlite3a
06a0: 73 79 6e 63 5f 68 61 6c 74 20 69 64 6c 65 0a 73  sync_halt idle.s
06b0: 71 6c 69 74 65 33 61 73 79 6e 63 5f 73 74 61 72  qlite3async_star
06c0: 74 0a 73 71 6c 69 74 65 33 61 73 79 6e 63 5f 77  t.sqlite3async_w
06d0: 61 69 74 0a 73 71 6c 69 74 65 33 61 73 79 6e 63  ait.sqlite3async
06e0: 5f 68 61 6c 74 20 6e 65 76 65 72 0a 73 71 6c 69  _halt never.sqli
06f0: 74 65 33 61 73 79 6e 63 5f 65 6e 61 62 6c 65 20  te3async_enable 
0700: 30 0a 73 65 74 20 73 71 6c 69 74 65 33 61 73 79  0.set sqlite3asy
0710: 6e 63 5f 74 72 61 63 65 20 30 0a 0a 72 65 61 6c  nc_trace 0..real
0720: 6c 79 5f 66 69 6e 69 73 68 5f 74 65 73 74 0a 72  ly_finish_test.r
0730: 65 6e 61 6d 65 20 72 65 61 6c 6c 79 5f 64 6f 5f  ename really_do_
0740: 74 65 73 74 20 64 6f 5f 74 65 73 74 0a 72 65 6e  test do_test.ren
0750: 61 6d 65 20 72 65 61 6c 6c 79 5f 66 69 6e 69 73  ame really_finis
0760: 68 5f 74 65 73 74 20 66 69 6e 69 73 68 5f 74 65  h_test finish_te
0770: 73 74 0a                                         st.