/ Hex Artifact Content
Login

Artifact 1317f06a03597eee29f40a49b6c21e1aaba4285f:


0000: 23 20 32 30 30 37 20 4a 75 6e 65 20 32 36 0a 23  # 2007 June 26.#
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: 20 20 54 68 65 0a 23 20 66 6f 63 75 73 20 6f 66    The.# focus of
01b0: 20 74 68 69 73 20 66 69 6c 65 20 69 73 20 27 68   this file is 'h
01c0: 69 64 64 65 6e 27 20 76 69 72 74 75 61 6c 20 74  idden' virtual t
01d0: 61 62 6c 65 20 63 6f 6c 75 6d 6e 73 2e 0a 23 0a  able columns..#.
01e0: 23 20 24 49 64 3a 20 76 74 61 62 41 2e 74 65 73  # $Id: vtabA.tes
01f0: 74 2c 76 20 31 2e 32 20 32 30 30 38 2f 30 37 2f  t,v 1.2 2008/07/
0200: 31 32 20 31 34 3a 35 32 3a 32 31 20 64 72 68 20  12 14:52:21 drh 
0210: 45 78 70 20 24 0a 0a 73 65 74 20 74 65 73 74 64  Exp $..set testd
0220: 69 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65  ir [file dirname
0230: 20 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20   $argv0].source 
0240: 24 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e  $testdir/tester.
0250: 74 63 6c 0a 0a 69 66 63 61 70 61 62 6c 65 20 21  tcl..ifcapable !
0260: 76 74 61 62 20 7b 0a 20 20 66 69 6e 69 73 68 5f  vtab {.  finish_
0270: 74 65 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a  test.  return.}.
0280: 0a 70 72 6f 63 20 67 65 74 5f 64 65 63 6c 74 79  .proc get_declty
0290: 70 65 20 7b 74 61 62 6c 65 20 63 6f 6c 7d 20 7b  pe {table col} {
02a0: 0a 20 20 73 65 74 20 53 54 4d 54 20 5b 73 71 6c  .  set STMT [sql
02b0: 69 74 65 33 5f 70 72 65 70 61 72 65 20 24 3a 3a  ite3_prepare $::
02c0: 44 42 20 22 53 45 4c 45 43 54 20 24 63 6f 6c 20  DB "SELECT $col 
02d0: 46 52 4f 4d 20 24 74 61 62 6c 65 22 20 2d 31 20  FROM $table" -1 
02e0: 54 41 49 4c 5d 0a 20 20 73 65 74 20 64 65 63 6c  TAIL].  set decl
02f0: 74 79 70 65 20 5b 73 71 6c 69 74 65 33 5f 63 6f  type [sqlite3_co
0300: 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 20 24 53  lumn_decltype $S
0310: 54 4d 54 20 30 5d 0a 20 20 73 71 6c 69 74 65 33  TMT 0].  sqlite3
0320: 5f 66 69 6e 61 6c 69 7a 65 20 24 53 54 4d 54 0a  _finalize $STMT.
0330: 20 20 73 65 74 20 64 65 63 6c 74 79 70 65 0a 7d    set decltype.}
0340: 0a 0a 70 72 6f 63 20 67 65 74 5f 63 6f 6c 6c 69  ..proc get_colli
0350: 73 74 20 7b 74 61 62 6c 65 7d 20 7b 0a 20 20 73  st {table} {.  s
0360: 65 74 20 72 65 74 20 5b 6c 69 73 74 5d 0a 20 20  et ret [list].  
0370: 64 62 20 65 76 61 6c 20 22 50 52 41 47 4d 41 20  db eval "PRAGMA 
0380: 74 61 62 6c 65 5f 69 6e 66 6f 28 24 74 61 62 6c  table_info($tabl
0390: 65 29 22 20 7b 20 6c 61 70 70 65 6e 64 20 72 65  e)" { lappend re
03a0: 74 20 24 6e 61 6d 65 20 7d 0a 20 20 73 65 74 20  t $name }.  set 
03b0: 72 65 74 0a 7d 0a 0a 23 20 52 65 67 69 73 74 65  ret.}..# Registe
03c0: 72 20 74 68 65 20 65 63 68 6f 20 6d 6f 64 75 6c  r the echo modul
03d0: 65 0a 72 65 67 69 73 74 65 72 5f 65 63 68 6f 5f  e.register_echo_
03e0: 6d 6f 64 75 6c 65 20 5b 73 71 6c 69 74 65 33 5f  module [sqlite3_
03f0: 63 6f 6e 6e 65 63 74 69 6f 6e 5f 70 6f 69 6e 74  connection_point
0400: 65 72 20 64 62 5d 0a 0a 23 20 43 72 65 61 74 65  er db]..# Create
0410: 20 61 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65   a virtual table
0420: 20 77 69 74 68 20 61 20 27 68 69 64 64 65 6e 27   with a 'hidden'
0430: 20 63 6f 6c 75 6d 6e 20 28 63 6f 6c 75 6d 6e 20   column (column 
0440: 62 29 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 74  b)..#.do_test vt
0450: 61 62 41 2d 31 2e 31 20 7b 0a 20 20 65 78 65 63  abA-1.1 {.  exec
0460: 73 71 6c 20 7b 20 43 52 45 41 54 45 20 54 41 42  sql { CREATE TAB
0470: 4c 45 20 74 31 28 61 2c 20 62 20 48 49 44 44 45  LE t1(a, b HIDDE
0480: 4e 20 56 41 52 43 48 41 52 2c 20 63 20 49 4e 54  N VARCHAR, c INT
0490: 45 47 45 52 29 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f  EGER) }.} {}.do_
04a0: 74 65 73 74 20 76 74 61 62 41 2d 31 2e 32 20 7b  test vtabA-1.2 {
04b0: 0a 20 20 65 78 65 63 73 71 6c 20 7b 20 43 52 45  .  execsql { CRE
04c0: 41 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c  ATE VIRTUAL TABL
04d0: 45 20 74 31 65 20 55 53 49 4e 47 20 65 63 68 6f  E t1e USING echo
04e0: 28 74 31 29 20 7d 0a 7d 20 7b 7d 0a 0a 23 20 54  (t1) }.} {}..# T
04f0: 65 73 74 20 74 68 61 74 20 74 68 65 20 68 69 64  est that the hid
0500: 64 65 6e 20 63 6f 6c 75 6d 6e 20 69 73 20 6e 6f  den column is no
0510: 74 20 6c 69 73 74 65 64 20 62 79 20 5b 50 52 41  t listed by [PRA
0520: 47 4d 41 20 74 61 62 6c 65 5f 69 6e 66 6f 5d 2e  GMA table_info].
0530: 0a 23 0a 64 6f 5f 74 65 73 74 20 76 74 61 62 41  .#.do_test vtabA
0540: 2d 31 2e 33 20 7b 0a 20 20 65 78 65 63 73 71 6c  -1.3 {.  execsql
0550: 20 7b 20 50 52 41 47 4d 41 20 74 61 62 6c 65 5f   { PRAGMA table_
0560: 69 6e 66 6f 28 74 31 65 29 20 7d 0a 7d 20 5b 6c  info(t1e) }.} [l
0570: 69 73 74 20 20 20 20 20 20 20 20 20 20 20 20 20  ist             
0580: 20 5c 0a 20 20 30 20 61 20 7b 7d 20 20 20 20 20   \.  0 a {}     
0590: 20 30 20 7b 7d 20 30 20 5c 0a 20 20 31 20 63 20   0 {} 0 \.  1 c 
05a0: 49 4e 54 45 47 45 52 20 30 20 7b 7d 20 30 20 5c  INTEGER 0 {} 0 \
05b0: 0a 5d 0a 0a 23 20 54 65 73 74 20 74 68 61 74 20  .]..# Test that 
05c0: 74 68 65 20 68 69 64 64 65 6e 20 63 6f 6c 75 6d  the hidden colum
05d0: 6e 20 69 73 20 6e 6f 74 20 72 65 71 75 69 72 65  n is not require
05e0: 20 69 6e 20 74 68 65 20 64 65 66 61 75 6c 74 20   in the default 
05f0: 63 6f 6c 75 6d 6e 0a 23 20 6c 69 73 74 20 66 6f  column.# list fo
0600: 72 20 61 6e 20 49 4e 53 45 52 54 20 73 74 61 74  r an INSERT stat
0610: 65 6d 65 6e 74 2e 0a 23 0a 64 6f 5f 74 65 73 74  ement..#.do_test
0620: 20 76 74 61 62 41 2d 31 2e 34 20 7b 0a 20 20 63   vtabA-1.4 {.  c
0630: 61 74 63 68 73 71 6c 20 7b 0a 20 20 20 20 49 4e  atchsql {.    IN
0640: 53 45 52 54 20 49 4e 54 4f 20 74 31 65 20 56 41  SERT INTO t1e VA
0650: 4c 55 45 53 28 27 76 61 6c 75 65 20 61 27 2c 20  LUES('value a', 
0660: 27 76 61 6c 75 65 20 63 27 29 3b 0a 20 20 7d 0a  'value c');.  }.
0670: 7d 20 7b 30 20 7b 7d 7d 0a 64 6f 5f 74 65 73 74  } {0 {}}.do_test
0680: 20 76 74 61 62 41 2d 31 2e 35 20 7b 0a 20 20 65   vtabA-1.5 {.  e
0690: 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c  xecsql {.    SEL
06a0: 45 43 54 20 61 2c 20 62 2c 20 63 20 46 52 4f 4d  ECT a, b, c FROM
06b0: 20 74 31 65 3b 0a 20 20 7d 0a 7d 20 7b 7b 76 61   t1e;.  }.} {{va
06c0: 6c 75 65 20 61 7d 20 7b 7d 20 7b 76 61 6c 75 65  lue a} {} {value
06d0: 20 63 7d 7d 0a 0a 64 6f 5f 74 65 73 74 20 76 74   c}}..do_test vt
06e0: 61 62 41 2d 31 2e 36 20 7b 0a 20 20 65 78 65 63  abA-1.6 {.  exec
06f0: 73 71 6c 20 7b 0a 20 20 20 20 53 45 4c 45 43 54  sql {.    SELECT
0700: 20 2a 20 46 52 4f 4d 20 74 31 65 3b 0a 20 20 7d   * FROM t1e;.  }
0710: 0a 7d 20 7b 7b 76 61 6c 75 65 20 61 7d 20 7b 76  .} {{value a} {v
0720: 61 6c 75 65 20 63 7d 7d 0a 64 6f 5f 65 78 65 63  alue c}}.do_exec
0730: 73 71 6c 5f 74 65 73 74 20 76 74 61 62 41 2d 31  sql_test vtabA-1
0740: 2e 37 20 7b 0a 20 20 44 45 4c 45 54 45 20 46 52  .7 {.  DELETE FR
0750: 4f 4d 20 74 31 65 3b 0a 20 20 49 4e 53 45 52 54  OM t1e;.  INSERT
0760: 20 49 4e 54 4f 20 74 31 65 20 53 45 4c 45 43 54   INTO t1e SELECT
0770: 20 27 61 62 63 27 2c 27 64 65 66 27 3b 0a 7d 20   'abc','def';.} 
0780: 7b 7d 0a 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65  {}.do_execsql_te
0790: 73 74 20 76 74 61 62 41 2d 31 2e 38 20 7b 0a 20  st vtabA-1.8 {. 
07a0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 65   INSERT INTO t1e
07b0: 20 56 41 4c 55 45 53 28 27 67 68 69 27 2c 27 6a   VALUES('ghi','j
07c0: 6b 6c 27 29 2c 28 27 6d 6e 6f 27 2c 27 70 71 72  kl'),('mno','pqr
07d0: 27 29 2c 28 27 73 74 75 27 2c 27 76 77 78 27 29  '),('stu','vwx')
07e0: 3b 0a 7d 20 7b 7d 0a 64 6f 5f 65 78 65 63 73 71  ;.} {}.do_execsq
07f0: 6c 5f 74 65 73 74 20 76 74 61 62 41 2d 31 2e 39  l_test vtabA-1.9
0800: 20 7b 0a 20 20 53 45 4c 45 43 54 20 61 2c 62 2c   {.  SELECT a,b,
0810: 63 2c 20 27 7c 27 20 46 52 4f 4d 20 74 31 65 20  c, '|' FROM t1e 
0820: 4f 52 44 45 52 20 42 59 20 31 3b 0a 7d 20 7b 61  ORDER BY 1;.} {a
0830: 62 63 20 7b 7d 20 64 65 66 20 7c 20 67 68 69 20  bc {} def | ghi 
0840: 7b 7d 20 6a 6b 6c 20 7c 20 6d 6e 6f 20 7b 7d 20  {} jkl | mno {} 
0850: 70 71 72 20 7c 20 73 74 75 20 7b 7d 20 76 77 78  pqr | stu {} vwx
0860: 20 7c 7d 0a 0a 0a 23 20 54 65 73 74 20 74 68 61   |}...# Test tha
0870: 74 20 74 68 65 20 65 78 70 61 6e 73 69 6f 6e 20  t the expansion 
0880: 6f 66 20 61 20 27 2a 27 20 65 78 70 72 65 73 73  of a '*' express
0890: 69 6f 6e 20 69 6e 20 74 68 65 20 72 65 73 75 6c  ion in the resul
08a0: 74 20 73 65 74 20 6f 66 0a 23 20 61 20 53 45 4c  t set of.# a SEL
08b0: 45 43 54 20 64 6f 65 73 20 6e 6f 74 20 69 6e 63  ECT does not inc
08c0: 6c 75 64 65 20 74 68 65 20 68 69 64 64 65 6e 20  lude the hidden 
08d0: 63 6f 6c 75 6d 6e 2e 0a 23 0a 64 6f 5f 74 65 73  column..#.do_tes
08e0: 74 20 76 74 61 62 41 2d 31 2e 32 30 20 7b 0a 20  t vtabA-1.20 {. 
08f0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 49   execsql {.    I
0900: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 65 20 53  NSERT INTO t1e S
0910: 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31 65  ELECT * FROM t1e
0920: 3b 0a 20 20 7d 0a 7d 20 7b 7d 0a 64 6f 5f 74 65  ;.  }.} {}.do_te
0930: 73 74 20 76 74 61 62 41 2d 31 2e 32 31 20 7b 0a  st vtabA-1.21 {.
0940: 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20    execsql {.    
0950: 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 31  SELECT * FROM t1
0960: 65 20 4f 52 44 45 52 20 42 59 20 31 3b 0a 20 20  e ORDER BY 1;.  
0970: 7d 0a 7d 20 7b 61 62 63 20 64 65 66 20 61 62 63  }.} {abc def abc
0980: 20 64 65 66 20 67 68 69 20 6a 6b 6c 20 67 68 69   def ghi jkl ghi
0990: 20 6a 6b 6c 20 6d 6e 6f 20 70 71 72 20 6d 6e 6f   jkl mno pqr mno
09a0: 20 70 71 72 20 73 74 75 20 76 77 78 20 73 74 75   pqr stu vwx stu
09b0: 20 76 77 78 7d 0a 0a 23 20 54 65 73 74 20 74 68   vwx}..# Test th
09c0: 61 74 20 74 68 65 20 64 65 63 6c 61 72 61 74 69  at the declarati
09d0: 6f 6e 20 74 79 70 65 20 6f 66 20 74 68 65 20 68  on type of the h
09e0: 69 64 64 65 6e 20 63 6f 6c 75 6d 6e 20 64 6f 65  idden column doe
09f0: 73 20 6e 6f 74 20 69 6e 63 6c 75 64 65 0a 23 20  s not include.# 
0a00: 74 68 65 20 74 6f 6b 65 6e 20 22 48 49 44 44 45  the token "HIDDE
0a10: 4e 22 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 74  N"..#.do_test vt
0a20: 61 62 41 2d 31 2e 32 32 20 7b 0a 20 20 67 65 74  abA-1.22 {.  get
0a30: 5f 64 65 63 6c 74 79 70 65 20 74 31 65 20 62 0a  _decltype t1e b.
0a40: 7d 20 7b 56 41 52 43 48 41 52 7d 0a 64 6f 5f 74  } {VARCHAR}.do_t
0a50: 65 73 74 20 76 74 61 62 41 2d 31 2e 32 33 20 7b  est vtabA-1.23 {
0a60: 0a 20 20 67 65 74 5f 63 6f 6c 6c 69 73 74 20 74  .  get_collist t
0a70: 31 65 0a 7d 20 7b 61 20 63 7d 0a 0a 23 2d 2d 2d  1e.} {a c}..#---
0a80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0a90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ac0: 2d 2d 2d 0a 23 20 54 68 65 73 65 20 74 65 73 74  ---.# These test
0ad0: 73 20 76 74 61 62 41 2d 32 2e 2a 20 63 6f 6e 63  s vtabA-2.* conc
0ae0: 65 6e 74 72 61 74 65 20 6f 6e 20 74 65 73 74 69  entrate on testi
0af0: 6e 67 20 74 68 61 74 20 74 68 65 20 48 49 44 44  ng that the HIDD
0b00: 45 4e 20 74 6f 6b 65 6e 0a 23 20 69 73 20 64 65  EN token.# is de
0b10: 74 65 63 74 65 64 20 61 6e 64 20 68 61 6e 64 6c  tected and handl
0b20: 65 64 20 63 6f 72 72 65 63 74 6c 79 20 69 6e 20  ed correctly in 
0b30: 76 61 72 69 6f 75 73 20 64 65 63 6c 61 72 61 74  various declarat
0b40: 69 6f 6e 73 2e 0a 23 0a 70 72 6f 63 20 61 6e 61  ions..#.proc ana
0b50: 6c 79 73 65 5f 70 61 72 73 65 20 7b 63 6f 6c 75  lyse_parse {colu
0b60: 6d 6e 73 20 64 65 63 6c 74 79 70 65 5f 6c 69 73  mns decltype_lis
0b70: 74 7d 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b  t} {.  db eval {
0b80: 20 44 52 4f 50 20 54 41 42 4c 45 20 49 46 20 45   DROP TABLE IF E
0b90: 58 49 53 54 53 20 74 31 65 3b 20 7d 0a 20 20 64  XISTS t1e; }.  d
0ba0: 62 20 65 76 61 6c 20 7b 20 44 52 4f 50 20 54 41  b eval { DROP TA
0bb0: 42 4c 45 20 49 46 20 45 58 49 53 54 53 20 74 31  BLE IF EXISTS t1
0bc0: 3b 20 7d 0a 20 20 64 62 20 65 76 61 6c 20 22 20  ; }.  db eval " 
0bd0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 31 20  CREATE TABLE t1 
0be0: 24 63 6f 6c 75 6d 6e 73 20 22 0a 20 20 64 62 20  $columns ".  db 
0bf0: 65 76 61 6c 20 7b 20 43 52 45 41 54 45 20 56 49  eval { CREATE VI
0c00: 52 54 55 41 4c 20 54 41 42 4c 45 20 74 31 65 20  RTUAL TABLE t1e 
0c10: 55 53 49 4e 47 20 65 63 68 6f 28 74 31 29 20 7d  USING echo(t1) }
0c20: 0a 20 20 73 65 74 20 72 65 74 20 5b 6c 69 73 74  .  set ret [list
0c30: 20 5b 67 65 74 5f 63 6f 6c 6c 69 73 74 20 74 31   [get_collist t1
0c40: 65 5d 5d 0a 20 20 66 6f 72 65 61 63 68 20 63 20  e]].  foreach c 
0c50: 24 64 65 63 6c 74 79 70 65 5f 6c 69 73 74 20 7b  $decltype_list {
0c60: 0a 20 20 20 20 6c 61 70 70 65 6e 64 20 72 65 74  .    lappend ret
0c70: 20 5b 67 65 74 5f 64 65 63 6c 74 79 70 65 20 74   [get_decltype t
0c80: 31 65 20 24 63 5d 0a 20 20 7d 0a 20 20 73 65 74  1e $c].  }.  set
0c90: 20 72 65 74 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20   ret.}..do_test 
0ca0: 76 74 61 62 41 2d 32 2e 31 20 7b 0a 20 20 61 6e  vtabA-2.1 {.  an
0cb0: 61 6c 79 73 65 5f 70 61 72 73 65 20 7b 28 61 20  alyse_parse {(a 
0cc0: 74 65 78 74 2c 20 62 20 69 6e 74 65 67 65 72 20  text, b integer 
0cd0: 68 69 64 64 65 6e 2c 20 63 20 68 69 64 64 65 6e  hidden, c hidden
0ce0: 29 7d 20 7b 61 20 62 20 63 7d 0a 7d 20 7b 61 20  )} {a b c}.} {a 
0cf0: 74 65 78 74 20 69 6e 74 65 67 65 72 20 7b 7d 7d  text integer {}}
0d00: 0a 0a 64 6f 5f 74 65 73 74 20 76 74 61 62 41 2d  ..do_test vtabA-
0d10: 32 2e 32 20 7b 0a 20 20 61 6e 61 6c 79 73 65 5f  2.2 {.  analyse_
0d20: 70 61 72 73 65 20 7b 28 61 20 68 69 64 64 65 6e  parse {(a hidden
0d30: 20 20 20 2c 20 62 20 69 6e 74 65 67 65 72 68 69     , b integerhi
0d40: 64 64 65 6e 2c 20 63 20 68 69 64 64 65 6e 31 29  dden, c hidden1)
0d50: 7d 20 7b 61 20 62 20 63 7d 0a 7d 20 7b 7b 62 20  } {a b c}.} {{b 
0d60: 63 7d 20 7b 7d 20 69 6e 74 65 67 65 72 68 69 64  c} {} integerhid
0d70: 64 65 6e 20 68 69 64 64 65 6e 31 7d 0a 0a 64 6f  den hidden1}..do
0d80: 5f 74 65 73 74 20 76 74 61 62 41 2d 32 2e 33 20  _test vtabA-2.3 
0d90: 7b 0a 20 20 61 6e 61 6c 79 73 65 5f 70 61 72 73  {.  analyse_pars
0da0: 65 20 7b 28 61 20 48 69 44 64 65 6e 2c 20 62 20  e {(a HiDden, b 
0db0: 48 49 44 44 45 4e 2c 20 63 20 68 69 64 64 65 6e  HIDDEN, c hidden
0dc0: 29 7d 20 7b 61 20 62 20 63 7d 0a 7d 20 7b 7b 7d  )} {a b c}.} {{}
0dd0: 20 7b 7d 20 7b 7d 20 7b 7d 7d 0a 0a 64 6f 5f 74   {} {} {}}..do_t
0de0: 65 73 74 20 76 74 61 62 41 2d 32 2e 34 20 7b 0a  est vtabA-2.4 {.
0df0: 20 20 61 6e 61 6c 79 73 65 5f 70 61 72 73 65 20    analyse_parse 
0e00: 7b 28 61 20 77 68 61 74 65 6c 73 65 20 63 61 6e  {(a whatelse can
0e10: 20 69 20 68 69 64 64 65 6e 20 74 65 73 74 2c 20   i hidden test, 
0e20: 62 20 48 49 44 44 45 4e 20 68 69 64 64 65 6e 29  b HIDDEN hidden)
0e30: 7d 20 7b 61 20 62 7d 0a 7d 20 7b 7b 7d 20 7b 77  } {a b}.} {{} {w
0e40: 68 61 74 65 6c 73 65 20 63 61 6e 20 69 20 74 65  hatelse can i te
0e50: 73 74 7d 20 68 69 64 64 65 6e 7d 0a 0a 0a 23 20  st} hidden}...# 
0e60: 54 69 63 6b 65 74 20 5b 64 32 66 30 32 64 33 37  Ticket [d2f02d37
0e70: 66 35 32 62 66 65 32 33 65 34 32 31 66 32 63 36  f52bfe23e421f2c6
0e80: 30 66 62 62 38 35 38 36 61 63 37 36 66 66 30 31  0fbb8586ac76ff01
0e90: 5d 3a 0a 23 20 61 73 73 65 72 74 69 6f 6e 20 66  ]:.# assertion f
0ea0: 61 69 6c 75 72 65 20 6f 6e 20 61 6e 20 55 50 44  ailure on an UPD
0eb0: 41 54 45 20 69 6e 76 6f 6c 76 69 6e 67 20 74 77  ATE involving tw
0ec0: 6f 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65 73  o virtual tables
0ed0: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 76 74 61 62  ..#.do_test vtab
0ee0: 41 2d 33 2e 31 20 7b 0a 20 20 64 62 20 65 76 61  A-3.1 {.  db eva
0ef0: 6c 20 7b 0a 20 20 20 20 44 52 4f 50 20 54 41 42  l {.    DROP TAB
0f00: 4c 45 20 49 46 20 45 58 49 53 54 53 20 74 31 3b  LE IF EXISTS t1;
0f10: 0a 20 20 20 20 44 52 4f 50 20 54 41 42 4c 45 20  .    DROP TABLE 
0f20: 49 46 20 45 58 49 53 54 53 20 74 32 3b 0a 20 20  IF EXISTS t2;.  
0f30: 20 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74    CREATE TABLE t
0f40: 31 28 61 2c 62 29 3b 0a 20 20 20 20 49 4e 53 45  1(a,b);.    INSE
0f50: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
0f60: 53 28 31 2c 32 29 3b 0a 20 20 20 20 43 52 45 41  S(1,2);.    CREA
0f70: 54 45 20 54 41 42 4c 45 20 74 32 28 78 2c 79 29  TE TABLE t2(x,y)
0f80: 3b 0a 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54  ;.    INSERT INT
0f90: 4f 20 74 32 20 56 41 4c 55 45 53 28 33 2c 34 29  O t2 VALUES(3,4)
0fa0: 3b 0a 20 20 20 20 43 52 45 41 54 45 20 56 49 52  ;.    CREATE VIR
0fb0: 54 55 41 4c 20 54 41 42 4c 45 20 76 74 31 20 55  TUAL TABLE vt1 U
0fc0: 53 49 4e 47 20 65 63 68 6f 28 74 31 29 3b 0a 20  SING echo(t1);. 
0fd0: 20 20 20 43 52 45 41 54 45 20 56 49 52 54 55 41     CREATE VIRTUA
0fe0: 4c 20 54 41 42 4c 45 20 76 74 32 20 55 53 49 4e  L TABLE vt2 USIN
0ff0: 47 20 65 63 68 6f 28 74 32 29 3b 0a 20 20 20 20  G echo(t2);.    
1000: 55 50 44 41 54 45 20 76 74 32 20 53 45 54 20 78  UPDATE vt2 SET x
1010: 3d 28 53 45 4c 45 43 54 20 61 20 46 52 4f 4d 20  =(SELECT a FROM 
1020: 76 74 31 20 57 48 45 52 45 20 62 3d 32 29 20 57  vt1 WHERE b=2) W
1030: 48 45 52 45 20 79 3d 34 3b 0a 20 20 20 20 53 45  HERE y=4;.    SE
1040: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 74 32 3b 0a  LECT * FROM t2;.
1050: 20 20 7d 0a 7d 20 7b 31 20 34 7d 0a 0a 66 69 6e    }.} {1 4}..fin
1060: 69 73 68 5f 74 65 73 74 0a                       ish_test.