/ Hex Artifact Content
Login

Artifact 1cb4b32f1a304ed9e291d7c4d49c91c2c8dc1b9450e6d2c1198b2cc895d40d77:


0000: 23 20 32 30 31 37 20 4a 61 6e 20 34 0a 23 0a 23  # 2017 Jan 4.#.#
0010: 20 54 68 65 20 61 75 74 68 6f 72 20 64 69 73 63   The author disc
0020: 6c 61 69 6d 73 20 63 6f 70 79 72 69 67 68 74 20  laims copyright 
0030: 74 6f 20 74 68 69 73 20 73 6f 75 72 63 65 20 63  to this source c
0040: 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f  ode.  In place o
0050: 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69  f.# a legal noti
0060: 63 65 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c  ce, here is a bl
0070: 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20 20 20 4d  essing:.#.#    M
0080: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
0090: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 23 20 20  nd not evil..#  
00a0: 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66    May you find f
00b0: 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79  orgiveness for y
00c0: 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67  ourself and forg
00d0: 69 76 65 20 6f 74 68 65 72 73 2e 0a 23 20 20 20  ive others..#   
00e0: 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20 66   May you share f
00f0: 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b  reely, never tak
0100: 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f  ing more than yo
0110: 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a 2a 2a 2a  u 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 0a 23 20 54 68 69 73 20 66 69 6c 65 20 69  **.# This file i
0170: 6d 70 6c 65 6d 65 6e 74 73 20 72 65 67 72 65 73  mplements regres
0180: 73 69 6f 6e 20 74 65 73 74 73 20 66 6f 72 20 53  sion tests for S
0190: 51 4c 69 74 65 20 6c 69 62 72 61 72 79 2e 0a 23  QLite library..#
01a0: 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b 66  ..set testdir [f
01b0: 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72 67  ile dirname $arg
01c0: 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73 74  v0].source $test
01d0: 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a 73  dir/tester.tcl.s
01e0: 65 74 20 74 65 73 74 70 72 65 66 69 78 20 70 72  et testprefix pr
01f0: 61 67 6d 61 34 0a 0a 70 72 6f 63 20 64 6f 5f 70  agma4..proc do_p
0200: 72 61 67 6d 61 5f 6e 63 6f 6c 5f 74 65 73 74 20  ragma_ncol_test 
0210: 7b 74 6e 20 73 71 6c 20 6e 43 6f 6c 7d 20 7b 0a  {tn sql nCol} {.
0220: 20 20 73 65 74 20 3a 3a 73 74 6d 74 20 30 0a 20    set ::stmt 0. 
0230: 20 73 65 74 20 3a 3a 73 74 6d 74 20 5b 73 71 6c   set ::stmt [sql
0240: 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 20  ite3_prepare_v2 
0250: 64 62 20 24 73 71 6c 20 2d 31 20 64 75 6d 6d 79  db $sql -1 dummy
0260: 5d 0a 20 20 75 70 6c 65 76 65 6c 20 5b 6c 69 73  ].  uplevel [lis
0270: 74 20 64 6f 5f 74 65 73 74 20 24 74 6e 20 7b 20  t do_test $tn { 
0280: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 63  sqlite3_column_c
0290: 6f 75 6e 74 20 24 3a 3a 73 74 6d 74 20 7d 20 24  ount $::stmt } $
02a0: 6e 43 6f 6c 5d 0a 20 20 73 71 6c 69 74 65 33 5f  nCol].  sqlite3_
02b0: 66 69 6e 61 6c 69 7a 65 20 24 3a 3a 73 74 6d 74  finalize $::stmt
02c0: 0a 7d 0a 0a 23 20 49 66 20 74 68 65 72 65 20 69  .}..# If there i
02d0: 73 20 6e 6f 20 52 48 53 20 61 72 67 75 6d 65 6e  s no RHS argumen
02e0: 74 2c 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  t, the following
02f0: 20 50 52 41 47 4d 41 20 73 74 61 74 65 6d 65 6e   PRAGMA statemen
0300: 74 73 20 6f 70 65 72 61 74 65 20 61 73 0a 23 20  ts operate as.# 
0310: 71 75 65 72 69 65 73 2c 20 72 65 74 75 72 6e 69  queries, returni
0320: 6e 67 20 61 20 73 69 6e 67 6c 65 20 72 6f 77 20  ng a single row 
0330: 63 6f 6e 74 61 69 6e 69 6e 67 20 61 20 73 69 6e  containing a sin
0340: 67 6c 65 20 63 6f 6c 75 6d 6e 2e 0a 23 0a 23 20  gle column..#.# 
0350: 4f 72 2c 20 69 66 20 74 68 65 72 65 20 69 73 20  Or, if there is 
0360: 52 48 53 20 61 72 67 75 6d 65 6e 74 2c 20 74 68  RHS argument, th
0370: 65 79 20 72 65 74 75 72 6e 20 7a 65 72 6f 20 72  ey return zero r
0380: 6f 77 73 20 6f 66 20 7a 65 72 6f 20 63 6f 6c 75  ows of zero colu
0390: 6d 6e 73 2e 0a 23 0a 66 6f 72 65 61 63 68 20 7b  mns..#.foreach {
03a0: 74 6e 20 73 71 6c 7d 20 7b 0a 20 20 31 20 22 50  tn sql} {.  1 "P
03b0: 52 41 47 4d 41 20 61 70 70 6c 69 63 61 74 69 6f  RAGMA applicatio
03c0: 6e 5f 69 64 20 3d 20 31 30 22 0a 20 20 32 20 22  n_id = 10".  2 "
03d0: 50 52 41 47 4d 41 20 61 75 74 6f 6d 61 74 69 63  PRAGMA automatic
03e0: 5f 69 6e 64 65 78 20 3d 20 31 22 0a 20 20 33 20  _index = 1".  3 
03f0: 22 50 52 41 47 4d 41 20 61 75 74 6f 5f 76 61 63  "PRAGMA auto_vac
0400: 75 75 6d 20 3d 20 31 22 0a 20 20 34 20 22 50 52  uum = 1".  4 "PR
0410: 41 47 4d 41 20 63 61 63 68 65 5f 73 69 7a 65 20  AGMA cache_size 
0420: 3d 20 2d 31 30 30 22 0a 20 20 35 20 22 50 52 41  = -100".  5 "PRA
0430: 47 4d 41 20 63 61 63 68 65 5f 73 70 69 6c 6c 20  GMA cache_spill 
0440: 3d 20 31 22 0a 20 20 36 20 22 50 52 41 47 4d 41  = 1".  6 "PRAGMA
0450: 20 63 65 6c 6c 5f 73 69 7a 65 5f 63 68 65 63 6b   cell_size_check
0460: 20 3d 20 31 22 0a 20 20 37 20 22 50 52 41 47 4d   = 1".  7 "PRAGM
0470: 41 20 63 68 65 63 6b 70 6f 69 6e 74 5f 66 75 6c  A checkpoint_ful
0480: 6c 66 73 79 6e 63 20 3d 20 31 22 0a 20 20 38 20  lfsync = 1".  8 
0490: 22 50 52 41 47 4d 41 20 63 6f 75 6e 74 5f 63 68  "PRAGMA count_ch
04a0: 61 6e 67 65 73 20 3d 20 31 22 0a 20 20 39 20 22  anges = 1".  9 "
04b0: 50 52 41 47 4d 41 20 64 65 66 61 75 6c 74 5f 63  PRAGMA default_c
04c0: 61 63 68 65 5f 73 69 7a 65 20 3d 20 31 30 30 22  ache_size = 100"
04d0: 0a 20 31 30 20 22 50 52 41 47 4d 41 20 64 65 66  . 10 "PRAGMA def
04e0: 65 72 5f 66 6f 72 65 69 67 6e 5f 6b 65 79 73 20  er_foreign_keys 
04f0: 3d 20 31 22 0a 20 31 31 20 22 50 52 41 47 4d 41  = 1". 11 "PRAGMA
0500: 20 65 6d 70 74 79 5f 72 65 73 75 6c 74 5f 63 61   empty_result_ca
0510: 6c 6c 62 61 63 6b 73 20 3d 20 31 22 0a 20 31 32  llbacks = 1". 12
0520: 20 22 50 52 41 47 4d 41 20 65 6e 63 6f 64 69 6e   "PRAGMA encodin
0530: 67 20 3d 20 27 75 74 66 2d 38 27 22 0a 20 31 33  g = 'utf-8'". 13
0540: 20 22 50 52 41 47 4d 41 20 66 6f 72 65 69 67 6e   "PRAGMA foreign
0550: 5f 6b 65 79 73 20 3d 20 31 22 0a 20 31 34 20 22  _keys = 1". 14 "
0560: 50 52 41 47 4d 41 20 66 75 6c 6c 5f 63 6f 6c 75  PRAGMA full_colu
0570: 6d 6e 5f 6e 61 6d 65 73 20 3d 20 31 22 0a 20 31  mn_names = 1". 1
0580: 35 20 22 50 52 41 47 4d 41 20 66 75 6c 6c 66 73  5 "PRAGMA fullfs
0590: 79 6e 63 20 3d 20 31 22 0a 20 31 36 20 22 50 52  ync = 1". 16 "PR
05a0: 41 47 4d 41 20 69 67 6e 6f 72 65 5f 63 68 65 63  AGMA ignore_chec
05b0: 6b 5f 63 6f 6e 73 74 72 61 69 6e 74 73 20 3d 20  k_constraints = 
05c0: 31 22 0a 20 31 37 20 22 50 52 41 47 4d 41 20 6c  1". 17 "PRAGMA l
05d0: 65 67 61 63 79 5f 66 69 6c 65 5f 66 6f 72 6d 61  egacy_file_forma
05e0: 74 20 3d 20 31 22 0a 20 31 38 20 22 50 52 41 47  t = 1". 18 "PRAG
05f0: 4d 41 20 70 61 67 65 5f 73 69 7a 65 20 3d 20 35  MA page_size = 5
0600: 31 31 22 0a 20 31 39 20 22 50 52 41 47 4d 41 20  11". 19 "PRAGMA 
0610: 70 61 67 65 5f 73 69 7a 65 20 3d 20 35 31 32 22  page_size = 512"
0620: 0a 20 32 30 20 22 50 52 41 47 4d 41 20 71 75 65  . 20 "PRAGMA que
0630: 72 79 5f 6f 6e 6c 79 20 3d 20 66 61 6c 73 65 22  ry_only = false"
0640: 0a 20 32 31 20 22 50 52 41 47 4d 41 20 72 65 61  . 21 "PRAGMA rea
0650: 64 5f 75 6e 63 6f 6d 6d 69 74 74 65 64 20 3d 20  d_uncommitted = 
0660: 74 72 75 65 22 0a 20 32 32 20 22 50 52 41 47 4d  true". 22 "PRAGM
0670: 41 20 72 65 63 75 72 73 69 76 65 5f 74 72 69 67  A recursive_trig
0680: 67 65 72 73 20 3d 20 66 61 6c 73 65 22 0a 20 32  gers = false". 2
0690: 33 20 22 50 52 41 47 4d 41 20 72 65 76 65 72 73  3 "PRAGMA revers
06a0: 65 5f 75 6e 6f 72 64 65 72 65 64 5f 73 65 6c 65  e_unordered_sele
06b0: 63 74 73 20 3d 20 66 61 6c 73 65 22 0a 20 32 34  cts = false". 24
06c0: 20 22 50 52 41 47 4d 41 20 73 63 68 65 6d 61 5f   "PRAGMA schema_
06d0: 76 65 72 73 69 6f 6e 20 3d 20 32 31 31 22 0a 20  version = 211". 
06e0: 32 35 20 22 50 52 41 47 4d 41 20 73 68 6f 72 74  25 "PRAGMA short
06f0: 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 73 20 3d 20  _column_names = 
0700: 31 22 0a 20 32 36 20 22 50 52 41 47 4d 41 20 73  1". 26 "PRAGMA s
0710: 79 6e 63 68 72 6f 6e 6f 75 73 20 3d 20 66 75 6c  ynchronous = ful
0720: 6c 22 0a 20 32 39 20 22 50 52 41 47 4d 41 20 74  l". 29 "PRAGMA t
0730: 65 6d 70 5f 73 74 6f 72 65 20 3d 20 6d 65 6d 6f  emp_store = memo
0740: 72 79 22 0a 20 33 30 20 22 50 52 41 47 4d 41 20  ry". 30 "PRAGMA 
0750: 75 73 65 72 5f 76 65 72 73 69 6f 6e 20 3d 20 34  user_version = 4
0760: 30 35 22 0a 20 33 31 20 22 50 52 41 47 4d 41 20  05". 31 "PRAGMA 
0770: 77 72 69 74 61 62 6c 65 5f 73 63 68 65 6d 61 20  writable_schema 
0780: 3d 20 31 22 0a 7d 20 7b 0a 20 20 72 65 73 65 74  = 1".} {.  reset
0790: 5f 64 62 0a 0a 20 20 23 20 57 69 74 68 6f 75 74  _db..  # Without
07a0: 20 52 48 53 3a 0a 20 20 64 6f 5f 70 72 61 67 6d   RHS:.  do_pragm
07b0: 61 5f 6e 63 6f 6c 5f 74 65 73 74 20 31 2e 24 74  a_ncol_test 1.$t
07c0: 6e 2e 31 20 5b 6c 69 6e 64 65 78 20 5b 73 70 6c  n.1 [lindex [spl
07d0: 69 74 20 24 73 71 6c 20 3d 5d 20 30 5d 20 31 0a  it $sql =] 0] 1.
07e0: 0a 20 20 23 20 57 69 74 68 20 52 48 53 3a 0a 20  .  # With RHS:. 
07f0: 20 64 6f 5f 70 72 61 67 6d 61 5f 6e 63 6f 6c 5f   do_pragma_ncol_
0800: 74 65 73 74 20 31 2e 24 74 6e 2e 32 20 24 73 71  test 1.$tn.2 $sq
0810: 6c 20 20 30 0a 7d 0a 0a 23 20 54 68 65 73 65 20  l  0.}..# These 
0820: 70 72 61 67 6d 61 73 20 73 68 6f 75 6c 64 20 6e  pragmas should n
0830: 65 76 65 72 20 72 65 74 75 72 6e 20 61 6e 79 20  ever return any 
0840: 76 61 6c 75 65 73 2e 0a 23 0a 66 6f 72 65 61 63  values..#.foreac
0850: 68 20 7b 74 6e 20 73 71 6c 7d 20 7b 0a 20 20 31  h {tn sql} {.  1
0860: 20 22 50 52 41 47 4d 41 20 73 68 72 69 6e 6b 5f   "PRAGMA shrink_
0870: 6d 65 6d 6f 72 79 22 0a 20 20 32 20 22 50 52 41  memory".  2 "PRA
0880: 47 4d 41 20 73 68 72 69 6e 6b 5f 6d 65 6d 6f 72  GMA shrink_memor
0890: 79 20 3d 20 31 30 22 0a 20 20 33 20 22 50 52 41  y = 10".  3 "PRA
08a0: 47 4d 41 20 63 61 73 65 5f 73 65 6e 73 69 74 69  GMA case_sensiti
08b0: 76 65 5f 6c 69 6b 65 20 3d 20 30 22 0a 20 20 34  ve_like = 0".  4
08c0: 20 22 50 52 41 47 4d 41 20 63 61 73 65 5f 73 65   "PRAGMA case_se
08d0: 6e 73 69 74 69 76 65 5f 6c 69 6b 65 20 3d 20 31  nsitive_like = 1
08e0: 22 0a 20 20 35 20 22 50 52 41 47 4d 41 20 63 61  ".  5 "PRAGMA ca
08f0: 73 65 5f 73 65 6e 73 69 74 69 76 65 5f 6c 69 6b  se_sensitive_lik
0900: 65 22 0a 7d 20 7b 0a 0a 20 20 64 6f 5f 70 72 61  e".} {..  do_pra
0910: 67 6d 61 5f 6e 63 6f 6c 5f 74 65 73 74 20 31 2e  gma_ncol_test 1.
0920: 24 74 6e 2e 31 20 24 73 71 6c 20 30 0a 7d 0a 0a  $tn.1 $sql 0.}..
0930: 23 20 45 58 50 4c 41 49 4e 20 6f 6e 20 61 20 50  # EXPLAIN on a P
0940: 52 41 47 4d 41 20 69 6e 74 65 67 72 69 74 79 5f  RAGMA integrity_
0950: 63 68 65 63 6b 2e 0a 23 20 56 65 72 69 66 79 20  check..# Verify 
0960: 74 68 61 74 20 74 68 61 74 20 50 34 5f 49 4e 54  that that P4_INT
0970: 41 52 52 41 59 20 61 72 67 75 6d 65 6e 74 20 74  ARRAY argument t
0980: 6f 20 4f 50 5f 49 6e 74 65 67 72 69 74 79 43 6b  o OP_IntegrityCk
0990: 20 69 73 20 72 65 6e 64 65 72 65 64 0a 23 20 63   is rendered.# c
09a0: 6f 72 72 65 63 74 6c 79 2e 0a 23 0a 64 62 20 63  orrectly..#.db c
09b0: 6c 6f 73 65 0a 66 6f 72 63 65 64 65 6c 65 74 65  lose.forcedelete
09c0: 20 74 65 73 74 2e 64 62 0a 73 71 6c 69 74 65 33   test.db.sqlite3
09d0: 20 64 62 20 74 65 73 74 2e 64 62 0a 64 6f 5f 74   db test.db.do_t
09e0: 65 73 74 20 70 72 61 67 6d 61 34 2d 32 2e 31 30  est pragma4-2.10
09f0: 30 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 0a  0 {.  db eval {.
0a00: 20 20 20 20 50 52 41 47 4d 41 20 70 61 67 65 5f      PRAGMA page_
0a10: 73 69 7a 65 3d 35 31 32 3b 0a 20 20 20 20 43 52  size=512;.    CR
0a20: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 78 29  EATE TABLE t1(x)
0a30: 3b 0a 20 20 20 20 57 49 54 48 20 52 45 43 55 52  ;.    WITH RECUR
0a40: 53 49 56 45 20 63 28 78 29 20 41 53 20 28 56 41  SIVE c(x) AS (VA
0a50: 4c 55 45 53 28 31 29 20 55 4e 49 4f 4e 20 41 4c  LUES(1) UNION AL
0a60: 4c 20 53 45 4c 45 43 54 20 78 2b 31 20 46 52 4f  L SELECT x+1 FRO
0a70: 4d 20 63 20 57 48 45 52 45 20 78 3c 31 30 30 30  M c WHERE x<1000
0a80: 30 29 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e  0).    INSERT IN
0a90: 54 4f 20 74 31 28 78 29 20 53 45 4c 45 43 54 20  TO t1(x) SELECT 
0aa0: 7a 65 72 6f 62 6c 6f 62 28 33 30 30 29 20 46 52  zeroblob(300) FR
0ab0: 4f 4d 20 63 3b 0a 20 20 20 20 43 52 45 41 54 45  OM c;.    CREATE
0ac0: 20 54 41 42 4c 45 20 74 32 28 79 29 3b 0a 20 20   TABLE t2(y);.  
0ad0: 20 20 44 52 4f 50 20 54 41 42 4c 45 20 74 31 3b    DROP TABLE t1;
0ae0: 0a 20 20 7d 0a 20 20 73 74 72 69 6e 67 20 6d 61  .  }.  string ma
0af0: 70 20 7b 5c 5b 20 78 20 5c 5d 20 78 20 5c 31 37  p {\[ x \] x \17
0b00: 33 20 7b 7d 20 5c 31 37 35 20 7b 7d 7d 20 5c 0a  3 {} \175 {}} \.
0b10: 20 20 20 20 5b 64 62 20 65 76 61 6c 20 7b 45 58      [db eval {EX
0b20: 50 4c 41 49 4e 20 50 52 41 47 4d 41 20 69 6e 74  PLAIN PRAGMA int
0b30: 65 67 72 69 74 79 5f 63 68 65 63 6b 7d 5d 0a 7d  egrity_check}].}
0b40: 20 7b 2f 20 49 6e 74 65 67 72 69 74 79 43 6b 20   {/ IntegrityCk 
0b50: 32 20 32 20 31 20 78 5b 30 2d 39 5d 2b 2c 31 78  2 2 1 x[0-9]+,1x
0b60: 20 2f 7d 0a 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d   /}...#---------
0b70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0bb0: 2d 0a 23 0a 72 65 73 65 74 5f 64 62 0a 66 6f 72  -.#.reset_db.for
0bc0: 63 65 64 65 6c 65 74 65 20 74 65 73 74 2e 64 62  cedelete test.db
0bd0: 32 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73  2.do_execsql_tes
0be0: 74 20 34 2e 31 2e 31 20 7b 0a 20 20 43 52 45 41  t 4.1.1 {.  CREA
0bf0: 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62  TE TABLE t1(a, b
0c00: 2c 20 63 29 3b 0a 20 20 41 54 54 41 43 48 20 27  , c);.  ATTACH '
0c10: 74 65 73 74 2e 64 62 32 27 20 41 53 20 61 75 78  test.db2' AS aux
0c20: 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45  ;.  CREATE TABLE
0c30: 20 61 75 78 2e 74 32 28 64 2c 20 65 2c 20 66 29   aux.t2(d, e, f)
0c40: 3b 0a 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74  ;.}.do_execsql_t
0c50: 65 73 74 20 34 2e 31 2e 32 20 7b 20 50 52 41 47  est 4.1.2 { PRAG
0c60: 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 20 3d 20  MA table_info = 
0c70: 74 31 20 7d 20 7b 0a 20 20 30 20 61 20 7b 7d 20  t1 } {.  0 a {} 
0c80: 30 20 7b 7d 20 30 20 31 20 62 20 7b 7d 20 30 20  0 {} 0 1 b {} 0 
0c90: 7b 7d 20 30 20 32 20 63 20 7b 7d 20 30 20 7b 7d  {} 0 2 c {} 0 {}
0ca0: 20 30 0a 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f   0.}.do_execsql_
0cb0: 74 65 73 74 20 34 2e 31 2e 33 20 7b 20 50 52 41  test 4.1.3 { PRA
0cc0: 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 20 3d  GMA table_info =
0cd0: 20 74 32 20 7d 20 7b 0a 20 20 30 20 64 20 7b 7d   t2 } {.  0 d {}
0ce0: 20 30 20 7b 7d 20 30 20 31 20 65 20 7b 7d 20 30   0 {} 0 1 e {} 0
0cf0: 20 7b 7d 20 30 20 32 20 66 20 7b 7d 20 30 20 7b   {} 0 2 f {} 0 {
0d00: 7d 20 30 0a 7d 0a 64 6f 5f 74 65 73 74 20 34 2e  } 0.}.do_test 4.
0d10: 31 2e 34 20 7b 20 0a 20 20 73 71 6c 69 74 65 33  1.4 { .  sqlite3
0d20: 20 64 62 33 20 74 65 73 74 2e 64 62 0a 20 20 73   db3 test.db.  s
0d30: 71 6c 69 74 65 33 20 64 62 32 20 74 65 73 74 2e  qlite3 db2 test.
0d40: 64 62 32 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  db2.  execsql { 
0d50: 44 52 4f 50 20 54 41 42 4c 45 20 74 31 20 7d 20  DROP TABLE t1 } 
0d60: 64 62 33 0a 20 20 65 78 65 63 73 71 6c 20 7b 20  db3.  execsql { 
0d70: 44 52 4f 50 20 54 41 42 4c 45 20 74 32 20 7d 20  DROP TABLE t2 } 
0d80: 64 62 32 0a 7d 20 7b 7d 0a 64 6f 5f 65 78 65 63  db2.} {}.do_exec
0d90: 73 71 6c 5f 74 65 73 74 20 34 2e 31 2e 35 20 7b  sql_test 4.1.5 {
0da0: 20 50 52 41 47 4d 41 20 74 61 62 6c 65 5f 69 6e   PRAGMA table_in
0db0: 66 6f 28 74 31 29 20 7d 0a 64 6f 5f 65 78 65 63  fo(t1) }.do_exec
0dc0: 73 71 6c 5f 74 65 73 74 20 34 2e 31 2e 36 20 7b  sql_test 4.1.6 {
0dd0: 20 50 52 41 47 4d 41 20 74 61 62 6c 65 5f 69 6e   PRAGMA table_in
0de0: 66 6f 28 74 32 29 20 7d 0a 0a 64 62 32 20 63 6c  fo(t2) }..db2 cl
0df0: 6f 73 65 0a 64 62 33 20 63 6c 6f 73 65 0a 72 65  ose.db3 close.re
0e00: 73 65 74 5f 64 62 0a 66 6f 72 63 65 64 65 6c 65  set_db.forcedele
0e10: 74 65 20 74 65 73 74 2e 64 62 32 0a 64 6f 5f 65  te test.db2.do_e
0e20: 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 32 2e  xecsql_test 4.2.
0e30: 31 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  1 {.  CREATE TAB
0e40: 4c 45 20 74 31 28 61 2c 20 62 2c 20 63 29 3b 0a  LE t1(a, b, c);.
0e50: 20 20 41 54 54 41 43 48 20 27 74 65 73 74 2e 64    ATTACH 'test.d
0e60: 62 32 27 20 41 53 20 61 75 78 3b 0a 20 20 43 52  b2' AS aux;.  CR
0e70: 45 41 54 45 20 54 41 42 4c 45 20 61 75 78 2e 74  EATE TABLE aux.t
0e80: 32 28 64 2c 20 65 2c 20 66 29 3b 0a 7d 0a 69 66  2(d, e, f);.}.if
0e90: 63 61 70 61 62 6c 65 20 76 74 61 62 20 7b 0a 20  capable vtab {. 
0ea0: 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74   do_execsql_test
0eb0: 20 34 2e 32 2e 32 20 7b 20 53 45 4c 45 43 54 20   4.2.2 { SELECT 
0ec0: 2a 20 46 52 4f 4d 20 70 72 61 67 6d 61 5f 74 61  * FROM pragma_ta
0ed0: 62 6c 65 5f 69 6e 66 6f 28 27 74 31 27 29 20 7d  ble_info('t1') }
0ee0: 20 7b 0a 20 20 20 20 30 20 61 20 7b 7d 20 30 20   {.    0 a {} 0 
0ef0: 7b 7d 20 30 20 31 20 62 20 7b 7d 20 30 20 7b 7d  {} 0 1 b {} 0 {}
0f00: 20 30 20 32 20 63 20 7b 7d 20 30 20 7b 7d 20 30   0 2 c {} 0 {} 0
0f10: 0a 20 20 7d 0a 20 20 64 6f 5f 65 78 65 63 73 71  .  }.  do_execsq
0f20: 6c 5f 74 65 73 74 20 34 2e 32 2e 33 20 7b 20 53  l_test 4.2.3 { S
0f30: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 72 61  ELECT * FROM pra
0f40: 67 6d 61 5f 74 61 62 6c 65 5f 69 6e 66 6f 28 27  gma_table_info('
0f50: 74 32 27 29 20 7d 20 7b 0a 20 20 20 20 30 20 64  t2') } {.    0 d
0f60: 20 7b 7d 20 30 20 7b 7d 20 30 20 31 20 65 20 7b   {} 0 {} 0 1 e {
0f70: 7d 20 30 20 7b 7d 20 30 20 32 20 66 20 7b 7d 20  } 0 {} 0 2 f {} 
0f80: 30 20 7b 7d 20 30 0a 20 20 7d 0a 7d 0a 64 6f 5f  0 {} 0.  }.}.do_
0f90: 74 65 73 74 20 34 2e 32 2e 34 20 7b 20 0a 20 20  test 4.2.4 { .  
0fa0: 73 71 6c 69 74 65 33 20 64 62 33 20 74 65 73 74  sqlite3 db3 test
0fb0: 2e 64 62 0a 20 20 73 71 6c 69 74 65 33 20 64 62  .db.  sqlite3 db
0fc0: 32 20 74 65 73 74 2e 64 62 32 0a 20 20 65 78 65  2 test.db2.  exe
0fd0: 63 73 71 6c 20 7b 20 44 52 4f 50 20 54 41 42 4c  csql { DROP TABL
0fe0: 45 20 74 31 20 7d 20 64 62 33 0a 20 20 65 78 65  E t1 } db3.  exe
0ff0: 63 73 71 6c 20 7b 20 44 52 4f 50 20 54 41 42 4c  csql { DROP TABL
1000: 45 20 74 32 20 7d 20 64 62 32 0a 7d 20 7b 7d 0a  E t2 } db2.} {}.
1010: 69 66 63 61 70 61 62 6c 65 20 76 74 61 62 20 7b  ifcapable vtab {
1020: 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .  do_execsql_te
1030: 73 74 20 34 2e 32 2e 35 20 7b 20 53 45 4c 45 43  st 4.2.5 { SELEC
1040: 54 20 2a 20 46 52 4f 4d 20 70 72 61 67 6d 61 5f  T * FROM pragma_
1050: 74 61 62 6c 65 5f 69 6e 66 6f 28 27 74 31 27 29  table_info('t1')
1060: 20 7d 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c   } .  do_execsql
1070: 5f 74 65 73 74 20 34 2e 32 2e 36 20 7b 20 53 45  _test 4.2.6 { SE
1080: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 72 61 67  LECT * FROM prag
1090: 6d 61 5f 74 61 62 6c 65 5f 69 6e 66 6f 28 27 74  ma_table_info('t
10a0: 32 27 29 20 7d 20 0a 7d 0a 0a 64 62 32 20 63 6c  2') } .}..db2 cl
10b0: 6f 73 65 0a 64 62 33 20 63 6c 6f 73 65 0a 72 65  ose.db3 close.re
10c0: 73 65 74 5f 64 62 0a 66 6f 72 63 65 64 65 6c 65  set_db.forcedele
10d0: 74 65 20 74 65 73 74 2e 64 62 32 0a 64 6f 5f 65  te test.db2.do_e
10e0: 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 33 2e  xecsql_test 4.3.
10f0: 31 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  1 {.  CREATE TAB
1100: 4c 45 20 74 31 28 61 2c 20 62 2c 20 63 29 3b 0a  LE t1(a, b, c);.
1110: 20 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 69    CREATE INDEX i
1120: 31 20 4f 4e 20 74 31 28 62 29 3b 0a 20 20 41 54  1 ON t1(b);.  AT
1130: 54 41 43 48 20 27 74 65 73 74 2e 64 62 32 27 20  TACH 'test.db2' 
1140: 41 53 20 61 75 78 3b 0a 20 20 43 52 45 41 54 45  AS aux;.  CREATE
1150: 20 54 41 42 4c 45 20 61 75 78 2e 74 32 28 64 2c   TABLE aux.t2(d,
1160: 20 65 2c 20 66 29 3b 0a 20 20 43 52 45 41 54 45   e, f);.  CREATE
1170: 20 49 4e 44 45 58 20 61 75 78 2e 69 32 20 4f 4e   INDEX aux.i2 ON
1180: 20 74 32 28 65 29 3b 0a 7d 0a 69 66 63 61 70 61   t2(e);.}.ifcapa
1190: 62 6c 65 20 76 74 61 62 20 7b 0a 20 20 64 6f 5f  ble vtab {.  do_
11a0: 65 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 33  execsql_test 4.3
11b0: 2e 32 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  .2 { SELECT * FR
11c0: 4f 4d 20 70 72 61 67 6d 61 5f 69 6e 64 65 78 5f  OM pragma_index_
11d0: 69 6e 66 6f 28 27 69 31 27 29 20 7d 20 7b 30 20  info('i1') } {0 
11e0: 31 20 62 7d 0a 20 20 64 6f 5f 65 78 65 63 73 71  1 b}.  do_execsq
11f0: 6c 5f 74 65 73 74 20 34 2e 33 2e 33 20 7b 20 53  l_test 4.3.3 { S
1200: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 72 61  ELECT * FROM pra
1210: 67 6d 61 5f 69 6e 64 65 78 5f 69 6e 66 6f 28 27  gma_index_info('
1220: 69 32 27 29 20 7d 20 7b 30 20 31 20 65 7d 0a 7d  i2') } {0 1 e}.}
1230: 0a 64 6f 5f 74 65 73 74 20 34 2e 33 2e 34 20 7b  .do_test 4.3.4 {
1240: 20 0a 20 20 73 71 6c 69 74 65 33 20 64 62 33 20   .  sqlite3 db3 
1250: 74 65 73 74 2e 64 62 0a 20 20 73 71 6c 69 74 65  test.db.  sqlite
1260: 33 20 64 62 32 20 74 65 73 74 2e 64 62 32 0a 20  3 db2 test.db2. 
1270: 20 65 78 65 63 73 71 6c 20 7b 20 44 52 4f 50 20   execsql { DROP 
1280: 49 4e 44 45 58 20 69 31 20 7d 20 64 62 33 0a 20  INDEX i1 } db3. 
1290: 20 65 78 65 63 73 71 6c 20 7b 20 44 52 4f 50 20   execsql { DROP 
12a0: 49 4e 44 45 58 20 69 32 20 7d 20 64 62 32 0a 7d  INDEX i2 } db2.}
12b0: 20 7b 7d 0a 69 66 20 7b 5b 70 65 72 6d 75 74 61   {}.if {[permuta
12c0: 74 69 6f 6e 5d 3d 3d 22 70 72 65 70 61 72 65 22  tion]=="prepare"
12d0: 7d 20 7b 20 63 61 74 63 68 73 71 6c 20 7b 20 53  } { catchsql { S
12e0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c  ELECT * FROM sql
12f0: 69 74 65 5f 6d 61 73 74 65 72 20 7d 20 7d 0a 69  ite_master } }.i
1300: 66 63 61 70 61 62 6c 65 20 76 74 61 62 20 7b 0a  fcapable vtab {.
1310: 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73    do_execsql_tes
1320: 74 20 34 2e 33 2e 35 20 7b 20 53 45 4c 45 43 54  t 4.3.5 { SELECT
1330: 20 2a 20 46 52 4f 4d 20 70 72 61 67 6d 61 5f 69   * FROM pragma_i
1340: 6e 64 65 78 5f 69 6e 66 6f 28 27 69 31 27 29 20  ndex_info('i1') 
1350: 7d 20 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f  } .  do_execsql_
1360: 74 65 73 74 20 34 2e 33 2e 36 20 7b 20 53 45 4c  test 4.3.6 { SEL
1370: 45 43 54 20 2a 20 46 52 4f 4d 20 70 72 61 67 6d  ECT * FROM pragm
1380: 61 5f 69 6e 64 65 78 5f 69 6e 66 6f 28 27 69 32  a_index_info('i2
1390: 27 29 20 7d 20 0a 7d 0a 0a 65 78 65 63 73 71 6c  ') } .}..execsql
13a0: 20 7b 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20   {SELECT * FROM 
13b0: 6d 61 69 6e 2e 73 71 6c 69 74 65 5f 6d 61 73 74  main.sqlite_mast
13c0: 65 72 2c 20 61 75 78 2e 73 71 6c 69 74 65 5f 6d  er, aux.sqlite_m
13d0: 61 73 74 65 72 7d 0a 64 6f 5f 65 78 65 63 73 71  aster}.do_execsq
13e0: 6c 5f 74 65 73 74 20 34 2e 34 2e 30 20 7b 0a 20  l_test 4.4.0 {. 
13f0: 20 43 52 45 41 54 45 20 49 4e 44 45 58 20 6d 61   CREATE INDEX ma
1400: 69 6e 2e 69 31 20 4f 4e 20 74 31 28 62 2c 20 63  in.i1 ON t1(b, c
1410: 29 3b 0a 20 20 43 52 45 41 54 45 20 49 4e 44 45  );.  CREATE INDE
1420: 58 20 61 75 78 2e 69 32 20 4f 4e 20 74 32 28 65  X aux.i2 ON t2(e
1430: 2c 20 66 29 3b 0a 7d 0a 69 66 63 61 70 61 62 6c  , f);.}.ifcapabl
1440: 65 20 76 74 61 62 20 7b 0a 20 20 64 6f 5f 65 78  e vtab {.  do_ex
1450: 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 34 2e 31  ecsql_test 4.4.1
1460: 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d   { SELECT * FROM
1470: 20 70 72 61 67 6d 61 5f 69 6e 64 65 78 5f 6c 69   pragma_index_li
1480: 73 74 28 27 74 31 27 29 20 7d 20 7b 30 20 69 31  st('t1') } {0 i1
1490: 20 30 20 63 20 30 7d 0a 20 20 64 6f 5f 65 78 65   0 c 0}.  do_exe
14a0: 63 73 71 6c 5f 74 65 73 74 20 34 2e 34 2e 32 20  csql_test 4.4.2 
14b0: 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20  { SELECT * FROM 
14c0: 70 72 61 67 6d 61 5f 69 6e 64 65 78 5f 6c 69 73  pragma_index_lis
14d0: 74 28 27 74 32 27 29 20 7d 20 7b 30 20 69 32 20  t('t2') } {0 i2 
14e0: 30 20 63 20 30 7d 0a 7d 0a 64 6f 5f 74 65 73 74  0 c 0}.}.do_test
14f0: 20 34 2e 34 2e 33 20 7b 20 0a 20 20 65 78 65 63   4.4.3 { .  exec
1500: 73 71 6c 20 7b 20 44 52 4f 50 20 49 4e 44 45 58  sql { DROP INDEX
1510: 20 69 31 20 7d 20 64 62 33 0a 20 20 65 78 65 63   i1 } db3.  exec
1520: 73 71 6c 20 7b 20 44 52 4f 50 20 49 4e 44 45 58  sql { DROP INDEX
1530: 20 69 32 20 7d 20 64 62 32 0a 7d 20 7b 7d 0a 69   i2 } db2.} {}.i
1540: 66 20 7b 5b 70 65 72 6d 75 74 61 74 69 6f 6e 5d  f {[permutation]
1550: 3d 3d 22 70 72 65 70 61 72 65 22 7d 20 7b 20 0a  =="prepare"} { .
1560: 20 20 63 61 74 63 68 73 71 6c 20 7b 20 53 45 4c    catchsql { SEL
1570: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
1580: 65 5f 6d 61 73 74 65 72 2c 20 61 75 78 2e 73 71  e_master, aux.sq
1590: 6c 69 74 65 5f 6d 61 73 74 65 72 20 7d 0a 7d 0a  lite_master }.}.
15a0: 69 66 63 61 70 61 62 6c 65 20 76 74 61 62 20 7b  ifcapable vtab {
15b0: 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .  do_execsql_te
15c0: 73 74 20 34 2e 34 2e 35 20 7b 20 53 45 4c 45 43  st 4.4.5 { SELEC
15d0: 54 20 2a 20 46 52 4f 4d 20 70 72 61 67 6d 61 5f  T * FROM pragma_
15e0: 69 6e 64 65 78 5f 6c 69 73 74 28 27 74 31 27 29  index_list('t1')
15f0: 20 7d 20 7b 7d 0a 20 20 64 6f 5f 65 78 65 63 73   } {}.  do_execs
1600: 71 6c 5f 74 65 73 74 20 34 2e 34 2e 36 20 7b 20  ql_test 4.4.6 { 
1610: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 72  SELECT * FROM pr
1620: 61 67 6d 61 5f 69 6e 64 65 78 5f 6c 69 73 74 28  agma_index_list(
1630: 27 74 32 27 29 20 7d 20 7b 7d 0a 7d 0a 65 78 65  't2') } {}.}.exe
1640: 63 73 71 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46  csql {SELECT * F
1650: 52 4f 4d 20 6d 61 69 6e 2e 73 71 6c 69 74 65 5f  ROM main.sqlite_
1660: 6d 61 73 74 65 72 2c 20 61 75 78 2e 73 71 6c 69  master, aux.sqli
1670: 74 65 5f 6d 61 73 74 65 72 7d 0a 0a 64 6f 5f 65  te_master}..do_e
1680: 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 35 2e  xecsql_test 4.5.
1690: 30 20 7b 0a 20 20 43 52 45 41 54 45 20 55 4e 49  0 {.  CREATE UNI
16a0: 51 55 45 20 49 4e 44 45 58 20 6d 61 69 6e 2e 69  QUE INDEX main.i
16b0: 31 20 4f 4e 20 74 31 28 61 29 3b 0a 20 20 43 52  1 ON t1(a);.  CR
16c0: 45 41 54 45 20 55 4e 49 51 55 45 20 49 4e 44 45  EATE UNIQUE INDE
16d0: 58 20 61 75 78 2e 69 32 20 4f 4e 20 74 32 28 64  X aux.i2 ON t2(d
16e0: 29 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c  );.  CREATE TABL
16f0: 45 20 6d 61 69 6e 2e 63 31 20 28 61 2c 20 62 2c  E main.c1 (a, b,
1700: 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   c REFERENCES t1
1710: 28 61 29 29 3b 0a 20 20 43 52 45 41 54 45 20 54  (a));.  CREATE T
1720: 41 42 4c 45 20 61 75 78 2e 63 32 20 28 64 2c 20  ABLE aux.c2 (d, 
1730: 65 2c 20 72 20 52 45 46 45 52 45 4e 43 45 53 20  e, r REFERENCES 
1740: 74 32 28 64 29 29 3b 0a 7d 0a 69 66 63 61 70 61  t2(d));.}.ifcapa
1750: 62 6c 65 20 76 74 61 62 20 7b 0a 20 20 64 6f 5f  ble vtab {.  do_
1760: 65 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 35  execsql_test 4.5
1770: 2e 31 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  .1 { SELECT * FR
1780: 4f 4d 20 70 72 61 67 6d 61 5f 66 6f 72 65 69 67  OM pragma_foreig
1790: 6e 5f 6b 65 79 5f 6c 69 73 74 28 27 63 31 27 29  n_key_list('c1')
17a0: 20 7d 20 7b 0a 20 20 20 20 30 20 30 20 74 31 20   } {.    0 0 t1 
17b0: 63 20 61 20 7b 4e 4f 20 41 43 54 49 4f 4e 7d 20  c a {NO ACTION} 
17c0: 7b 4e 4f 20 41 43 54 49 4f 4e 7d 20 4e 4f 4e 45  {NO ACTION} NONE
17d0: 0a 20 20 7d 0a 20 20 64 6f 5f 65 78 65 63 73 71  .  }.  do_execsq
17e0: 6c 5f 74 65 73 74 20 34 2e 35 2e 32 20 7b 20 53  l_test 4.5.2 { S
17f0: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 70 72 61  ELECT * FROM pra
1800: 67 6d 61 5f 66 6f 72 65 69 67 6e 5f 6b 65 79 5f  gma_foreign_key_
1810: 6c 69 73 74 28 27 63 32 27 29 20 7d 20 7b 0a 20  list('c2') } {. 
1820: 20 20 20 30 20 30 20 74 32 20 72 20 64 20 7b 4e     0 0 t2 r d {N
1830: 4f 20 41 43 54 49 4f 4e 7d 20 7b 4e 4f 20 41 43  O ACTION} {NO AC
1840: 54 49 4f 4e 7d 20 4e 4f 4e 45 0a 20 20 7d 0a 7d  TION} NONE.  }.}
1850: 0a 64 6f 5f 74 65 73 74 20 34 2e 35 2e 33 20 7b  .do_test 4.5.3 {
1860: 20 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 44 52   .  execsql { DR
1870: 4f 50 20 54 41 42 4c 45 20 63 31 20 7d 20 64 62  OP TABLE c1 } db
1880: 33 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 44 52  3.  execsql { DR
1890: 4f 50 20 54 41 42 4c 45 20 63 32 20 7d 20 64 62  OP TABLE c2 } db
18a0: 32 0a 7d 20 7b 7d 0a 69 66 20 7b 5b 70 65 72 6d  2.} {}.if {[perm
18b0: 75 74 61 74 69 6f 6e 5d 3d 3d 22 70 72 65 70 61  utation]=="prepa
18c0: 72 65 22 7d 20 7b 20 0a 20 20 63 61 74 63 68 73  re"} { .  catchs
18d0: 71 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52  ql { SELECT * FR
18e0: 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  OM sqlite_master
18f0: 2c 20 61 75 78 2e 73 71 6c 69 74 65 5f 6d 61 73  , aux.sqlite_mas
1900: 74 65 72 20 7d 0a 7d 0a 69 66 63 61 70 61 62 6c  ter }.}.ifcapabl
1910: 65 20 76 74 61 62 20 7b 0a 20 20 64 6f 5f 65 78  e vtab {.  do_ex
1920: 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 35 2e 34  ecsql_test 4.5.4
1930: 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d   { SELECT * FROM
1940: 20 70 72 61 67 6d 61 5f 66 6f 72 65 69 67 6e 5f   pragma_foreign_
1950: 6b 65 79 5f 6c 69 73 74 28 27 63 31 27 29 20 7d  key_list('c1') }
1960: 0a 20 20 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  .  do_execsql_te
1970: 73 74 20 34 2e 35 2e 35 20 7b 20 53 45 4c 45 43  st 4.5.5 { SELEC
1980: 54 20 2a 20 46 52 4f 4d 20 70 72 61 67 6d 61 5f  T * FROM pragma_
1990: 66 6f 72 65 69 67 6e 5f 6b 65 79 5f 6c 69 73 74  foreign_key_list
19a0: 28 27 63 32 27 29 20 7d 20 0a 7d 0a 65 78 65 63  ('c2') } .}.exec
19b0: 73 71 6c 20 7b 53 45 4c 45 43 54 20 2a 20 46 52  sql {SELECT * FR
19c0: 4f 4d 20 6d 61 69 6e 2e 73 71 6c 69 74 65 5f 6d  OM main.sqlite_m
19d0: 61 73 74 65 72 2c 20 61 75 78 2e 73 71 6c 69 74  aster, aux.sqlit
19e0: 65 5f 6d 61 73 74 65 72 7d 0a 0a 64 6f 5f 65 78  e_master}..do_ex
19f0: 65 63 73 71 6c 5f 74 65 73 74 20 34 2e 36 2e 30  ecsql_test 4.6.0
1a00: 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c   {.  CREATE TABL
1a10: 45 20 6d 61 69 6e 2e 63 31 20 28 61 2c 20 62 2c  E main.c1 (a, b,
1a20: 20 63 20 52 45 46 45 52 45 4e 43 45 53 20 74 31   c REFERENCES t1
1a30: 28 61 29 29 3b 0a 20 20 43 52 45 41 54 45 20 54  (a));.  CREATE T
1a40: 41 42 4c 45 20 61 75 78 2e 63 32 20 28 64 2c 20  ABLE aux.c2 (d, 
1a50: 65 2c 20 72 20 52 45 46 45 52 45 4e 43 45 53 20  e, r REFERENCES 
1a60: 74 32 28 64 29 29 3b 0a 20 20 49 4e 53 45 52 54  t2(d));.  INSERT
1a70: 20 49 4e 54 4f 20 6d 61 69 6e 2e 63 31 20 56 41   INTO main.c1 VA
1a80: 4c 55 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 20  LUES(1, 2, 3);. 
1a90: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 61 75 78   INSERT INTO aux
1aa0: 2e 63 32 20 56 41 4c 55 45 53 28 34 2c 20 35 2c  .c2 VALUES(4, 5,
1ab0: 20 36 29 3b 0a 7d 0a 64 6f 5f 65 78 65 63 73 71   6);.}.do_execsq
1ac0: 6c 5f 74 65 73 74 20 34 2e 36 2e 31 20 7b 20 70  l_test 4.6.1 { p
1ad0: 72 61 67 6d 61 20 66 6f 72 65 69 67 6e 5f 6b 65  ragma foreign_ke
1ae0: 79 5f 63 68 65 63 6b 28 27 63 31 27 29 20 7d 20  y_check('c1') } 
1af0: 7b 0a 20 20 63 31 20 31 20 74 31 20 30 0a 7d 0a  {.  c1 1 t1 0.}.
1b00: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
1b10: 34 2e 36 2e 32 20 7b 20 70 72 61 67 6d 61 20 66  4.6.2 { pragma f
1b20: 6f 72 65 69 67 6e 5f 6b 65 79 5f 63 68 65 63 6b  oreign_key_check
1b30: 28 27 63 32 27 29 20 7d 20 7b 0a 20 20 63 32 20  ('c2') } {.  c2 
1b40: 31 20 74 32 20 30 0a 7d 0a 64 6f 5f 74 65 73 74  1 t2 0.}.do_test
1b50: 20 34 2e 36 2e 33 20 7b 20 0a 20 20 65 78 65 63   4.6.3 { .  exec
1b60: 73 71 6c 20 7b 20 44 52 4f 50 20 54 41 42 4c 45  sql { DROP TABLE
1b70: 20 63 32 20 7d 20 64 62 32 0a 7d 20 7b 7d 0a 64   c2 } db2.} {}.d
1b80: 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 34  o_execsql_test 4
1b90: 2e 36 2e 34 20 7b 20 70 72 61 67 6d 61 20 66 6f  .6.4 { pragma fo
1ba0: 72 65 69 67 6e 5f 6b 65 79 5f 63 68 65 63 6b 28  reign_key_check(
1bb0: 27 63 31 27 29 20 7d 20 7b 63 31 20 31 20 74 31  'c1') } {c1 1 t1
1bc0: 20 30 7d 0a 64 6f 5f 63 61 74 63 68 73 71 6c 5f   0}.do_catchsql_
1bd0: 74 65 73 74 20 34 2e 36 2e 35 20 7b 20 0a 20 20  test 4.6.5 { .  
1be0: 70 72 61 67 6d 61 20 66 6f 72 65 69 67 6e 5f 6b  pragma foreign_k
1bf0: 65 79 5f 63 68 65 63 6b 28 27 63 32 27 29 20 0a  ey_check('c2') .
1c00: 7d 20 7b 31 20 7b 6e 6f 20 73 75 63 68 20 74 61  } {1 {no such ta
1c10: 62 6c 65 3a 20 63 32 7d 7d 0a 0a 64 6f 5f 65 78  ble: c2}}..do_ex
1c20: 65 63 73 71 6c 5f 74 65 73 74 20 35 2e 30 20 7b  ecsql_test 5.0 {
1c30: 0a 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20  .  CREATE TABLE 
1c40: 74 34 28 61 20 44 45 46 41 55 4c 54 20 27 61 62  t4(a DEFAULT 'ab
1c50: 63 27 20 2f 2a 20 63 6f 6d 6d 65 6e 74 20 2a 2f  c' /* comment */
1c60: 2c 20 62 20 44 45 46 41 55 4c 54 20 2d 31 20 2d  , b DEFAULT -1 -
1c70: 2d 20 63 6f 6d 6d 65 6e 74 0a 20 20 20 20 20 2c  - comment.     ,
1c80: 20 63 20 44 45 46 41 55 4c 54 20 2b 34 2e 30 20   c DEFAULT +4.0 
1c90: 2f 2a 20 61 6e 6f 74 68 65 72 20 63 6f 6d 6d 65  /* another comme
1ca0: 6e 74 20 2a 2f 0a 20 20 29 3b 0a 20 20 50 52 41  nt */.  );.  PRA
1cb0: 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 20 3d  GMA table_info =
1cc0: 20 74 34 3b 0a 7d 20 7b 0a 20 20 30 20 61 20 7b   t4;.} {.  0 a {
1cd0: 7d 20 30 20 27 61 62 63 27 20 30 20 31 20 62 20  } 0 'abc' 0 1 b 
1ce0: 7b 7d 20 30 20 2d 31 20 30 20 32 20 63 20 7b 7d  {} 0 -1 0 2 c {}
1cf0: 20 30 20 2b 34 2e 30 20 30 0a 7d 0a 0a 0a 66 69   0 +4.0 0.}...fi
1d00: 6e 69 73 68 5f 74 65 73 74 0a                    nish_test.