/ Hex Artifact Content
Login

Artifact 56780c031b454abac2340dbb3b71ac5c56c3d7fe:


0000: 23 20 32 30 30 38 20 41 70 72 69 6c 20 31 35 0a  # 2008 April 15.
0010: 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64  #.# The author d
0020: 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67  isclaims copyrig
0030: 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63  ht to this sourc
0040: 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63  e code.  In plac
0050: 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e  e of.# a legal n
0060: 6f 74 69 63 65 27 2c 20 68 65 72 65 20 69 73 20  otice', here is 
0070: 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20  a blessing:.#.# 
0080: 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f     May you do go
0090: 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e  od and not evil.
00a0: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69  .#    May you fi
00b0: 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66  nd forgiveness f
00c0: 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20  or yourself and 
00d0: 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a  forgive others..
00e0: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61  #    May you sha
00f0: 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72  re freely, never
0100: 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61   taking more tha
0110: 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a  n 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 2a 2a 0a 23 20 54 68 69 73 20 66 69  ******.# This fi
0170: 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20 72 65  le implements re
0180: 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73 20 66  gression tests f
0190: 6f 72 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72  or SQLite librar
01a0: 79 2e 20 53 70 65 63 69 66 69 63 61 6c 6c 79 2c  y. Specifically,
01b0: 0a 23 20 69 74 20 74 65 73 74 73 20 75 70 64 61  .# it tests upda
01c0: 74 69 6e 67 20 74 61 62 6c 65 73 20 77 69 74 68  ting tables with
01d0: 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 77 69 74   constraints wit
01e0: 68 69 6e 20 61 20 74 72 69 67 67 65 72 2e 20 20  hin a trigger.  
01f0: 54 69 63 6b 65 74 20 23 33 30 35 35 2e 0a 23 0a  Ticket #3055..#.
0200: 0a 73 65 74 20 74 65 73 74 64 69 72 20 5b 66 69  .set testdir [fi
0210: 6c 65 20 64 69 72 6e 61 6d 65 20 24 61 72 67 76  le dirname $argv
0220: 30 5d 0a 73 6f 75 72 63 65 20 24 74 65 73 74 64  0].source $testd
0230: 69 72 2f 74 65 73 74 65 72 2e 74 63 6c 0a 69 66  ir/tester.tcl.if
0240: 63 61 70 61 62 6c 65 20 7b 21 74 72 69 67 67 65  capable {!trigge
0250: 72 7d 20 7b 0a 20 20 66 69 6e 69 73 68 5f 74 65  r} {.  finish_te
0260: 73 74 0a 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 23  st.  return.}..#
0270: 20 43 72 65 61 74 65 20 74 65 73 74 20 74 61 62   Create test tab
0280: 6c 65 73 20 77 69 74 68 20 63 6f 6e 73 74 72 61  les with constra
0290: 69 6e 74 73 2e 0a 23 0a 64 6f 5f 74 65 73 74 20  ints..#.do_test 
02a0: 74 72 69 67 67 65 72 42 2d 31 2e 31 20 7b 0a 20  triggerB-1.1 {. 
02b0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43   execsql {.    C
02c0: 52 45 41 54 45 20 54 41 42 4c 45 20 78 28 78 20  REATE TABLE x(x 
02d0: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20  INTEGER PRIMARY 
02e0: 4b 45 59 2c 20 79 20 49 4e 54 20 4e 4f 54 20 4e  KEY, y INT NOT N
02f0: 55 4c 4c 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  ULL);.    INSERT
0300: 20 49 4e 54 4f 20 78 28 79 29 20 56 41 4c 55 45   INTO x(y) VALUE
0310: 53 28 31 29 3b 0a 20 20 20 20 49 4e 53 45 52 54  S(1);.    INSERT
0320: 20 49 4e 54 4f 20 78 28 79 29 20 56 41 4c 55 45   INTO x(y) VALUE
0330: 53 28 31 29 3b 0a 20 20 20 20 43 52 45 41 54 45  S(1);.    CREATE
0340: 20 54 45 4d 50 20 56 49 45 57 20 76 78 20 41 53   TEMP VIEW vx AS
0350: 20 53 45 4c 45 43 54 20 78 2c 20 79 2c 20 30 20   SELECT x, y, 0 
0360: 41 53 20 79 79 20 46 52 4f 4d 20 78 3b 0a 20 20  AS yy FROM x;.  
0370: 20 20 43 52 45 41 54 45 20 54 45 4d 50 20 54 52    CREATE TEMP TR
0380: 49 47 47 45 52 20 74 78 20 49 4e 53 54 45 41 44  IGGER tx INSTEAD
0390: 20 4f 46 20 55 50 44 41 54 45 20 4f 46 20 79 20   OF UPDATE OF y 
03a0: 4f 4e 20 76 78 0a 20 20 20 20 42 45 47 49 4e 0a  ON vx.    BEGIN.
03b0: 20 20 20 20 20 20 55 50 44 41 54 45 20 78 20 53        UPDATE x S
03c0: 45 54 20 79 20 3d 20 6e 65 77 2e 79 20 57 48 45  ET y = new.y WHE
03d0: 52 45 20 78 20 3d 20 6e 65 77 2e 78 3b 0a 20 20  RE x = new.x;.  
03e0: 20 20 45 4e 44 3b 0a 20 20 20 20 53 45 4c 45 43    END;.    SELEC
03f0: 54 20 2a 20 46 52 4f 4d 20 76 78 3b 0a 20 20 7d  T * FROM vx;.  }
0400: 0a 7d 20 7b 31 20 31 20 30 20 32 20 31 20 30 7d  .} {1 1 0 2 1 0}
0410: 0a 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72  .do_test trigger
0420: 42 2d 31 2e 32 20 7b 0a 20 20 65 78 65 63 73 71  B-1.2 {.  execsq
0430: 6c 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20 76  l {.    UPDATE v
0440: 78 20 53 45 54 20 79 20 3d 20 79 79 3b 0a 20 20  x SET y = yy;.  
0450: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0460: 76 78 3b 0a 20 20 7d 0a 7d 20 7b 31 20 30 20 30  vx;.  }.} {1 0 0
0470: 20 32 20 30 20 30 7d 0a 0a 23 20 41 64 64 65 64   2 0 0}..# Added
0480: 20 32 30 30 38 2d 30 38 2d 32 32 3a 0a 23 0a 23   2008-08-22:.#.#
0490: 20 4e 61 6d 65 20 72 65 73 6f 6c 75 74 69 6f 6e   Name resolution
04a0: 20 77 69 74 68 69 6e 20 74 72 69 67 67 65 72 73   within triggers
04b0: 2e 0a 23 0a 64 6f 5f 74 65 73 74 20 74 72 69 67  ..#.do_test trig
04c0: 67 65 72 42 2d 32 2e 31 20 7b 0a 20 20 63 61 74  gerB-2.1 {.  cat
04d0: 63 68 73 71 6c 20 7b 0a 20 20 20 20 43 52 45 41  chsql {.    CREA
04e0: 54 45 20 54 52 49 47 47 45 52 20 74 79 20 41 46  TE TRIGGER ty AF
04f0: 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 78 20  TER INSERT ON x 
0500: 42 45 47 49 4e 0a 20 20 20 20 20 20 20 53 45 4c  BEGIN.       SEL
0510: 45 43 54 20 77 65 6e 2e 78 3b 20 2d 2d 20 55 6e  ECT wen.x; -- Un
0520: 72 65 63 6f 67 6e 69 7a 65 64 20 6e 61 6d 65 0a  recognized name.
0530: 20 20 20 20 45 4e 44 3b 0a 20 20 20 20 49 4e 53      END;.    INS
0540: 45 52 54 20 49 4e 54 4f 20 78 20 56 41 4c 55 45  ERT INTO x VALUE
0550: 53 28 31 2c 32 29 3b 0a 20 20 7d 0a 7d 20 7b 31  S(1,2);.  }.} {1
0560: 20 7b 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d 6e   {no such column
0570: 3a 20 77 65 6e 2e 78 7d 7d 0a 64 6f 5f 74 65 73  : wen.x}}.do_tes
0580: 74 20 74 72 69 67 67 65 72 42 2d 32 2e 32 20 7b  t triggerB-2.2 {
0590: 0a 20 20 63 61 74 63 68 73 71 6c 20 7b 0a 20 20  .  catchsql {.  
05a0: 20 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52    CREATE TRIGGER
05b0: 20 74 7a 20 41 46 54 45 52 20 55 50 44 41 54 45   tz AFTER UPDATE
05c0: 20 4f 4e 20 78 20 42 45 47 49 4e 0a 20 20 20 20   ON x BEGIN.    
05d0: 20 20 20 53 45 4c 45 43 54 20 64 6c 6f 2e 78 3b     SELECT dlo.x;
05e0: 20 2d 2d 20 55 6e 72 65 63 6f 67 6e 69 7a 65 64   -- Unrecognized
05f0: 20 6e 61 6d 65 0a 20 20 20 20 45 4e 44 3b 0a 20   name.    END;. 
0600: 20 20 20 55 50 44 41 54 45 20 78 20 53 45 54 20     UPDATE x SET 
0610: 79 3d 79 2b 31 3b 0a 20 20 7d 0a 7d 20 7b 31 20  y=y+1;.  }.} {1 
0620: 7b 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d 6e 3a  {no such column:
0630: 20 64 6c 6f 2e 78 7d 7d 0a 0a 64 6f 5f 74 65 73   dlo.x}}..do_tes
0640: 74 20 74 72 69 67 67 65 72 42 2d 32 2e 33 20 7b  t triggerB-2.3 {
0650: 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20  .  execsql {.   
0660: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 32   CREATE TABLE t2
0670: 28 61 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41  (a INTEGER PRIMA
0680: 52 59 20 4b 45 59 2c 20 62 29 3b 0a 20 20 20 20  RY KEY, b);.    
0690: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 56  INSERT INTO t2 V
06a0: 41 4c 55 45 53 28 31 2c 32 29 3b 0a 20 20 20 20  ALUES(1,2);.    
06b0: 43 52 45 41 54 45 20 54 41 42 4c 45 20 63 68 61  CREATE TABLE cha
06c0: 6e 67 65 73 28 78 2c 79 29 3b 0a 20 20 20 20 43  nges(x,y);.    C
06d0: 52 45 41 54 45 20 54 52 49 47 47 45 52 20 72 31  REATE TRIGGER r1
06e0: 74 32 20 41 46 54 45 52 20 55 50 44 41 54 45 20  t2 AFTER UPDATE 
06f0: 4f 4e 20 74 32 20 42 45 47 49 4e 0a 20 20 20 20  ON t2 BEGIN.    
0700: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 68    INSERT INTO ch
0710: 61 6e 67 65 73 20 56 41 4c 55 45 53 28 6e 65 77  anges VALUES(new
0720: 2e 61 2c 20 6e 65 77 2e 62 29 3b 0a 20 20 20 20  .a, new.b);.    
0730: 45 4e 44 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73  END;.  }.  execs
0740: 71 6c 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20  ql {.    UPDATE 
0750: 74 32 20 53 45 54 20 61 3d 61 2b 31 30 3b 0a 20  t2 SET a=a+10;. 
0760: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
0770: 20 63 68 61 6e 67 65 73 3b 0a 20 20 7d 0a 7d 20   changes;.  }.} 
0780: 7b 31 31 20 32 7d 0a 64 6f 5f 74 65 73 74 20 74  {11 2}.do_test t
0790: 72 69 67 67 65 72 42 2d 32 2e 34 20 7b 0a 20 20  riggerB-2.4 {.  
07a0: 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 43 52  execsql {.    CR
07b0: 45 41 54 45 20 54 52 49 47 47 45 52 20 72 32 74  EATE TRIGGER r2t
07c0: 32 20 41 46 54 45 52 20 44 45 4c 45 54 45 20 4f  2 AFTER DELETE O
07d0: 4e 20 74 32 20 42 45 47 49 4e 0a 20 20 20 20 20  N t2 BEGIN.     
07e0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 63 68 61   INSERT INTO cha
07f0: 6e 67 65 73 20 56 41 4c 55 45 53 28 6f 6c 64 2e  nges VALUES(old.
0800: 61 2c 20 6f 6c 64 2e 63 29 3b 0a 20 20 20 20 45  a, old.c);.    E
0810: 4e 44 3b 0a 20 20 7d 0a 20 20 63 61 74 63 68 73  ND;.  }.  catchs
0820: 71 6c 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  ql {.    DELETE 
0830: 46 52 4f 4d 20 74 32 3b 0a 20 20 7d 0a 7d 20 7b  FROM t2;.  }.} {
0840: 31 20 7b 6e 6f 20 73 75 63 68 20 63 6f 6c 75 6d  1 {no such colum
0850: 6e 3a 20 6f 6c 64 2e 63 7d 7d 0a 0a 23 20 54 72  n: old.c}}..# Tr
0860: 69 67 67 65 72 73 20 6d 61 69 6e 74 61 69 6e 20  iggers maintain 
0870: 61 20 6d 61 73 6b 20 6f 66 20 63 6f 6c 75 6d 6e  a mask of column
0880: 73 20 66 72 6f 6d 20 74 68 65 20 69 6e 76 6f 6b  s from the invok
0890: 69 6e 67 20 74 61 62 6c 65 20 74 68 61 74 20 61  ing table that a
08a0: 72 65 0a 23 20 75 73 65 64 20 69 6e 20 74 68 65  re.# used in the
08b0: 20 74 72 69 67 67 65 72 20 62 6f 64 79 20 61 73   trigger body as
08c0: 20 4e 45 57 2e 63 6f 6c 75 6d 6e 20 6f 72 20 4f   NEW.column or O
08d0: 4c 44 2e 63 6f 6c 75 6d 6e 2e 20 20 54 68 61 74  LD.column.  That
08e0: 20 6d 61 73 6b 20 69 73 20 74 68 65 6e 0a 23 20   mask is then.# 
08f0: 75 73 65 64 20 74 6f 20 72 65 64 75 63 65 20 74  used to reduce t
0900: 68 65 20 61 6d 6f 75 6e 74 20 6f 66 20 69 6e 66  he amount of inf
0910: 6f 72 6d 61 74 69 6f 6e 20 74 68 61 74 20 6e 65  ormation that ne
0920: 65 64 73 20 74 6f 20 62 65 20 6c 6f 61 64 65 64  eds to be loaded
0930: 20 69 6e 74 6f 0a 23 20 74 68 65 20 4e 45 57 20   into.# the NEW 
0940: 61 6e 64 20 4f 4c 44 20 70 73 65 75 64 6f 2d 74  and OLD pseudo-t
0950: 61 62 6c 65 73 20 61 74 20 72 75 6e 2d 74 69 6d  ables at run-tim
0960: 65 2e 0a 23 0a 23 20 54 68 65 73 65 20 74 65 73  e..#.# These tes
0970: 74 73 20 63 61 73 65 73 20 63 68 65 63 6b 20 74  ts cases check t
0980: 68 65 20 6c 6f 67 69 63 20 66 6f 72 20 77 68 65  he logic for whe
0990: 6e 20 74 68 65 72 65 20 61 72 65 20 6d 61 6e 79  n there are many
09a0: 20 63 6f 6c 75 6d 6e 73 20 2d 20 6d 6f 72 65 0a   columns - more.
09b0: 23 20 74 68 61 6e 20 77 69 6c 6c 20 66 69 74 20  # than will fit 
09c0: 69 6e 20 61 20 62 69 74 6d 61 73 6b 2e 0a 23 0a  in a bitmask..#.
09d0: 64 6f 5f 74 65 73 74 20 74 72 69 67 67 65 72 42  do_test triggerB
09e0: 2d 33 2e 31 20 7b 0a 20 20 65 78 65 63 73 71 6c  -3.1 {.  execsql
09f0: 20 7b 0a 20 20 20 20 43 52 45 41 54 45 20 54 41   {.    CREATE TA
0a00: 42 4c 45 20 74 33 28 0a 20 20 20 20 20 20 20 63  BLE t3(.       c
0a10: 30 2c 20 20 63 31 2c 20 20 63 32 2c 20 20 63 33  0,  c1,  c2,  c3
0a20: 2c 20 20 63 34 2c 20 20 63 35 2c 20 20 63 36 2c  ,  c4,  c5,  c6,
0a30: 20 20 63 37 2c 20 20 63 38 2c 20 20 63 39 2c 0a    c7,  c8,  c9,.
0a40: 20 20 20 20 20 20 20 63 31 30 2c 20 63 31 31 2c         c10, c11,
0a50: 20 63 31 32 2c 20 63 31 33 2c 20 63 31 34 2c 20   c12, c13, c14, 
0a60: 63 31 35 2c 20 63 31 36 2c 20 63 31 37 2c 20 63  c15, c16, c17, c
0a70: 31 38 2c 20 63 31 39 2c 0a 20 20 20 20 20 20 20  18, c19,.       
0a80: 63 32 30 2c 20 63 32 31 2c 20 63 32 32 2c 20 63  c20, c21, c22, c
0a90: 32 33 2c 20 63 32 34 2c 20 63 32 35 2c 20 63 32  23, c24, c25, c2
0aa0: 36 2c 20 63 32 37 2c 20 63 32 38 2c 20 63 32 39  6, c27, c28, c29
0ab0: 2c 0a 20 20 20 20 20 20 20 63 33 30 2c 20 63 33  ,.       c30, c3
0ac0: 31 2c 20 63 33 32 2c 20 63 33 33 2c 20 63 33 34  1, c32, c33, c34
0ad0: 2c 20 63 33 35 2c 20 63 33 36 2c 20 63 33 37 2c  , c35, c36, c37,
0ae0: 20 63 33 38 2c 20 63 33 39 2c 0a 20 20 20 20 20   c38, c39,.     
0af0: 20 20 63 34 30 2c 20 63 34 31 2c 20 63 34 32 2c    c40, c41, c42,
0b00: 20 63 34 33 2c 20 63 34 34 2c 20 63 34 35 2c 20   c43, c44, c45, 
0b10: 63 34 36 2c 20 63 34 37 2c 20 63 34 38 2c 20 63  c46, c47, c48, c
0b20: 34 39 2c 0a 20 20 20 20 20 20 20 63 35 30 2c 20  49,.       c50, 
0b30: 63 35 31 2c 20 63 35 32 2c 20 63 35 33 2c 20 63  c51, c52, c53, c
0b40: 35 34 2c 20 63 35 35 2c 20 63 35 36 2c 20 63 35  54, c55, c56, c5
0b50: 37 2c 20 63 35 38 2c 20 63 35 39 2c 0a 20 20 20  7, c58, c59,.   
0b60: 20 20 20 20 63 36 30 2c 20 63 36 31 2c 20 63 36      c60, c61, c6
0b70: 32 2c 20 63 36 33 2c 20 63 36 34 2c 20 63 36 35  2, c63, c64, c65
0b80: 0a 20 20 20 20 29 3b 0a 20 20 20 20 43 52 45 41  .    );.    CREA
0b90: 54 45 20 54 41 42 4c 45 20 74 33 5f 63 68 61 6e  TE TABLE t3_chan
0ba0: 67 65 73 28 63 6f 6c 6e 75 6d 2c 20 6f 6c 64 76  ges(colnum, oldv
0bb0: 61 6c 2c 20 6e 65 77 76 61 6c 29 3b 0a 20 20 20  al, newval);.   
0bc0: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 33 20   INSERT INTO t3 
0bd0: 56 41 4c 55 45 53 28 0a 20 20 20 20 20 20 20 27  VALUES(.       '
0be0: 61 30 27 2c 20 27 61 31 27 2c 20 27 61 32 27 2c  a0', 'a1', 'a2',
0bf0: 20 27 61 33 27 2c 20 27 61 34 27 2c 20 27 61 35   'a3', 'a4', 'a5
0c00: 27 2c 20 27 61 36 27 2c 20 27 61 37 27 2c 20 27  ', 'a6', 'a7', '
0c10: 61 38 27 2c 20 27 61 39 27 2c 0a 20 20 20 20 20  a8', 'a9',.     
0c20: 20 20 27 61 31 30 27 2c 27 61 31 31 27 2c 27 61    'a10','a11','a
0c30: 31 32 27 2c 27 61 31 33 27 2c 27 61 31 34 27 2c  12','a13','a14',
0c40: 27 61 31 35 27 2c 27 61 31 36 27 2c 27 61 31 37  'a15','a16','a17
0c50: 27 2c 27 61 31 38 27 2c 27 61 31 39 27 2c 0a 20  ','a18','a19',. 
0c60: 20 20 20 20 20 20 27 61 32 30 27 2c 27 61 32 31        'a20','a21
0c70: 27 2c 27 61 32 32 27 2c 27 61 32 33 27 2c 27 61  ','a22','a23','a
0c80: 32 34 27 2c 27 61 32 35 27 2c 27 61 32 36 27 2c  24','a25','a26',
0c90: 27 61 32 37 27 2c 27 61 32 38 27 2c 27 61 32 39  'a27','a28','a29
0ca0: 27 2c 0a 20 20 20 20 20 20 20 27 61 33 30 27 2c  ',.       'a30',
0cb0: 27 61 33 31 27 2c 27 61 33 32 27 2c 27 61 33 33  'a31','a32','a33
0cc0: 27 2c 27 61 33 34 27 2c 27 61 33 35 27 2c 27 61  ','a34','a35','a
0cd0: 33 36 27 2c 27 61 33 37 27 2c 27 61 33 38 27 2c  36','a37','a38',
0ce0: 27 61 33 39 27 2c 0a 20 20 20 20 20 20 20 27 61  'a39',.       'a
0cf0: 34 30 27 2c 27 61 34 31 27 2c 27 61 34 32 27 2c  40','a41','a42',
0d00: 27 61 34 33 27 2c 27 61 34 34 27 2c 27 61 34 35  'a43','a44','a45
0d10: 27 2c 27 61 34 36 27 2c 27 61 34 37 27 2c 27 61  ','a46','a47','a
0d20: 34 38 27 2c 27 61 34 39 27 2c 0a 20 20 20 20 20  48','a49',.     
0d30: 20 20 27 61 35 30 27 2c 27 61 35 31 27 2c 27 61    'a50','a51','a
0d40: 35 32 27 2c 27 61 35 33 27 2c 27 61 35 34 27 2c  52','a53','a54',
0d50: 27 61 35 35 27 2c 27 61 35 36 27 2c 27 61 35 37  'a55','a56','a57
0d60: 27 2c 27 61 35 38 27 2c 27 61 35 39 27 2c 0a 20  ','a58','a59',. 
0d70: 20 20 20 20 20 20 27 61 36 30 27 2c 27 61 36 31        'a60','a61
0d80: 27 2c 27 61 36 32 27 2c 27 61 36 33 27 2c 27 61  ','a62','a63','a
0d90: 36 34 27 2c 27 61 36 35 27 0a 20 20 20 20 29 3b  64','a65'.    );
0da0: 0a 20 20 7d 0a 20 20 66 6f 72 20 7b 73 65 74 20  .  }.  for {set 
0db0: 69 20 30 7d 20 7b 24 69 3c 3d 36 35 7d 20 7b 69  i 0} {$i<=65} {i
0dc0: 6e 63 72 20 69 7d 20 7b 0a 20 20 20 20 73 65 74  ncr i} {.    set
0dd0: 20 73 71 6c 20 5b 73 75 62 73 74 20 7b 0a 20 20   sql [subst {.  
0de0: 20 20 20 20 43 52 45 41 54 45 20 54 52 49 47 47      CREATE TRIGG
0df0: 45 52 20 74 33 63 24 69 20 41 46 54 45 52 20 55  ER t3c$i AFTER U
0e00: 50 44 41 54 45 20 4f 4e 20 74 33 0a 20 20 20 20  PDATE ON t3.    
0e10: 20 20 20 20 20 57 48 45 4e 20 6f 6c 64 2e 63 24       WHEN old.c$
0e20: 69 21 3d 6e 65 77 2e 63 24 69 20 42 45 47 49 4e  i!=new.c$i BEGIN
0e30: 0a 20 20 20 20 20 20 20 20 20 20 49 4e 53 45 52  .          INSER
0e40: 54 20 49 4e 54 4f 20 74 33 5f 63 68 61 6e 67 65  T INTO t3_change
0e50: 73 20 56 41 4c 55 45 53 28 24 69 2c 20 6f 6c 64  s VALUES($i, old
0e60: 2e 63 24 69 2c 20 6e 65 77 2e 63 24 69 29 3b 0a  .c$i, new.c$i);.
0e70: 20 20 20 20 20 20 45 4e 44 0a 20 20 20 20 7d 5d        END.    }]
0e80: 0a 20 20 20 20 64 62 20 65 76 61 6c 20 24 73 71  .    db eval $sq
0e90: 6c 0a 20 20 7d 0a 20 20 65 78 65 63 73 71 6c 20  l.  }.  execsql 
0ea0: 7b 0a 20 20 20 20 53 45 4c 45 43 54 20 2a 20 46  {.    SELECT * F
0eb0: 52 4f 4d 20 74 33 5f 63 68 61 6e 67 65 73 0a 20  ROM t3_changes. 
0ec0: 20 7d 0a 7d 20 7b 7d 0a 66 6f 72 20 7b 73 65 74   }.} {}.for {set
0ed0: 20 69 20 30 7d 20 7b 24 69 3c 3d 36 34 7d 20 7b   i 0} {$i<=64} {
0ee0: 69 6e 63 72 20 69 7d 20 7b 0a 20 20 64 6f 5f 74  incr i} {.  do_t
0ef0: 65 73 74 20 74 72 69 67 67 65 72 42 2d 33 2e 32  est triggerB-3.2
0f00: 2e 24 69 2e 31 20 5b 73 75 62 73 74 20 7b 0a 20  .$i.1 [subst {. 
0f10: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
0f20: 20 20 20 55 50 44 41 54 45 20 74 33 20 53 45 54     UPDATE t3 SET
0f30: 20 63 24 69 3d 27 62 24 69 27 3b 0a 20 20 20 20   c$i='b$i';.    
0f40: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
0f50: 74 33 5f 63 68 61 6e 67 65 73 20 4f 52 44 45 52  t3_changes ORDER
0f60: 20 42 59 20 72 6f 77 69 64 20 44 45 53 43 20 4c   BY rowid DESC L
0f70: 49 4d 49 54 20 31 3b 0a 20 20 20 20 7d 0a 20 20  IMIT 1;.    }.  
0f80: 7d 5d 20 5b 73 75 62 73 74 20 7b 24 69 20 61 24  }] [subst {$i a$
0f90: 69 20 62 24 69 7d 5d 0a 20 20 64 6f 5f 74 65 73  i b$i}].  do_tes
0fa0: 74 20 74 72 69 67 67 65 72 42 2d 33 2e 32 2e 24  t triggerB-3.2.$
0fb0: 69 2e 32 20 5b 73 75 62 73 74 20 7b 0a 20 20 20  i.2 [subst {.   
0fc0: 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20 20 20   execsql {.     
0fd0: 20 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29   SELECT count(*)
0fe0: 20 46 52 4f 4d 20 74 33 5f 63 68 61 6e 67 65 73   FROM t3_changes
0ff0: 0a 20 20 20 20 7d 0a 20 20 7d 5d 20 5b 65 78 70  .    }.  }] [exp
1000: 72 20 7b 24 69 2b 31 7d 5d 0a 20 20 64 6f 5f 74  r {$i+1}].  do_t
1010: 65 73 74 20 74 72 69 67 67 65 72 42 2d 33 2e 32  est triggerB-3.2
1020: 2e 24 69 2e 32 20 5b 73 75 62 73 74 20 7b 0a 20  .$i.2 [subst {. 
1030: 20 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20 20     execsql {.   
1040: 20 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d     SELECT * FROM
1050: 20 74 33 5f 63 68 61 6e 67 65 73 20 57 48 45 52   t3_changes WHER
1060: 45 20 63 6f 6c 6e 75 6d 3d 24 69 0a 20 20 20 20  E colnum=$i.    
1070: 7d 0a 20 20 7d 5d 20 5b 73 75 62 73 74 20 7b 24  }.  }] [subst {$
1080: 69 20 61 24 69 20 62 24 69 7d 5d 0a 7d 0a 20 20  i a$i b$i}].}.  
1090: 0a 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a        ..finish_test.