/ Hex Artifact Content
Login

Artifact bc52702ade3d18d94af193b487ce86b2e4704dc1:


0000: 23 20 32 30 30 36 20 53 65 70 74 65 6d 62 65 72  # 2006 September
0010: 20 34 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f   4.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  #***************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 0a 23 20 54 68 69 73 20  ********.# This 
0170: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0180: 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73  regression tests
0190: 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72   for SQLite libr
01a0: 61 72 79 2e 0a 23 0a 23 20 24 49 64 3a 20 6d 69  ary..#.# $Id: mi
01b0: 73 63 37 2e 74 65 73 74 2c 76 20 31 2e 32 20 32  sc7.test,v 1.2 2
01c0: 30 30 37 2f 30 33 2f 32 39 20 31 37 3a 30 37 3a  007/03/29 17:07:
01d0: 35 33 20 64 61 6e 69 65 6c 6b 31 39 37 37 20 45  53 danielk1977 E
01e0: 78 70 20 24 0a 0a 73 65 74 20 74 65 73 74 64 69  xp $..set testdi
01f0: 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20  r [file dirname 
0200: 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24  $argv0].source $
0210: 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74  testdir/tester.t
0220: 63 6c 0a 0a 64 6f 5f 74 65 73 74 20 6d 69 73 63  cl..do_test misc
0230: 37 2d 31 20 7b 0a 20 20 63 5f 6d 69 73 75 73 65  7-1 {.  c_misuse
0240: 5f 74 65 73 74 0a 7d 20 7b 7d 0a 0a 64 6f 5f 74  _test.} {}..do_t
0250: 65 73 74 20 6d 69 73 63 37 2d 32 20 7b 0a 20 20  est misc7-2 {.  
0260: 63 5f 72 65 61 6c 6c 6f 63 5f 74 65 73 74 0a 7d  c_realloc_test.}
0270: 20 7b 7d 0a 0a 64 6f 5f 74 65 73 74 20 6d 69 73   {}..do_test mis
0280: 63 37 2d 33 20 7b 0a 20 20 63 5f 63 6f 6c 6c 61  c7-3 {.  c_colla
0290: 74 69 6f 6e 5f 74 65 73 74 0a 7d 20 7b 7d 0a 0a  tion_test.} {}..
02a0: 23 20 54 72 79 20 74 6f 20 6f 70 65 6e 20 61 20  # Try to open a 
02b0: 64 69 72 65 63 74 6f 72 79 3a 0a 23 0a 64 6f 5f  directory:.#.do_
02c0: 74 65 73 74 20 6d 69 73 63 37 2d 34 20 7b 0a 20  test misc7-4 {. 
02d0: 20 66 69 6c 65 20 64 65 6c 65 74 65 20 6d 79 64   file delete myd
02e0: 69 72 0a 20 20 66 69 6c 65 20 6d 6b 64 69 72 20  ir.  file mkdir 
02f0: 6d 79 64 69 72 0a 20 20 73 65 74 20 72 63 20 5b  mydir.  set rc [
0300: 63 61 74 63 68 20 7b 0a 20 20 20 20 73 71 6c 69  catch {.    sqli
0310: 74 65 33 20 64 62 32 20 2e 2f 6d 79 64 69 72 0a  te3 db2 ./mydir.
0320: 20 20 7d 20 6d 73 67 5d 0a 20 20 6c 69 73 74 20    } msg].  list 
0330: 24 72 63 20 24 6d 73 67 0a 7d 20 7b 31 20 7b 75  $rc $msg.} {1 {u
0340: 6e 61 62 6c 65 20 74 6f 20 6f 70 65 6e 20 64 61  nable to open da
0350: 74 61 62 61 73 65 20 66 69 6c 65 7d 7d 0a 0a 23  tabase file}}..#
0360: 20 54 72 79 20 74 6f 20 6f 70 65 6e 20 61 20 66   Try to open a f
0370: 69 6c 65 20 77 69 74 68 20 61 20 64 69 72 65 63  ile with a direc
0380: 74 6f 72 79 20 77 68 65 72 65 20 69 74 27 73 20  tory where it's 
0390: 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20 73 68 6f  journal file sho
03a0: 75 6c 64 20 62 65 2e 0a 23 0a 64 6f 5f 74 65 73  uld be..#.do_tes
03b0: 74 20 6d 69 73 63 37 2d 35 20 7b 0a 20 20 66 69  t misc7-5 {.  fi
03c0: 6c 65 20 64 65 6c 65 74 65 20 6d 79 64 69 72 0a  le delete mydir.
03d0: 20 20 66 69 6c 65 20 6d 6b 64 69 72 20 6d 79 64    file mkdir myd
03e0: 69 72 2d 6a 6f 75 72 6e 61 6c 0a 20 20 73 71 6c  ir-journal.  sql
03f0: 69 74 65 33 20 64 62 32 20 2e 2f 6d 79 64 69 72  ite3 db2 ./mydir
0400: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
0410: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 61    CREATE TABLE a
0420: 62 63 28 61 2c 20 62 2c 20 63 29 3b 0a 20 20 7d  bc(a, b, c);.  }
0430: 20 64 62 32 0a 7d 20 7b 31 20 7b 75 6e 61 62 6c   db2.} {1 {unabl
0440: 65 20 74 6f 20 6f 70 65 6e 20 64 61 74 61 62 61  e to open databa
0450: 73 65 20 66 69 6c 65 7d 7d 0a 64 62 32 20 63 6c  se file}}.db2 cl
0460: 6f 73 65 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ose..#----------
0470: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0480: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0490: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
04a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 54 68 65  ----------.# The
04b0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 65 73 74 73   following tests
04c0: 2c 20 6d 69 73 63 37 2d 36 2e 2a 20 74 65 73 74  , misc7-6.* test
04d0: 20 74 68 65 20 6c 69 62 72 61 72 69 65 73 20 62   the libraries b
04e0: 65 68 61 76 69 6f 75 72 20 77 68 65 6e 0a 23 20  ehaviour when.# 
04f0: 69 74 20 63 61 6e 6e 6f 74 20 6f 70 65 6e 20 61  it cannot open a
0500: 20 66 69 6c 65 2e 20 54 6f 20 66 6f 72 63 65 20   file. To force 
0510: 74 68 69 73 20 63 6f 6e 64 69 74 69 6f 6e 2c 20  this condition, 
0520: 77 65 20 75 73 65 20 75 70 20 61 6c 6c 20 74 68  we use up all th
0530: 65 0a 23 20 66 69 6c 65 2d 64 65 73 63 72 69 70  e.# file-descrip
0540: 74 6f 72 73 20 62 65 66 6f 72 65 20 72 75 6e 6e  tors before runn
0550: 69 6e 67 20 73 71 6c 69 74 65 2e 20 54 68 69 73  ing sqlite. This
0560: 20 70 72 6f 62 61 62 6c 79 20 6f 6e 6c 79 20 77   probably only w
0570: 6f 72 6b 73 0a 23 20 6f 6e 20 75 6e 69 78 2e 0a  orks.# on unix..
0580: 23 0a 0a 70 72 6f 63 20 75 73 65 5f 75 70 5f 66  #..proc use_up_f
0590: 69 6c 65 73 20 7b 7d 20 7b 0a 20 20 73 65 74 20  iles {} {.  set 
05a0: 72 65 74 20 5b 6c 69 73 74 5d 0a 20 20 63 61 74  ret [list].  cat
05b0: 63 68 20 7b 0a 20 20 20 20 77 68 69 6c 65 20 31  ch {.    while 1
05c0: 20 7b 20 6c 61 70 70 65 6e 64 20 72 65 74 20 5b   { lappend ret [
05d0: 6f 70 65 6e 20 74 65 73 74 2e 64 62 5d 20 7d 0a  open test.db] }.
05e0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 24 72 65    }.  return $re
05f0: 74 0a 7d 0a 0a 65 78 65 63 73 71 6c 20 7b 20 43  t.}..execsql { C
0600: 52 45 41 54 45 20 54 41 42 4c 45 20 61 62 63 28  REATE TABLE abc(
0610: 61 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62  a PRIMARY KEY, b
0620: 2c 20 63 29 3b 20 7d 0a 64 62 20 63 6c 6f 73 65  , c); }.db close
0630: 0a 73 65 74 20 66 64 5f 6c 69 73 74 20 5b 75 73  .set fd_list [us
0640: 65 5f 75 70 5f 66 69 6c 65 73 5d 0a 0a 73 65 74  e_up_files]..set
0650: 20 3a 3a 67 6f 20 31 0a 73 65 74 20 3a 3a 6e 20   ::go 1.set ::n 
0660: 31 0a 77 68 69 6c 65 20 7b 24 3a 3a 67 6f 7d 20  1.while {$::go} 
0670: 7b 0a 20 20 63 61 74 63 68 20 7b 64 62 20 63 6c  {.  catch {db cl
0680: 6f 73 65 7d 0a 20 20 64 6f 5f 74 65 73 74 20 6d  ose}.  do_test m
0690: 69 73 63 37 2d 36 2e 24 3a 3a 6e 20 7b 0a 20 20  isc7-6.$::n {.  
06a0: 20 20 73 65 74 20 72 63 20 5b 63 61 74 63 68 20    set rc [catch 
06b0: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 20 64  {.      sqlite d
06c0: 62 20 74 65 73 74 2e 64 62 0a 20 20 20 20 20 20  b test.db.      
06d0: 64 62 20 65 76 61 6c 20 7b 0a 20 20 20 20 20 20  db eval {.      
06e0: 20 20 42 45 47 49 4e 3b 0a 20 20 20 20 20 20 20    BEGIN;.       
06f0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 62 63   INSERT INTO abc
0700: 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33 29   VALUES(1, 2, 3)
0710: 3b 0a 20 20 20 20 20 20 20 20 49 4e 53 45 52 54  ;.        INSERT
0720: 20 49 4e 54 4f 20 61 62 63 20 56 41 4c 55 45 53   INTO abc VALUES
0730: 28 32 2c 20 33 2c 20 34 29 3b 0a 20 20 20 20 20  (2, 3, 4);.     
0740: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61     INSERT INTO a
0750: 62 63 20 53 45 4c 45 43 54 20 61 2b 32 2c 20 62  bc SELECT a+2, b
0760: 2c 20 63 20 46 52 4f 4d 20 61 62 63 3b 0a 20 20  , c FROM abc;.  
0770: 20 20 20 20 20 20 43 4f 4d 4d 49 54 3b 0a 20 20        COMMIT;.  
0780: 20 20 20 20 7d 0a 20 20 20 20 7d 20 6d 73 67 5d      }.    } msg]
0790: 0a 20 20 20 20 69 66 20 7b 24 72 63 20 3d 3d 20  .    if {$rc == 
07a0: 30 7d 20 7b 73 65 74 20 3a 3a 67 6f 20 30 7d 0a  0} {set ::go 0}.
07b0: 0a 20 20 20 20 65 78 70 72 20 7b 24 72 63 20 3d  .    expr {$rc =
07c0: 3d 20 30 20 7c 7c 20 28 24 72 63 20 3d 3d 20 31  = 0 || ($rc == 1
07d0: 20 26 26 20 24 6d 73 67 20 65 71 20 22 75 6e 61   && $msg eq "una
07e0: 62 6c 65 20 74 6f 20 6f 70 65 6e 20 64 61 74 61  ble to open data
07f0: 62 61 73 65 20 66 69 6c 65 22 29 7d 0a 20 20 7d  base file")}.  }
0800: 20 31 0a 0a 20 20 63 6c 6f 73 65 20 5b 6c 69 6e   1..  close [lin
0810: 64 65 78 20 24 66 64 5f 6c 69 73 74 20 30 5d 0a  dex $fd_list 0].
0820: 20 20 73 65 74 20 66 64 5f 6c 69 73 74 20 5b 6c    set fd_list [l
0830: 72 61 6e 67 65 20 24 66 64 5f 6c 69 73 74 20 31  range $fd_list 1
0840: 20 65 6e 64 5d 0a 20 20 69 6e 63 72 20 3a 3a 6e   end].  incr ::n
0850: 0a 7d 0a 66 6f 72 65 61 63 68 20 66 64 20 24 66  .}.foreach fd $f
0860: 64 5f 6c 69 73 74 20 7b 0a 20 20 63 6c 6f 73 65  d_list {.  close
0870: 20 24 66 64 0a 7d 0a 0a 66 69 6e 69 73 68 5f 74   $fd.}..finish_t
0880: 65 73 74 0a 0a                                   est..