/ Hex Artifact Content
Login

Artifact c4fb7f8a688787111606e123a555f18ee04f65bb9f2a4bb2aa71d55ce4e6d02c:


0000: 23 20 32 30 31 34 20 41 75 67 75 73 74 20 31 36  # 2014 August 16
0010: 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20  .#.# The author 
0020: 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69  disclaims copyri
0030: 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72  ght to this sour
0040: 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61  ce code.  In pla
0050: 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20  ce of.# a legal 
0060: 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73 20  notice, 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 0a 23 20 54 68 69 73 20  ******.#.# This 
0170: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0180: 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74 73  regression tests
0190: 20 66 6f 72 20 73 65 73 73 69 6f 6e 73 20 53 51   for sessions SQ
01a0: 4c 69 74 65 20 65 78 74 65 6e 73 69 6f 6e 2e 0a  Lite extension..
01b0: 23 20 53 70 65 63 69 66 69 63 61 6c 6c 79 2c 20  # Specifically, 
01c0: 74 68 69 73 20 66 69 6c 65 20 63 6f 6e 74 61 69  this file contai
01d0: 6e 73 20 74 65 73 74 73 20 66 6f 72 20 22 70 61  ns tests for "pa
01e0: 74 63 68 73 65 74 22 20 63 68 61 6e 67 65 73 2e  tchset" changes.
01f0: 0a 23 0a 0a 69 66 20 7b 21 5b 69 6e 66 6f 20 65  .#..if {![info e
0200: 78 69 73 74 73 20 74 65 73 74 64 69 72 5d 7d 20  xists testdir]} 
0210: 7b 0a 20 20 73 65 74 20 74 65 73 74 64 69 72 20  {.  set testdir 
0220: 5b 66 69 6c 65 20 6a 6f 69 6e 20 5b 66 69 6c 65  [file join [file
0230: 20 64 69 72 6e 61 6d 65 20 5b 69 6e 66 6f 20 73   dirname [info s
0240: 63 72 69 70 74 5d 5d 20 2e 2e 20 2e 2e 20 74 65  cript]] .. .. te
0250: 73 74 5d 0a 7d 20 0a 73 6f 75 72 63 65 20 5b 66  st].} .source [f
0260: 69 6c 65 20 6a 6f 69 6e 20 5b 66 69 6c 65 20 64  ile join [file d
0270: 69 72 6e 61 6d 65 20 5b 69 6e 66 6f 20 73 63 72  irname [info scr
0280: 69 70 74 5d 5d 20 73 65 73 73 69 6f 6e 5f 63 6f  ipt]] session_co
0290: 6d 6d 6f 6e 2e 74 63 6c 5d 0a 73 6f 75 72 63 65  mmon.tcl].source
02a0: 20 24 74 65 73 74 64 69 72 2f 74 65 73 74 65 72   $testdir/tester
02b0: 2e 74 63 6c 0a 69 66 63 61 70 61 62 6c 65 20 21  .tcl.ifcapable !
02c0: 73 65 73 73 69 6f 6e 20 7b 66 69 6e 69 73 68 5f  session {finish_
02d0: 74 65 73 74 3b 20 72 65 74 75 72 6e 7d 0a 0a 73  test; return}..s
02e0: 65 74 20 74 65 73 74 70 72 65 66 69 78 20 73 65  et testprefix se
02f0: 73 73 69 6f 6e 42 0a 0a 23 0a 23 20 31 2e 2a 3a  ssionB..#.# 1.*:
0300: 20 54 65 73 74 20 74 68 61 74 20 74 68 65 20 62   Test that the b
0310: 6c 6f 62 73 20 72 65 74 75 72 6e 65 64 20 62 79  lobs returned by
0320: 20 74 68 65 20 73 65 73 73 69 6f 6e 5f 70 61 74   the session_pat
0330: 63 68 73 65 74 28 29 20 41 50 49 20 61 72 65 20  chset() API are 
0340: 0a 23 20 20 20 20 20 20 61 73 20 65 78 70 65 63  .#      as expec
0350: 74 65 64 2e 20 41 6c 73 6f 20 74 68 65 20 73 71  ted. Also the sq
0360: 6c 69 74 65 33 5f 63 68 61 6e 67 65 73 65 74 5f  lite3_changeset_
0370: 69 74 65 72 20 66 75 6e 63 74 69 6f 6e 73 2e 0a  iter functions..
0380: 23 0a 23 20 32 2e 2a 3a 20 54 65 73 74 20 74 68  #.# 2.*: Test th
0390: 61 74 20 70 61 74 63 68 73 65 74 20 62 6c 6f 62  at patchset blob
03a0: 73 20 61 72 65 20 68 61 6e 64 6c 65 64 20 62 79  s are handled by
03b0: 20 73 71 6c 69 74 65 33 63 68 61 6e 67 65 73 65   sqlite3changese
03c0: 74 5f 61 70 70 6c 79 28 29 2e 0a 23 0a 23 20 33  t_apply()..#.# 3
03d0: 2e 2a 3a 20 54 65 73 74 20 74 68 61 74 20 73 71  .*: Test that sq
03e0: 6c 69 74 65 33 63 68 61 6e 67 65 73 65 74 5f 69  lite3changeset_i
03f0: 6e 76 65 72 74 28 29 20 77 6f 72 6b 73 20 77 69  nvert() works wi
0400: 74 68 20 70 61 74 63 68 73 65 74 20 62 6c 6f 62  th patchset blob
0410: 73 2e 20 0a 23 20 20 20 20 20 20 43 6f 72 72 65  s. .#      Corre
0420: 63 74 20 62 65 68 61 76 69 6f 75 72 20 69 73 20  ct behaviour is 
0430: 74 6f 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  to return SQLITE
0440: 5f 43 4f 52 52 55 50 54 2e 0a 0a 70 72 6f 63 20  _CORRUPT...proc 
0450: 64 6f 5f 73 71 6c 32 70 61 74 63 68 73 65 74 5f  do_sql2patchset_
0460: 74 65 73 74 20 7b 74 6e 20 73 71 6c 20 72 65 73  test {tn sql res
0470: 7d 20 7b 0a 20 20 73 71 6c 69 74 65 33 73 65 73  } {.  sqlite3ses
0480: 73 69 6f 6e 20 53 20 64 62 20 6d 61 69 6e 0a 20  sion S db main. 
0490: 20 53 20 61 74 74 61 63 68 20 2a 0a 20 20 65 78   S attach *.  ex
04a0: 65 63 73 71 6c 20 24 73 71 6c 0a 20 20 75 70 6c  ecsql $sql.  upl
04b0: 65 76 65 6c 20 5b 6c 69 73 74 20 64 6f 5f 70 61  evel [list do_pa
04c0: 74 63 68 73 65 74 5f 74 65 73 74 20 24 74 6e 20  tchset_test $tn 
04d0: 53 20 24 72 65 73 5d 0a 20 20 53 20 64 65 6c 65  S $res].  S dele
04e0: 74 65 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  te.}..#---------
04f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0500: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0510: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0520: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0530: 0a 23 20 52 75 6e 20 73 69 6d 70 6c 65 20 74 65  .# Run simple te
0540: 73 74 73 20 6f 66 20 74 68 65 20 5f 70 61 74 63  sts of the _patc
0550: 68 73 65 74 28 29 20 41 50 49 2e 0a 23 0a 64 6f  hset() API..#.do
0560: 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 31 2e  _execsql_test 1.
0570: 30 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  0 {.  CREATE TAB
0580: 4c 45 20 74 31 28 61 2c 20 62 2c 20 63 2c 20 64  LE t1(a, b, c, d
0590: 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28 64 2c  , PRIMARY KEY(d,
05a0: 20 61 29 29 3b 0a 20 20 49 4e 53 45 52 54 20 49   a));.  INSERT I
05b0: 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 2c  NTO t1 VALUES(1,
05c0: 20 32 2c 20 33 2c 20 34 29 3b 0a 20 20 49 4e 53   2, 3, 4);.  INS
05d0: 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55  ERT INTO t1 VALU
05e0: 45 53 28 35 2c 20 36 2c 20 37 2c 20 38 29 3b 0a  ES(5, 6, 7, 8);.
05f0: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
0600: 20 56 41 4c 55 45 53 28 39 2c 20 31 30 2c 20 31   VALUES(9, 10, 1
0610: 31 2c 20 31 32 29 3b 0a 7d 0a 0a 64 6f 5f 74 65  1, 12);.}..do_te
0620: 73 74 20 31 2e 31 20 7b 0a 20 20 73 71 6c 69 74  st 1.1 {.  sqlit
0630: 65 33 73 65 73 73 69 6f 6e 20 53 20 64 62 20 6d  e3session S db m
0640: 61 69 6e 0a 20 20 53 20 61 74 74 61 63 68 20 74  ain.  S attach t
0650: 31 0a 20 20 65 78 65 63 73 71 6c 20 7b 0a 20 20  1.  execsql {.  
0660: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
0670: 20 56 41 4c 55 45 53 28 27 77 27 2c 20 27 78 27   VALUES('w', 'x'
0680: 2c 20 27 79 27 2c 20 27 7a 27 29 3b 0a 20 20 20  , 'y', 'z');.   
0690: 20 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 20   DELETE FROM t1 
06a0: 57 48 45 52 45 20 64 3d 34 3b 0a 20 20 20 20 55  WHERE d=4;.    U
06b0: 50 44 41 54 45 20 74 31 20 53 45 54 20 63 20 3d  PDATE t1 SET c =
06c0: 20 31 34 20 57 48 45 52 45 20 61 3d 35 3b 0a 20   14 WHERE a=5;. 
06d0: 20 7d 0a 7d 20 7b 7d 0a 0a 64 6f 5f 70 61 74 63   }.} {}..do_patc
06e0: 68 73 65 74 5f 74 65 73 74 20 31 2e 32 20 53 20  hset_test 1.2 S 
06f0: 7b 0a 20 20 7b 55 50 44 41 54 45 20 74 31 20 30  {.  {UPDATE t1 0
0700: 20 58 2e 2e 58 20 7b 69 20 35 20 7b 7d 20 7b 7d   X..X {i 5 {} {}
0710: 20 7b 7d 20 7b 7d 20 69 20 38 7d 20 7b 7b 7d 20   {} {} i 8} {{} 
0720: 7b 7d 20 7b 7d 20 7b 7d 20 69 20 31 34 20 7b 7d  {} {} {} i 14 {}
0730: 20 7b 7d 7d 7d 0a 20 20 7b 49 4e 53 45 52 54 20   {}}}.  {INSERT 
0740: 74 31 20 30 20 58 2e 2e 58 20 7b 7d 20 7b 74 20  t1 0 X..X {} {t 
0750: 77 20 74 20 78 20 74 20 79 20 74 20 7a 7d 7d 0a  w t x t y t z}}.
0760: 20 20 7b 44 45 4c 45 54 45 20 74 31 20 30 20 58    {DELETE t1 0 X
0770: 2e 2e 58 20 7b 69 20 31 20 7b 7d 20 7b 7d 20 7b  ..X {i 1 {} {} {
0780: 7d 20 7b 7d 20 69 20 34 7d 20 7b 7d 7d 0a 7d 0a  } {} i 4} {}}.}.
0790: 0a 64 6f 5f 74 65 73 74 20 31 2e 33 20 7b 0a 20  .do_test 1.3 {. 
07a0: 20 53 20 64 65 6c 65 74 65 0a 7d 20 7b 7d 0a 0a   S delete.} {}..
07b0: 64 6f 5f 73 71 6c 32 70 61 74 63 68 73 65 74 5f  do_sql2patchset_
07c0: 74 65 73 74 20 31 2e 34 20 7b 0a 20 20 44 45 4c  test 1.4 {.  DEL
07d0: 45 54 45 20 46 52 4f 4d 20 74 31 3b 0a 7d 20 7b  ETE FROM t1;.} {
07e0: 0a 20 20 7b 44 45 4c 45 54 45 20 74 31 20 30 20  .  {DELETE t1 0 
07f0: 58 2e 2e 58 20 7b 69 20 35 20 7b 7d 20 7b 7d 20  X..X {i 5 {} {} 
0800: 7b 7d 20 7b 7d 20 69 20 38 7d 20 7b 7d 7d 0a 20  {} {} i 8} {}}. 
0810: 20 7b 44 45 4c 45 54 45 20 74 31 20 30 20 58 2e   {DELETE t1 0 X.
0820: 2e 58 20 7b 74 20 77 20 7b 7d 20 7b 7d 20 7b 7d  .X {t w {} {} {}
0830: 20 7b 7d 20 74 20 7a 7d 20 7b 7d 7d 0a 20 20 7b   {} t z} {}}.  {
0840: 44 45 4c 45 54 45 20 74 31 20 30 20 58 2e 2e 58  DELETE t1 0 X..X
0850: 20 7b 69 20 39 20 7b 7d 20 7b 7d 20 7b 7d 20 7b   {i 9 {} {} {} {
0860: 7d 20 69 20 31 32 7d 20 7b 7d 7d 0a 7d 0a 0a 64  } i 12} {}}.}..d
0870: 6f 5f 73 71 6c 32 70 61 74 63 68 73 65 74 5f 74  o_sql2patchset_t
0880: 65 73 74 20 31 2e 35 20 7b 0a 20 20 49 4e 53 45  est 1.5 {.  INSE
0890: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
08a0: 53 28 58 27 36 31 36 32 36 33 36 34 27 2c 20 4e  S(X'61626364', N
08b0: 55 4c 4c 2c 20 4e 55 4c 4c 2c 20 34 2e 32 29 3b  ULL, NULL, 4.2);
08c0: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  .  INSERT INTO t
08d0: 31 20 56 41 4c 55 45 53 28 34 2e 32 2c 20 4e 55  1 VALUES(4.2, NU
08e0: 4c 4c 2c 20 4e 55 4c 4c 2c 20 58 27 36 31 36 32  LL, NULL, X'6162
08f0: 36 33 36 34 27 29 3b 0a 7d 20 7b 0a 20 20 7b 49  6364');.} {.  {I
0900: 4e 53 45 52 54 20 74 31 20 30 20 58 2e 2e 58 20  NSERT t1 0 X..X 
0910: 7b 7d 20 7b 66 20 34 2e 32 20 6e 20 7b 7d 20 6e  {} {f 4.2 n {} n
0920: 20 7b 7d 20 62 20 61 62 63 64 7d 7d 20 0a 20 20   {} b abcd}} .  
0930: 7b 49 4e 53 45 52 54 20 74 31 20 30 20 58 2e 2e  {INSERT t1 0 X..
0940: 58 20 7b 7d 20 7b 62 20 61 62 63 64 20 6e 20 7b  X {} {b abcd n {
0950: 7d 20 6e 20 7b 7d 20 66 20 34 2e 32 7d 7d 0a 7d  } n {} f 4.2}}.}
0960: 0a 0a 64 6f 5f 73 71 6c 32 70 61 74 63 68 73 65  ..do_sql2patchse
0970: 74 5f 74 65 73 74 20 31 2e 36 20 7b 0a 20 20 55  t_test 1.6 {.  U
0980: 50 44 41 54 45 20 74 31 20 53 45 54 20 62 3d 34  PDATE t1 SET b=4
0990: 35 20 57 48 45 52 45 20 74 79 70 65 6f 66 28 61  5 WHERE typeof(a
09a0: 29 3d 3d 27 62 6c 6f 62 27 3b 0a 20 20 55 50 44  )=='blob';.  UPD
09b0: 41 54 45 20 74 31 20 53 45 54 20 63 3d 27 7a 7a  ATE t1 SET c='zz
09c0: 7a 7a 27 20 57 48 45 52 45 20 74 79 70 65 6f 66  zz' WHERE typeof
09d0: 28 61 29 21 3d 27 62 6c 6f 62 27 3b 0a 7d 20 7b  (a)!='blob';.} {
09e0: 0a 20 20 7b 55 50 44 41 54 45 20 74 31 20 30 20  .  {UPDATE t1 0 
09f0: 58 2e 2e 58 20 7b 66 20 34 2e 32 20 7b 7d 20 7b  X..X {f 4.2 {} {
0a00: 7d 20 7b 7d 20 7b 7d 20 62 20 61 62 63 64 7d 20  } {} {} b abcd} 
0a10: 7b 7b 7d 20 7b 7d 20 7b 7d 20 7b 7d 20 74 20 7a  {{} {} {} {} t z
0a20: 7a 7a 7a 20 7b 7d 20 7b 7d 7d 7d 0a 20 20 7b 55  zzz {} {}}}.  {U
0a30: 50 44 41 54 45 20 74 31 20 30 20 58 2e 2e 58 20  PDATE t1 0 X..X 
0a40: 7b 62 20 61 62 63 64 20 7b 7d 20 7b 7d 20 7b 7d  {b abcd {} {} {}
0a50: 20 7b 7d 20 66 20 34 2e 32 7d 20 7b 7b 7d 20 7b   {} f 4.2} {{} {
0a60: 7d 20 69 20 34 35 20 7b 7d 20 7b 7d 20 7b 7d 20  } i 45 {} {} {} 
0a70: 7b 7d 7d 7d 0a 7d 0a 0a 64 6f 5f 73 71 6c 32 70  {}}}.}..do_sql2p
0a80: 61 74 63 68 73 65 74 5f 74 65 73 74 20 31 2e 37  atchset_test 1.7
0a90: 20 7b 0a 20 20 55 50 44 41 54 45 20 74 31 20 53   {.  UPDATE t1 S
0aa0: 45 54 20 62 3d 27 78 79 7a 27 20 57 48 45 52 45  ET b='xyz' WHERE
0ab0: 20 74 79 70 65 6f 66 28 61 29 3d 3d 27 62 6c 6f   typeof(a)=='blo
0ac0: 62 27 3b 0a 20 20 55 50 44 41 54 45 20 74 31 20  b';.  UPDATE t1 
0ad0: 53 45 54 20 63 3d 27 78 79 7a 27 20 57 48 45 52  SET c='xyz' WHER
0ae0: 45 20 74 79 70 65 6f 66 28 61 29 21 3d 27 62 6c  E typeof(a)!='bl
0af0: 6f 62 27 3b 0a 20 20 55 50 44 41 54 45 20 74 31  ob';.  UPDATE t1
0b00: 20 53 45 54 20 62 3d 34 35 20 57 48 45 52 45 20   SET b=45 WHERE 
0b10: 74 79 70 65 6f 66 28 61 29 3d 3d 27 62 6c 6f 62  typeof(a)=='blob
0b20: 27 3b 0a 20 20 55 50 44 41 54 45 20 74 31 20 53  ';.  UPDATE t1 S
0b30: 45 54 20 63 3d 27 7a 7a 7a 7a 27 20 57 48 45 52  ET c='zzzz' WHER
0b40: 45 20 74 79 70 65 6f 66 28 61 29 21 3d 27 62 6c  E typeof(a)!='bl
0b50: 6f 62 27 3b 0a 7d 20 7b 0a 7d 0a 0a 64 6f 5f 73  ob';.} {.}..do_s
0b60: 71 6c 32 70 61 74 63 68 73 65 74 5f 74 65 73 74  ql2patchset_test
0b70: 20 31 2e 38 20 7b 0a 20 20 44 45 4c 45 54 45 20   1.8 {.  DELETE 
0b80: 46 52 4f 4d 20 74 31 3b 0a 7d 20 7b 0a 20 20 7b  FROM t1;.} {.  {
0b90: 44 45 4c 45 54 45 20 74 31 20 30 20 58 2e 2e 58  DELETE t1 0 X..X
0ba0: 20 7b 66 20 34 2e 32 20 7b 7d 20 7b 7d 20 7b 7d   {f 4.2 {} {} {}
0bb0: 20 7b 7d 20 62 20 61 62 63 64 7d 20 7b 7d 7d 20   {} b abcd} {}} 
0bc0: 0a 20 20 7b 44 45 4c 45 54 45 20 74 31 20 30 20  .  {DELETE t1 0 
0bd0: 58 2e 2e 58 20 7b 62 20 61 62 63 64 20 7b 7d 20  X..X {b abcd {} 
0be0: 7b 7d 20 7b 7d 20 7b 7d 20 66 20 34 2e 32 7d 20  {} {} {} f 4.2} 
0bf0: 7b 7d 7d 0a 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d  {}}.}..#--------
0c00: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c20: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0c40: 2d 0a 23 20 52 75 6e 20 73 69 6d 70 6c 65 20 74  -.# Run simple t
0c50: 65 73 74 73 20 6f 66 20 5f 61 70 70 6c 79 28 29  ests of _apply()
0c60: 20 77 69 74 68 20 70 61 74 63 68 73 65 74 20 6f   with patchset o
0c70: 62 6a 65 63 74 73 2e 0a 23 0a 72 65 73 65 74 5f  bjects..#.reset_
0c80: 64 62 0a 0a 70 72 6f 63 20 6e 6f 6f 70 20 7b 61  db..proc noop {a
0c90: 72 67 73 7d 20 7b 20 65 72 72 6f 72 20 24 61 72  rgs} { error $ar
0ca0: 67 73 20 7d 0a 70 72 6f 63 20 65 78 65 63 5f 72  gs }.proc exec_r
0cb0: 6f 6c 6c 62 61 63 6b 5f 72 65 70 6c 61 79 20 7b  ollback_replay {
0cc0: 73 71 6c 7d 20 7b 0a 20 20 73 71 6c 69 74 65 33  sql} {.  sqlite3
0cd0: 73 65 73 73 69 6f 6e 20 53 20 64 62 20 6d 61 69  session S db mai
0ce0: 6e 0a 20 20 53 20 61 74 74 61 63 68 20 2a 0a 20  n.  S attach *. 
0cf0: 20 65 78 65 63 73 71 6c 20 42 45 47 49 4e 0a 20   execsql BEGIN. 
0d00: 20 65 78 65 63 73 71 6c 20 24 73 71 6c 0a 20 20   execsql $sql.  
0d10: 73 65 74 20 70 61 74 63 68 73 65 74 20 5b 53 20  set patchset [S 
0d20: 70 61 74 63 68 73 65 74 5d 0a 20 20 53 20 64 65  patchset].  S de
0d30: 6c 65 74 65 0a 20 20 65 78 65 63 73 71 6c 20 52  lete.  execsql R
0d40: 4f 4c 4c 42 41 43 4b 0a 20 20 73 71 6c 69 74 65  OLLBACK.  sqlite
0d50: 33 63 68 61 6e 67 65 73 65 74 5f 61 70 70 6c 79  3changeset_apply
0d60: 20 64 62 20 24 70 61 74 63 68 73 65 74 20 6e 6f   db $patchset no
0d70: 6f 70 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73 71 6c  op.}..do_execsql
0d80: 5f 74 65 73 74 20 32 2e 30 20 7b 0a 20 20 43 52  _test 2.0 {.  CR
0d90: 45 41 54 45 20 54 41 42 4c 45 20 74 32 28 61 2c  EATE TABLE t2(a,
0da0: 20 62 2c 20 63 2c 20 64 2c 20 50 52 49 4d 41 52   b, c, d, PRIMAR
0db0: 59 20 4b 45 59 28 62 2c 63 29 29 3b 0a 20 20 43  Y KEY(b,c));.  C
0dc0: 52 45 41 54 45 20 54 41 42 4c 45 20 74 33 28 77  REATE TABLE t3(w
0dd0: 2c 20 78 2c 20 79 2c 20 7a 2c 20 50 52 49 4d 41  , x, y, z, PRIMA
0de0: 52 59 20 4b 45 59 28 77 29 29 3b 0a 7d 0a 0a 64  RY KEY(w));.}..d
0df0: 6f 5f 74 65 73 74 20 32 2e 31 20 7b 0a 20 20 65  o_test 2.1 {.  e
0e00: 78 65 63 5f 72 6f 6c 6c 62 61 63 6b 5f 72 65 70  xec_rollback_rep
0e10: 6c 61 79 20 7b 0a 20 20 20 20 49 4e 53 45 52 54  lay {.    INSERT
0e20: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
0e30: 31 2c 20 32 2c 20 33 2c 20 34 29 3b 0a 20 20 20  1, 2, 3, 4);.   
0e40: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20   INSERT INTO t2 
0e50: 56 41 4c 55 45 53 28 27 77 27 2c 20 27 78 27 2c  VALUES('w', 'x',
0e60: 20 27 79 27 2c 20 27 7a 27 29 3b 0a 20 20 7d 0a   'y', 'z');.  }.
0e70: 20 20 65 78 65 63 73 71 6c 20 7b 20 53 45 4c 45    execsql { SELE
0e80: 43 54 20 2a 20 46 52 4f 4d 20 74 32 20 7d 0a 7d  CT * FROM t2 }.}
0e90: 20 7b 31 20 32 20 33 20 34 20 77 20 78 20 79 20   {1 2 3 4 w x y 
0ea0: 7a 7d 0a 0a 64 6f 5f 74 65 73 74 20 32 2e 32 20  z}..do_test 2.2 
0eb0: 7b 0a 20 20 65 78 65 63 5f 72 6f 6c 6c 62 61 63  {.  exec_rollbac
0ec0: 6b 5f 72 65 70 6c 61 79 20 7b 0a 20 20 20 20 44  k_replay {.    D
0ed0: 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48  ELETE FROM t2 WH
0ee0: 45 52 45 20 61 3d 31 3b 0a 20 20 20 20 55 50 44  ERE a=1;.    UPD
0ef0: 41 54 45 20 74 32 20 53 45 54 20 64 20 3d 20 27  ATE t2 SET d = '
0f00: 61 27 3b 0a 20 20 7d 0a 20 20 65 78 65 63 73 71  a';.  }.  execsq
0f10: 6c 20 7b 20 53 45 4c 45 43 54 20 2a 20 46 52 4f  l { SELECT * FRO
0f20: 4d 20 74 32 20 7d 0a 7d 20 7b 77 20 78 20 79 20  M t2 }.} {w x y 
0f30: 61 7d 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  a}..#-----------
0f40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0f70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23  --------------.#
0f80: 20 73 71 6c 69 74 65 33 63 68 61 6e 67 65 73 65   sqlite3changese
0f90: 74 5f 69 6e 76 65 72 74 28 29 0a 23 0a 72 65 73  t_invert().#.res
0fa0: 65 74 5f 64 62 0a 0a 64 6f 5f 65 78 65 63 73 71  et_db..do_execsq
0fb0: 6c 5f 74 65 73 74 20 33 2e 31 20 7b 20 43 52 45  l_test 3.1 { CRE
0fc0: 41 54 45 20 54 41 42 4c 45 20 74 31 28 78 20 50  ATE TABLE t1(x P
0fd0: 52 49 4d 41 52 59 20 4b 45 59 2c 20 79 29 20 7d  RIMARY KEY, y) }
0fe0: 0a 64 6f 5f 74 65 73 74 20 33 2e 32 20 7b 0a 20  .do_test 3.2 {. 
0ff0: 20 73 71 6c 69 74 65 33 73 65 73 73 69 6f 6e 20   sqlite3session 
1000: 53 20 64 62 20 6d 61 69 6e 0a 20 20 53 20 61 74  S db main.  S at
1010: 74 61 63 68 20 2a 0a 20 20 65 78 65 63 73 71 6c  tach *.  execsql
1020: 20 7b 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74   { INSERT INTO t
1030: 31 20 56 41 4c 55 45 53 28 31 2c 20 32 29 20 7d  1 VALUES(1, 2) }
1040: 0a 20 20 73 65 74 20 70 61 74 63 68 73 65 74 20  .  set patchset 
1050: 5b 53 20 70 61 74 63 68 73 65 74 5d 0a 20 20 53  [S patchset].  S
1060: 20 64 65 6c 65 74 65 0a 20 20 6c 69 73 74 20 5b   delete.  list [
1070: 63 61 74 63 68 20 7b 20 73 71 6c 69 74 65 33 63  catch { sqlite3c
1080: 68 61 6e 67 65 73 65 74 5f 69 6e 76 65 72 74 20  hangeset_invert 
1090: 24 70 61 74 63 68 73 65 74 20 7d 20 6d 73 67 5d  $patchset } msg]
10a0: 20 5b 73 65 74 20 6d 73 67 5d 0a 7d 20 7b 31 20   [set msg].} {1 
10b0: 53 51 4c 49 54 45 5f 43 4f 52 52 55 50 54 7d 0a  SQLITE_CORRUPT}.
10c0: 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..#-------------
10d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
10e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
10f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1100: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 73  ------------.# s
1110: 71 6c 69 74 65 33 63 68 61 6e 67 65 73 65 74 5f  qlite3changeset_
1120: 63 6f 6e 63 61 74 28 29 0a 23 0a 72 65 73 65 74  concat().#.reset
1130: 5f 64 62 0a 0a 70 72 6f 63 20 64 6f 5f 70 61 74  _db..proc do_pat
1140: 63 68 63 6f 6e 63 61 74 5f 74 65 73 74 20 7b 74  chconcat_test {t
1150: 6e 20 61 72 67 73 7d 20 7b 0a 20 20 73 65 74 20  n args} {.  set 
1160: 62 52 65 76 65 72 74 20 30 0a 20 20 69 66 20 7b  bRevert 0.  if {
1170: 5b 6c 69 6e 64 65 78 20 24 61 72 67 73 20 30 5d  [lindex $args 0]
1180: 20 3d 3d 20 22 2d 72 65 76 65 72 74 22 7d 20 7b   == "-revert"} {
1190: 0a 20 20 20 20 73 65 74 20 62 52 65 76 65 72 74  .    set bRevert
11a0: 20 31 0a 20 20 20 20 73 65 74 20 61 72 67 73 20   1.    set args 
11b0: 5b 6c 72 61 6e 67 65 20 24 61 72 67 73 20 31 20  [lrange $args 1 
11c0: 65 6e 64 5d 0a 20 20 7d 0a 20 20 73 65 74 20 6e  end].  }.  set n
11d0: 53 71 6c 20 5b 65 78 70 72 20 5b 6c 6c 65 6e 67  Sql [expr [lleng
11e0: 74 68 20 24 61 72 67 73 5d 2d 31 5d 0a 20 20 73  th $args]-1].  s
11f0: 65 74 20 72 65 73 20 5b 6c 69 6e 64 65 78 20 24  et res [lindex $
1200: 61 72 67 73 20 24 6e 53 71 6c 5d 0a 20 20 73 65  args $nSql].  se
1210: 74 20 70 61 74 63 68 6c 69 73 74 20 5b 6c 69 73  t patchlist [lis
1220: 74 5d 0a 0a 20 20 65 78 65 63 73 71 6c 20 42 45  t]..  execsql BE
1230: 47 49 4e 0a 20 20 69 66 20 7b 24 62 52 65 76 65  GIN.  if {$bReve
1240: 72 74 7d 20 7b 20 65 78 65 63 73 71 6c 20 7b 20  rt} { execsql { 
1250: 53 41 56 45 50 4f 49 4e 54 20 78 20 7d 20 7d 0a  SAVEPOINT x } }.
1260: 20 20 66 6f 72 65 61 63 68 20 73 71 6c 20 5b 6c    foreach sql [l
1270: 72 61 6e 67 65 20 24 61 72 67 73 20 30 20 65 6e  range $args 0 en
1280: 64 2d 31 5d 20 7b 0a 20 20 20 20 73 71 6c 69 74  d-1] {.    sqlit
1290: 65 33 73 65 73 73 69 6f 6e 20 53 20 64 62 20 6d  e3session S db m
12a0: 61 69 6e 0a 20 20 20 20 53 20 61 74 74 61 63 68  ain.    S attach
12b0: 20 2a 0a 20 20 20 20 65 78 65 63 73 71 6c 20 24   *.    execsql $
12c0: 73 71 6c 0a 20 20 20 20 6c 61 70 70 65 6e 64 20  sql.    lappend 
12d0: 70 61 74 63 68 6c 69 73 74 20 5b 53 20 70 61 74  patchlist [S pat
12e0: 63 68 73 65 74 5d 0a 20 20 20 20 53 20 64 65 6c  chset].    S del
12f0: 65 74 65 0a 20 20 20 20 69 66 20 7b 24 62 52 65  ete.    if {$bRe
1300: 76 65 72 74 7d 20 7b 20 65 78 65 63 73 71 6c 20  vert} { execsql 
1310: 7b 20 52 4f 4c 4c 42 41 43 4b 20 54 4f 20 78 20  { ROLLBACK TO x 
1320: 7d 20 7d 0a 20 20 7d 0a 20 20 65 78 65 63 73 71  } }.  }.  execsq
1330: 6c 20 52 4f 4c 4c 42 41 43 4b 0a 0a 20 20 73 65  l ROLLBACK..  se
1340: 74 20 70 61 74 63 68 20 5b 6c 69 6e 64 65 78 20  t patch [lindex 
1350: 24 70 61 74 63 68 6c 69 73 74 20 30 5d 0a 20 20  $patchlist 0].  
1360: 66 6f 72 65 61 63 68 20 70 20 5b 6c 72 61 6e 67  foreach p [lrang
1370: 65 20 24 70 61 74 63 68 6c 69 73 74 20 31 20 65  e $patchlist 1 e
1380: 6e 64 5d 20 7b 0a 20 20 20 20 73 65 74 20 70 61  nd] {.    set pa
1390: 74 63 68 20 5b 73 71 6c 69 74 65 33 63 68 61 6e  tch [sqlite3chan
13a0: 67 65 73 65 74 5f 63 6f 6e 63 61 74 20 24 70 61  geset_concat $pa
13b0: 74 63 68 20 24 70 5d 0a 20 20 7d 0a 0a 20 20 73  tch $p].  }..  s
13c0: 65 74 20 78 20 5b 6c 69 73 74 5d 0a 20 20 73 71  et x [list].  sq
13d0: 6c 69 74 65 33 73 65 73 73 69 6f 6e 5f 66 6f 72  lite3session_for
13e0: 65 61 63 68 20 63 20 24 70 61 74 63 68 20 7b 20  each c $patch { 
13f0: 6c 61 70 70 65 6e 64 20 78 20 24 63 20 7d 0a 0a  lappend x $c }..
1400: 20 20 75 70 6c 65 76 65 6c 20 5b 6c 69 73 74 20    uplevel [list 
1410: 64 6f 5f 74 65 73 74 20 24 74 6e 20 5b 6c 69 73  do_test $tn [lis
1420: 74 20 73 65 74 20 7b 7d 20 24 78 5d 20 5b 6c 69  t set {} $x] [li
1430: 73 74 20 7b 2a 7d 24 72 65 73 5d 5d 0a 7d 0a 0a  st {*}$res]].}..
1440: 64 6f 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20  do_execsql_test 
1450: 34 2e 31 2e 31 20 7b 0a 20 20 43 52 45 41 54 45  4.1.1 {.  CREATE
1460: 20 54 41 42 4c 45 20 74 31 28 78 20 50 52 49 4d   TABLE t1(x PRIM
1470: 41 52 59 20 4b 45 59 2c 20 79 2c 20 7a 29 3b 0a  ARY KEY, y, z);.
1480: 7d 0a 64 6f 5f 70 61 74 63 68 63 6f 6e 63 61 74  }.do_patchconcat
1490: 5f 74 65 73 74 20 34 2e 31 2e 32 20 7b 0a 20 20  _test 4.1.2 {.  
14a0: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56  INSERT INTO t1 V
14b0: 41 4c 55 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a  ALUES(1, 2, 3);.
14c0: 7d 20 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  } {.  INSERT INT
14d0: 4f 20 74 31 20 56 41 4c 55 45 53 28 34 2c 20 35  O t1 VALUES(4, 5
14e0: 2c 20 36 29 3b 0a 7d 20 7b 0a 20 20 7b 49 4e 53  , 6);.} {.  {INS
14f0: 45 52 54 20 74 31 20 30 20 58 2e 2e 20 7b 7d 20  ERT t1 0 X.. {} 
1500: 7b 69 20 31 20 69 20 32 20 69 20 33 7d 7d 20 0a  {i 1 i 2 i 3}} .
1510: 20 20 7b 49 4e 53 45 52 54 20 74 31 20 30 20 58    {INSERT t1 0 X
1520: 2e 2e 20 7b 7d 20 7b 69 20 34 20 69 20 35 20 69  .. {} {i 4 i 5 i
1530: 20 36 7d 7d 0a 7d 0a 0a 64 6f 5f 65 78 65 63 73   6}}.}..do_execs
1540: 71 6c 5f 74 65 73 74 20 34 2e 32 2e 31 20 7b 0a  ql_test 4.2.1 {.
1550: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
1560: 20 56 41 4c 55 45 53 28 31 2c 20 32 2c 20 33 29   VALUES(1, 2, 3)
1570: 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  ;.  INSERT INTO 
1580: 74 31 20 56 41 4c 55 45 53 28 34 2c 20 35 2c 20  t1 VALUES(4, 5, 
1590: 36 29 3b 0a 7d 0a 0a 64 6f 5f 70 61 74 63 68 63  6);.}..do_patchc
15a0: 6f 6e 63 61 74 5f 74 65 73 74 20 34 2e 32 2e 32  oncat_test 4.2.2
15b0: 20 7b 0a 20 20 55 50 44 41 54 45 20 74 31 20 53   {.  UPDATE t1 S
15c0: 45 54 20 7a 20 3d 20 27 61 62 63 27 20 57 48 45  ET z = 'abc' WHE
15d0: 52 45 20 78 3d 31 0a 7d 20 7b 0a 20 20 55 50 44  RE x=1.} {.  UPD
15e0: 41 54 45 20 74 31 20 53 45 54 20 7a 20 3d 20 27  ATE t1 SET z = '
15f0: 64 65 66 27 20 57 48 45 52 45 20 78 3d 34 0a 7d  def' WHERE x=4.}
1600: 20 7b 0a 20 20 7b 55 50 44 41 54 45 20 74 31 20   {.  {UPDATE t1 
1610: 30 20 58 2e 2e 20 7b 69 20 31 20 7b 7d 20 7b 7d  0 X.. {i 1 {} {}
1620: 20 7b 7d 20 7b 7d 7d 20 7b 7b 7d 20 7b 7d 20 7b   {} {}} {{} {} {
1630: 7d 20 7b 7d 20 74 20 61 62 63 7d 7d 20 0a 20 20  } {} t abc}} .  
1640: 7b 55 50 44 41 54 45 20 74 31 20 30 20 58 2e 2e  {UPDATE t1 0 X..
1650: 20 7b 69 20 34 20 7b 7d 20 7b 7d 20 7b 7d 20 7b   {i 4 {} {} {} {
1660: 7d 7d 20 7b 7b 7d 20 7b 7d 20 7b 7d 20 7b 7d 20  }} {{} {} {} {} 
1670: 74 20 64 65 66 7d 7d 0a 7d 0a 0a 64 6f 5f 70 61  t def}}.}..do_pa
1680: 74 63 68 63 6f 6e 63 61 74 5f 74 65 73 74 20 34  tchconcat_test 4
1690: 2e 32 2e 33 20 7b 0a 20 20 44 45 4c 45 54 45 20  .2.3 {.  DELETE 
16a0: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 78 3d  FROM t1 WHERE x=
16b0: 31 3b 0a 7d 20 7b 0a 20 20 44 45 4c 45 54 45 20  1;.} {.  DELETE 
16c0: 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20 78 3d  FROM t1 WHERE x=
16d0: 34 3b 0a 7d 20 7b 0a 20 20 7b 44 45 4c 45 54 45  4;.} {.  {DELETE
16e0: 20 74 31 20 30 20 58 2e 2e 20 7b 69 20 31 20 7b   t1 0 X.. {i 1 {
16f0: 7d 20 7b 7d 20 7b 7d 20 7b 7d 7d 20 7b 7d 7d 20  } {} {} {}} {}} 
1700: 0a 20 20 7b 44 45 4c 45 54 45 20 74 31 20 30 20  .  {DELETE t1 0 
1710: 58 2e 2e 20 7b 69 20 34 20 7b 7d 20 7b 7d 20 7b  X.. {i 4 {} {} {
1720: 7d 20 7b 7d 7d 20 7b 7d 7d 0a 7d 0a 0a 0a 64 6f  } {}} {}}.}...do
1730: 5f 65 78 65 63 73 71 6c 5f 74 65 73 74 20 34 2e  _execsql_test 4.
1740: 33 2e 31 20 7b 0a 20 20 43 52 45 41 54 45 20 54  3.1 {.  CREATE T
1750: 41 42 4c 45 20 74 32 28 61 2c 20 62 2c 20 63 2c  ABLE t2(a, b, c,
1760: 20 64 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28   d, PRIMARY KEY(
1770: 63 2c 20 62 29 29 3b 0a 20 20 49 4e 53 45 52 54  c, b));.  INSERT
1780: 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28   INTO t2 VALUES(
1790: 27 2e 27 2c 20 31 2c 20 31 2c 20 27 2e 27 29 3b  '.', 1, 1, '.');
17a0: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  .  INSERT INTO t
17b0: 32 20 56 41 4c 55 45 53 28 27 2e 27 2c 20 31 2c  2 VALUES('.', 1,
17c0: 20 32 2c 20 27 2e 27 29 3b 0a 20 20 49 4e 53 45   2, '.');.  INSE
17d0: 52 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45  RT INTO t2 VALUE
17e0: 53 28 27 2e 27 2c 20 32 2c 20 31 2c 20 27 2e 27  S('.', 2, 1, '.'
17f0: 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f  );.  INSERT INTO
1800: 20 74 32 20 56 41 4c 55 45 53 28 27 2e 27 2c 20   t2 VALUES('.', 
1810: 32 2c 20 32 2c 20 27 2e 27 29 3b 0a 7d 0a 0a 23  2, 2, '.');.}..#
1820: 20 49 4e 53 45 52 54 20 2b 20 49 4e 53 45 52 54   INSERT + INSERT
1830: 20 0a 64 6f 5f 70 61 74 63 68 63 6f 6e 63 61 74   .do_patchconcat
1840: 5f 74 65 73 74 20 34 2e 33 2e 32 20 2d 72 65 76  _test 4.3.2 -rev
1850: 65 72 74 20 7b 0a 20 20 49 4e 53 45 52 54 20 49  ert {.  INSERT I
1860: 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27 61  NTO t2 VALUES('a
1870: 27 2c 20 27 61 27 2c 20 27 61 27 2c 20 27 61 27  ', 'a', 'a', 'a'
1880: 29 3b 0a 7d 20 7b 0a 20 20 49 4e 53 45 52 54 20  );.} {.  INSERT 
1890: 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53 28 27  INTO t2 VALUES('
18a0: 62 27 2c 20 27 61 27 2c 20 27 61 27 2c 20 27 62  b', 'a', 'a', 'b
18b0: 27 29 3b 0a 7d 20 7b 0a 20 20 7b 49 4e 53 45 52  ');.} {.  {INSER
18c0: 54 20 74 32 20 30 20 2e 58 58 2e 20 7b 7d 20 7b  T t2 0 .XX. {} {
18d0: 74 20 61 20 74 20 61 20 74 20 61 20 74 20 61 7d  t a t a t a t a}
18e0: 7d 0a 7d 0a 0a 23 20 49 4e 53 45 52 54 20 2b 20  }.}..# INSERT + 
18f0: 44 45 4c 45 54 45 20 0a 64 6f 5f 70 61 74 63 68  DELETE .do_patch
1900: 63 6f 6e 63 61 74 5f 74 65 73 74 20 34 2e 33 2e  concat_test 4.3.
1910: 33 20 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  3 {.  INSERT INT
1920: 4f 20 74 32 20 56 41 4c 55 45 53 28 27 61 27 2c  O t2 VALUES('a',
1930: 20 27 61 27 2c 20 27 61 27 2c 20 27 61 27 29 3b   'a', 'a', 'a');
1940: 0a 7d 20 7b 0a 20 20 44 45 4c 45 54 45 20 46 52  .} {.  DELETE FR
1950: 4f 4d 20 74 32 20 57 48 45 52 45 20 63 20 3d 20  OM t2 WHERE c = 
1960: 27 61 27 3b 0a 7d 20 7b 7d 0a 0a 23 20 49 4e 53  'a';.} {}..# INS
1970: 45 52 54 20 2b 20 55 50 44 41 54 45 0a 64 6f 5f  ERT + UPDATE.do_
1980: 70 61 74 63 68 63 6f 6e 63 61 74 5f 74 65 73 74  patchconcat_test
1990: 20 34 2e 33 2e 34 20 7b 0a 20 20 49 4e 53 45 52   4.3.4 {.  INSER
19a0: 54 20 49 4e 54 4f 20 74 32 20 56 41 4c 55 45 53  T INTO t2 VALUES
19b0: 28 27 61 27 2c 20 27 61 27 2c 20 27 61 27 2c 20  ('a', 'a', 'a', 
19c0: 27 61 27 29 3b 0a 7d 20 7b 0a 20 20 55 50 44 41  'a');.} {.  UPDA
19d0: 54 45 20 74 32 20 53 45 54 20 64 20 3d 20 27 62  TE t2 SET d = 'b
19e0: 27 20 57 48 45 52 45 20 63 3d 27 61 27 3b 0a 7d  ' WHERE c='a';.}
19f0: 20 7b 0a 20 20 7b 49 4e 53 45 52 54 20 74 32 20   {.  {INSERT t2 
1a00: 30 20 2e 58 58 2e 20 7b 7d 20 7b 74 20 61 20 74  0 .XX. {} {t a t
1a10: 20 61 20 74 20 61 20 74 20 62 7d 7d 0a 7d 0a 0a   a t a t b}}.}..
1a20: 23 20 55 50 44 41 54 45 20 2b 20 55 50 44 41 54  # UPDATE + UPDAT
1a30: 45 0a 64 6f 5f 70 61 74 63 68 63 6f 6e 63 61 74  E.do_patchconcat
1a40: 5f 74 65 73 74 20 34 2e 33 2e 35 20 7b 0a 20 20  _test 4.3.5 {.  
1a50: 55 50 44 41 54 45 20 74 32 20 53 45 54 20 61 20  UPDATE t2 SET a 
1a60: 3d 20 27 61 27 20 57 48 45 52 45 20 63 3d 31 20  = 'a' WHERE c=1 
1a70: 41 4e 44 20 62 3d 32 3b 0a 7d 20 7b 0a 20 20 55  AND b=2;.} {.  U
1a80: 50 44 41 54 45 20 74 32 20 53 45 54 20 64 20 3d  PDATE t2 SET d =
1a90: 20 27 64 27 20 57 48 45 52 45 20 63 3d 31 20 41   'd' WHERE c=1 A
1aa0: 4e 44 20 62 3d 32 3b 0a 7d 20 7b 0a 20 20 7b 55  ND b=2;.} {.  {U
1ab0: 50 44 41 54 45 20 74 32 20 30 20 2e 58 58 2e 20  PDATE t2 0 .XX. 
1ac0: 7b 7b 7d 20 7b 7d 20 69 20 32 20 69 20 31 20 7b  {{} {} i 2 i 1 {
1ad0: 7d 20 7b 7d 7d 20 7b 74 20 61 20 7b 7d 20 7b 7d  } {}} {t a {} {}
1ae0: 20 7b 7d 20 7b 7d 20 74 20 64 7d 7d 0a 7d 0a 0a   {} {} t d}}.}..
1af0: 23 20 55 50 44 41 54 45 20 2b 20 44 45 4c 45 54  # UPDATE + DELET
1b00: 45 0a 64 6f 5f 70 61 74 63 68 63 6f 6e 63 61 74  E.do_patchconcat
1b10: 5f 74 65 73 74 20 34 2e 33 2e 36 20 7b 0a 20 20  _test 4.3.6 {.  
1b20: 55 50 44 41 54 45 20 74 32 20 53 45 54 20 61 20  UPDATE t2 SET a 
1b30: 3d 20 27 61 27 20 57 48 45 52 45 20 63 3d 31 20  = 'a' WHERE c=1 
1b40: 41 4e 44 20 62 3d 32 3b 0a 7d 20 7b 0a 20 20 44  AND b=2;.} {.  D
1b50: 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48  ELETE FROM t2 WH
1b60: 45 52 45 20 63 3d 31 20 41 4e 44 20 62 3d 32 3b  ERE c=1 AND b=2;
1b70: 0a 7d 20 7b 0a 20 20 7b 44 45 4c 45 54 45 20 74  .} {.  {DELETE t
1b80: 32 20 30 20 2e 58 58 2e 20 7b 7b 7d 20 7b 7d 20  2 0 .XX. {{} {} 
1b90: 69 20 32 20 69 20 31 20 7b 7d 20 7b 7d 7d 20 7b  i 2 i 1 {} {}} {
1ba0: 7d 7d 0a 7d 0a 0a 23 20 44 45 4c 45 54 45 20 2b  }}.}..# DELETE +
1bb0: 20 49 4e 53 45 52 54 0a 64 6f 5f 70 61 74 63 68   INSERT.do_patch
1bc0: 63 6f 6e 63 61 74 5f 74 65 73 74 20 34 2e 33 2e  concat_test 4.3.
1bd0: 37 20 7b 0a 20 20 44 45 4c 45 54 45 20 46 52 4f  7 {.  DELETE FRO
1be0: 4d 20 74 32 20 57 48 45 52 45 20 62 3d 31 3b 0a  M t2 WHERE b=1;.
1bf0: 7d 20 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  } {.  INSERT INT
1c00: 4f 20 74 32 20 56 41 4c 55 45 53 28 27 78 27 2c  O t2 VALUES('x',
1c10: 20 31 2c 20 32 2c 20 27 2e 27 29 3b 0a 7d 20 7b   1, 2, '.');.} {
1c20: 0a 20 20 7b 44 45 4c 45 54 45 20 74 32 20 30 20  .  {DELETE t2 0 
1c30: 2e 58 58 2e 20 7b 7b 7d 20 7b 7d 20 69 20 31 20  .XX. {{} {} i 1 
1c40: 69 20 31 20 7b 7d 20 7b 7d 7d 20 7b 7d 7d 20 0a  i 1 {} {}} {}} .
1c50: 20 20 7b 55 50 44 41 54 45 20 74 32 20 30 20 2e    {UPDATE t2 0 .
1c60: 58 58 2e 20 7b 7b 7d 20 7b 7d 20 69 20 31 20 69  XX. {{} {} i 1 i
1c70: 20 32 20 7b 7d 20 7b 7d 7d 20 7b 74 20 78 20 7b   2 {} {}} {t x {
1c80: 7d 20 7b 7d 20 7b 7d 20 7b 7d 20 74 20 2e 7d 7d  } {} {} {} t .}}
1c90: 0a 7d 0a 0a 23 20 44 45 4c 45 54 45 20 2b 20 55  .}..# DELETE + U
1ca0: 50 44 41 54 45 0a 64 6f 5f 70 61 74 63 68 63 6f  PDATE.do_patchco
1cb0: 6e 63 61 74 5f 74 65 73 74 20 34 2e 33 2e 38 20  ncat_test 4.3.8 
1cc0: 2d 72 65 76 65 72 74 20 7b 0a 20 20 44 45 4c 45  -revert {.  DELE
1cd0: 54 45 20 46 52 4f 4d 20 74 32 20 57 48 45 52 45  TE FROM t2 WHERE
1ce0: 20 62 3d 31 20 41 4e 44 20 63 3d 32 3b 0a 7d 20   b=1 AND c=2;.} 
1cf0: 7b 0a 20 20 55 50 44 41 54 45 20 74 32 20 53 45  {.  UPDATE t2 SE
1d00: 54 20 61 3d 35 20 57 48 45 52 45 20 62 3d 31 20  T a=5 WHERE b=1 
1d10: 41 4e 44 20 63 3d 32 3b 0a 7d 20 7b 0a 20 20 7b  AND c=2;.} {.  {
1d20: 44 45 4c 45 54 45 20 74 32 20 30 20 2e 58 58 2e  DELETE t2 0 .XX.
1d30: 20 7b 7b 7d 20 7b 7d 20 69 20 31 20 69 20 32 20   {{} {} i 1 i 2 
1d40: 7b 7d 20 7b 7d 7d 20 7b 7d 7d 20 0a 7d 0a 0a 23  {} {}} {}} .}..#
1d50: 20 44 45 4c 45 54 45 20 2b 20 55 50 44 41 54 45   DELETE + UPDATE
1d60: 0a 64 6f 5f 70 61 74 63 68 63 6f 6e 63 61 74 5f  .do_patchconcat_
1d70: 74 65 73 74 20 34 2e 33 2e 39 20 2d 72 65 76 65  test 4.3.9 -reve
1d80: 72 74 20 7b 0a 20 20 44 45 4c 45 54 45 20 46 52  rt {.  DELETE FR
1d90: 4f 4d 20 74 32 20 57 48 45 52 45 20 62 3d 31 20  OM t2 WHERE b=1 
1da0: 41 4e 44 20 63 3d 32 3b 0a 7d 20 7b 0a 20 20 44  AND c=2;.} {.  D
1db0: 45 4c 45 54 45 20 46 52 4f 4d 20 74 32 20 57 48  ELETE FROM t2 WH
1dc0: 45 52 45 20 62 3d 31 3b 0a 7d 20 7b 0a 20 20 7b  ERE b=1;.} {.  {
1dd0: 44 45 4c 45 54 45 20 74 32 20 30 20 2e 58 58 2e  DELETE t2 0 .XX.
1de0: 20 7b 7b 7d 20 7b 7d 20 69 20 31 20 69 20 31 20   {{} {} i 1 i 1 
1df0: 7b 7d 20 7b 7d 7d 20 7b 7d 7d 20 0a 20 20 7b 44  {} {}} {}} .  {D
1e00: 45 4c 45 54 45 20 74 32 20 30 20 2e 58 58 2e 20  ELETE t2 0 .XX. 
1e10: 7b 7b 7d 20 7b 7d 20 69 20 31 20 69 20 32 20 7b  {{} {} i 1 i 2 {
1e20: 7d 20 7b 7d 7d 20 7b 7d 7d 20 0a 7d 0a 0a 23 2d  } {}} {}} .}..#-
1e30: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e50: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1e70: 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 4d 6f 72 65 20  --------.# More 
1e80: 72 69 67 6f 72 6f 75 73 20 74 65 73 74 69 6e 67  rigorous testing
1e90: 20 6f 66 20 74 68 65 20 5f 70 61 74 63 68 73 65   of the _patchse
1ea0: 74 28 29 2c 20 5f 61 70 70 6c 79 20 61 6e 64 20  t(), _apply and 
1eb0: 5f 63 6f 6e 63 61 74 28 29 20 41 50 49 73 2e 0a  _concat() APIs..
1ec0: 23 0a 23 20 54 68 65 20 69 6e 70 75 74 73 20 74  #.# The inputs t
1ed0: 6f 20 65 61 63 68 20 74 65 73 74 20 61 72 65 20  o each test are 
1ee0: 61 20 70 6f 70 75 6c 61 74 65 20 64 61 74 61 62  a populate datab
1ef0: 61 73 65 20 61 6e 64 20 61 20 6c 69 73 74 20 6f  ase and a list o
1f00: 66 20 44 4d 4c 20 0a 23 20 73 74 61 74 65 6d 65  f DML .# stateme
1f10: 6e 74 73 2e 20 54 68 69 73 20 74 65 73 74 20 64  nts. This test d
1f20: 65 74 65 72 6d 69 6e 65 73 20 74 68 61 74 20 74  etermines that t
1f30: 68 65 20 66 69 6e 61 6c 20 64 61 74 61 62 61 73  he final databas
1f40: 65 20 69 73 20 74 68 65 20 73 61 6d 65 0a 23 20  e is the same.# 
1f50: 69 66 3a 0a 23 20 0a 23 20 20 20 31 29 20 74 68  if:.# .#   1) th
1f60: 65 20 73 74 61 74 65 6d 65 6e 74 73 20 61 72 65  e statements are
1f70: 20 65 78 65 63 75 74 65 64 20 64 69 72 65 63 74   executed direct
1f80: 6c 79 20 6f 6e 20 74 68 65 20 64 61 74 61 62 61  ly on the databa
1f90: 73 65 2e 0a 23 0a 23 20 20 20 32 29 20 61 20 73  se..#.#   2) a s
1fa0: 69 6e 67 6c 65 20 70 61 74 63 68 73 65 74 20 69  ingle patchset i
1fb0: 73 20 63 6f 6c 6c 65 63 74 65 64 20 77 68 69 6c  s collected whil
1fc0: 65 20 65 78 65 63 75 74 69 6e 67 20 74 68 65 20  e executing the 
1fd0: 73 74 61 74 65 6d 65 6e 74 73 20 61 6e 64 0a 23  statements and.#
1fe0: 20 20 20 20 20 20 74 68 65 6e 20 61 70 70 6c 69        then appli
1ff0: 65 64 20 74 6f 20 61 20 63 6f 70 79 20 6f 66 20  ed to a copy of 
2000: 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 64 61 74  the original dat
2010: 61 62 61 73 65 20 66 69 6c 65 2e 0a 23 0a 23 20  abase file..#.# 
2020: 20 20 33 29 20 69 6e 64 69 76 69 64 75 61 6c 20    3) individual 
2030: 70 61 74 63 68 73 65 74 73 20 61 72 65 20 63 6f  patchsets are co
2040: 6c 6c 65 63 74 65 64 20 66 6f 72 20 73 74 61 74  llected for stat
2050: 65 6d 65 6e 74 20 77 68 69 6c 65 20 65 78 65 63  ement while exec
2060: 75 74 69 6e 67 0a 23 20 20 20 20 20 20 74 68 65  uting.#      the
2070: 6d 20 61 6e 64 20 63 6f 6e 63 61 74 65 6e 61 74  m and concatenat
2080: 65 64 20 74 6f 67 65 74 68 65 72 20 62 65 66 6f  ed together befo
2090: 72 65 20 62 65 69 6e 67 20 61 70 70 6c 69 65 64  re being applied
20a0: 20 74 6f 20 61 20 63 6f 70 79 20 6f 66 0a 23 20   to a copy of.# 
20b0: 20 20 20 20 20 74 68 65 20 6f 72 69 67 69 6e 61       the origina
20c0: 6c 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20  l database. The 
20d0: 63 6f 6e 63 61 74 65 6e 61 74 69 6f 6e 20 69 73  concatenation is
20e0: 20 64 6f 6e 65 20 69 6e 20 61 20 63 6f 75 70 6c   done in a coupl
20f0: 65 20 6f 66 0a 23 20 20 20 20 20 20 64 69 66 66  e of.#      diff
2100: 65 72 65 6e 74 20 77 61 79 73 20 2d 20 6c 69 6e  erent ways - lin
2110: 65 61 72 2c 20 70 61 69 72 77 69 73 65 20 65 74  ear, pairwise et
2120: 63 2e 0a 23 0a 23 20 41 6c 6c 20 74 65 73 74 73  c..#.# All tests
2130: 2c 20 61 73 20 69 74 20 68 61 70 70 65 6e 73 2c  , as it happens,
2140: 20 61 72 65 20 72 75 6e 20 77 69 74 68 20 62 6f   are run with bo
2150: 74 68 20 63 68 61 6e 67 65 73 65 74 73 20 61 6e  th changesets an
2160: 64 20 70 61 74 63 68 73 65 74 73 2e 0a 23 20 42  d patchsets..# B
2170: 75 74 20 74 68 65 20 66 6f 63 75 73 20 69 73 20  ut the focus is 
2180: 6f 6e 20 70 61 74 63 68 73 65 74 20 63 61 70 61  on patchset capa
2190: 62 69 6c 69 74 69 65 73 2e 0a 23 0a 0a 23 20 52  bilities..#..# R
21a0: 65 74 75 72 6e 20 61 20 63 68 65 63 6b 73 75 6d  eturn a checksum
21b0: 20 6f 66 20 74 68 65 20 63 6f 6e 74 65 6e 74 73   of the contents
21c0: 20 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65   of the database
21d0: 20 66 69 6c 65 2e 20 49 6d 70 6c 69 63 69 74 20   file. Implicit 
21e0: 49 50 4b 0a 23 20 63 6f 6c 75 6d 6e 73 20 61 72  IPK.# columns ar
21f0: 65 20 6e 6f 74 20 69 6e 63 6c 75 64 65 64 20 69  e not included i
2200: 6e 20 74 68 65 20 63 68 65 63 6b 73 75 6d 20 2d  n the checksum -
2210: 20 6a 75 73 74 20 6d 6f 64 69 66 79 69 6e 67 20   just modifying 
2220: 72 6f 77 69 64 73 20 64 6f 65 73 0a 23 20 6e 6f  rowids does.# no
2230: 74 20 63 68 61 6e 67 65 20 74 68 65 20 64 61 74  t change the dat
2240: 61 62 61 73 65 20 63 68 65 63 6b 73 75 6d 2e 0a  abase checksum..
2250: 23 0a 70 72 6f 63 20 64 61 74 61 62 61 73 65 63  #.proc databasec
2260: 6b 73 75 6d 20 7b 64 62 7d 20 7b 0a 20 20 73 65  ksum {db} {.  se
2270: 74 20 61 6c 6c 74 61 62 20 5b 24 64 62 20 65 76  t alltab [$db ev
2280: 61 6c 20 7b 53 45 4c 45 43 54 20 6e 61 6d 65 20  al {SELECT name 
2290: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74  FROM sqlite_mast
22a0: 65 72 20 57 48 45 52 45 20 74 79 70 65 3d 27 74  er WHERE type='t
22b0: 61 62 6c 65 27 7d 5d 0a 20 20 66 6f 72 65 61 63  able'}].  foreac
22c0: 68 20 74 61 62 20 24 61 6c 6c 74 61 62 20 7b 0a  h tab $alltab {.
22d0: 20 20 20 20 24 64 62 20 65 76 61 6c 20 22 53 45      $db eval "SE
22e0: 4c 45 43 54 20 2a 20 46 52 4f 4d 20 24 74 61 62  LECT * FROM $tab
22f0: 20 4c 49 4d 49 54 20 31 22 20 72 65 73 20 7b 20   LIMIT 1" res { 
2300: 7d 0a 20 20 20 20 73 65 74 20 73 6c 69 73 74 20  }.    set slist 
2310: 5b 6c 69 73 74 5d 0a 20 20 20 20 66 6f 72 65 61  [list].    forea
2320: 63 68 20 63 6f 6c 20 5b 6c 73 6f 72 74 20 24 72  ch col [lsort $r
2330: 65 73 28 2a 29 5d 20 7b 0a 20 20 20 20 20 20 6c  es(*)] {.      l
2340: 61 70 70 65 6e 64 20 73 6c 69 73 74 20 22 71 75  append slist "qu
2350: 6f 74 65 28 24 63 6f 6c 29 22 0a 20 20 20 20 7d  ote($col)".    }
2360: 0a 20 20 20 20 73 65 74 20 73 71 6c 20 22 53 45  .    set sql "SE
2370: 4c 45 43 54 20 5b 6a 6f 69 6e 20 24 73 6c 69 73  LECT [join $slis
2380: 74 20 2c 5d 20 46 52 4f 4d 20 24 74 61 62 22 0a  t ,] FROM $tab".
2390: 20 20 20 20 61 70 70 65 6e 64 20 74 78 74 20 22      append txt "
23a0: 5b 6c 73 6f 72 74 20 5b 24 64 62 20 65 76 61 6c  [lsort [$db eval
23b0: 20 24 73 71 6c 5d 5d 5c 6e 22 0a 20 20 7d 0a 20   $sql]]\n".  }. 
23c0: 20 72 65 74 75 72 6e 20 5b 6d 64 35 20 24 74 78   return [md5 $tx
23d0: 74 5d 0a 7d 0a 0a 70 72 6f 63 20 64 6f 5f 70 61  t].}..proc do_pa
23e0: 74 63 68 73 65 74 5f 74 65 73 74 20 7b 74 6e 20  tchset_test {tn 
23f0: 74 73 74 63 6d 64 20 6c 53 71 6c 7d 20 7b 0a 20  tstcmd lSql} {. 
2400: 20 69 66 20 7b 24 74 73 74 63 6d 64 20 21 3d 20   if {$tstcmd != 
2410: 22 70 61 74 63 68 73 65 74 22 20 26 26 20 24 74  "patchset" && $t
2420: 73 74 63 6d 64 20 21 3d 20 22 63 68 61 6e 67 65  stcmd != "change
2430: 73 65 74 22 7d 20 7b 0a 20 20 20 20 65 72 72 6f  set"} {.    erro
2440: 72 20 22 68 61 76 65 20 24 74 73 74 63 6d 64 3a  r "have $tstcmd:
2450: 20 6d 75 73 74 20 62 65 20 70 61 74 63 68 73 65   must be patchse
2460: 74 20 6f 72 20 63 68 61 6e 67 65 73 65 74 22 0a  t or changeset".
2470: 20 20 7d 0a 0a 20 20 66 6f 72 65 61 63 68 20 66    }..  foreach f
2480: 6e 61 6d 65 20 7b 74 65 73 74 2e 64 62 32 20 74  name {test.db2 t
2490: 65 73 74 2e 64 62 33 20 74 65 73 74 2e 64 62 34  est.db3 test.db4
24a0: 20 74 65 73 74 2e 64 62 35 7d 20 7b 0a 20 20 20   test.db5} {.   
24b0: 20 66 6f 72 63 65 64 65 6c 65 74 65 20 24 66 6e   forcedelete $fn
24c0: 61 6d 65 0a 20 20 20 20 66 6f 72 63 65 63 6f 70  ame.    forcecop
24d0: 79 20 74 65 73 74 2e 64 62 20 24 66 6e 61 6d 65  y test.db $fname
24e0: 0a 20 20 7d 0a 0a 20 20 23 20 45 78 65 63 75 74  .  }..  # Execut
24f0: 65 20 74 68 65 20 53 51 4c 20 73 74 61 74 65 6d  e the SQL statem
2500: 65 6e 74 73 20 6f 6e 20 5b 64 62 5d 2e 20 43 6f  ents on [db]. Co
2510: 6c 6c 65 63 74 20 61 20 70 61 74 63 68 73 65 74  llect a patchset
2520: 20 66 6f 72 20 65 61 63 68 20 0a 20 20 23 20 69   for each .  # i
2530: 6e 64 69 76 69 64 75 61 6c 20 73 74 61 74 65 6d  ndividual statem
2540: 65 6e 74 2c 20 61 73 20 77 65 6c 6c 20 61 73 20  ent, as well as 
2550: 61 20 73 69 6e 67 6c 65 20 70 61 74 63 68 73 65  a single patchse
2560: 74 20 66 6f 72 20 74 68 65 20 65 6e 74 69 72 65  t for the entire
2570: 20 0a 20 20 23 20 6f 70 65 72 61 74 69 6f 6e 2e   .  # operation.
2580: 0a 20 20 73 71 6c 69 74 65 33 73 65 73 73 69 6f  .  sqlite3sessio
2590: 6e 20 53 20 64 62 20 6d 61 69 6e 0a 20 20 53 20  n S db main.  S 
25a0: 61 74 74 61 63 68 20 2a 0a 20 20 66 6f 72 65 61  attach *.  forea
25b0: 63 68 20 73 71 6c 20 24 6c 53 71 6c 20 7b 20 0a  ch sql $lSql { .
25c0: 20 20 20 20 73 71 6c 69 74 65 33 73 65 73 73 69      sqlite3sessi
25d0: 6f 6e 20 54 20 64 62 20 6d 61 69 6e 0a 20 20 20  on T db main.   
25e0: 20 54 20 61 74 74 61 63 68 20 2a 0a 20 20 20 20   T attach *.    
25f0: 64 62 20 65 76 61 6c 20 24 73 71 6c 20 0a 20 20  db eval $sql .  
2600: 20 20 6c 61 70 70 65 6e 64 20 6c 50 61 74 63 68    lappend lPatch
2610: 20 5b 54 20 24 74 73 74 63 6d 64 5d 0a 20 20 20   [T $tstcmd].   
2620: 20 54 20 64 65 6c 65 74 65 0a 20 20 7d 0a 20 20   T delete.  }.  
2630: 73 65 74 20 70 61 74 63 68 73 65 74 20 5b 53 20  set patchset [S 
2640: 24 74 73 74 63 6d 64 5d 0a 20 20 53 20 64 65 6c  $tstcmd].  S del
2650: 65 74 65 0a 0a 20 20 23 20 43 61 6c 63 75 6c 61  ete..  # Calcula
2660: 74 65 20 61 20 63 68 65 63 6b 73 75 6d 20 66 6f  te a checksum fo
2670: 72 20 74 68 65 20 66 69 6e 61 6c 20 64 61 74 61  r the final data
2680: 62 61 73 65 2e 0a 20 20 73 65 74 20 63 6b 73 75  base..  set cksu
2690: 6d 20 5b 64 61 74 61 62 61 73 65 63 6b 73 75 6d  m [databasecksum
26a0: 20 64 62 5d 0a 0a 20 20 23 20 31 2e 20 41 70 70   db]..  # 1. App
26b0: 6c 79 20 74 68 65 20 73 69 6e 67 6c 65 20 6c 61  ly the single la
26c0: 72 67 65 20 70 61 74 63 68 73 65 74 20 74 6f 20  rge patchset to 
26d0: 74 65 73 74 2e 64 62 32 0a 20 20 73 71 6c 69 74  test.db2.  sqlit
26e0: 65 33 20 64 62 32 20 74 65 73 74 2e 64 62 32 0a  e3 db2 test.db2.
26f0: 20 20 73 71 6c 69 74 65 33 63 68 61 6e 67 65 73    sqlite3changes
2700: 65 74 5f 61 70 70 6c 79 20 64 62 32 20 24 70 61  et_apply db2 $pa
2710: 74 63 68 73 65 74 20 6e 6f 6f 70 0a 20 20 75 70  tchset noop.  up
2720: 6c 65 76 65 6c 20 5b 6c 69 73 74 20 64 6f 5f 74  level [list do_t
2730: 65 73 74 20 24 74 6e 2e 31 20 7b 20 64 61 74 61  est $tn.1 { data
2740: 62 61 73 65 63 6b 73 75 6d 20 64 62 32 20 7d 20  basecksum db2 } 
2750: 24 63 6b 73 75 6d 20 5d 0a 20 20 64 62 32 20 63  $cksum ].  db2 c
2760: 6c 6f 73 65 0a 20 20 0a 20 20 23 20 32 2e 20 41  lose.  .  # 2. A
2770: 70 70 6c 79 20 65 61 63 68 20 6f 66 20 74 68 65  pply each of the
2780: 20 73 69 6e 67 6c 65 2d 73 74 61 74 65 6d 65 6e   single-statemen
2790: 74 20 70 61 74 63 68 73 65 74 73 20 74 6f 20 74  t patchsets to t
27a0: 65 73 74 2e 64 62 33 0a 20 20 73 71 6c 69 74 65  est.db3.  sqlite
27b0: 33 20 64 62 32 20 74 65 73 74 2e 64 62 33 0a 20  3 db2 test.db3. 
27c0: 20 66 6f 72 65 61 63 68 20 70 20 24 6c 50 61 74   foreach p $lPat
27d0: 63 68 20 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  ch {.    sqlite3
27e0: 63 68 61 6e 67 65 73 65 74 5f 61 70 70 6c 79 20  changeset_apply 
27f0: 64 62 32 20 24 70 20 6e 6f 6f 70 0a 20 20 7d 0a  db2 $p noop.  }.
2800: 20 20 75 70 6c 65 76 65 6c 20 5b 6c 69 73 74 20    uplevel [list 
2810: 64 6f 5f 74 65 73 74 20 24 74 6e 2e 32 20 7b 20  do_test $tn.2 { 
2820: 64 61 74 61 62 61 73 65 63 6b 73 75 6d 20 64 62  databasecksum db
2830: 32 20 7d 20 24 63 6b 73 75 6d 20 5d 0a 20 20 64  2 } $cksum ].  d
2840: 62 32 20 63 6c 6f 73 65 0a 0a 20 20 23 20 33 2e  b2 close..  # 3.
2850: 20 43 6f 6e 63 61 74 65 6e 61 74 65 20 61 6c 6c   Concatenate all
2860: 20 73 69 6e 67 6c 65 2d 73 74 61 74 65 6d 65 6e   single-statemen
2870: 74 20 70 61 74 63 68 73 65 74 73 20 69 6e 74 6f  t patchsets into
2880: 20 61 20 73 69 6e 67 6c 65 20 6c 61 72 67 65 0a   a single large.
2890: 20 20 23 20 20 20 20 70 61 74 63 68 73 65 74 2c    #    patchset,
28a0: 20 74 68 65 6e 20 61 70 70 6c 79 20 69 74 20 74   then apply it t
28b0: 6f 20 74 65 73 74 2e 64 62 34 2e 0a 20 20 23 0a  o test.db4..  #.
28c0: 20 20 73 71 6c 69 74 65 33 20 64 62 32 20 74 65    sqlite3 db2 te
28d0: 73 74 2e 64 62 34 0a 20 20 73 65 74 20 62 69 67  st.db4.  set big
28e0: 20 22 22 0a 20 20 66 6f 72 65 61 63 68 20 70 20   "".  foreach p 
28f0: 24 6c 50 61 74 63 68 20 7b 0a 20 20 20 20 73 65  $lPatch {.    se
2900: 74 20 62 69 67 20 5b 73 71 6c 69 74 65 33 63 68  t big [sqlite3ch
2910: 61 6e 67 65 73 65 74 5f 63 6f 6e 63 61 74 20 24  angeset_concat $
2920: 62 69 67 20 24 70 5d 0a 20 20 7d 0a 20 20 73 71  big $p].  }.  sq
2930: 6c 69 74 65 33 63 68 61 6e 67 65 73 65 74 5f 61  lite3changeset_a
2940: 70 70 6c 79 20 64 62 32 20 24 62 69 67 20 6e 6f  pply db2 $big no
2950: 6f 70 0a 20 20 75 70 6c 65 76 65 6c 20 5b 6c 69  op.  uplevel [li
2960: 73 74 20 64 6f 5f 74 65 73 74 20 24 74 6e 2e 33  st do_test $tn.3
2970: 20 7b 20 64 61 74 61 62 61 73 65 63 6b 73 75 6d   { databasecksum
2980: 20 64 62 32 20 7d 20 24 63 6b 73 75 6d 20 5d 0a   db2 } $cksum ].
2990: 20 20 64 62 32 20 63 6c 6f 73 65 0a 0a 20 20 23    db2 close..  #
29a0: 20 34 2e 20 43 6f 6e 63 61 74 65 6e 61 74 65 20   4. Concatenate 
29b0: 61 6c 6c 20 73 69 6e 67 6c 65 2d 73 74 61 74 65  all single-state
29c0: 6d 65 6e 74 20 70 61 74 63 68 73 65 74 73 20 70  ment patchsets p
29d0: 61 69 72 77 69 73 65 20 69 6e 74 6f 20 61 20 73  airwise into a s
29e0: 69 6e 67 6c 65 0a 20 20 23 20 20 20 20 6c 61 72  ingle.  #    lar
29f0: 67 65 20 70 61 74 63 68 73 65 74 2c 20 74 68 65  ge patchset, the
2a00: 6e 20 61 70 70 6c 79 20 69 74 20 74 6f 20 74 65  n apply it to te
2a10: 73 74 2e 64 62 35 2e 20 50 61 69 72 77 69 73 65  st.db5. Pairwise
2a20: 20 63 6f 6e 63 61 74 65 6e 61 74 69 6f 6e 3a 0a   concatenation:.
2a30: 20 20 23 0a 20 20 23 20 20 20 20 20 20 20 20 20    #.  #         
2a40: 61 20 62 20 63 20 64 20 65 20 66 20 67 20 68 20  a b c d e f g h 
2a50: 69 20 6a 20 6b 0a 20 20 23 20 20 20 20 20 20 2d  i j k.  #      -
2a60: 3e 20 7b 61 20 62 7d 20 7b 63 20 64 7d 20 7b 65  > {a b} {c d} {e
2a70: 20 66 7d 20 7b 67 20 68 7d 20 7b 69 20 6a 7d 20   f} {g h} {i j} 
2a80: 6b 0a 20 20 23 20 20 20 20 20 20 2d 3e 20 7b 61  k.  #      -> {a
2a90: 20 62 20 63 20 64 7d 20 7b 65 20 66 20 67 20 68   b c d} {e f g h
2aa0: 7d 20 7b 69 20 6a 20 6b 7d 0a 20 20 23 20 20 20  } {i j k}.  #   
2ab0: 20 20 20 2d 3e 20 7b 61 20 62 20 63 20 64 20 65     -> {a b c d e
2ac0: 20 66 20 67 20 68 7d 20 7b 69 20 6a 20 6b 7d 0a   f g h} {i j k}.
2ad0: 20 20 23 20 20 20 20 20 20 2d 3e 20 7b 61 20 62    #      -> {a b
2ae0: 20 63 20 64 20 65 20 66 20 67 20 68 20 69 20 6a   c d e f g h i j
2af0: 20 6b 7d 0a 20 20 23 20 20 20 20 20 20 2d 3e 20   k}.  #      -> 
2b00: 41 50 50 4c 59 21 0a 20 20 23 0a 20 20 73 71 6c  APPLY!.  #.  sql
2b10: 69 74 65 33 20 64 62 32 20 74 65 73 74 2e 64 62  ite3 db2 test.db
2b20: 35 0a 20 20 73 65 74 20 4c 20 24 6c 50 61 74 63  5.  set L $lPatc
2b30: 68 0a 20 20 77 68 69 6c 65 20 7b 5b 6c 6c 65 6e  h.  while {[llen
2b40: 67 74 68 20 24 4c 5d 20 3e 20 31 7d 20 7b 0a 20  gth $L] > 1} {. 
2b50: 20 20 20 73 65 74 20 4f 20 5b 6c 69 73 74 5d 0a     set O [list].
2b60: 20 20 20 20 66 6f 72 20 7b 73 65 74 20 69 20 30      for {set i 0
2b70: 7d 20 7b 24 69 20 3c 20 5b 6c 6c 65 6e 67 74 68  } {$i < [llength
2b80: 20 24 4c 5d 7d 20 7b 69 6e 63 72 20 69 20 32 7d   $L]} {incr i 2}
2b90: 20 7b 0a 20 20 20 20 20 20 69 66 20 7b 24 69 3d   {.      if {$i=
2ba0: 3d 5b 6c 6c 65 6e 67 74 68 20 24 4c 5d 2d 31 7d  =[llength $L]-1}
2bb0: 20 7b 0a 20 20 20 20 20 20 20 20 6c 61 70 70 65   {.        lappe
2bc0: 6e 64 20 4f 20 5b 6c 69 6e 64 65 78 20 24 4c 20  nd O [lindex $L 
2bd0: 24 69 5d 0a 20 20 20 20 20 20 7d 20 65 6c 73 65  $i].      } else
2be0: 20 7b 0a 20 20 20 20 20 20 20 20 73 65 74 20 69   {.        set i
2bf0: 31 20 5b 65 78 70 72 20 24 69 2b 31 5d 0a 20 20  1 [expr $i+1].  
2c00: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 4f 20        lappend O 
2c10: 5b 73 71 6c 69 74 65 33 63 68 61 6e 67 65 73 65  [sqlite3changese
2c20: 74 5f 63 6f 6e 63 61 74 20 5b 6c 69 6e 64 65 78  t_concat [lindex
2c30: 20 24 4c 20 24 69 5d 20 5b 6c 69 6e 64 65 78 20   $L $i] [lindex 
2c40: 24 4c 20 24 69 31 5d 5d 0a 20 20 20 20 20 20 7d  $L $i1]].      }
2c50: 0a 20 20 20 20 7d 0a 20 20 20 20 73 65 74 20 4c  .    }.    set L
2c60: 20 24 4f 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65   $O.  }.  sqlite
2c70: 33 63 68 61 6e 67 65 73 65 74 5f 61 70 70 6c 79  3changeset_apply
2c80: 20 64 62 32 20 5b 6c 69 6e 64 65 78 20 24 4c 20   db2 [lindex $L 
2c90: 30 5d 20 6e 6f 6f 70 0a 20 20 75 70 6c 65 76 65  0] noop.  upleve
2ca0: 6c 20 5b 6c 69 73 74 20 64 6f 5f 74 65 73 74 20  l [list do_test 
2cb0: 24 74 6e 2e 34 20 7b 20 64 61 74 61 62 61 73 65  $tn.4 { database
2cc0: 63 6b 73 75 6d 20 64 62 32 20 7d 20 24 63 6b 73  cksum db2 } $cks
2cd0: 75 6d 20 5d 0a 20 20 64 62 32 20 63 6c 6f 73 65  um ].  db2 close
2ce0: 0a 7d 0a 0a 70 72 6f 63 20 64 6f 5f 70 61 74 63  .}..proc do_patc
2cf0: 68 73 65 74 5f 63 68 61 6e 67 65 73 65 74 5f 74  hset_changeset_t
2d00: 65 73 74 20 7b 74 6e 20 69 6e 69 74 73 71 6c 20  est {tn initsql 
2d10: 61 72 67 73 7d 20 7b 0a 20 20 66 6f 72 65 61 63  args} {.  foreac
2d20: 68 20 74 73 74 63 6d 64 20 7b 70 61 74 63 68 73  h tstcmd {patchs
2d30: 65 74 20 63 68 61 6e 67 65 73 65 74 7d 20 7b 0a  et changeset} {.
2d40: 20 20 20 20 72 65 73 65 74 5f 64 62 0a 20 20 20      reset_db.   
2d50: 20 65 78 65 63 73 71 6c 20 24 69 6e 69 74 73 71   execsql $initsq
2d60: 6c 0a 20 20 20 20 73 65 74 20 78 20 30 0a 20 20  l.    set x 0.  
2d70: 20 20 66 6f 72 65 61 63 68 20 73 71 6c 20 24 61    foreach sql $a
2d80: 72 67 73 20 7b 0a 20 20 20 20 20 20 69 6e 63 72  rgs {.      incr
2d90: 20 78 0a 20 20 20 20 20 20 73 65 74 20 6c 53 71   x.      set lSq
2da0: 6c 20 5b 73 70 6c 69 74 20 24 73 71 6c 20 22 3b  l [split $sql ";
2db0: 22 5d 0a 20 20 20 20 20 20 75 70 6c 65 76 65 6c  "].      uplevel
2dc0: 20 5b 6c 69 73 74 20 64 6f 5f 70 61 74 63 68 73   [list do_patchs
2dd0: 65 74 5f 74 65 73 74 20 24 74 6e 2e 24 74 73 74  et_test $tn.$tst
2de0: 63 6d 64 2e 24 78 20 24 74 73 74 63 6d 64 20 24  cmd.$x $tstcmd $
2df0: 6c 53 71 6c 5d 0a 20 20 20 20 7d 0a 20 20 7d 0a  lSql].    }.  }.
2e00: 7d 0a 0a 64 6f 5f 70 61 74 63 68 73 65 74 5f 63  }..do_patchset_c
2e10: 68 61 6e 67 65 73 65 74 5f 74 65 73 74 20 35 2e  hangeset_test 5.
2e20: 31 20 7b 0a 20 20 43 52 45 41 54 45 20 54 41 42  1 {.  CREATE TAB
2e30: 4c 45 20 74 31 28 61 20 50 52 49 4d 41 52 59 20  LE t1(a PRIMARY 
2e40: 4b 45 59 2c 20 62 2c 20 63 29 3b 0a 20 20 49 4e  KEY, b, c);.  IN
2e50: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
2e60: 55 45 53 28 31 2c 20 32 2c 20 33 29 3b 0a 7d 20  UES(1, 2, 3);.} 
2e70: 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20  {.  INSERT INTO 
2e80: 74 31 20 56 41 4c 55 45 53 28 34 2c 20 35 2c 20  t1 VALUES(4, 5, 
2e90: 36 29 3b 0a 20 20 44 45 4c 45 54 45 20 46 52 4f  6);.  DELETE FRO
2ea0: 4d 20 74 31 20 57 48 45 52 45 20 61 3d 31 3b 0a  M t1 WHERE a=1;.
2eb0: 7d 20 7b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  } {.  INSERT INT
2ec0: 4f 20 74 31 20 56 41 4c 55 45 53 28 37 2c 20 38  O t1 VALUES(7, 8
2ed0: 2c 20 39 29 3b 0a 20 20 55 50 44 41 54 45 20 74  , 9);.  UPDATE t
2ee0: 31 20 53 45 54 20 63 20 3d 20 35 3b 0a 20 20 49  1 SET c = 5;.  I
2ef0: 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41  NSERT INTO t1 VA
2f00: 4c 55 45 53 28 31 30 2c 20 31 31 2c 20 31 32 29  LUES(10, 11, 12)
2f10: 3b 0a 20 20 55 50 44 41 54 45 20 74 31 20 53 45  ;.  UPDATE t1 SE
2f20: 54 20 63 20 3d 20 36 3b 0a 20 20 49 4e 53 45 52  T c = 6;.  INSER
2f30: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
2f40: 28 31 33 2c 20 31 34 2c 20 31 35 29 3b 0a 7d 20  (13, 14, 15);.} 
2f50: 7b 0a 20 20 55 50 44 41 54 45 20 74 31 20 53 45  {.  UPDATE t1 SE
2f60: 54 20 63 3d 63 2b 31 3b 0a 20 20 44 45 4c 45 54  T c=c+1;.  DELET
2f70: 45 20 46 52 4f 4d 20 74 31 20 57 48 45 52 45 20  E FROM t1 WHERE 
2f80: 28 61 25 32 29 3b 0a 7d 20 0a 0a 64 6f 5f 70 61  (a%2);.} ..do_pa
2f90: 74 63 68 73 65 74 5f 63 68 61 6e 67 65 73 65 74  tchset_changeset
2fa0: 5f 74 65 73 74 20 35 2e 32 20 7b 0a 20 20 43 52  _test 5.2 {.  CR
2fb0: 45 41 54 45 20 54 41 42 4c 45 20 74 31 28 61 20  EATE TABLE t1(a 
2fc0: 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 2c 20  PRIMARY KEY, b, 
2fd0: 63 29 3b 0a 20 20 43 52 45 41 54 45 20 54 41 42  c);.  CREATE TAB
2fe0: 4c 45 20 74 32 28 61 2c 20 62 2c 20 63 2c 20 64  LE t2(a, b, c, d
2ff0: 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28 63 2c  , PRIMARY KEY(c,
3000: 20 62 29 29 3b 0a 7d 20 7b 0a 20 20 49 4e 53 45   b));.} {.  INSE
3010: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
3020: 53 28 78 27 30 30 27 2c 20 30 2c 20 27 7a 65 72  S(x'00', 0, 'zer
3030: 6f 27 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e  o');.  INSERT IN
3040: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 78 27 30  TO t1 VALUES(x'0
3050: 31 27 2c 20 31 2c 20 27 6f 6e 65 27 29 3b 0a 20  1', 1, 'one');. 
3060: 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 20   INSERT INTO t1 
3070: 56 41 4c 55 45 53 28 78 27 30 32 27 2c 20 34 2c  VALUES(x'02', 4,
3080: 20 27 66 6f 75 72 27 29 3b 0a 20 20 49 4e 53 45   'four');.  INSE
3090: 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45  RT INTO t1 VALUE
30a0: 53 28 78 27 30 33 27 2c 20 39 2c 20 27 6e 69 6e  S(x'03', 9, 'nin
30b0: 65 27 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e  e');.  INSERT IN
30c0: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 78 27 30  TO t1 VALUES(x'0
30d0: 34 27 2c 20 31 36 2c 20 27 73 69 78 74 65 65 6e  4', 16, 'sixteen
30e0: 27 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  ');.  INSERT INT
30f0: 4f 20 74 31 20 56 41 4c 55 45 53 28 78 27 30 35  O t1 VALUES(x'05
3100: 27 2c 20 32 35 2c 20 27 74 77 65 6e 74 79 2d 66  ', 25, 'twenty-f
3110: 69 76 65 27 29 3b 0a 7d 20 7b 0a 20 20 55 50 44  ive');.} {.  UPD
3120: 41 54 45 20 74 31 20 53 45 54 20 61 20 3d 20 62  ATE t1 SET a = b
3130: 20 57 48 45 52 45 20 62 3c 3d 34 3b 0a 20 20 49   WHERE b<=4;.  I
3140: 4e 53 45 52 54 20 49 4e 54 4f 20 74 32 20 53 45  NSERT INTO t2 SE
3150: 4c 45 43 54 20 4e 55 4c 4c 2c 20 2a 20 46 52 4f  LECT NULL, * FRO
3160: 4d 20 74 31 3b 0a 20 20 44 45 4c 45 54 45 20 46  M t1;.  DELETE F
3170: 52 4f 4d 20 74 31 20 57 48 45 52 45 20 62 3d 32  ROM t1 WHERE b=2
3180: 35 3b 0a 7d 20 7b 0a 20 20 44 45 4c 45 54 45 20  5;.} {.  DELETE 
3190: 46 52 4f 4d 20 74 32 3b 0a 20 20 49 4e 53 45 52  FROM t2;.  INSER
31a0: 54 20 49 4e 54 4f 20 74 32 20 53 45 4c 45 43 54  T INTO t2 SELECT
31b0: 20 4e 55 4c 4c 2c 20 2a 20 46 52 4f 4d 20 74 31   NULL, * FROM t1
31c0: 3b 0a 20 20 44 45 4c 45 54 45 20 46 52 4f 4d 20  ;.  DELETE FROM 
31d0: 74 31 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e 54  t1;.  INSERT INT
31e0: 4f 20 74 31 20 53 45 4c 45 43 54 20 62 2c 20 63  O t1 SELECT b, c
31f0: 2c 20 64 20 46 52 4f 4d 20 74 32 3b 0a 20 20 55  , d FROM t2;.  U
3200: 50 44 41 54 45 20 74 31 20 53 45 54 20 62 20 3d  PDATE t1 SET b =
3210: 20 62 2b 31 3b 0a 20 20 55 50 44 41 54 45 20 74   b+1;.  UPDATE t
3220: 31 20 53 45 54 20 62 20 3d 20 62 2b 31 3b 0a 20  1 SET b = b+1;. 
3230: 20 55 50 44 41 54 45 20 74 31 20 53 45 54 20 62   UPDATE t1 SET b
3240: 20 3d 20 62 2b 31 3b 0a 7d 0a 0a 73 65 74 20 69   = b+1;.}..set i
3250: 6e 69 74 73 71 6c 20 7b 20 43 52 45 41 54 45 20  nitsql { CREATE 
3260: 54 41 42 4c 45 20 74 31 28 61 2c 20 62 2c 20 63  TABLE t1(a, b, c
3270: 2c 20 50 52 49 4d 41 52 59 20 4b 45 59 28 63 2c  , PRIMARY KEY(c,
3280: 20 62 29 29 3b 20 7d 0a 66 6f 72 20 7b 73 65 74   b)); }.for {set
3290: 20 69 20 30 7d 20 7b 24 69 20 3c 20 31 30 30 30   i 0} {$i < 1000
32a0: 7d 20 7b 69 6e 63 72 20 69 7d 20 7b 0a 20 20 61  } {incr i} {.  a
32b0: 70 70 65 6e 64 20 69 6e 73 65 72 74 20 22 49 4e  ppend insert "IN
32c0: 53 45 52 54 20 49 4e 54 4f 20 74 31 20 56 41 4c  SERT INTO t1 VAL
32d0: 55 45 53 28 24 69 2c 20 24 69 2c 20 24 69 29 3b  UES($i, $i, $i);
32e0: 22 0a 20 20 61 70 70 65 6e 64 20 64 65 6c 65 74  ".  append delet
32f0: 65 20 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 74  e "DELETE FROM t
3300: 31 20 57 48 45 52 45 20 62 3d 24 69 3b 22 0a 7d  1 WHERE b=$i;".}
3310: 0a 64 6f 5f 70 61 74 63 68 73 65 74 5f 63 68 61  .do_patchset_cha
3320: 6e 67 65 73 65 74 5f 74 65 73 74 20 35 2e 33 20  ngeset_test 5.3 
3330: 5c 0a 20 20 24 69 6e 69 74 73 71 6c 20 24 69 6e  \.  $initsql $in
3340: 73 65 72 74 20 24 64 65 6c 65 74 65 20 20 20 20  sert $delete    
3350: 20 5c 0a 20 20 24 69 6e 73 65 72 74 20 24 64 65   \.  $insert $de
3360: 6c 65 74 65 20 20 20 20 20 20 20 20 20 20 20 20  lete            
3370: 20 20 5c 0a 20 20 22 24 69 6e 73 65 72 74 20 24    \.  "$insert $
3380: 64 65 6c 65 74 65 22 20 20 20 20 20 20 20 20 20  delete"         
3390: 20 20 20 5c 0a 20 20 24 64 65 6c 65 74 65 0a 0a     \.  $delete..
33a0: 0a 66 69 6e 69 73 68 5f 74 65 73 74 0a           .finish_test.