/ Hex Artifact Content
Login

Artifact e763be8238c8a5a0cd8b75e8eec70b957da6081b:


0000: 23 20 32 30 30 32 20 4d 61 72 63 68 20 36 0a 23  # 2002 March 6.#
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 20 54 68 69 73 20 66 69 6c 65  ****.# This file
0170: 20 69 6d 70 6c 65 6d 65 6e 74 73 20 72 65 67 72   implements regr
0180: 65 73 73 69 6f 6e 20 74 65 73 74 73 20 66 6f 72  ession tests for
0190: 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79 2e   SQLite library.
01a0: 0a 23 0a 23 20 54 68 69 73 20 66 69 6c 65 20 69  .#.# This file i
01b0: 6d 70 6c 65 6d 65 6e 74 73 20 74 65 73 74 73 20  mplements tests 
01c0: 66 6f 72 20 74 68 65 20 50 52 41 47 4d 41 20 63  for the PRAGMA c
01d0: 6f 6d 6d 61 6e 64 2e 0a 23 0a 23 20 24 49 64 3a  ommand..#.# $Id:
01e0: 20 70 72 61 67 6d 61 2e 74 65 73 74 2c 76 20 31   pragma.test,v 1
01f0: 2e 31 31 20 32 30 30 34 2f 30 35 2f 32 31 20 30  .11 2004/05/21 0
0200: 32 3a 31 34 3a 32 35 20 64 72 68 20 45 78 70 20  2:14:25 drh Exp 
0210: 24 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b  $..set testdir [
0220: 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72  file dirname $ar
0230: 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73  gv0].source $tes
0240: 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a  tdir/tester.tcl.
0250: 0a 23 20 44 65 6c 65 74 65 20 74 68 65 20 70 72  .# Delete the pr
0260: 65 65 78 69 73 74 69 6e 67 20 64 61 74 61 62 61  eexisting databa
0270: 73 65 20 74 6f 20 61 76 6f 69 64 20 74 68 65 20  se to avoid the 
0280: 73 70 65 63 69 61 6c 20 73 65 74 75 70 0a 23 20  special setup.# 
0290: 74 68 61 74 20 74 68 65 20 22 61 6c 6c 2e 74 65  that the "all.te
02a0: 73 74 22 20 73 63 72 69 70 74 20 64 6f 65 73 2e  st" script does.
02b0: 0a 23 0a 64 62 20 63 6c 6f 73 65 0a 66 69 6c 65  .#.db close.file
02c0: 20 64 65 6c 65 74 65 20 74 65 73 74 2e 64 62 0a   delete test.db.
02d0: 73 65 74 20 44 42 20 5b 73 71 6c 69 74 65 20 64  set DB [sqlite d
02e0: 62 20 74 65 73 74 2e 64 62 5d 0a 0a 64 6f 5f 74  b test.db]..do_t
02f0: 65 73 74 20 70 72 61 67 6d 61 2d 31 2e 31 20 7b  est pragma-1.1 {
0300: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0310: 20 50 52 41 47 4d 41 20 63 61 63 68 65 5f 73 69   PRAGMA cache_si
0320: 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64  ze;.    PRAGMA d
0330: 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69 7a  efault_cache_siz
0340: 65 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 73 79  e;.    PRAGMA sy
0350: 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20 20 20 50  nchronous;.    P
0360: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 73 79  RAGMA default_sy
0370: 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20 7d 0a 7d  nchronous;.  }.}
0380: 20 7b 32 30 30 30 20 32 30 30 30 20 31 20 31 7d   {2000 2000 1 1}
0390: 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d  .do_test pragma-
03a0: 31 2e 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20  1.2 {.  execsql 
03b0: 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61 63  {.    PRAGMA cac
03c0: 68 65 5f 73 69 7a 65 3d 31 32 33 34 3b 0a 20 20  he_size=1234;.  
03d0: 20 20 50 52 41 47 4d 41 20 63 61 63 68 65 5f 73    PRAGMA cache_s
03e0: 69 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d 41 20  ize;.    PRAGMA 
03f0: 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73 69  default_cache_si
0400: 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 73  ze;.    PRAGMA s
0410: 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20 20 20  ynchronous;.    
0420: 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 73  PRAGMA default_s
0430: 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20 7d 0a  ynchronous;.  }.
0440: 7d 20 7b 31 32 33 34 20 32 30 30 30 20 31 20 31  } {1234 2000 1 1
0450: 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d 61  }.do_test pragma
0460: 2d 31 2e 33 20 7b 0a 20 20 64 62 20 63 6c 6f 73  -1.3 {.  db clos
0470: 65 0a 20 20 73 71 6c 69 74 65 20 64 62 20 74 65  e.  sqlite db te
0480: 73 74 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20  st.db.  execsql 
0490: 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61 63  {.    PRAGMA cac
04a0: 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41  he_size;.    PRA
04b0: 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61 63 68  GMA default_cach
04c0: 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47  e_size;.    PRAG
04d0: 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a  MA synchronous;.
04e0: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
04f0: 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a  lt_synchronous;.
0500: 20 20 7d 0a 7d 20 7b 32 30 30 30 20 32 30 30 30    }.} {2000 2000
0510: 20 31 20 31 7d 0a 64 6f 5f 74 65 73 74 20 70 72   1 1}.do_test pr
0520: 61 67 6d 61 2d 31 2e 34 20 7b 0a 20 20 65 78 65  agma-1.4 {.  exe
0530: 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d  csql {.    PRAGM
0540: 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46  A synchronous=OF
0550: 46 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61  F;.    PRAGMA ca
0560: 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52  che_size;.    PR
0570: 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61 63  AGMA default_cac
0580: 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41  he_size;.    PRA
0590: 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b  GMA synchronous;
05a0: 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61  .    PRAGMA defa
05b0: 75 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3b  ult_synchronous;
05c0: 0a 20 20 7d 0a 7d 20 7b 32 30 30 30 20 32 30 30  .  }.} {2000 200
05d0: 30 20 30 20 31 7d 0a 64 6f 5f 74 65 73 74 20 70  0 0 1}.do_test p
05e0: 72 61 67 6d 61 2d 31 2e 35 20 7b 0a 20 20 65 78  ragma-1.5 {.  ex
05f0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47  ecsql {.    PRAG
0600: 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3d 34 33  MA cache_size=43
0610: 32 31 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 63  21;.    PRAGMA c
0620: 61 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50  ache_size;.    P
0630: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
0640: 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52  che_size;.    PR
0650: 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73  AGMA synchronous
0660: 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65 66  ;.    PRAGMA def
0670: 61 75 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73  ault_synchronous
0680: 3b 0a 20 20 7d 0a 7d 20 7b 34 33 32 31 20 32 30  ;.  }.} {4321 20
0690: 30 30 20 30 20 31 7d 0a 64 6f 5f 74 65 73 74 20  00 0 1}.do_test 
06a0: 70 72 61 67 6d 61 2d 31 2e 36 20 7b 0a 20 20 65  pragma-1.6 {.  e
06b0: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41  xecsql {.    PRA
06c0: 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3d  GMA synchronous=
06d0: 4f 4e 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 63  ON;.    PRAGMA c
06e0: 61 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50  ache_size;.    P
06f0: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61  RAGMA default_ca
0700: 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52  che_size;.    PR
0710: 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73  AGMA synchronous
0720: 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65 66  ;.    PRAGMA def
0730: 61 75 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73  ault_synchronous
0740: 3b 0a 20 20 7d 0a 7d 20 7b 34 33 32 31 20 32 30  ;.  }.} {4321 20
0750: 30 30 20 31 20 31 7d 0a 64 6f 5f 74 65 73 74 20  00 1 1}.do_test 
0760: 70 72 61 67 6d 61 2d 31 2e 37 20 7b 0a 20 20 64  pragma-1.7 {.  d
0770: 62 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65  b close.  sqlite
0780: 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78   db test.db.  ex
0790: 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47  ecsql {.    PRAG
07a0: 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20  MA cache_size;. 
07b0: 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c     PRAGMA defaul
07c0: 74 5f 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20 20  t_cache_size;.  
07d0: 20 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f    PRAGMA synchro
07e0: 6e 6f 75 73 3b 0a 20 20 20 20 50 52 41 47 4d 41  nous;.    PRAGMA
07f0: 20 64 65 66 61 75 6c 74 5f 73 79 6e 63 68 72 6f   default_synchro
0800: 6e 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b 32 30 30  nous;.  }.} {200
0810: 30 20 32 30 30 30 20 31 20 31 7d 0a 64 6f 5f 74  0 2000 1 1}.do_t
0820: 65 73 74 20 70 72 61 67 6d 61 2d 31 2e 38 20 7b  est pragma-1.8 {
0830: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0840: 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f   PRAGMA default_
0850: 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46 46 3b  synchronous=OFF;
0860: 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61 63 68  .    PRAGMA cach
0870: 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47  e_size;.    PRAG
0880: 4d 41 20 64 65 66 61 75 6c 74 5f 63 61 63 68 65  MA default_cache
0890: 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d  _size;.    PRAGM
08a0: 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20  A synchronous;. 
08b0: 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c     PRAGMA defaul
08c0: 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20  t_synchronous;. 
08d0: 20 7d 0a 7d 20 7b 32 30 30 30 20 32 30 30 30 20   }.} {2000 2000 
08e0: 30 20 30 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  0 0}.do_test pra
08f0: 67 6d 61 2d 31 2e 39 20 7b 0a 20 20 65 78 65 63  gma-1.9 {.  exec
0900: 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41  sql {.    PRAGMA
0910: 20 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f 73   default_cache_s
0920: 69 7a 65 3d 31 32 33 3b 0a 20 20 20 20 50 52 41  ize=123;.    PRA
0930: 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3b 0a  GMA cache_size;.
0940: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
0950: 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20  lt_cache_size;. 
0960: 20 20 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72     PRAGMA synchr
0970: 6f 6e 6f 75 73 3b 0a 20 20 20 20 50 52 41 47 4d  onous;.    PRAGM
0980: 41 20 64 65 66 61 75 6c 74 5f 73 79 6e 63 68 72  A default_synchr
0990: 6f 6e 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b 31 32  onous;.  }.} {12
09a0: 33 20 31 32 33 20 30 20 30 7d 0a 64 6f 5f 74 65  3 123 0 0}.do_te
09b0: 73 74 20 70 72 61 67 6d 61 2d 31 2e 31 30 20 7b  st pragma-1.10 {
09c0: 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73 65  .  db close.  se
09d0: 74 20 3a 3a 44 42 20 5b 73 71 6c 69 74 65 20 64  t ::DB [sqlite d
09e0: 62 20 74 65 73 74 2e 64 62 5d 0a 20 20 65 78 65  b test.db].  exe
09f0: 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d  csql {.    PRAGM
0a00: 41 20 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20 20  A cache_size;.  
0a10: 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74    PRAGMA default
0a20: 5f 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20 20 20  _cache_size;.   
0a30: 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e   PRAGMA synchron
0a40: 6f 75 73 3b 0a 20 20 20 20 50 52 41 47 4d 41 20  ous;.    PRAGMA 
0a50: 64 65 66 61 75 6c 74 5f 73 79 6e 63 68 72 6f 6e  default_synchron
0a60: 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b 31 32 33 20  ous;.  }.} {123 
0a70: 31 32 33 20 30 20 30 7d 0a 64 6f 5f 74 65 73 74  123 0 0}.do_test
0a80: 20 70 72 61 67 6d 61 2d 31 2e 31 31 20 7b 0a 20   pragma-1.11 {. 
0a90: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50   execsql {.    P
0aa0: 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75  RAGMA synchronou
0ab0: 73 3d 4e 4f 52 4d 41 4c 3b 0a 20 20 20 20 50 52  s=NORMAL;.    PR
0ac0: 41 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3b  AGMA cache_size;
0ad0: 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61  .    PRAGMA defa
0ae0: 75 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65 3b 0a  ult_cache_size;.
0af0: 20 20 20 20 50 52 41 47 4d 41 20 73 79 6e 63 68      PRAGMA synch
0b00: 72 6f 6e 6f 75 73 3b 0a 20 20 20 20 50 52 41 47  ronous;.    PRAG
0b10: 4d 41 20 64 65 66 61 75 6c 74 5f 73 79 6e 63 68  MA default_synch
0b20: 72 6f 6e 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b 31  ronous;.  }.} {1
0b30: 32 33 20 31 32 33 20 31 20 30 7d 0a 64 6f 5f 74  23 123 1 0}.do_t
0b40: 65 73 74 20 70 72 61 67 6d 61 2d 31 2e 31 32 20  est pragma-1.12 
0b50: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
0b60: 20 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f    PRAGMA synchro
0b70: 6e 6f 75 73 3d 46 55 4c 4c 3b 0a 20 20 20 20 50  nous=FULL;.    P
0b80: 52 41 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65  RAGMA cache_size
0b90: 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65 66  ;.    PRAGMA def
0ba0: 61 75 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65 3b  ault_cache_size;
0bb0: 0a 20 20 20 20 50 52 41 47 4d 41 20 73 79 6e 63  .    PRAGMA sync
0bc0: 68 72 6f 6e 6f 75 73 3b 0a 20 20 20 20 50 52 41  hronous;.    PRA
0bd0: 47 4d 41 20 64 65 66 61 75 6c 74 5f 73 79 6e 63  GMA default_sync
0be0: 68 72 6f 6e 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b  hronous;.  }.} {
0bf0: 31 32 33 20 31 32 33 20 32 20 30 7d 0a 64 6f 5f  123 123 2 0}.do_
0c00: 74 65 73 74 20 70 72 61 67 6d 61 2d 31 2e 31 33  test pragma-1.13
0c10: 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20   {.  db close.  
0c20: 73 65 74 20 3a 3a 44 42 20 5b 73 71 6c 69 74 65  set ::DB [sqlite
0c30: 20 64 62 20 74 65 73 74 2e 64 62 5d 0a 20 20 65   db test.db].  e
0c40: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41  xecsql {.    PRA
0c50: 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 3b 0a  GMA cache_size;.
0c60: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
0c70: 6c 74 5f 63 61 63 68 65 5f 73 69 7a 65 3b 0a 20  lt_cache_size;. 
0c80: 20 20 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72     PRAGMA synchr
0c90: 6f 6e 6f 75 73 3b 0a 20 20 20 20 50 52 41 47 4d  onous;.    PRAGM
0ca0: 41 20 64 65 66 61 75 6c 74 5f 73 79 6e 63 68 72  A default_synchr
0cb0: 6f 6e 6f 75 73 3b 0a 20 20 7d 0a 7d 20 7b 31 32  onous;.  }.} {12
0cc0: 33 20 31 32 33 20 30 20 30 7d 0a 64 6f 5f 74 65  3 123 0 0}.do_te
0cd0: 73 74 20 70 72 61 67 6d 61 2d 31 2e 31 34 20 7b  st pragma-1.14 {
0ce0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0cf0: 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f   PRAGMA default_
0d00: 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 46 55 4c 4c  synchronous=FULL
0d10: 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 63 61 63  ;.    PRAGMA cac
0d20: 68 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41  he_size;.    PRA
0d30: 47 4d 41 20 64 65 66 61 75 6c 74 5f 63 61 63 68  GMA default_cach
0d40: 65 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47  e_size;.    PRAG
0d50: 4d 41 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a  MA synchronous;.
0d60: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
0d70: 6c 74 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a  lt_synchronous;.
0d80: 20 20 7d 0a 7d 20 7b 31 32 33 20 31 32 33 20 32    }.} {123 123 2
0d90: 20 32 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61 67   2}.do_test prag
0da0: 6d 61 2d 31 2e 31 35 20 7b 0a 20 20 64 62 20 63  ma-1.15 {.  db c
0db0: 6c 6f 73 65 0a 20 20 73 65 74 20 3a 3a 44 42 20  lose.  set ::DB 
0dc0: 5b 73 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e  [sqlite db test.
0dd0: 64 62 5d 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  db].  execsql {.
0de0: 20 20 20 20 50 52 41 47 4d 41 20 63 61 63 68 65      PRAGMA cache
0df0: 5f 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d  _size;.    PRAGM
0e00: 41 20 64 65 66 61 75 6c 74 5f 63 61 63 68 65 5f  A default_cache_
0e10: 73 69 7a 65 3b 0a 20 20 20 20 50 52 41 47 4d 41  size;.    PRAGMA
0e20: 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20   synchronous;.  
0e30: 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74    PRAGMA default
0e40: 5f 73 79 6e 63 68 72 6f 6e 6f 75 73 3b 0a 20 20  _synchronous;.  
0e50: 7d 0a 7d 20 7b 31 32 33 20 31 32 33 20 32 20 32  }.} {123 123 2 2
0e60: 7d 0a 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d  }..do_test pragm
0e70: 61 2d 32 2e 31 20 7b 0a 20 20 65 78 65 63 73 71  a-2.1 {.  execsq
0e80: 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 73  l {.    PRAGMA s
0e90: 68 6f 77 5f 64 61 74 61 74 79 70 65 73 3d 6f 6e  how_datatypes=on
0ea0: 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 65 6d 70  ;.    PRAGMA emp
0eb0: 74 79 5f 72 65 73 75 6c 74 5f 63 61 6c 6c 62 61  ty_result_callba
0ec0: 63 6b 73 3d 6f 66 66 3b 0a 20 20 7d 0a 20 20 73  cks=off;.  }.  s
0ed0: 71 6c 69 74 65 5f 64 61 74 61 74 79 70 65 73 20  qlite_datatypes 
0ee0: 24 3a 3a 44 42 20 7b 53 45 4c 45 43 54 20 2a 20  $::DB {SELECT * 
0ef0: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74  FROM sqlite_mast
0f00: 65 72 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74  er}.} {}.do_test
0f10: 20 70 72 61 67 6d 61 2d 32 2e 32 20 7b 0a 20 20   pragma-2.2 {.  
0f20: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52  execsql {.    PR
0f30: 41 47 4d 41 20 65 6d 70 74 79 5f 72 65 73 75 6c  AGMA empty_resul
0f40: 74 5f 63 61 6c 6c 62 61 63 6b 73 3d 6f 6e 3b 0a  t_callbacks=on;.
0f50: 20 20 7d 0a 20 20 73 71 6c 69 74 65 5f 64 61 74    }.  sqlite_dat
0f60: 61 74 79 70 65 73 20 24 3a 3a 44 42 20 7b 53 45  atypes $::DB {SE
0f70: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69  LECT * FROM sqli
0f80: 74 65 5f 6d 61 73 74 65 72 7d 0a 7d 20 7b 74 65  te_master}.} {te
0f90: 78 74 20 74 65 78 74 20 74 65 78 74 20 69 6e 74  xt text text int
0fa0: 65 67 65 72 20 74 65 78 74 7d 0a 0a 23 20 4d 61  eger text}..# Ma
0fb0: 6b 65 20 73 75 72 65 20 77 65 20 63 61 6e 20 72  ke sure we can r
0fc0: 65 61 64 20 74 68 65 20 73 63 68 65 6d 61 20 77  ead the schema w
0fd0: 68 65 6e 20 65 6d 70 74 79 5f 72 65 73 75 6c 74  hen empty_result
0fe0: 5f 63 61 6c 6c 62 61 63 6b 73 20 61 72 65 0a 23  _callbacks are.#
0ff0: 20 74 75 72 6e 65 64 20 6f 6e 2e 20 54 69 63 6b   turned on. Tick
1000: 65 74 20 23 34 30 36 0a 64 6f 5f 74 65 73 74 20  et #406.do_test 
1010: 70 72 61 67 6d 61 2d 32 2e 32 2e 31 20 7b 0a 20  pragma-2.2.1 {. 
1020: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 42   execsql {.    B
1030: 45 47 49 4e 3b 0a 20 20 20 20 43 52 45 41 54 45  EGIN;.    CREATE
1040: 20 54 41 42 4c 45 20 74 61 62 78 28 61 2c 62 2c   TABLE tabx(a,b,
1050: 63 2c 64 29 3b 0a 20 20 20 20 52 4f 4c 4c 42 41  c,d);.    ROLLBA
1060: 43 4b 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 63  CK;.    SELECT c
1070: 6f 75 6e 74 28 2a 29 20 46 52 4f 4d 20 73 71 6c  ount(*) FROM sql
1080: 69 74 65 5f 6d 61 73 74 65 72 3b 0a 20 20 7d 0a  ite_master;.  }.
1090: 7d 20 7b 30 7d 0a 0a 64 6f 5f 74 65 73 74 20 70  } {0}..do_test p
10a0: 72 61 67 6d 61 2d 32 2e 33 20 7b 0a 20 20 65 78  ragma-2.3 {.  ex
10b0: 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  ecsql {.    CREA
10c0: 54 45 20 54 41 42 4c 45 20 74 31 28 0a 20 20 20  TE TABLE t1(.   
10d0: 20 20 20 20 61 20 49 4e 54 45 47 45 52 2c 0a 20      a INTEGER,. 
10e0: 20 20 20 20 20 20 62 20 54 45 58 54 2c 0a 20 20        b TEXT,.  
10f0: 20 20 20 20 20 63 20 57 48 41 54 45 56 45 52 2c       c WHATEVER,
1100: 0a 20 20 20 20 20 20 20 64 20 43 4c 4f 42 2c 0a  .       d CLOB,.
1110: 20 20 20 20 20 20 20 65 20 42 4c 4f 42 2c 0a 20         e BLOB,. 
1120: 20 20 20 20 20 20 66 20 56 41 52 43 48 41 52 28        f VARCHAR(
1130: 31 32 33 29 2c 0a 20 20 20 20 20 20 20 67 20 6e  123),.       g n
1140: 56 61 52 63 48 61 52 28 34 33 32 29 0a 20 20 20  VaRcHaR(432).   
1150: 20 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65   );.  }.  sqlite
1160: 5f 64 61 74 61 74 79 70 65 73 20 24 3a 3a 44 42  _datatypes $::DB
1170: 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   {SELECT * FROM 
1180: 74 31 7d 0a 7d 20 7b 49 4e 54 45 47 45 52 20 54  t1}.} {INTEGER T
1190: 45 58 54 20 57 48 41 54 45 56 45 52 20 43 4c 4f  EXT WHATEVER CLO
11a0: 42 20 42 4c 4f 42 20 56 41 52 43 48 41 52 28 31  B BLOB VARCHAR(1
11b0: 32 33 29 20 6e 56 61 52 63 48 61 52 28 34 33 32  23) nVaRcHaR(432
11c0: 29 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d  )}.do_test pragm
11d0: 61 2d 32 2e 34 20 7b 0a 20 20 73 71 6c 69 74 65  a-2.4 {.  sqlite
11e0: 5f 64 61 74 61 74 79 70 65 73 20 24 3a 3a 44 42  _datatypes $::DB
11f0: 20 7b 0a 20 20 20 20 20 53 45 4c 45 43 54 20 31   {.     SELECT 1
1200: 2c 20 27 68 65 6c 6c 6f 27 2c 20 4e 55 4c 4c 0a  , 'hello', NULL.
1210: 20 20 7d 0a 7d 20 7b 4e 55 4d 45 52 49 43 20 54    }.} {NUMERIC T
1220: 45 58 54 20 41 4e 59 7d 0a 64 6f 5f 74 65 73 74  EXT ANY}.do_test
1230: 20 70 72 61 67 6d 61 2d 32 2e 35 20 7b 0a 20 20   pragma-2.5 {.  
1240: 73 71 6c 69 74 65 5f 64 61 74 61 74 79 70 65 73  sqlite_datatypes
1250: 20 24 3a 3a 44 42 20 7b 0a 20 20 20 20 20 53 45   $::DB {.     SE
1260: 4c 45 43 54 20 31 2b 32 20 41 53 20 58 2c 20 27  LECT 1+2 AS X, '
1270: 68 65 6c 6c 6f 27 20 7c 7c 20 35 20 41 53 20 59  hello' || 5 AS Y
1280: 2c 20 4e 55 4c 4c 20 41 53 20 5a 0a 20 20 7d 0a  , NULL AS Z.  }.
1290: 7d 20 7b 4e 55 4d 45 52 49 43 20 54 45 58 54 20  } {NUMERIC TEXT 
12a0: 41 4e 59 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  ANY}.do_test pra
12b0: 67 6d 61 2d 32 2e 36 20 7b 0a 20 20 65 78 65 63  gma-2.6 {.  exec
12c0: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
12d0: 20 56 49 45 57 20 76 31 20 41 53 20 53 45 4c 45   VIEW v1 AS SELE
12e0: 43 54 20 61 2b 62 2c 20 62 7c 7c 63 2c 20 2a 20  CT a+b, b||c, * 
12f0: 46 52 4f 4d 20 74 31 3b 0a 20 20 7d 0a 20 20 73  FROM t1;.  }.  s
1300: 71 6c 69 74 65 5f 64 61 74 61 74 79 70 65 73 20  qlite_datatypes 
1310: 24 3a 3a 44 42 20 7b 53 45 4c 45 43 54 20 2a 20  $::DB {SELECT * 
1320: 46 52 4f 4d 20 76 31 7d 0a 7d 20 7b 4e 55 4d 45  FROM v1}.} {NUME
1330: 52 49 43 20 54 45 58 54 20 49 4e 54 45 47 45 52  RIC TEXT INTEGER
1340: 20 54 45 58 54 20 57 48 41 54 45 56 45 52 20 43   TEXT WHATEVER C
1350: 4c 4f 42 20 42 4c 4f 42 20 56 41 52 43 48 41 52  LOB BLOB VARCHAR
1360: 28 31 32 33 29 20 6e 56 61 52 63 48 61 52 28 34  (123) nVaRcHaR(4
1370: 33 32 29 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  32)}.do_test pra
1380: 67 6d 61 2d 32 2e 37 20 7b 0a 20 20 73 71 6c 69  gma-2.7 {.  sqli
1390: 74 65 5f 64 61 74 61 74 79 70 65 73 20 24 3a 3a  te_datatypes $::
13a0: 44 42 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  DB {.    SELECT 
13b0: 64 2c 65 20 46 52 4f 4d 20 74 31 20 55 4e 49 4f  d,e FROM t1 UNIO
13c0: 4e 20 53 45 4c 45 43 54 20 61 2c 63 20 46 52 4f  N SELECT a,c FRO
13d0: 4d 20 74 31 0a 20 20 7d 0a 7d 20 7b 49 4e 54 45  M t1.  }.} {INTE
13e0: 47 45 52 20 57 48 41 54 45 56 45 52 7d 0a 64 6f  GER WHATEVER}.do
13f0: 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 32 2e 38  _test pragma-2.8
1400: 20 7b 0a 20 20 73 71 6c 69 74 65 5f 64 61 74 61   {.  sqlite_data
1410: 74 79 70 65 73 20 24 3a 3a 44 42 20 7b 0a 20 20  types $::DB {.  
1420: 20 20 53 45 4c 45 43 54 20 64 2c 65 20 46 52 4f    SELECT d,e FRO
1430: 4d 20 74 31 20 45 58 43 45 50 54 20 53 45 4c 45  M t1 EXCEPT SELE
1440: 43 54 20 63 2c 65 20 46 52 4f 4d 20 74 31 0a 20  CT c,e FROM t1. 
1450: 20 7d 0a 7d 20 7b 57 48 41 54 45 56 45 52 20 42   }.} {WHATEVER B
1460: 4c 4f 42 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  LOB}.do_test pra
1470: 67 6d 61 2d 32 2e 39 20 7b 0a 20 20 73 71 6c 69  gma-2.9 {.  sqli
1480: 74 65 5f 64 61 74 61 74 79 70 65 73 20 24 3a 3a  te_datatypes $::
1490: 44 42 20 7b 0a 20 20 20 20 53 45 4c 45 43 54 20  DB {.    SELECT 
14a0: 64 2c 65 20 46 52 4f 4d 20 74 31 20 49 4e 54 45  d,e FROM t1 INTE
14b0: 52 53 45 43 54 20 53 45 4c 45 43 54 20 63 2c 65  RSECT SELECT c,e
14c0: 20 46 52 4f 4d 20 74 31 0a 20 20 7d 0a 7d 20 7b   FROM t1.  }.} {
14d0: 57 48 41 54 45 56 45 52 20 42 4c 4f 42 7d 0a 64  WHATEVER BLOB}.d
14e0: 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 32 2e  o_test pragma-2.
14f0: 31 30 20 7b 0a 20 20 73 71 6c 69 74 65 5f 64 61  10 {.  sqlite_da
1500: 74 61 74 79 70 65 73 20 24 3a 3a 44 42 20 7b 0a  tatypes $::DB {.
1510: 20 20 20 20 53 45 4c 45 43 54 20 64 2c 65 20 46      SELECT d,e F
1520: 52 4f 4d 20 74 31 20 49 4e 54 45 52 53 45 43 54  ROM t1 INTERSECT
1530: 20 53 45 4c 45 43 54 20 63 2c 65 20 46 52 4f 4d   SELECT c,e FROM
1540: 20 76 31 0a 20 20 7d 0a 7d 20 7b 57 48 41 54 45   v1.  }.} {WHATE
1550: 56 45 52 20 42 4c 4f 42 7d 0a 0a 23 20 43 6f 6e  VER BLOB}..# Con
1560: 73 74 72 75 63 74 20 61 20 63 6f 72 72 75 70 74  struct a corrupt
1570: 65 64 20 69 6e 64 65 78 20 61 6e 64 20 6d 61 6b  ed index and mak
1580: 65 20 73 75 72 65 20 74 68 65 20 69 6e 74 65 67  e sure the integ
1590: 72 69 74 79 5f 63 68 65 63 6b 0a 23 20 70 72 61  rity_check.# pra
15a0: 67 6d 61 20 66 69 6e 64 73 20 69 74 2e 0a 23 0a  gma finds it..#.
15b0: 69 66 20 7b 21 5b 73 71 6c 69 74 65 20 2d 68 61  if {![sqlite -ha
15c0: 73 2d 63 6f 64 65 63 5d 7d 20 7b 0a 64 6f 5f 74  s-codec]} {.do_t
15d0: 65 73 74 20 70 72 61 67 6d 61 2d 33 2e 31 20 7b  est pragma-3.1 {
15e0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
15f0: 20 42 45 47 49 4e 3b 0a 20 20 20 20 43 52 45 41   BEGIN;.    CREA
1600: 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c 62 2c  TE TABLE t2(a,b,
1610: 63 29 3b 0a 20 20 20 20 43 52 45 41 54 45 20 49  c);.    CREATE I
1620: 4e 44 45 58 20 69 32 20 4f 4e 20 74 32 28 61 29  NDEX i2 ON t2(a)
1630: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
1640: 4f 20 74 32 20 56 41 4c 55 45 53 28 31 31 2c 32  O t2 VALUES(11,2
1650: 2c 33 29 3b 0a 20 20 20 20 49 4e 53 45 52 54 20  ,3);.    INSERT 
1660: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 32  INTO t2 VALUES(2
1670: 32 2c 33 2c 34 29 3b 0a 20 20 20 20 43 4f 4d 4d  2,3,4);.    COMM
1680: 49 54 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 72  IT;.    SELECT r
1690: 6f 77 69 64 2c 20 2a 20 66 72 6f 6d 20 74 32 3b  owid, * from t2;
16a0: 0a 20 20 7d 0a 7d 20 7b 31 20 31 31 20 32 20 33  .  }.} {1 11 2 3
16b0: 20 32 20 32 32 20 33 20 34 7d 0a 64 6f 5f 74 65   2 22 3 4}.do_te
16c0: 73 74 20 70 72 61 67 6d 61 2d 33 2e 32 20 7b 0a  st pragma-3.2 {.
16d0: 20 20 73 65 74 20 72 6f 6f 74 70 61 67 65 20 5b    set rootpage [
16e0: 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43 54 20  execsql {SELECT 
16f0: 72 6f 6f 74 70 61 67 65 20 46 52 4f 4d 20 73 71  rootpage FROM sq
1700: 6c 69 74 65 5f 6d 61 73 74 65 72 20 57 48 45 52  lite_master WHER
1710: 45 20 6e 61 6d 65 3d 27 69 32 27 7d 5d 0a 20 20  E name='i2'}].  
1720: 73 65 74 20 64 62 20 5b 62 74 72 65 65 5f 6f 70  set db [btree_op
1730: 65 6e 20 74 65 73 74 2e 64 62 20 31 30 30 20 30  en test.db 100 0
1740: 5d 0a 20 20 62 74 72 65 65 5f 62 65 67 69 6e 5f  ].  btree_begin_
1750: 74 72 61 6e 73 61 63 74 69 6f 6e 20 24 64 62 0a  transaction $db.
1760: 20 20 73 65 74 20 63 20 5b 62 74 72 65 65 5f 63    set c [btree_c
1770: 75 72 73 6f 72 20 24 64 62 20 24 72 6f 6f 74 70  ursor $db $rootp
1780: 61 67 65 20 31 5d 0a 20 20 62 74 72 65 65 5f 66  age 1].  btree_f
1790: 69 72 73 74 20 24 63 0a 20 20 62 74 72 65 65 5f  irst $c.  btree_
17a0: 64 65 6c 65 74 65 20 24 63 0a 20 20 62 74 72 65  delete $c.  btre
17b0: 65 5f 63 6f 6d 6d 69 74 20 24 64 62 0a 20 20 62  e_commit $db.  b
17c0: 74 72 65 65 5f 63 6c 6f 73 65 20 24 64 62 0a 20  tree_close $db. 
17d0: 20 65 78 65 63 73 71 6c 20 7b 50 52 41 47 4d 41   execsql {PRAGMA
17e0: 20 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63 6b   integrity_check
17f0: 7d 0a 7d 20 7b 7b 72 6f 77 69 64 20 31 20 6d 69  }.} {{rowid 1 mi
1800: 73 73 69 6e 67 20 66 72 6f 6d 20 69 6e 64 65 78  ssing from index
1810: 20 69 32 7d 20 7b 77 72 6f 6e 67 20 23 20 6f 66   i2} {wrong # of
1820: 20 65 6e 74 72 69 65 73 20 69 6e 20 69 6e 64 65   entries in inde
1830: 78 20 69 32 7d 7d 0a 7d 3b 20 23 20 65 6e 64 69  x i2}}.}; # endi
1840: 66 20 68 61 73 2d 63 6f 64 65 63 0a 0a 23 20 54  f has-codec..# T
1850: 65 73 74 20 74 68 65 20 74 65 6d 70 5f 73 74 6f  est the temp_sto
1860: 72 65 20 61 6e 64 20 64 65 66 61 75 6c 74 5f 74  re and default_t
1870: 65 6d 70 5f 73 74 6f 72 65 20 70 72 61 67 6d 61  emp_store pragma
1880: 73 0a 23 0a 64 6f 5f 74 65 73 74 20 70 72 61 67  s.#.do_test prag
1890: 6d 61 2d 34 2e 32 20 7b 0a 20 20 65 78 65 63 73  ma-4.2 {.  execs
18a0: 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41 20  ql {.    PRAGMA 
18b0: 74 65 6d 70 5f 73 74 6f 72 65 3d 27 64 65 66 61  temp_store='defa
18c0: 75 6c 74 27 3b 0a 20 20 20 20 50 52 41 47 4d 41  ult';.    PRAGMA
18d0: 20 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20 20 7d   temp_store;.  }
18e0: 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74 20 70  .} {0}.do_test p
18f0: 72 61 67 6d 61 2d 34 2e 33 20 7b 0a 20 20 65 78  ragma-4.3 {.  ex
1900: 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47  ecsql {.    PRAG
1910: 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 3d 27 66  MA temp_store='f
1920: 69 6c 65 27 3b 0a 20 20 20 20 50 52 41 47 4d 41  ile';.    PRAGMA
1930: 20 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20 20 7d   temp_store;.  }
1940: 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74 20 70  .} {1}.do_test p
1950: 72 61 67 6d 61 2d 34 2e 34 20 7b 0a 20 20 65 78  ragma-4.4 {.  ex
1960: 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47  ecsql {.    PRAG
1970: 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 3d 27 6d  MA temp_store='m
1980: 65 6d 6f 72 79 27 3b 0a 20 20 20 20 50 52 41 47  emory';.    PRAG
1990: 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20  MA temp_store;. 
19a0: 20 7d 0a 7d 20 7b 32 7d 0a 64 6f 5f 74 65 73 74   }.} {2}.do_test
19b0: 20 70 72 61 67 6d 61 2d 34 2e 35 20 7b 0a 20 20   pragma-4.5 {.  
19c0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52  execsql {.    PR
19d0: 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 74 65 6d  AGMA default_tem
19e0: 70 5f 73 74 6f 72 65 3d 27 64 65 66 61 75 6c 74  p_store='default
19f0: 27 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65  ';.    PRAGMA de
1a00: 66 61 75 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65  fault_temp_store
1a10: 3b 0a 20 20 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74  ;.  }.} {0}.do_t
1a20: 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 36 20 7b  est pragma-4.6 {
1a30: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1a40: 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f   PRAGMA temp_sto
1a50: 72 65 3b 0a 20 20 7d 0a 7d 20 7b 32 7d 0a 64 6f  re;.  }.} {2}.do
1a60: 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 37  _test pragma-4.7
1a70: 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20   {.  db close.  
1a80: 73 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e 64  sqlite db test.d
1a90: 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  b.  execsql {.  
1aa0: 20 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74    PRAGMA temp_st
1ab0: 6f 72 65 3b 0a 20 20 7d 0a 7d 20 7b 30 7d 0a 64  ore;.  }.} {0}.d
1ac0: 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 34 2e  o_test pragma-4.
1ad0: 38 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  8 {.  execsql {.
1ae0: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
1af0: 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20  lt_temp_store;. 
1b00: 20 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74 65 73 74   }.} {0}.do_test
1b10: 20 70 72 61 67 6d 61 2d 34 2e 39 20 7b 0a 20 20   pragma-4.9 {.  
1b20: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50 52  execsql {.    PR
1b30: 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 74 65 6d  AGMA default_tem
1b40: 70 5f 73 74 6f 72 65 3d 27 66 69 6c 65 27 3b 0a  p_store='file';.
1b50: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
1b60: 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20  lt_temp_store;. 
1b70: 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74   }.} {1}.do_test
1b80: 20 70 72 61 67 6d 61 2d 34 2e 31 30 20 7b 0a 20   pragma-4.10 {. 
1b90: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50   execsql {.    P
1ba0: 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72 65  RAGMA temp_store
1bb0: 3b 0a 20 20 7d 0a 7d 20 7b 30 7d 0a 64 6f 5f 74  ;.  }.} {0}.do_t
1bc0: 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 31 31 20  est pragma-4.11 
1bd0: 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 73  {.  db close.  s
1be0: 71 6c 69 74 65 20 64 62 20 74 65 73 74 2e 64 62  qlite db test.db
1bf0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
1c00: 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f   PRAGMA temp_sto
1c10: 72 65 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f  re;.  }.} {1}.do
1c20: 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 31  _test pragma-4.1
1c30: 32 20 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  2 {.  execsql {.
1c40: 20 20 20 20 50 52 41 47 4d 41 20 64 65 66 61 75      PRAGMA defau
1c50: 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65 3b 0a 20  lt_temp_store;. 
1c60: 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74 65 73 74   }.} {1}.do_test
1c70: 20 70 72 61 67 6d 61 2d 34 2e 31 33 20 7b 0a 20   pragma-4.13 {. 
1c80: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 50   execsql {.    P
1c90: 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 74 65  RAGMA default_te
1ca0: 6d 70 5f 73 74 6f 72 65 3d 27 6d 65 6d 6f 72 79  mp_store='memory
1cb0: 27 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65  ';.    PRAGMA de
1cc0: 66 61 75 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65  fault_temp_store
1cd0: 3b 0a 20 20 7d 0a 7d 20 7b 32 7d 0a 64 6f 5f 74  ;.  }.} {2}.do_t
1ce0: 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 31 34 20  est pragma-4.14 
1cf0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1d00: 20 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74    PRAGMA temp_st
1d10: 6f 72 65 3b 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64  ore;.  }.} {1}.d
1d20: 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d 34 2e  o_test pragma-4.
1d30: 31 35 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a  15 {.  db close.
1d40: 20 20 73 71 6c 69 74 65 20 64 62 20 74 65 73 74    sqlite db test
1d50: 2e 64 62 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a  .db.  execsql {.
1d60: 20 20 20 20 50 52 41 47 4d 41 20 74 65 6d 70 5f      PRAGMA temp_
1d70: 73 74 6f 72 65 3b 0a 20 20 7d 0a 7d 20 7b 32 7d  store;.  }.} {2}
1d80: 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d  .do_test pragma-
1d90: 34 2e 31 36 20 7b 0a 20 20 65 78 65 63 73 71 6c  4.16 {.  execsql
1da0: 20 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 64 65   {.    PRAGMA de
1db0: 66 61 75 6c 74 5f 74 65 6d 70 5f 73 74 6f 72 65  fault_temp_store
1dc0: 3b 0a 20 20 7d 0a 7d 20 7b 32 7d 0a 64 6f 5f 74  ;.  }.} {2}.do_t
1dd0: 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 31 37 20  est pragma-4.17 
1de0: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1df0: 20 20 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74    PRAGMA temp_st
1e00: 6f 72 65 3d 27 66 69 6c 65 27 3b 0a 20 20 20 20  ore='file';.    
1e10: 50 52 41 47 4d 41 20 74 65 6d 70 5f 73 74 6f 72  PRAGMA temp_stor
1e20: 65 0a 20 20 7d 0a 7d 20 7b 31 7d 0a 64 6f 5f 74  e.  }.} {1}.do_t
1e30: 65 73 74 20 70 72 61 67 6d 61 2d 34 2e 31 38 20  est pragma-4.18 
1e40: 7b 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  {.  execsql {.  
1e50: 20 20 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74    PRAGMA default
1e60: 5f 74 65 6d 70 5f 73 74 6f 72 65 0a 20 20 7d 0a  _temp_store.  }.
1e70: 7d 20 7b 32 7d 0a 64 6f 5f 74 65 73 74 20 70 72  } {2}.do_test pr
1e80: 61 67 6d 61 2d 34 2e 31 39 20 7b 0a 20 20 64 62  agma-4.19 {.  db
1e90: 20 63 6c 6f 73 65 0a 20 20 73 71 6c 69 74 65 20   close.  sqlite 
1ea0: 64 62 20 74 65 73 74 2e 64 62 0a 20 20 65 78 65  db test.db.  exe
1eb0: 63 73 71 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d  csql {.    PRAGM
1ec0: 41 20 74 65 6d 70 5f 73 74 6f 72 65 0a 20 20 7d  A temp_store.  }
1ed0: 0a 7d 20 7b 32 7d 0a 0a 23 20 43 68 61 6e 67 69  .} {2}..# Changi
1ee0: 6e 67 20 74 68 65 20 54 45 4d 50 5f 53 54 4f 52  ng the TEMP_STOR
1ef0: 45 20 64 65 6c 65 74 65 73 20 61 6e 79 20 65 78  E deletes any ex
1f00: 69 73 74 69 6e 67 20 74 65 6d 70 6f 72 61 72 79  isting temporary
1f10: 20 74 61 62 6c 65 73 0a 23 0a 64 6f 5f 74 65 73   tables.#.do_tes
1f20: 74 20 70 72 61 67 6d 61 2d 34 2e 32 30 20 7b 0a  t pragma-4.20 {.
1f30: 20 20 65 78 65 63 73 71 6c 20 7b 53 45 4c 45 43    execsql {SELEC
1f40: 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69  T name FROM sqli
1f50: 74 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 7d 0a  te_temp_master}.
1f60: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  } {}.do_test pra
1f70: 67 6d 61 2d 34 2e 32 31 20 7b 0a 20 20 65 78 65  gma-4.21 {.  exe
1f80: 63 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54  csql {.    CREAT
1f90: 45 20 54 45 4d 50 20 54 41 42 4c 45 20 74 65 73  E TEMP TABLE tes
1fa0: 74 31 28 61 2c 62 2c 63 29 3b 0a 20 20 20 20 53  t1(a,b,c);.    S
1fb0: 45 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d 20  ELECT name FROM 
1fc0: 73 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74  sqlite_temp_mast
1fd0: 65 72 3b 0a 20 20 7d 0a 7d 20 7b 74 65 73 74 31  er;.  }.} {test1
1fe0: 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d 61  }.do_test pragma
1ff0: 2d 34 2e 32 32 20 7b 0a 20 20 65 78 65 63 73 71  -4.22 {.  execsq
2000: 6c 20 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 74  l {.    PRAGMA t
2010: 65 6d 70 5f 73 74 6f 72 65 3d 27 66 69 6c 65 27  emp_store='file'
2020: 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 6e 61 6d  ;.    SELECT nam
2030: 65 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 74 65  e FROM sqlite_te
2040: 6d 70 5f 6d 61 73 74 65 72 3b 0a 20 20 7d 0a 7d  mp_master;.  }.}
2050: 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61 67   {}.do_test prag
2060: 6d 61 2d 34 2e 32 33 20 7b 0a 20 20 65 78 65 63  ma-4.23 {.  exec
2070: 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41 54 45  sql {.    CREATE
2080: 20 54 45 4d 50 20 54 41 42 4c 45 20 74 65 73 74   TEMP TABLE test
2090: 31 28 61 2c 62 2c 63 29 3b 0a 20 20 20 20 53 45  1(a,b,c);.    SE
20a0: 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73  LECT name FROM s
20b0: 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74 65  qlite_temp_maste
20c0: 72 3b 0a 20 20 7d 0a 7d 20 7b 74 65 73 74 31 7d  r;.  }.} {test1}
20d0: 0a 64 6f 5f 74 65 73 74 20 70 72 61 67 6d 61 2d  .do_test pragma-
20e0: 34 2e 32 34 20 7b 0a 20 20 65 78 65 63 73 71 6c  4.24 {.  execsql
20f0: 20 7b 0a 20 20 20 20 50 52 41 47 4d 41 20 74 65   {.    PRAGMA te
2100: 6d 70 5f 73 74 6f 72 65 3d 27 6d 65 6d 6f 72 79  mp_store='memory
2110: 27 3b 0a 20 20 20 20 53 45 4c 45 43 54 20 6e 61  ';.    SELECT na
2120: 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 74  me FROM sqlite_t
2130: 65 6d 70 5f 6d 61 73 74 65 72 3b 0a 20 20 7d 0a  emp_master;.  }.
2140: 7d 20 7b 7d 0a 64 6f 5f 74 65 73 74 20 70 72 61  } {}.do_test pra
2150: 67 6d 61 2d 34 2e 32 35 20 7b 0a 20 20 63 61 74  gma-4.25 {.  cat
2160: 63 68 73 71 6c 20 7b 0a 20 20 20 20 42 45 47 49  chsql {.    BEGI
2170: 4e 3b 0a 20 20 20 20 50 52 41 47 4d 41 20 74 65  N;.    PRAGMA te
2180: 6d 70 5f 73 74 6f 72 65 3d 27 64 65 66 61 75 6c  mp_store='defaul
2190: 74 27 3b 0a 20 20 20 20 43 4f 4d 4d 49 54 3b 0a  t';.    COMMIT;.
21a0: 20 20 7d 0a 7d 20 7b 31 20 7b 74 65 6d 70 6f 72    }.} {1 {tempor
21b0: 61 72 79 20 73 74 6f 72 61 67 65 20 63 61 6e 6e  ary storage cann
21c0: 6f 74 20 62 65 20 63 68 61 6e 67 65 64 20 66 72  ot be changed fr
21d0: 6f 6d 20 77 69 74 68 69 6e 20 61 20 74 72 61 6e  om within a tran
21e0: 73 61 63 74 69 6f 6e 7d 7d 0a 63 61 74 63 68 73  saction}}.catchs
21f0: 71 6c 20 7b 43 4f 4d 4d 49 54 7d 0a 0a 66 69 6e  ql {COMMIT}..fin
2200: 69 73 68 5f 74 65 73 74 0a                       ish_test.