SQLite4
Hex Artifact Content
Not logged in

Artifact 19895f211a3c060c4ea03eb4110d59b80a7564fe:


0000: 23 20 32 30 30 35 20 4e 6f 76 65 6d 62 65 72 20  # 2005 November 
0010: 33 30 0a 23 0a 23 20 54 68 65 20 61 75 74 68 6f  30.#.# The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67 61  lace of.# a lega
0060: 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20 69  l notice, here i
0070: 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a  s a blessing:.#.
0080: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f 20  #    May you do 
0090: 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76 69  good and not evi
00a0: 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  l..#    May you 
00b0: 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73 73  find forgiveness
00c0: 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61 6e   for yourself an
00d0: 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72 73  d forgive others
00e0: 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 73  ..#    May you s
00f0: 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65 76  hare freely, nev
0100: 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74  er taking more t
0110: 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a  han you give..#.
0120: 23 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 2a 2a 0a 23 0a 23 20 54 68 69  ********.#.# Thi
0170: 73 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20  s file contains 
0180: 74 65 73 74 73 20 74 6f 20 65 6e 73 75 72 65 20  tests to ensure 
0190: 74 68 61 74 20 74 68 65 20 6c 69 62 72 61 72 79  that the library
01a0: 20 68 61 6e 64 6c 65 73 20 6d 61 6c 6c 6f 63 28   handles malloc(
01b0: 29 20 66 61 69 6c 75 72 65 73 0a 23 20 63 6f 72  ) failures.# cor
01c0: 72 65 63 74 6c 79 2e 20 54 68 65 20 65 6d 70 68  rectly. The emph
01d0: 61 73 69 73 20 69 6e 20 74 68 69 73 20 66 69 6c  asis in this fil
01e0: 65 20 69 73 20 6f 6e 20 73 71 6c 69 74 65 34 5f  e is on sqlite4_
01f0: 63 6f 6c 75 6d 6e 5f 58 58 58 28 29 20 41 50 49  column_XXX() API
0200: 73 2e 0a 23 0a 23 20 24 49 64 3a 20 6d 61 6c 6c  s..#.# $Id: mall
0210: 6f 63 34 2e 74 65 73 74 2c 76 20 31 2e 31 30 20  oc4.test,v 1.10 
0220: 32 30 30 38 2f 30 32 2f 31 38 20 32 32 3a 32 34  2008/02/18 22:24
0230: 3a 35 38 20 64 72 68 20 45 78 70 20 24 0a 0a 23  :58 drh Exp $..#
0240: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0250: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0280: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 23 20 4e 4f  -----------.# NO
0290: 54 45 53 20 4f 4e 20 45 58 50 45 43 54 45 44 20  TES ON EXPECTED 
02a0: 42 45 48 41 56 49 4f 55 52 0a 23 0a 23 20 5b 31  BEHAVIOUR.#.# [1
02b0: 39 33 5d 20 57 68 65 6e 20 61 20 6d 65 6d 6f 72  93] When a memor
02c0: 79 20 61 6c 6c 6f 63 61 74 69 6f 6e 20 66 61 69  y allocation fai
02d0: 6c 75 72 65 20 6f 63 63 75 72 73 20 64 75 72 69  lure occurs duri
02e0: 6e 67 20 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d  ng sqlite4_colum
02f0: 6e 5f 6e 61 6d 65 28 29 2c 0a 23 20 20 20 20 20  n_name(),.#     
0300: 20 20 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e    sqlite4_column
0310: 5f 6e 61 6d 65 31 36 28 29 2c 20 73 71 6c 69 74  _name16(), sqlit
0320: 65 34 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79  e4_column_declty
0330: 70 65 28 29 2c 20 6f 72 0a 23 20 20 20 20 20 20  pe(), or.#      
0340: 20 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f   sqlite4_column_
0350: 64 65 63 6c 74 79 70 65 31 36 28 29 20 74 68 65  decltype16() the
0360: 20 66 75 6e 63 74 69 6f 6e 20 73 68 61 6c 6c 20   function shall 
0370: 72 65 74 75 72 6e 20 4e 55 4c 4c 2e 0a 23 0a 23  return NULL..#.#
0380: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0390: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
03c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 0a 73 65 74  -----------..set
03d0: 20 74 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64   testdir [file d
03e0: 69 72 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73  irname $argv0].s
03f0: 6f 75 72 63 65 20 24 74 65 73 74 64 69 72 2f 74  ource $testdir/t
0400: 65 73 74 65 72 2e 74 63 6c 0a 73 6f 75 72 63 65  ester.tcl.source
0410: 20 24 74 65 73 74 64 69 72 2f 6d 61 6c 6c 6f 63   $testdir/malloc
0420: 5f 63 6f 6d 6d 6f 6e 2e 74 63 6c 0a 0a 23 20 4f  _common.tcl..# O
0430: 6e 6c 79 20 72 75 6e 20 74 68 65 73 65 20 74 65  nly run these te
0440: 73 74 73 20 69 66 20 6d 65 6d 6f 72 79 20 64 65  sts if memory de
0450: 62 75 67 67 69 6e 67 20 69 73 20 74 75 72 6e 65  bugging is turne
0460: 64 20 6f 6e 2e 0a 69 66 20 7b 21 24 4d 45 4d 44  d on..if {!$MEMD
0470: 45 42 55 47 7d 20 7b 0a 20 20 20 70 75 74 73 20  EBUG} {.   puts 
0480: 22 53 6b 69 70 70 69 6e 67 20 6d 61 6c 6c 6f 63  "Skipping malloc
0490: 34 20 74 65 73 74 73 3a 20 6e 6f 74 20 63 6f 6d  4 tests: not com
04a0: 70 69 6c 65 64 20 77 69 74 68 20 2d 44 53 51 4c  piled with -DSQL
04b0: 49 54 45 34 5f 4d 45 4d 44 45 42 55 47 2e 2e 2e  ITE4_MEMDEBUG...
04c0: 22 0a 20 20 20 66 69 6e 69 73 68 5f 74 65 73 74  ".   finish_test
04d0: 0a 20 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 69 66  .   return.}..if
04e0: 63 61 70 61 62 6c 65 20 21 75 74 66 31 36 20 7b  capable !utf16 {
04f0: 0a 20 20 66 69 6e 69 73 68 5f 74 65 73 74 0a 20  .  finish_test. 
0500: 20 72 65 74 75 72 6e 0a 7d 0a 0a 70 72 6f 63 20   return.}..proc 
0510: 64 6f 5f 73 74 6d 74 5f 74 65 73 74 20 7b 69 64  do_stmt_test {id
0520: 20 73 71 6c 7d 20 7b 0a 20 20 73 65 74 20 3a 3a   sql} {.  set ::
0530: 73 71 6c 20 24 73 71 6c 0a 20 20 73 65 74 20 67  sql $sql.  set g
0540: 6f 20 31 0a 20 20 66 6f 72 20 7b 73 65 74 20 6e  o 1.  for {set n
0550: 20 30 7d 20 7b 24 67 6f 7d 20 7b 69 6e 63 72 20   0} {$go} {incr 
0560: 6e 7d 20 7b 0a 20 20 20 20 73 65 74 20 74 65 73  n} {.    set tes
0570: 74 69 64 20 22 6d 61 6c 6c 6f 63 34 2d 24 69 64  tid "malloc4-$id
0580: 2e 24 6e 22 0a 0a 20 20 20 20 23 20 50 72 65 70  .$n"..    # Prep
0590: 61 72 65 20 74 68 65 20 73 74 61 74 65 6d 65 6e  are the statemen
05a0: 74 0a 20 20 20 20 64 6f 5f 74 65 73 74 20 24 7b  t.    do_test ${
05b0: 74 65 73 74 69 64 7d 2e 31 20 7b 0a 20 20 20 20  testid}.1 {.    
05c0: 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b 73 71    set ::STMT [sq
05d0: 6c 69 74 65 34 5f 70 72 65 70 61 72 65 20 24 3a  lite4_prepare $:
05e0: 3a 44 42 20 24 73 71 6c 20 2d 31 20 54 41 49 4c  :DB $sql -1 TAIL
05f0: 5d 0a 20 20 20 20 20 20 65 78 70 72 20 5b 73 74  ].      expr [st
0600: 72 69 6e 67 20 6c 65 6e 67 74 68 20 24 3a 3a 53  ring length $::S
0610: 54 4d 54 5d 20 3e 20 30 0a 20 20 20 20 7d 20 7b  TMT] > 0.    } {
0620: 31 7d 0a 0a 20 20 20 20 23 20 53 65 74 20 74 68  1}..    # Set th
0630: 65 20 4e 74 68 20 6d 61 6c 6c 6f 63 28 29 20 74  e Nth malloc() t
0640: 6f 20 66 61 69 6c 2e 0a 20 20 20 20 73 71 6c 69  o fail..    sqli
0650: 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61 69  te4_memdebug_fai
0660: 6c 20 24 6e 20 2d 72 65 70 65 61 74 20 30 0a 0a  l $n -repeat 0..
0670: 20 20 20 20 23 20 54 65 73 74 20 6d 61 6c 6c 6f      # Test mallo
0680: 63 20 66 61 69 6c 75 72 65 20 69 6e 20 74 68 65  c failure in the
0690: 20 5f 6e 61 6d 65 28 29 2c 20 5f 6e 61 6d 65 31   _name(), _name1
06a0: 36 28 29 2c 20 64 65 63 6c 74 79 70 65 28 29 20  6(), decltype() 
06b0: 61 6e 64 0a 20 20 20 20 23 20 64 65 63 6c 74 79  and.    # declty
06c0: 70 65 31 36 28 29 20 41 50 49 73 2e 20 43 61 6c  pe16() APIs. Cal
06d0: 6c 73 20 74 68 61 74 20 6f 63 63 75 72 20 61 66  ls that occur af
06e0: 74 65 72 20 74 68 65 20 6d 61 6c 6c 6f 63 28 29  ter the malloc()
06f0: 20 66 61 69 6c 75 72 65 20 73 68 6f 75 6c 64 0a   failure should.
0700: 20 20 20 20 23 20 72 65 74 75 72 6e 20 4e 55 4c      # return NUL
0710: 4c 2e 20 4e 6f 20 65 72 72 6f 72 20 69 73 20 72  L. No error is r
0720: 61 69 73 65 64 20 74 68 6f 75 67 68 2e 0a 20 20  aised though..  
0730: 20 20 23 0a 20 20 20 20 23 20 24 7b 74 65 73 74    #.    # ${test
0740: 69 64 7d 2e 32 2e 31 20 2d 20 43 61 6c 6c 20 5f  id}.2.1 - Call _
0750: 6e 61 6d 65 28 29 0a 20 20 20 20 23 20 24 7b 74  name().    # ${t
0760: 65 73 74 69 64 7d 2e 32 2e 32 20 2d 20 43 61 6c  estid}.2.2 - Cal
0770: 6c 20 5f 6e 61 6d 65 31 36 28 29 0a 20 20 20 20  l _name16().    
0780: 23 20 24 7b 74 65 73 74 69 64 7d 2e 32 2e 33 20  # ${testid}.2.3 
0790: 2d 20 43 61 6c 6c 20 5f 6e 61 6d 65 28 29 0a 20  - Call _name(). 
07a0: 20 20 20 23 20 24 7b 74 65 73 74 69 64 7d 2e 32     # ${testid}.2
07b0: 2e 34 20 2d 20 43 68 65 63 6b 20 74 68 61 74 20  .4 - Check that 
07c0: 74 68 65 20 72 65 74 75 72 6e 20 76 61 6c 75 65  the return value
07d0: 73 20 6f 66 20 74 68 65 20 61 62 6f 76 65 20 74  s of the above t
07e0: 68 72 65 65 20 63 61 6c 6c 73 20 61 72 65 0a 20  hree calls are. 
07f0: 20 20 20 23 20 20 20 20 20 20 20 20 20 20 20 20     #            
0800: 20 20 20 20 20 63 6f 6e 73 69 73 74 65 6e 74 20       consistent 
0810: 77 69 74 68 20 65 61 63 68 20 6f 74 68 65 72 20  with each other 
0820: 61 6e 64 20 77 69 74 68 20 74 68 65 20 73 69 6d  and with the sim
0830: 75 6c 61 74 65 64 0a 20 20 20 20 23 20 20 20 20  ulated.    #    
0840: 20 20 20 20 20 20 20 20 20 20 20 20 20 6d 61 6c               mal
0850: 6c 6f 63 28 29 20 66 61 69 6c 75 72 65 73 2e 0a  loc() failures..
0860: 20 20 20 20 23 0a 20 20 20 20 23 20 42 65 63 61      #.    # Beca
0870: 75 73 65 20 74 68 65 20 63 6f 64 65 20 74 68 61  use the code tha
0880: 74 20 69 6d 70 6c 65 6d 65 6e 74 73 20 74 68 65  t implements the
0890: 20 5f 64 65 63 6c 74 79 70 65 28 29 20 61 6e 64   _decltype() and
08a0: 20 5f 64 65 63 6c 74 79 70 65 31 36 28 29 20 41   _decltype16() A
08b0: 50 49 73 0a 20 20 20 20 23 20 69 73 20 74 68 65  PIs.    # is the
08c0: 20 73 61 6d 65 20 61 73 20 74 68 65 20 5f 6e 61   same as the _na
08d0: 6d 65 28 29 20 61 6e 64 20 5f 6e 61 6d 65 31 36  me() and _name16
08e0: 28 29 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  () implementatio
08f0: 6e 73 2c 20 77 65 20 64 6f 6e 27 74 20 77 6f 72  ns, we don't wor
0900: 72 79 0a 20 20 20 20 23 20 61 62 6f 75 74 20 65  ry.    # about e
0910: 78 70 6c 69 63 69 74 6c 79 20 74 65 73 74 69 6e  xplicitly testin
0920: 67 20 74 68 65 6d 2e 0a 20 20 20 20 23 0a 20 20  g them..    #.  
0930: 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74    do_test ${test
0940: 69 64 7d 2e 32 2e 31 20 7b 0a 20 20 20 20 20 20  id}.2.1 {.      
0950: 73 65 74 20 6d 66 31 20 5b 65 78 70 72 20 5b 73  set mf1 [expr [s
0960: 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f  qlite4_memdebug_
0970: 70 65 6e 64 69 6e 67 5d 20 3c 20 30 5d 0a 20 20  pending] < 0].  
0980: 20 20 20 20 73 65 74 20 3a 3a 6e 61 6d 65 38 20      set ::name8 
0990: 20 5b 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e   [sqlite4_column
09a0: 5f 6e 61 6d 65 20 24 3a 3a 53 54 4d 54 20 30 5d  _name $::STMT 0]
09b0: 0a 20 20 20 20 20 20 73 65 74 20 6d 66 32 20 5b  .      set mf2 [
09c0: 65 78 70 72 20 5b 73 71 6c 69 74 65 34 5f 6d 65  expr [sqlite4_me
09d0: 6d 64 65 62 75 67 5f 70 65 6e 64 69 6e 67 5d 20  mdebug_pending] 
09e0: 3c 20 30 5d 0a 20 20 20 20 20 20 65 78 70 72 20  < 0].      expr 
09f0: 7b 24 6d 66 31 20 3d 3d 20 24 6d 66 32 20 7c 7c  {$mf1 == $mf2 ||
0a00: 20 24 3a 3a 6e 61 6d 65 38 20 3d 3d 20 22 22 7d   $::name8 == ""}
0a10: 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20 20 20 64  .    } {1}.    d
0a20: 6f 5f 74 65 73 74 20 24 7b 74 65 73 74 69 64 7d  o_test ${testid}
0a30: 2e 32 2e 32 20 7b 0a 20 20 20 20 20 20 73 65 74  .2.2 {.      set
0a40: 20 6d 66 31 20 5b 65 78 70 72 20 5b 73 71 6c 69   mf1 [expr [sqli
0a50: 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 70 65 6e  te4_memdebug_pen
0a60: 64 69 6e 67 5d 20 3c 20 30 5d 0a 20 20 20 20 20  ding] < 0].     
0a70: 20 73 65 74 20 3a 3a 6e 61 6d 65 31 36 20 5b 73   set ::name16 [s
0a80: 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f 6e 61  qlite4_column_na
0a90: 6d 65 31 36 20 24 3a 3a 53 54 4d 54 20 30 5d 0a  me16 $::STMT 0].
0aa0: 20 20 20 20 20 20 73 65 74 20 3a 3a 6e 61 6d 65        set ::name
0ab0: 31 36 20 5b 65 6e 63 6f 64 69 6e 67 20 63 6f 6e  16 [encoding con
0ac0: 76 65 72 74 66 72 6f 6d 20 75 6e 69 63 6f 64 65  vertfrom unicode
0ad0: 20 24 3a 3a 6e 61 6d 65 31 36 5d 0a 20 20 20 20   $::name16].    
0ae0: 20 20 73 65 74 20 3a 3a 6e 61 6d 65 31 36 20 5b    set ::name16 [
0af0: 73 74 72 69 6e 67 20 72 61 6e 67 65 20 24 3a 3a  string range $::
0b00: 6e 61 6d 65 31 36 20 30 20 65 6e 64 2d 31 5d 0a  name16 0 end-1].
0b10: 20 20 20 20 20 20 73 65 74 20 6d 66 32 20 5b 65        set mf2 [e
0b20: 78 70 72 20 5b 73 71 6c 69 74 65 34 5f 6d 65 6d  xpr [sqlite4_mem
0b30: 64 65 62 75 67 5f 70 65 6e 64 69 6e 67 5d 20 3c  debug_pending] <
0b40: 20 30 5d 0a 20 20 20 20 20 20 65 78 70 72 20 7b   0].      expr {
0b50: 24 6d 66 31 20 3d 3d 20 24 6d 66 32 20 7c 7c 20  $mf1 == $mf2 || 
0b60: 24 3a 3a 6e 61 6d 65 31 36 20 3d 3d 20 22 22 7d  $::name16 == ""}
0b70: 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20 20 20 64  .    } {1}.    d
0b80: 6f 5f 74 65 73 74 20 24 7b 74 65 73 74 69 64 7d  o_test ${testid}
0b90: 2e 32 2e 33 20 7b 0a 20 20 20 20 20 20 73 65 74  .2.3 {.      set
0ba0: 20 6d 66 31 20 5b 65 78 70 72 20 5b 73 71 6c 69   mf1 [expr [sqli
0bb0: 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 70 65 6e  te4_memdebug_pen
0bc0: 64 69 6e 67 5d 20 3c 20 30 5d 0a 20 20 20 20 20  ding] < 0].     
0bd0: 20 73 65 74 20 3a 3a 6e 61 6d 65 38 5f 32 20 5b   set ::name8_2 [
0be0: 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f 6e  sqlite4_column_n
0bf0: 61 6d 65 20 24 3a 3a 53 54 4d 54 20 30 5d 0a 20  ame $::STMT 0]. 
0c00: 20 20 20 20 20 73 65 74 20 6d 66 32 20 5b 65 78       set mf2 [ex
0c10: 70 72 20 5b 73 71 6c 69 74 65 34 5f 6d 65 6d 64  pr [sqlite4_memd
0c20: 65 62 75 67 5f 70 65 6e 64 69 6e 67 5d 20 3c 20  ebug_pending] < 
0c30: 30 5d 0a 20 20 20 20 20 20 65 78 70 72 20 7b 24  0].      expr {$
0c40: 6d 66 31 20 3d 3d 20 24 6d 66 32 20 7c 7c 20 24  mf1 == $mf2 || $
0c50: 3a 3a 6e 61 6d 65 38 5f 32 20 3d 3d 20 22 22 7d  ::name8_2 == ""}
0c60: 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20 20 20 73  .    } {1}.    s
0c70: 65 74 20 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65  et ::mallocFaile
0c80: 64 20 5b 65 78 70 72 20 5b 73 71 6c 69 74 65 34  d [expr [sqlite4
0c90: 5f 6d 65 6d 64 65 62 75 67 5f 70 65 6e 64 69 6e  _memdebug_pendin
0ca0: 67 5d 20 3c 20 30 5d 0a 20 20 20 20 64 6f 5f 74  g] < 0].    do_t
0cb0: 65 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 32 2e  est ${testid}.2.
0cc0: 34 20 7b 0a 20 20 20 20 20 20 65 78 70 72 20 7b  4 {.      expr {
0cd0: 0a 20 20 20 20 20 20 20 20 24 3a 3a 6e 61 6d 65  .        $::name
0ce0: 38 20 3d 3d 20 24 3a 3a 6e 61 6d 65 38 5f 32 20  8 == $::name8_2 
0cf0: 26 26 20 24 3a 3a 6e 61 6d 65 31 36 20 3d 3d 20  && $::name16 == 
0d00: 24 3a 3a 6e 61 6d 65 38 20 26 26 20 21 24 3a 3a  $::name8 && !$::
0d10: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 7c 7c 0a  mallocFailed ||.
0d20: 20 20 20 20 20 20 20 20 24 3a 3a 6e 61 6d 65 38          $::name8
0d30: 20 3d 3d 20 24 3a 3a 6e 61 6d 65 38 5f 32 20 26   == $::name8_2 &
0d40: 26 20 24 3a 3a 6e 61 6d 65 31 36 20 3d 3d 20 22  & $::name16 == "
0d50: 22 20 26 26 20 20 20 20 20 20 20 20 24 3a 3a 6d  " &&        $::m
0d60: 61 6c 6c 6f 63 46 61 69 6c 65 64 20 7c 7c 0a 20  allocFailed ||. 
0d70: 20 20 20 20 20 20 20 24 3a 3a 6e 61 6d 65 38 20         $::name8 
0d80: 3d 3d 20 24 3a 3a 6e 61 6d 65 31 36 20 26 26 20  == $::name16 && 
0d90: 24 3a 3a 6e 61 6d 65 38 5f 32 20 3d 3d 20 22 22  $::name8_2 == ""
0da0: 20 26 26 20 20 20 20 20 20 20 20 24 3a 3a 6d 61   &&        $::ma
0db0: 6c 6c 6f 63 46 61 69 6c 65 64 20 7c 7c 0a 20 20  llocFailed ||.  
0dc0: 20 20 20 20 20 20 24 3a 3a 6e 61 6d 65 38 5f 32        $::name8_2
0dd0: 20 3d 3d 20 24 3a 3a 6e 61 6d 65 31 36 20 26 26   == $::name16 &&
0de0: 20 24 3a 3a 6e 61 6d 65 38 20 3d 3d 20 22 22 20   $::name8 == "" 
0df0: 26 26 20 20 20 20 20 20 20 20 24 3a 3a 6d 61 6c  &&        $::mal
0e00: 6c 6f 63 46 61 69 6c 65 64 0a 20 20 20 20 20 20  locFailed.      
0e10: 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a 0a 20 20 20  }.    } {1}..   
0e20: 20 23 20 53 74 65 70 20 74 68 65 20 73 74 61 74   # Step the stat
0e30: 65 6d 65 6e 74 20 73 6f 20 74 68 61 74 20 77 65  ement so that we
0e40: 20 63 61 6e 20 63 61 6c 6c 20 5f 74 65 78 74 28   can call _text(
0e50: 29 20 61 6e 64 20 5f 74 65 78 74 31 36 28 29 2e  ) and _text16().
0e60: 20 20 42 65 66 6f 72 65 0a 20 20 20 20 23 20 72    Before.    # r
0e70: 75 6e 6e 69 6e 67 20 73 71 6c 69 74 65 34 5f 73  unning sqlite4_s
0e80: 74 65 70 28 29 2c 20 6d 61 6b 65 20 73 75 72 65  tep(), make sure
0e90: 20 74 68 61 74 20 6d 61 6c 6c 6f 63 28 29 20 69   that malloc() i
0ea0: 73 20 6e 6f 74 20 61 62 6f 75 74 20 74 6f 20 66  s not about to f
0eb0: 61 69 6c 2e 0a 20 20 20 20 23 20 4d 65 6d 6f 72  ail..    # Memor
0ec0: 79 20 61 6c 6c 6f 63 61 74 69 6f 6e 20 66 61 69  y allocation fai
0ed0: 6c 75 72 65 73 20 74 68 61 74 20 6f 63 63 75 72  lures that occur
0ee0: 20 77 69 74 68 69 6e 20 73 71 6c 69 74 65 34 5f   within sqlite4_
0ef0: 73 74 65 70 28 29 20 61 72 65 20 74 65 73 74 65  step() are teste
0f00: 64 0a 20 20 20 20 23 20 65 6c 73 65 77 68 65 72  d.    # elsewher
0f10: 65 2e 0a 20 20 20 20 73 65 74 20 6d 66 20 5b 73  e..    set mf [s
0f20: 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f  qlite4_memdebug_
0f30: 70 65 6e 64 69 6e 67 5d 0a 20 20 20 20 73 71 6c  pending].    sql
0f40: 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61  ite4_memdebug_fa
0f50: 69 6c 20 2d 31 0a 20 20 20 20 64 6f 5f 74 65 73  il -1.    do_tes
0f60: 74 20 24 7b 74 65 73 74 69 64 7d 2e 33 20 7b 0a  t ${testid}.3 {.
0f70: 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 73 74        sqlite4_st
0f80: 65 70 20 24 3a 3a 53 54 4d 54 0a 20 20 20 20 7d  ep $::STMT.    }
0f90: 20 7b 53 51 4c 49 54 45 34 5f 52 4f 57 7d 0a 20   {SQLITE4_ROW}. 
0fa0: 20 20 20 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65     sqlite4_memde
0fb0: 62 75 67 5f 66 61 69 6c 20 24 6d 66 0a 0a 20 20  bug_fail $mf..  
0fc0: 20 20 23 20 54 65 73 74 20 66 6f 72 20 6d 61 6c    # Test for mal
0fd0: 6c 6f 63 28 29 20 66 61 69 6c 75 72 65 73 20 77  loc() failures w
0fe0: 69 74 68 69 6e 20 5f 74 65 78 74 28 29 20 61 6e  ithin _text() an
0ff0: 64 20 5f 74 65 78 74 31 36 28 29 2e 0a 20 20 20  d _text16()..   
1000: 20 23 0a 20 20 20 20 64 6f 5f 74 65 73 74 20 24   #.    do_test $
1010: 7b 74 65 73 74 69 64 7d 2e 34 2e 31 20 7b 0a 20  {testid}.4.1 {. 
1020: 20 20 20 20 20 73 65 74 20 3a 3a 74 65 78 74 38       set ::text8
1030: 20 5b 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e   [sqlite4_column
1040: 5f 74 65 78 74 20 24 3a 3a 53 54 4d 54 20 30 5d  _text $::STMT 0]
1050: 0a 20 20 20 20 20 20 73 65 74 20 6d 66 20 5b 65  .      set mf [e
1060: 78 70 72 20 5b 73 71 6c 69 74 65 34 5f 6d 65 6d  xpr [sqlite4_mem
1070: 64 65 62 75 67 5f 70 65 6e 64 69 6e 67 5d 20 3c  debug_pending] <
1080: 20 30 20 26 26 20 21 24 3a 3a 6d 61 6c 6c 6f 63   0 && !$::malloc
1090: 46 61 69 6c 65 64 5d 0a 20 20 20 20 20 20 65 78  Failed].      ex
10a0: 70 72 20 7b 24 6d 66 3d 3d 30 20 7c 7c 20 24 3a  pr {$mf==0 || $:
10b0: 3a 74 65 78 74 38 20 3d 3d 20 22 22 7d 0a 20 20  :text8 == ""}.  
10c0: 20 20 7d 20 7b 31 7d 0a 20 20 20 20 64 6f 5f 74    } {1}.    do_t
10d0: 65 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 34 2e  est ${testid}.4.
10e0: 32 20 7b 0a 20 20 20 20 20 20 73 65 74 20 3a 3a  2 {.      set ::
10f0: 74 65 78 74 31 36 20 5b 73 71 6c 69 74 65 34 5f  text16 [sqlite4_
1100: 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 20 24 3a  column_text16 $:
1110: 3a 53 54 4d 54 20 30 5d 0a 20 20 20 20 20 20 73  :STMT 0].      s
1120: 65 74 20 3a 3a 74 65 78 74 31 36 20 5b 65 6e 63  et ::text16 [enc
1130: 6f 64 69 6e 67 20 63 6f 6e 76 65 72 74 66 72 6f  oding convertfro
1140: 6d 20 75 6e 69 63 6f 64 65 20 24 3a 3a 74 65 78  m unicode $::tex
1150: 74 31 36 5d 0a 20 20 20 20 20 20 73 65 74 20 3a  t16].      set :
1160: 3a 74 65 78 74 31 36 20 5b 73 74 72 69 6e 67 20  :text16 [string 
1170: 72 61 6e 67 65 20 24 3a 3a 74 65 78 74 31 36 20  range $::text16 
1180: 30 20 65 6e 64 2d 31 5d 0a 20 20 20 20 20 20 73  0 end-1].      s
1190: 65 74 20 6d 66 20 5b 65 78 70 72 20 5b 73 71 6c  et mf [expr [sql
11a0: 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 70 65  ite4_memdebug_pe
11b0: 6e 64 69 6e 67 5d 20 3c 20 30 20 26 26 20 21 24  nding] < 0 && !$
11c0: 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 5d 0a  ::mallocFailed].
11d0: 20 20 20 20 20 20 65 78 70 72 20 7b 24 6d 66 3d        expr {$mf=
11e0: 3d 30 20 7c 7c 20 24 3a 3a 74 65 78 74 31 36 20  =0 || $::text16 
11f0: 3d 3d 20 22 22 7d 0a 20 20 20 20 7d 20 7b 31 7d  == ""}.    } {1}
1200: 0a 20 20 20 20 64 6f 5f 74 65 73 74 20 24 7b 74  .    do_test ${t
1210: 65 73 74 69 64 7d 2e 34 2e 33 20 7b 0a 20 20 20  estid}.4.3 {.   
1220: 20 20 20 73 65 74 20 3a 3a 74 65 78 74 38 5f 32     set ::text8_2
1230: 20 5b 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e   [sqlite4_column
1240: 5f 74 65 78 74 20 24 3a 3a 53 54 4d 54 20 30 5d  _text $::STMT 0]
1250: 0a 20 20 20 20 20 20 73 65 74 20 6d 66 20 5b 65  .      set mf [e
1260: 78 70 72 20 5b 73 71 6c 69 74 65 34 5f 6d 65 6d  xpr [sqlite4_mem
1270: 64 65 62 75 67 5f 70 65 6e 64 69 6e 67 5d 20 3c  debug_pending] <
1280: 20 30 20 26 26 20 21 24 3a 3a 6d 61 6c 6c 6f 63   0 && !$::malloc
1290: 46 61 69 6c 65 64 5d 0a 20 20 20 20 20 20 65 78  Failed].      ex
12a0: 70 72 20 7b 24 6d 66 3d 3d 30 20 7c 7c 20 24 3a  pr {$mf==0 || $:
12b0: 3a 74 65 78 74 38 5f 32 20 3d 3d 20 22 22 20 7c  :text8_2 == "" |
12c0: 7c 20 28 24 3a 3a 74 65 78 74 31 36 20 3d 3d 20  | ($::text16 == 
12d0: 22 22 20 26 26 20 24 3a 3a 74 65 78 74 38 20 21  "" && $::text8 !
12e0: 3d 20 22 22 29 7d 0a 20 20 20 20 7d 20 7b 31 7d  = "")}.    } {1}
12f0: 0a 0a 20 20 20 20 23 20 54 65 73 74 20 66 6f 72  ..    # Test for
1300: 20 6d 61 6c 6c 6f 63 28 29 20 66 61 69 6c 75 72   malloc() failur
1310: 65 73 20 77 69 74 68 69 6e 20 5f 69 6e 74 28 29  es within _int()
1320: 2c 20 5f 69 6e 74 36 34 28 29 20 61 6e 64 20 5f  , _int64() and _
1330: 72 65 61 6c 28 29 2e 20 54 68 65 20 6f 6e 6c 79  real(). The only
1340: 0a 20 20 20 20 23 20 77 61 79 20 74 68 69 73 20  .    # way this 
1350: 63 61 6e 20 6f 63 63 75 72 20 69 73 20 69 66 20  can occur is if 
1360: 74 68 65 20 73 74 72 69 6e 67 20 68 61 73 20 74  the string has t
1370: 6f 20 62 65 20 74 72 61 6e 73 6c 61 74 65 64 20  o be translated 
1380: 66 72 6f 6d 20 55 54 46 2d 31 36 20 74 6f 0a 20  from UTF-16 to. 
1390: 20 20 20 23 20 55 54 46 2d 38 20 62 65 66 6f 72     # UTF-8 befor
13a0: 65 20 62 65 69 6e 67 20 63 6f 6e 76 65 72 74 65  e being converte
13b0: 64 20 74 6f 20 61 20 6e 75 6d 65 72 69 63 20 76  d to a numeric v
13c0: 61 6c 75 65 2e 0a 20 20 20 20 64 6f 5f 74 65 73  alue..    do_tes
13d0: 74 20 24 7b 74 65 73 74 69 64 7d 2e 34 2e 34 2e  t ${testid}.4.4.
13e0: 31 20 7b 0a 20 20 20 20 20 20 73 65 74 20 6d 66  1 {.      set mf
13f0: 20 5b 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62   [sqlite4_memdeb
1400: 75 67 5f 70 65 6e 64 69 6e 67 5d 0a 20 20 20 20  ug_pending].    
1410: 20 20 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62    sqlite4_memdeb
1420: 75 67 5f 66 61 69 6c 20 2d 31 0a 20 20 20 20 20  ug_fail -1.     
1430: 20 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f   sqlite4_column_
1440: 74 65 78 74 31 36 20 24 3a 3a 53 54 4d 54 20 30  text16 $::STMT 0
1450: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 6d  .      sqlite4_m
1460: 65 6d 64 65 62 75 67 5f 66 61 69 6c 20 24 6d 66  emdebug_fail $mf
1470: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 63  .      sqlite4_c
1480: 6f 6c 75 6d 6e 5f 69 6e 74 20 24 3a 3a 53 54 4d  olumn_int $::STM
1490: 54 20 30 0a 20 20 20 20 7d 20 7b 30 7d 0a 20 20  T 0.    } {0}.  
14a0: 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74    do_test ${test
14b0: 69 64 7d 2e 34 2e 35 20 7b 0a 20 20 20 20 20 20  id}.4.5 {.      
14c0: 73 65 74 20 6d 66 20 5b 73 71 6c 69 74 65 34 5f  set mf [sqlite4_
14d0: 6d 65 6d 64 65 62 75 67 5f 70 65 6e 64 69 6e 67  memdebug_pending
14e0: 5d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f  ].      sqlite4_
14f0: 6d 65 6d 64 65 62 75 67 5f 66 61 69 6c 20 2d 31  memdebug_fail -1
1500: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 63  .      sqlite4_c
1510: 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 20 24 3a 3a  olumn_text16 $::
1520: 53 54 4d 54 20 30 0a 20 20 20 20 20 20 73 71 6c  STMT 0.      sql
1530: 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61  ite4_memdebug_fa
1540: 69 6c 20 24 6d 66 0a 20 20 20 20 20 20 73 71 6c  il $mf.      sql
1550: 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36  ite4_column_int6
1560: 34 20 24 3a 3a 53 54 4d 54 20 30 0a 20 20 20 20  4 $::STMT 0.    
1570: 7d 20 7b 30 7d 0a 0a 20 20 20 20 64 6f 5f 74 65  } {0}..    do_te
1580: 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 34 2e 36  st ${testid}.4.6
1590: 20 7b 0a 20 20 20 20 20 20 73 65 74 20 6d 66 20   {.      set mf 
15a0: 5b 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62 75  [sqlite4_memdebu
15b0: 67 5f 70 65 6e 64 69 6e 67 5d 0a 20 20 20 20 20  g_pending].     
15c0: 20 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62 75   sqlite4_memdebu
15d0: 67 5f 66 61 69 6c 20 2d 31 0a 20 20 20 20 20 20  g_fail -1.      
15e0: 73 71 6c 69 74 65 34 5f 63 6f 6c 75 6d 6e 5f 74  sqlite4_column_t
15f0: 65 78 74 31 36 20 24 3a 3a 53 54 4d 54 20 30 0a  ext16 $::STMT 0.
1600: 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 6d 65        sqlite4_me
1610: 6d 64 65 62 75 67 5f 66 61 69 6c 20 24 6d 66 0a  mdebug_fail $mf.
1620: 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 63 6f        sqlite4_co
1630: 6c 75 6d 6e 5f 64 6f 75 62 6c 65 20 24 3a 3a 53  lumn_double $::S
1640: 54 4d 54 20 30 0a 20 20 20 20 7d 20 7b 30 2e 30  TMT 0.    } {0.0
1650: 7d 0a 0a 20 20 20 20 73 65 74 20 6d 61 6c 6c 6f  }..    set mallo
1660: 63 46 61 69 6c 65 64 41 66 74 65 72 53 74 65 70  cFailedAfterStep
1670: 20 5b 65 78 70 72 20 5c 0a 20 20 20 20 20 20 5b   [expr \.      [
1680: 73 71 6c 69 74 65 34 5f 6d 65 6d 64 65 62 75 67  sqlite4_memdebug
1690: 5f 70 65 6e 64 69 6e 67 5d 20 3c 20 30 20 26 26  _pending] < 0 &&
16a0: 20 21 24 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65   !$::mallocFaile
16b0: 64 0a 20 20 20 20 5d 0a 0a 20 20 20 20 73 71 6c  d.    ]..    sql
16c0: 69 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61  ite4_memdebug_fa
16d0: 69 6c 20 2d 31 0a 20 20 20 20 23 20 54 65 73 74  il -1.    # Test
16e0: 20 74 68 61 74 20 69 66 20 61 20 6d 61 6c 6c 6f   that if a mallo
16f0: 63 28 29 20 66 61 69 6c 65 64 20 74 68 65 20 6e  c() failed the n
1700: 65 78 74 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69  ext call to sqli
1710: 74 65 34 5f 73 74 65 70 28 29 20 72 65 74 75 72  te4_step() retur
1720: 6e 73 0a 20 20 20 20 23 20 53 51 4c 49 54 45 34  ns.    # SQLITE4
1730: 5f 45 52 52 4f 52 2e 20 49 66 20 6d 61 6c 6c 6f  _ERROR. If mallo
1740: 63 28 29 20 64 69 64 20 6e 6f 74 20 66 61 69 6c  c() did not fail
1750: 2c 20 69 74 20 73 68 6f 75 6c 64 20 72 65 74 75  , it should retu
1760: 72 6e 20 53 51 4c 49 54 45 34 5f 44 4f 4e 45 2e  rn SQLITE4_DONE.
1770: 0a 20 20 20 20 23 0a 20 20 20 20 64 6f 5f 74 65  .    #.    do_te
1780: 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 35 20 7b  st ${testid}.5 {
1790: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 73  .      sqlite4_s
17a0: 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20 20 20 20  tep $::STMT.    
17b0: 7d 20 5b 65 78 70 72 20 7b 24 6d 61 6c 6c 6f 63  } [expr {$malloc
17c0: 46 61 69 6c 65 64 41 66 74 65 72 53 74 65 70 20  FailedAfterStep 
17d0: 3f 20 22 53 51 4c 49 54 45 34 5f 45 52 52 4f 52  ? "SQLITE4_ERROR
17e0: 22 20 3a 20 22 53 51 4c 49 54 45 34 5f 44 4f 4e  " : "SQLITE4_DON
17f0: 45 22 7d 5d 0a 0a 20 20 20 20 64 6f 5f 74 65 73  E"}]..    do_tes
1800: 74 20 24 7b 74 65 73 74 69 64 7d 2e 36 20 7b 0a  t ${testid}.6 {.
1810: 20 20 20 20 20 20 73 71 6c 69 74 65 34 5f 66 69        sqlite4_fi
1820: 6e 61 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 20  nalize $::STMT. 
1830: 20 20 20 7d 20 5b 65 78 70 72 20 7b 24 6d 61 6c     } [expr {$mal
1840: 6c 6f 63 46 61 69 6c 65 64 41 66 74 65 72 53 74  locFailedAfterSt
1850: 65 70 20 3f 20 22 53 51 4c 49 54 45 34 5f 4e 4f  ep ? "SQLITE4_NO
1860: 4d 45 4d 22 20 3a 20 22 53 51 4c 49 54 45 34 5f  MEM" : "SQLITE4_
1870: 4f 4b 22 7d 5d 0a 0a 20 20 20 20 69 66 20 7b 24  OK"}]..    if {$
1880: 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 3d  ::mallocFailed =
1890: 3d 20 30 20 26 26 20 24 6d 61 6c 6c 6f 63 46 61  = 0 && $mallocFa
18a0: 69 6c 65 64 41 66 74 65 72 53 74 65 70 20 3d 3d  iledAfterStep ==
18b0: 20 30 7d 20 7b 0a 20 20 20 20 20 20 73 71 6c 69   0} {.      sqli
18c0: 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61 69  te4_memdebug_fai
18d0: 6c 20 2d 31 0a 20 20 20 20 20 20 73 65 74 20 67  l -1.      set g
18e0: 6f 20 30 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a  o 0.    }.  }.}.
18f0: 0a 65 78 65 63 73 71 6c 20 7b 0a 20 20 43 52 45  .execsql {.  CRE
1900: 41 54 45 20 54 41 42 4c 45 20 74 62 6c 28 0a 20  ATE TABLE tbl(. 
1910: 20 20 20 74 68 65 5f 66 69 72 73 74 5f 72 65 61     the_first_rea
1920: 73 6f 6e 61 62 6c 79 5f 6c 6f 6e 67 5f 63 6f 6c  sonably_long_col
1930: 75 6d 6e 5f 6e 61 6d 65 20 74 68 61 74 5f 61 6c  umn_name that_al
1940: 73 6f 5f 68 61 73 5f 71 75 69 74 65 5f 61 5f 6c  so_has_quite_a_l
1950: 65 6e 67 74 68 79 5f 74 79 70 65 0a 20 20 29 3b  engthy_type.  );
1960: 0a 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  .  INSERT INTO t
1970: 62 6c 20 56 41 4c 55 45 53 28 0a 20 20 20 20 27  bl VALUES(.    '
1980: 41 6e 20 65 78 74 72 61 20 6c 6f 6e 67 20 73 74  An extra long st
1990: 72 69 6e 67 2e 20 46 61 72 20 74 6f 6f 20 6c 6f  ring. Far too lo
19a0: 6e 67 20 74 6f 20 62 65 20 73 74 6f 72 65 64 20  ng to be stored 
19b0: 69 6e 20 4e 42 46 53 20 62 79 74 65 73 2e 27 0a  in NBFS bytes.'.
19c0: 20 20 29 3b 0a 7d 0a 0a 64 6f 5f 73 74 6d 74 5f    );.}..do_stmt_
19d0: 74 65 73 74 20 31 20 22 53 45 4c 45 43 54 20 2a  test 1 "SELECT *
19e0: 20 46 52 4f 4d 20 74 62 6c 22 0a 0a 73 71 6c 69   FROM tbl"..sqli
19f0: 74 65 34 5f 6d 65 6d 64 65 62 75 67 5f 66 61 69  te4_memdebug_fai
1a00: 6c 20 2d 31 0a 66 69 6e 69 73 68 5f 74 65 73 74  l -1.finish_test
1a10: 0a                                               .