/ Hex Artifact Content
Login

Artifact 1f0cac8ff3895e9359ed87e41aaabee982a812eb:


0000: 23 20 32 30 30 35 20 44 65 63 65 6d 62 65 72 20  # 2005 December 
0010: 32 39 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  29.#.# 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 54 68 69 73 20 66 69  ary..#.# This fi
01b0: 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20 74 65  le implements te
01c0: 73 74 73 20 74 6f 20 76 65 72 69 66 79 20 74 68  sts to verify th
01d0: 61 74 20 74 68 65 20 6e 65 77 20 73 65 72 69 61  at the new seria
01e0: 6c 5f 74 79 70 65 0a 23 20 76 61 6c 75 65 73 20  l_type.# values 
01f0: 6f 66 20 38 20 28 69 6e 74 65 67 65 72 20 30 29  of 8 (integer 0)
0200: 20 61 6e 64 20 39 20 28 69 6e 74 65 67 65 72 20   and 9 (integer 
0210: 31 29 20 77 6f 72 6b 20 63 6f 72 72 65 63 74 6c  1) work correctl
0220: 79 2e 0a 23 0a 0a 73 65 74 20 74 65 73 74 64 69  y..#..set testdi
0230: 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20  r [file dirname 
0240: 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24  $argv0].source $
0250: 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74  testdir/tester.t
0260: 63 6c 0a 0a 64 62 20 65 76 61 6c 20 7b 50 52 41  cl..db eval {PRA
0270: 47 4d 41 20 6c 65 67 61 63 79 5f 66 69 6c 65 5f  GMA legacy_file_
0280: 66 6f 72 6d 61 74 3d 4f 46 46 7d 0a 0a 23 20 54  format=OFF}..# T
0290: 68 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20 64  he size of the d
02a0: 61 74 61 62 61 73 65 20 64 65 70 65 6e 64 73 20  atabase depends 
02b0: 6f 6e 20 77 68 65 74 68 65 72 20 6f 72 20 6e 6f  on whether or no
02c0: 74 20 61 75 74 6f 76 61 63 75 75 6d 0a 23 20 69  t autovacuum.# i
02d0: 73 20 65 6e 61 62 6c 65 64 2e 0a 23 0a 69 66 63  s enabled..#.ifc
02e0: 61 70 61 62 6c 65 20 61 75 74 6f 76 61 63 75 75  apable autovacuu
02f0: 6d 20 7b 0a 20 20 69 66 20 7b 5b 64 62 20 6f 6e  m {.  if {[db on
0300: 65 20 7b 50 52 41 47 4d 41 20 61 75 74 6f 5f 76  e {PRAGMA auto_v
0310: 61 63 75 75 6d 7d 5d 7d 20 7b 0a 20 20 20 20 73  acuum}]} {.    s
0320: 65 74 20 73 6d 61 6c 6c 20 33 30 37 32 0a 20 20  et small 3072.  
0330: 20 20 73 65 74 20 6c 61 72 67 65 20 35 31 32 30    set large 5120
0340: 0a 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20  .  } else {.    
0350: 73 65 74 20 73 6d 61 6c 6c 20 32 30 34 38 0a 20  set small 2048. 
0360: 20 20 20 73 65 74 20 6c 61 72 67 65 20 34 30 39     set large 409
0370: 36 0a 20 20 7d 0a 7d 20 65 6c 73 65 20 7b 0a 20  6.  }.} else {. 
0380: 20 73 65 74 20 73 6d 61 6c 6c 20 32 30 34 38 0a   set small 2048.
0390: 20 20 73 65 74 20 6c 61 72 67 65 20 34 30 39 36    set large 4096
03a0: 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20 66 6f 72 6d  .}..do_test form
03b0: 61 74 34 2d 31 2e 31 20 7b 0a 20 20 65 78 65 63  at4-1.1 {.  exec
03c0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
03d0: 20 54 41 42 4c 45 20 74 31 28 78 30 2c 78 31 2c   TABLE t1(x0,x1,
03e0: 78 32 2c 78 33 2c 78 34 2c 78 35 2c 78 36 2c 78  x2,x3,x4,x5,x6,x
03f0: 37 2c 78 38 2c 78 39 29 3b 0a 20 20 20 20 49 4e  7,x8,x9);.    IN
0400: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
0410: 55 45 53 28 30 2c 30 2c 30 2c 30 2c 30 2c 30 2c  UES(0,0,0,0,0,0,
0420: 30 2c 30 2c 30 2c 30 29 3b 0a 20 20 20 20 49 4e  0,0,0,0);.    IN
0430: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 53 45 4c  SERT INTO t1 SEL
0440: 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20  ECT * FROM t1;. 
0450: 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74     INSERT INTO t
0460: 31 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  1 SELECT * FROM 
0470: 74 31 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49  t1;.    INSERT I
0480: 4e 54 4f 20 74 31 20 53 45 4c 45 43 54 20 2a 20  NTO t1 SELECT * 
0490: 46 52 4f 4d 20 74 31 3b 0a 20 20 20 20 49 4e 53  FROM t1;.    INS
04a0: 45 52 54 20 49 4e 54 4f 20 74 31 20 53 45 4c 45  ERT INTO t1 SELE
04b0: 43 54 20 2a 20 46 52 4f 4d 20 74 31 3b 0a 20 20  CT * FROM t1;.  
04c0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
04d0: 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74   SELECT * FROM t
04e0: 31 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  1;.    INSERT IN
04f0: 54 4f 20 74 31 20 53 45 4c 45 43 54 20 2a 20 46  TO t1 SELECT * F
0500: 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 66 69  ROM t1;.  }.  fi
0510: 6c 65 20 73 69 7a 65 20 74 65 73 74 2e 64 62 0a  le size test.db.
0520: 7d 20 24 73 6d 61 6c 6c 0a 64 6f 5f 74 65 73 74  } $small.do_test
0530: 20 66 6f 72 6d 61 74 34 2d 31 2e 32 20 7b 0a 20   format4-1.2 {. 
0540: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 55   execsql {.    U
0550: 50 44 41 54 45 20 74 31 20 53 45 54 20 78 30 3d  PDATE t1 SET x0=
0560: 31 2c 20 78 31 3d 31 2c 20 78 32 3d 31 2c 20 78  1, x1=1, x2=1, x
0570: 33 3d 31 2c 20 78 34 3d 31 2c 20 78 35 3d 31 2c  3=1, x4=1, x5=1,
0580: 20 78 36 3d 31 2c 20 78 37 3d 31 2c 20 78 38 3d   x6=1, x7=1, x8=
0590: 31 2c 20 78 39 3d 31 0a 20 20 7d 0a 20 20 66 69  1, x9=1.  }.  fi
05a0: 6c 65 20 73 69 7a 65 20 74 65 73 74 2e 64 62 0a  le size test.db.
05b0: 7d 20 24 73 6d 61 6c 6c 0a 64 6f 5f 74 65 73 74  } $small.do_test
05c0: 20 66 6f 72 6d 61 74 34 2d 31 2e 33 20 7b 0a 20   format4-1.3 {. 
05d0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 55   execsql {.    U
05e0: 50 44 41 54 45 20 74 31 20 53 45 54 20 78 30 3d  PDATE t1 SET x0=
05f0: 32 2c 20 78 31 3d 32 2c 20 78 32 3d 32 2c 20 78  2, x1=2, x2=2, x
0600: 33 3d 32 2c 20 78 34 3d 32 2c 20 78 35 3d 32 2c  3=2, x4=2, x5=2,
0610: 20 78 36 3d 32 2c 20 78 37 3d 32 2c 20 78 38 3d   x6=2, x7=2, x8=
0620: 32 2c 20 78 39 3d 32 0a 20 20 7d 0a 20 20 66 69  2, x9=2.  }.  fi
0630: 6c 65 20 73 69 7a 65 20 74 65 73 74 2e 64 62 0a  le size test.db.
0640: 7d 20 24 6c 61 72 67 65 0a 0a 0a 66 69 6e 69 73  } $large...finis
0650: 68 5f 74 65 73 74 0a                             h_test.