/ Hex Artifact Content
Login

Artifact 59cd02f71b363302a04c4e77b97c0a1572eaa210:


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 33 5f  e is on sqlite3_
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 33 20 32  oc4.test,v 1.3 2
0220: 30 30 36 2f 30 31 2f 32 33 20 30 37 3a 35 32 3a  006/01/23 07:52:
0230: 34 31 20 64 61 6e 69 65 6c 6b 31 39 37 37 20 45  41 danielk1977 E
0240: 78 70 20 24 0a 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  xp $..#---------
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 2d 2d 2d 2d 2d  ----------------
0290: 2d 2d 0a 23 20 4e 4f 54 45 53 20 4f 4e 20 45 58  --.# NOTES ON EX
02a0: 50 45 43 54 45 44 20 42 45 48 41 56 49 4f 55 52  PECTED BEHAVIOUR
02b0: 0a 23 0a 23 20 5b 31 39 33 5d 20 57 68 65 6e 20  .#.# [193] When 
02c0: 61 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61 74  a memory allocat
02d0: 69 6f 6e 20 66 61 69 6c 75 72 65 20 6f 63 63 75  ion failure occu
02e0: 72 73 20 64 75 72 69 6e 67 20 73 71 6c 69 74 65  rs during sqlite
02f0: 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 28 29 2c  3_column_name(),
0300: 0a 23 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .#       sqlite3
0310: 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 31 36 28 29  _column_name16()
0320: 2c 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  , sqlite3_column
0330: 5f 64 65 63 6c 74 79 70 65 28 29 2c 20 6f 72 0a  _decltype(), or.
0340: 23 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  #       sqlite3_
0350: 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 31  column_decltype1
0360: 36 28 29 20 74 68 65 20 66 75 6e 63 74 69 6f 6e  6() the function
0370: 20 73 68 61 6c 6c 20 72 65 74 75 72 6e 20 4e 55   shall return NU
0380: 4c 4c 2e 0a 23 0a 23 2d 2d 2d 2d 2d 2d 2d 2d 2d  LL..#.#---------
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 2d 2d 2d 2d 2d  ----------------
03d0: 2d 2d 0a 0a 73 65 74 20 74 65 73 74 64 69 72 20  --..set testdir 
03e0: 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20 24 61  [file dirname $a
03f0: 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24 74 65  rgv0].source $te
0400: 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74 63 6c  stdir/tester.tcl
0410: 0a 0a 23 20 4f 6e 6c 79 20 72 75 6e 20 74 68 65  ..# Only run the
0420: 73 65 20 74 65 73 74 73 20 69 66 20 6d 65 6d 6f  se tests if memo
0430: 72 79 20 64 65 62 75 67 67 69 6e 67 20 69 73 20  ry debugging is 
0440: 74 75 72 6e 65 64 20 6f 6e 2e 0a 69 66 20 7b 5b  turned on..if {[
0450: 69 6e 66 6f 20 63 6f 6d 6d 61 6e 64 20 73 71 6c  info command sql
0460: 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d  ite_malloc_stat]
0470: 3d 3d 22 22 7d 20 7b 0a 20 20 20 70 75 74 73 20  ==""} {.   puts 
0480: 22 53 6b 69 70 70 69 6e 67 20 6d 61 6c 6c 6f 63  "Skipping malloc
0490: 20 74 65 73 74 73 3a 20 6e 6f 74 20 63 6f 6d 70   tests: not comp
04a0: 69 6c 65 64 20 77 69 74 68 20 2d 44 53 51 4c 49  iled with -DSQLI
04b0: 54 45 5f 4d 45 4d 44 45 42 55 47 2e 2e 2e 22 0a  TE_MEMDEBUG...".
04c0: 20 20 20 66 69 6e 69 73 68 5f 74 65 73 74 0a 20     finish_test. 
04d0: 20 20 72 65 74 75 72 6e 0a 7d 0a 0a 69 66 63 61    return.}..ifca
04e0: 70 61 62 6c 65 20 21 75 74 66 31 36 20 7b 0a 20  pable !utf16 {. 
04f0: 20 66 69 6e 69 73 68 5f 74 65 73 74 0a 20 20 72   finish_test.  r
0500: 65 74 75 72 6e 0a 7d 0a 0a 70 72 6f 63 20 64 6f  eturn.}..proc do
0510: 5f 73 74 6d 74 5f 74 65 73 74 20 7b 69 64 20 73  _stmt_test {id s
0520: 71 6c 7d 20 7b 0a 20 20 73 65 74 20 3a 3a 73 71  ql} {.  set ::sq
0530: 6c 20 24 73 71 6c 0a 20 20 73 65 74 20 67 6f 20  l $sql.  set go 
0540: 31 0a 20 20 66 6f 72 20 7b 73 65 74 20 6e 20 31  1.  for {set n 1
0550: 7d 20 7b 24 67 6f 7d 20 7b 69 6e 63 72 20 6e 7d  } {$go} {incr n}
0560: 20 7b 0a 20 20 20 20 73 65 74 20 74 65 73 74 69   {.    set testi
0570: 64 20 22 6d 61 6c 6c 6f 63 34 2d 24 69 64 2e 28  d "malloc4-$id.(
0580: 69 46 61 69 6c 20 24 6e 29 22 0a 0a 20 20 20 20  iFail $n)"..    
0590: 23 20 50 72 65 70 61 72 65 20 74 68 65 20 73 74  # Prepare the st
05a0: 61 74 65 6d 65 6e 74 0a 20 20 20 20 64 6f 5f 74  atement.    do_t
05b0: 65 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 31 20  est ${testid}.1 
05c0: 7b 0a 20 20 20 20 20 20 73 65 74 20 3a 3a 53 54  {.      set ::ST
05d0: 4d 54 20 5b 73 71 6c 69 74 65 33 5f 70 72 65 70  MT [sqlite3_prep
05e0: 61 72 65 20 24 3a 3a 44 42 20 24 73 71 6c 20 2d  are $::DB $sql -
05f0: 31 20 54 41 49 4c 5d 0a 20 20 20 20 20 20 65 78  1 TAIL].      ex
0600: 70 72 20 5b 73 74 72 69 6e 67 20 6c 65 6e 67 74  pr [string lengt
0610: 68 20 24 3a 3a 53 54 4d 54 5d 20 3e 20 30 0a 20  h $::STMT] > 0. 
0620: 20 20 20 7d 20 7b 31 7d 0a 0a 20 20 20 20 23 20     } {1}..    # 
0630: 53 65 74 20 74 68 65 20 4e 74 68 20 6d 61 6c 6c  Set the Nth mall
0640: 6f 63 28 29 20 74 6f 20 66 61 69 6c 2e 0a 20 20  oc() to fail..  
0650: 20 20 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f    sqlite_malloc_
0660: 66 61 69 6c 20 24 6e 0a 0a 20 20 20 20 23 20 54  fail $n..    # T
0670: 65 73 74 20 6d 61 6c 6c 6f 63 20 66 61 69 6c 75  est malloc failu
0680: 72 65 20 69 6e 20 74 68 65 20 5f 6e 61 6d 65 28  re in the _name(
0690: 29 2c 20 5f 6e 61 6d 65 31 36 28 29 2c 20 64 65  ), _name16(), de
06a0: 63 6c 74 79 70 65 28 29 20 61 6e 64 0a 20 20 20  cltype() and.   
06b0: 20 23 20 64 65 63 6c 74 79 70 65 31 36 28 29 20   # decltype16() 
06c0: 41 50 49 73 2e 20 43 61 6c 6c 73 20 74 68 61 74  APIs. Calls that
06d0: 20 6f 63 63 75 72 20 61 66 74 65 72 20 74 68 65   occur after the
06e0: 20 6d 61 6c 6c 6f 63 28 29 20 66 61 69 6c 75 72   malloc() failur
06f0: 65 20 73 68 6f 75 6c 64 0a 20 20 20 20 23 20 72  e should.    # r
0700: 65 74 75 72 6e 20 4e 55 4c 4c 2e 20 4e 6f 20 65  eturn NULL. No e
0710: 72 72 6f 72 20 69 73 20 72 61 69 73 65 64 20 74  rror is raised t
0720: 68 6f 75 67 68 2e 0a 20 20 20 20 23 0a 20 20 20  hough..    #.   
0730: 20 23 20 24 7b 74 65 73 74 69 64 7d 2e 32 2e 31   # ${testid}.2.1
0740: 20 2d 20 43 61 6c 6c 20 5f 6e 61 6d 65 28 29 0a   - Call _name().
0750: 20 20 20 20 23 20 24 7b 74 65 73 74 69 64 7d 2e      # ${testid}.
0760: 32 2e 32 20 2d 20 43 61 6c 6c 20 5f 6e 61 6d 65  2.2 - Call _name
0770: 31 36 28 29 0a 20 20 20 20 23 20 24 7b 74 65 73  16().    # ${tes
0780: 74 69 64 7d 2e 32 2e 33 20 2d 20 43 61 6c 6c 20  tid}.2.3 - Call 
0790: 5f 6e 61 6d 65 28 29 0a 20 20 20 20 23 20 24 7b  _name().    # ${
07a0: 74 65 73 74 69 64 7d 2e 32 2e 34 20 2d 20 43 68  testid}.2.4 - Ch
07b0: 65 63 6b 20 74 68 61 74 20 74 68 65 20 72 65 74  eck that the ret
07c0: 75 72 6e 20 76 61 6c 75 65 73 20 6f 66 20 74 68  urn values of th
07d0: 65 20 61 62 6f 76 65 20 74 68 72 65 65 20 63 61  e above three ca
07e0: 6c 6c 73 20 61 72 65 0a 20 20 20 20 23 20 20 20  lls are.    #   
07f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 6f                co
0800: 6e 73 69 73 74 65 6e 74 20 77 69 74 68 20 65 61  nsistent with ea
0810: 63 68 20 6f 74 68 65 72 20 61 6e 64 20 77 69 74  ch other and wit
0820: 68 20 74 68 65 20 73 69 6d 75 6c 61 74 65 64 0a  h the simulated.
0830: 20 20 20 20 23 20 20 20 20 20 20 20 20 20 20 20      #           
0840: 20 20 20 20 20 20 6d 61 6c 6c 6f 63 28 29 20 66        malloc() f
0850: 61 69 6c 75 72 65 73 2e 0a 20 20 20 20 23 0a 20  ailures..    #. 
0860: 20 20 20 23 20 42 65 63 61 75 73 65 20 74 68 65     # Because the
0870: 20 63 6f 64 65 20 74 68 61 74 20 69 6d 70 6c 65   code that imple
0880: 6d 65 6e 74 73 20 74 68 65 20 5f 64 65 63 6c 74  ments the _declt
0890: 79 70 65 28 29 20 61 6e 64 20 5f 64 65 63 6c 74  ype() and _declt
08a0: 79 70 65 31 36 28 29 20 41 50 49 73 0a 20 20 20  ype16() APIs.   
08b0: 20 23 20 69 73 20 74 68 65 20 73 61 6d 65 20 61   # is the same a
08c0: 73 20 74 68 65 20 5f 6e 61 6d 65 28 29 20 61 6e  s the _name() an
08d0: 64 20 5f 6e 61 6d 65 31 36 28 29 20 69 6d 70 6c  d _name16() impl
08e0: 65 6d 65 6e 74 61 74 69 6f 6e 73 2c 20 77 65 20  ementations, we 
08f0: 64 6f 6e 27 74 20 77 6f 72 72 79 0a 20 20 20 20  don't worry.    
0900: 23 20 61 62 6f 75 74 20 65 78 70 6c 69 63 69 74  # about explicit
0910: 6c 79 20 74 65 73 74 69 6e 67 20 74 68 65 6d 2e  ly testing them.
0920: 0a 20 20 20 20 23 0a 20 20 20 20 64 6f 5f 74 65  .    #.    do_te
0930: 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 32 2e 31  st ${testid}.2.1
0940: 20 7b 0a 20 20 20 20 20 20 73 65 74 20 6d 66 31   {.      set mf1
0950: 20 5b 65 78 70 72 20 5b 6c 69 6e 64 65 78 20 5b   [expr [lindex [
0960: 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74  sqlite_malloc_st
0970: 61 74 5d 20 32 5d 20 3c 3d 20 30 5d 0a 20 20 20  at] 2] <= 0].   
0980: 20 20 20 73 65 74 20 3a 3a 6e 61 6d 65 38 20 20     set ::name8  
0990: 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f  [sqlite3_column_
09a0: 6e 61 6d 65 20 24 3a 3a 53 54 4d 54 20 30 5d 0a  name $::STMT 0].
09b0: 20 20 20 20 20 20 73 65 74 20 6d 66 32 20 5b 65        set mf2 [e
09c0: 78 70 72 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c  xpr [lindex [sql
09d0: 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d  ite_malloc_stat]
09e0: 20 32 5d 20 3c 3d 20 30 5d 0a 20 20 20 20 20 20   2] <= 0].      
09f0: 65 78 70 72 20 7b 24 6d 66 31 20 3d 3d 20 24 6d  expr {$mf1 == $m
0a00: 66 32 20 7c 7c 20 24 3a 3a 6e 61 6d 65 38 20 3d  f2 || $::name8 =
0a10: 3d 20 22 22 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a  = ""}.    } {1}.
0a20: 20 20 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65      do_test ${te
0a30: 73 74 69 64 7d 2e 32 2e 32 20 7b 0a 20 20 20 20  stid}.2.2 {.    
0a40: 20 20 73 65 74 20 6d 66 31 20 5b 65 78 70 72 20    set mf1 [expr 
0a50: 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 5f  [lindex [sqlite_
0a60: 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d 20 32 5d 20  malloc_stat] 2] 
0a70: 3c 3d 20 30 5d 0a 20 20 20 20 20 20 73 65 74 20  <= 0].      set 
0a80: 3a 3a 6e 61 6d 65 31 36 20 5b 73 71 6c 69 74 65  ::name16 [sqlite
0a90: 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 31 36 20  3_column_name16 
0aa0: 24 3a 3a 53 54 4d 54 20 30 5d 0a 20 20 20 20 20  $::STMT 0].     
0ab0: 20 73 65 74 20 3a 3a 6e 61 6d 65 31 36 20 5b 65   set ::name16 [e
0ac0: 6e 63 6f 64 69 6e 67 20 63 6f 6e 76 65 72 74 66  ncoding convertf
0ad0: 72 6f 6d 20 75 6e 69 63 6f 64 65 20 24 3a 3a 6e  rom unicode $::n
0ae0: 61 6d 65 31 36 5d 0a 20 20 20 20 20 20 73 65 74  ame16].      set
0af0: 20 3a 3a 6e 61 6d 65 31 36 20 5b 73 74 72 69 6e   ::name16 [strin
0b00: 67 20 72 61 6e 67 65 20 24 3a 3a 6e 61 6d 65 31  g range $::name1
0b10: 36 20 30 20 65 6e 64 2d 31 5d 0a 20 20 20 20 20  6 0 end-1].     
0b20: 20 73 65 74 20 6d 66 32 20 5b 65 78 70 72 20 5b   set mf2 [expr [
0b30: 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 5f 6d  lindex [sqlite_m
0b40: 61 6c 6c 6f 63 5f 73 74 61 74 5d 20 32 5d 20 3c  alloc_stat] 2] <
0b50: 3d 20 30 5d 0a 20 20 20 20 20 20 65 78 70 72 20  = 0].      expr 
0b60: 7b 24 6d 66 31 20 3d 3d 20 24 6d 66 32 20 7c 7c  {$mf1 == $mf2 ||
0b70: 20 24 3a 3a 6e 61 6d 65 31 36 20 3d 3d 20 22 22   $::name16 == ""
0b80: 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20 20 20  }.    } {1}.    
0b90: 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74 69 64  do_test ${testid
0ba0: 7d 2e 32 2e 33 20 7b 0a 20 20 20 20 20 20 73 65  }.2.3 {.      se
0bb0: 74 20 6d 66 31 20 5b 65 78 70 72 20 5b 6c 69 6e  t mf1 [expr [lin
0bc0: 64 65 78 20 5b 73 71 6c 69 74 65 5f 6d 61 6c 6c  dex [sqlite_mall
0bd0: 6f 63 5f 73 74 61 74 5d 20 32 5d 20 3c 3d 20 30  oc_stat] 2] <= 0
0be0: 5d 0a 20 20 20 20 20 20 73 65 74 20 3a 3a 6e 61  ].      set ::na
0bf0: 6d 65 38 5f 32 20 5b 73 71 6c 69 74 65 33 5f 63  me8_2 [sqlite3_c
0c00: 6f 6c 75 6d 6e 5f 6e 61 6d 65 20 24 3a 3a 53 54  olumn_name $::ST
0c10: 4d 54 20 30 5d 0a 20 20 20 20 20 20 73 65 74 20  MT 0].      set 
0c20: 6d 66 32 20 5b 65 78 70 72 20 5b 6c 69 6e 64 65  mf2 [expr [linde
0c30: 78 20 5b 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63  x [sqlite_malloc
0c40: 5f 73 74 61 74 5d 20 32 5d 20 3c 3d 20 30 5d 0a  _stat] 2] <= 0].
0c50: 20 20 20 20 20 20 65 78 70 72 20 7b 24 6d 66 31        expr {$mf1
0c60: 20 3d 3d 20 24 6d 66 32 20 7c 7c 20 24 3a 3a 6e   == $mf2 || $::n
0c70: 61 6d 65 38 5f 32 20 3d 3d 20 22 22 7d 0a 20 20  ame8_2 == ""}.  
0c80: 20 20 7d 20 7b 31 7d 0a 20 20 20 20 73 65 74 20    } {1}.    set 
0c90: 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 5b  ::mallocFailed [
0ca0: 65 78 70 72 20 5b 6c 69 6e 64 65 78 20 5b 73 71  expr [lindex [sq
0cb0: 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74  lite_malloc_stat
0cc0: 5d 20 32 5d 20 3c 3d 20 30 5d 0a 20 20 20 20 64  ] 2] <= 0].    d
0cd0: 6f 5f 74 65 73 74 20 24 7b 74 65 73 74 69 64 7d  o_test ${testid}
0ce0: 2e 32 2e 34 20 7b 0a 20 20 20 20 20 20 65 78 70  .2.4 {.      exp
0cf0: 72 20 7b 0a 20 20 20 20 20 20 20 20 24 3a 3a 6e  r {.        $::n
0d00: 61 6d 65 38 20 3d 3d 20 24 3a 3a 6e 61 6d 65 38  ame8 == $::name8
0d10: 5f 32 20 26 26 20 24 3a 3a 6e 61 6d 65 31 36 20  _2 && $::name16 
0d20: 3d 3d 20 24 3a 3a 6e 61 6d 65 38 20 26 26 20 21  == $::name8 && !
0d30: 24 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20  $::mallocFailed 
0d40: 7c 7c 0a 20 20 20 20 20 20 20 20 24 3a 3a 6e 61  ||.        $::na
0d50: 6d 65 38 20 3d 3d 20 24 3a 3a 6e 61 6d 65 38 5f  me8 == $::name8_
0d60: 32 20 26 26 20 24 3a 3a 6e 61 6d 65 31 36 20 3d  2 && $::name16 =
0d70: 3d 20 22 22 20 26 26 20 20 20 20 20 20 20 20 24  = "" &&        $
0d80: 3a 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 7c  ::mallocFailed |
0d90: 7c 0a 20 20 20 20 20 20 20 20 24 3a 3a 6e 61 6d  |.        $::nam
0da0: 65 38 20 3d 3d 20 24 3a 3a 6e 61 6d 65 31 36 20  e8 == $::name16 
0db0: 26 26 20 24 3a 3a 6e 61 6d 65 38 5f 32 20 3d 3d  && $::name8_2 ==
0dc0: 20 22 22 20 26 26 20 20 20 20 20 20 20 20 24 3a   "" &&        $:
0dd0: 3a 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 7c 7c  :mallocFailed ||
0de0: 0a 20 20 20 20 20 20 20 20 24 3a 3a 6e 61 6d 65  .        $::name
0df0: 38 5f 32 20 3d 3d 20 24 3a 3a 6e 61 6d 65 31 36  8_2 == $::name16
0e00: 20 26 26 20 24 3a 3a 6e 61 6d 65 38 20 3d 3d 20   && $::name8 == 
0e10: 22 22 20 26 26 20 20 20 20 20 20 20 20 24 3a 3a  "" &&        $::
0e20: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 0a 20 20 20  mallocFailed.   
0e30: 20 20 20 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a 0a     }.    } {1}..
0e40: 20 20 20 20 23 20 53 74 65 70 20 74 68 65 20 73      # Step the s
0e50: 74 61 74 65 6d 65 6e 74 20 73 6f 20 74 68 61 74  tatement so that
0e60: 20 77 65 20 63 61 6e 20 63 61 6c 6c 20 5f 74 65   we can call _te
0e70: 78 74 28 29 20 61 6e 64 20 5f 74 65 78 74 31 36  xt() and _text16
0e80: 28 29 2e 20 20 42 65 66 6f 72 65 0a 20 20 20 20  ().  Before.    
0e90: 23 20 72 75 6e 6e 69 6e 67 20 73 71 6c 69 74 65  # running sqlite
0ea0: 33 5f 73 74 65 70 28 29 2c 20 6d 61 6b 65 20 73  3_step(), make s
0eb0: 75 72 65 20 74 68 61 74 20 6d 61 6c 6c 6f 63 28  ure that malloc(
0ec0: 29 20 69 73 20 6e 6f 74 20 61 62 6f 75 74 20 74  ) is not about t
0ed0: 6f 20 66 61 69 6c 2e 0a 20 20 20 20 23 20 4d 65  o fail..    # Me
0ee0: 6d 6f 72 79 20 61 6c 6c 6f 63 61 74 69 6f 6e 20  mory allocation 
0ef0: 66 61 69 6c 75 72 65 73 20 74 68 61 74 20 6f 63  failures that oc
0f00: 63 75 72 20 77 69 74 68 69 6e 20 73 71 6c 69 74  cur within sqlit
0f10: 65 33 5f 73 74 65 70 28 29 20 61 72 65 20 74 65  e3_step() are te
0f20: 73 74 65 64 0a 20 20 20 20 23 20 65 6c 73 65 77  sted.    # elsew
0f30: 68 65 72 65 2e 0a 20 20 20 20 73 65 74 20 6d 66  here..    set mf
0f40: 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65   [lindex [sqlite
0f50: 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d 20 32 5d  _malloc_stat] 2]
0f60: 0a 20 20 20 20 73 71 6c 69 74 65 5f 6d 61 6c 6c  .    sqlite_mall
0f70: 6f 63 5f 66 61 69 6c 20 30 0a 20 20 20 20 64 6f  oc_fail 0.    do
0f80: 5f 74 65 73 74 20 24 7b 74 65 73 74 69 64 7d 2e  _test ${testid}.
0f90: 33 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  3 {.      sqlite
0fa0: 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20  3_step $::STMT. 
0fb0: 20 20 20 7d 20 7b 53 51 4c 49 54 45 5f 52 4f 57     } {SQLITE_ROW
0fc0: 7d 0a 20 20 20 20 73 71 6c 69 74 65 5f 6d 61 6c  }.    sqlite_mal
0fd0: 6c 6f 63 5f 66 61 69 6c 20 24 6d 66 0a 0a 20 20  loc_fail $mf..  
0fe0: 20 20 23 20 54 65 73 74 20 66 6f 72 20 6d 61 6c    # Test for mal
0ff0: 6c 6f 63 28 29 20 66 61 69 6c 75 72 65 73 20 77  loc() failures w
1000: 69 74 68 69 6e 20 5f 74 65 78 74 28 29 20 61 6e  ithin _text() an
1010: 64 20 5f 74 65 78 74 31 36 28 29 2e 0a 20 20 20  d _text16()..   
1020: 20 23 0a 20 20 20 20 64 6f 5f 74 65 73 74 20 24   #.    do_test $
1030: 7b 74 65 73 74 69 64 7d 2e 34 2e 31 20 7b 0a 20  {testid}.4.1 {. 
1040: 20 20 20 20 20 73 65 74 20 3a 3a 74 65 78 74 38       set ::text8
1050: 20 5b 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e   [sqlite3_column
1060: 5f 74 65 78 74 20 24 3a 3a 53 54 4d 54 20 30 5d  _text $::STMT 0]
1070: 0a 20 20 20 20 20 20 73 65 74 20 6d 66 20 5b 65  .      set mf [e
1080: 78 70 72 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c  xpr [lindex [sql
1090: 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d  ite_malloc_stat]
10a0: 20 32 5d 20 3c 3d 20 30 20 26 26 20 21 24 3a 3a   2] <= 0 && !$::
10b0: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 5d 0a 20 20  mallocFailed].  
10c0: 20 20 20 20 65 78 70 72 20 7b 24 6d 66 3d 3d 30      expr {$mf==0
10d0: 20 7c 7c 20 24 3a 3a 74 65 78 74 38 20 3d 3d 20   || $::text8 == 
10e0: 22 22 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20  ""}.    } {1}.  
10f0: 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74    do_test ${test
1100: 69 64 7d 2e 34 2e 32 20 7b 0a 20 20 20 20 20 20  id}.4.2 {.      
1110: 73 65 74 20 3a 3a 74 65 78 74 31 36 20 5b 73 71  set ::text16 [sq
1120: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
1130: 74 31 36 20 24 3a 3a 53 54 4d 54 20 30 5d 0a 20  t16 $::STMT 0]. 
1140: 20 20 20 20 20 73 65 74 20 3a 3a 74 65 78 74 31       set ::text1
1150: 36 20 5b 65 6e 63 6f 64 69 6e 67 20 63 6f 6e 76  6 [encoding conv
1160: 65 72 74 66 72 6f 6d 20 75 6e 69 63 6f 64 65 20  ertfrom unicode 
1170: 24 3a 3a 74 65 78 74 31 36 5d 0a 20 20 20 20 20  $::text16].     
1180: 20 73 65 74 20 3a 3a 74 65 78 74 31 36 20 5b 73   set ::text16 [s
1190: 74 72 69 6e 67 20 72 61 6e 67 65 20 24 3a 3a 74  tring range $::t
11a0: 65 78 74 31 36 20 30 20 65 6e 64 2d 31 5d 0a 20  ext16 0 end-1]. 
11b0: 20 20 20 20 20 73 65 74 20 6d 66 20 5b 65 78 70       set mf [exp
11c0: 72 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74  r [lindex [sqlit
11d0: 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d 20 32  e_malloc_stat] 2
11e0: 5d 20 3c 3d 20 30 20 26 26 20 21 24 3a 3a 6d 61  ] <= 0 && !$::ma
11f0: 6c 6c 6f 63 46 61 69 6c 65 64 5d 0a 20 20 20 20  llocFailed].    
1200: 20 20 65 78 70 72 20 7b 24 6d 66 3d 3d 30 20 7c    expr {$mf==0 |
1210: 7c 20 24 3a 3a 74 65 78 74 31 36 20 3d 3d 20 22  | $::text16 == "
1220: 22 7d 0a 20 20 20 20 7d 20 7b 31 7d 0a 20 20 20  "}.    } {1}.   
1230: 20 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74 69   do_test ${testi
1240: 64 7d 2e 34 2e 33 20 7b 0a 20 20 20 20 20 20 73  d}.4.3 {.      s
1250: 65 74 20 3a 3a 74 65 78 74 38 5f 32 20 5b 73 71  et ::text8_2 [sq
1260: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
1270: 74 20 24 3a 3a 53 54 4d 54 20 30 5d 0a 20 20 20  t $::STMT 0].   
1280: 20 20 20 73 65 74 20 6d 66 20 5b 65 78 70 72 20     set mf [expr 
1290: 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 5f  [lindex [sqlite_
12a0: 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d 20 32 5d 20  malloc_stat] 2] 
12b0: 3c 3d 20 30 20 26 26 20 21 24 3a 3a 6d 61 6c 6c  <= 0 && !$::mall
12c0: 6f 63 46 61 69 6c 65 64 5d 0a 20 20 20 20 20 20  ocFailed].      
12d0: 65 78 70 72 20 7b 24 6d 66 3d 3d 30 20 7c 7c 20  expr {$mf==0 || 
12e0: 24 3a 3a 74 65 78 74 38 5f 32 20 3d 3d 20 22 22  $::text8_2 == ""
12f0: 20 7c 7c 20 28 24 3a 3a 74 65 78 74 31 36 20 3d   || ($::text16 =
1300: 3d 20 22 22 20 26 26 20 24 3a 3a 74 65 78 74 38  = "" && $::text8
1310: 20 21 3d 20 22 22 29 7d 0a 20 20 20 20 7d 20 7b   != "")}.    } {
1320: 31 7d 0a 0a 20 20 20 20 23 20 54 65 73 74 20 66  1}..    # Test f
1330: 6f 72 20 6d 61 6c 6c 6f 63 28 29 20 66 61 69 6c  or malloc() fail
1340: 75 72 65 73 20 77 69 74 68 69 6e 20 5f 69 6e 74  ures within _int
1350: 28 29 2c 20 5f 69 6e 74 36 34 28 29 20 61 6e 64  (), _int64() and
1360: 20 5f 72 65 61 6c 28 29 2e 20 54 68 65 20 6f 6e   _real(). The on
1370: 6c 79 0a 20 20 20 20 23 20 77 61 79 20 74 68 69  ly.    # way thi
1380: 73 20 63 61 6e 20 6f 63 63 75 72 20 69 73 20 69  s can occur is i
1390: 66 20 74 68 65 20 73 74 72 69 6e 67 20 68 61 73  f the string has
13a0: 20 74 6f 20 62 65 20 74 72 61 6e 73 6c 61 74 65   to be translate
13b0: 64 20 66 72 6f 6d 20 55 54 46 2d 31 36 20 74 6f  d from UTF-16 to
13c0: 0a 20 20 20 20 23 20 55 54 46 2d 38 20 62 65 66  .    # UTF-8 bef
13d0: 6f 72 65 20 62 65 69 6e 67 20 63 6f 6e 76 65 72  ore being conver
13e0: 74 65 64 20 74 6f 20 61 20 6e 75 6d 65 72 69 63  ted to a numeric
13f0: 20 76 61 6c 75 65 2e 0a 20 20 20 20 64 6f 5f 74   value..    do_t
1400: 65 73 74 20 24 7b 74 65 73 74 69 64 7d 2e 34 2e  est ${testid}.4.
1410: 34 2e 31 20 7b 0a 20 20 20 20 20 20 73 65 74 20  4.1 {.      set 
1420: 6d 66 20 5b 6c 69 6e 64 65 78 20 5b 73 71 6c 69  mf [lindex [sqli
1430: 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74 61 74 5d 20  te_malloc_stat] 
1440: 32 5d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 5f  2].      sqlite_
1450: 6d 61 6c 6c 6f 63 5f 66 61 69 6c 20 30 0a 20 20  malloc_fail 0.  
1460: 20 20 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75      sqlite3_colu
1470: 6d 6e 5f 74 65 78 74 31 36 20 24 3a 3a 53 54 4d  mn_text16 $::STM
1480: 54 20 30 0a 20 20 20 20 20 20 73 71 6c 69 74 65  T 0.      sqlite
1490: 5f 6d 61 6c 6c 6f 63 5f 66 61 69 6c 20 24 6d 66  _malloc_fail $mf
14a0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63  .      sqlite3_c
14b0: 6f 6c 75 6d 6e 5f 69 6e 74 20 24 3a 3a 53 54 4d  olumn_int $::STM
14c0: 54 20 30 0a 20 20 20 20 7d 20 7b 30 7d 0a 20 20  T 0.    } {0}.  
14d0: 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65 73 74    do_test ${test
14e0: 69 64 7d 2e 34 2e 35 20 7b 0a 20 20 20 20 20 20  id}.4.5 {.      
14f0: 73 65 74 20 6d 66 20 5b 6c 69 6e 64 65 78 20 5b  set mf [lindex [
1500: 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 73 74  sqlite_malloc_st
1510: 61 74 5d 20 32 5d 0a 20 20 20 20 20 20 73 71 6c  at] 2].      sql
1520: 69 74 65 5f 6d 61 6c 6c 6f 63 5f 66 61 69 6c 20  ite_malloc_fail 
1530: 30 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  0.      sqlite3_
1540: 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 20 24 3a  column_text16 $:
1550: 3a 53 54 4d 54 20 30 0a 20 20 20 20 20 20 73 71  :STMT 0.      sq
1560: 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 66 61 69 6c  lite_malloc_fail
1570: 20 24 6d 66 0a 20 20 20 20 20 20 73 71 6c 69 74   $mf.      sqlit
1580: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 20  e3_column_int64 
1590: 24 3a 3a 53 54 4d 54 20 30 0a 20 20 20 20 7d 20  $::STMT 0.    } 
15a0: 7b 30 7d 0a 0a 20 20 20 20 64 6f 5f 74 65 73 74  {0}..    do_test
15b0: 20 24 7b 74 65 73 74 69 64 7d 2e 34 2e 36 20 7b   ${testid}.4.6 {
15c0: 0a 20 20 20 20 20 20 73 65 74 20 6d 66 20 5b 6c  .      set mf [l
15d0: 69 6e 64 65 78 20 5b 73 71 6c 69 74 65 5f 6d 61  index [sqlite_ma
15e0: 6c 6c 6f 63 5f 73 74 61 74 5d 20 32 5d 0a 20 20  lloc_stat] 2].  
15f0: 20 20 20 20 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f      sqlite_mallo
1600: 63 5f 66 61 69 6c 20 30 0a 20 20 20 20 20 20 73  c_fail 0.      s
1610: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65  qlite3_column_te
1620: 78 74 31 36 20 24 3a 3a 53 54 4d 54 20 30 0a 20  xt16 $::STMT 0. 
1630: 20 20 20 20 20 73 71 6c 69 74 65 5f 6d 61 6c 6c       sqlite_mall
1640: 6f 63 5f 66 61 69 6c 20 24 6d 66 0a 20 20 20 20  oc_fail $mf.    
1650: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e    sqlite3_column
1660: 5f 64 6f 75 62 6c 65 20 24 3a 3a 53 54 4d 54 20  _double $::STMT 
1670: 30 0a 20 20 20 20 7d 20 7b 30 2e 30 7d 0a 0a 20  0.    } {0.0}.. 
1680: 20 20 20 73 65 74 20 6d 61 6c 6c 6f 63 46 61 69     set mallocFai
1690: 6c 65 64 41 66 74 65 72 53 74 65 70 20 5b 65 78  ledAfterStep [ex
16a0: 70 72 20 5c 0a 20 20 20 20 20 20 5b 6c 69 6e 64  pr \.      [lind
16b0: 65 78 20 5b 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f  ex [sqlite_mallo
16c0: 63 5f 73 74 61 74 5d 20 32 5d 20 3c 3d 20 30 20  c_stat] 2] <= 0 
16d0: 26 26 20 21 24 3a 3a 6d 61 6c 6c 6f 63 46 61 69  && !$::mallocFai
16e0: 6c 65 64 0a 20 20 20 20 5d 0a 0a 20 20 20 20 73  led.    ]..    s
16f0: 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 66 61 69  qlite_malloc_fai
1700: 6c 20 30 0a 20 20 20 20 23 20 54 65 73 74 20 74  l 0.    # Test t
1710: 68 61 74 20 69 66 20 61 20 6d 61 6c 6c 6f 63 28  hat if a malloc(
1720: 29 20 66 61 69 6c 65 64 20 74 68 65 20 6e 65 78  ) failed the nex
1730: 74 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65  t call to sqlite
1740: 33 5f 73 74 65 70 28 29 20 72 65 74 75 72 6e 73  3_step() returns
1750: 0a 20 20 20 20 23 20 53 51 4c 49 54 45 5f 45 52  .    # SQLITE_ER
1760: 52 4f 52 2e 20 49 66 20 6d 61 6c 6c 6f 63 28 29  ROR. If malloc()
1770: 20 64 69 64 20 6e 6f 74 20 66 61 69 6c 2c 20 69   did not fail, i
1780: 74 20 73 68 6f 75 6c 64 20 72 65 74 75 72 6e 20  t should return 
1790: 53 51 4c 49 54 45 5f 44 4f 4e 45 2e 0a 20 20 20  SQLITE_DONE..   
17a0: 20 23 0a 20 20 20 20 64 6f 5f 74 65 73 74 20 24   #.    do_test $
17b0: 7b 74 65 73 74 69 64 7d 2e 35 20 7b 0a 20 20 20  {testid}.5 {.   
17c0: 20 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20     sqlite3_step 
17d0: 24 3a 3a 53 54 4d 54 0a 20 20 20 20 7d 20 5b 65  $::STMT.    } [e
17e0: 78 70 72 20 7b 24 6d 61 6c 6c 6f 63 46 61 69 6c  xpr {$mallocFail
17f0: 65 64 41 66 74 65 72 53 74 65 70 20 3f 20 22 53  edAfterStep ? "S
1800: 51 4c 49 54 45 5f 45 52 52 4f 52 22 20 3a 20 22  QLITE_ERROR" : "
1810: 53 51 4c 49 54 45 5f 44 4f 4e 45 22 7d 5d 0a 0a  SQLITE_DONE"}]..
1820: 20 20 20 20 64 6f 5f 74 65 73 74 20 24 7b 74 65      do_test ${te
1830: 73 74 69 64 7d 2e 36 20 7b 0a 20 20 20 20 20 20  stid}.6 {.      
1840: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
1850: 20 24 3a 3a 53 54 4d 54 0a 20 20 20 20 7d 20 5b   $::STMT.    } [
1860: 65 78 70 72 20 7b 24 6d 61 6c 6c 6f 63 46 61 69  expr {$mallocFai
1870: 6c 65 64 41 66 74 65 72 53 74 65 70 20 3f 20 22  ledAfterStep ? "
1880: 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 22 20 3a 20  SQLITE_NOMEM" : 
1890: 22 53 51 4c 49 54 45 5f 4f 4b 22 7d 5d 0a 0a 20  "SQLITE_OK"}].. 
18a0: 20 20 20 69 66 20 7b 24 3a 3a 6d 61 6c 6c 6f 63     if {$::malloc
18b0: 46 61 69 6c 65 64 20 3d 3d 20 30 20 26 26 20 24  Failed == 0 && $
18c0: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 41 66 74 65  mallocFailedAfte
18d0: 72 53 74 65 70 20 3d 3d 20 30 7d 20 7b 0a 20 20  rStep == 0} {.  
18e0: 20 20 20 20 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f      sqlite_mallo
18f0: 63 5f 66 61 69 6c 20 30 0a 20 20 20 20 20 20 73  c_fail 0.      s
1900: 65 74 20 67 6f 20 30 0a 20 20 20 20 7d 0a 20 20  et go 0.    }.  
1910: 7d 0a 7d 0a 0a 65 78 65 63 73 71 6c 20 7b 0a 20  }.}..execsql {. 
1920: 20 43 52 45 41 54 45 20 54 41 42 4c 45 20 74 62   CREATE TABLE tb
1930: 6c 28 0a 20 20 20 20 74 68 65 5f 66 69 72 73 74  l(.    the_first
1940: 5f 72 65 61 73 6f 6e 61 62 6c 79 5f 6c 6f 6e 67  _reasonably_long
1950: 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 20 74 68 61  _column_name tha
1960: 74 5f 61 6c 73 6f 5f 68 61 73 5f 71 75 69 74 65  t_also_has_quite
1970: 5f 61 5f 6c 65 6e 67 74 68 79 5f 74 79 70 65 0a  _a_lengthy_type.
1980: 20 20 29 3b 0a 20 20 49 4e 53 45 52 54 20 49 4e    );.  INSERT IN
1990: 54 4f 20 74 62 6c 20 56 41 4c 55 45 53 28 0a 20  TO tbl VALUES(. 
19a0: 20 20 20 27 41 6e 20 65 78 74 72 61 20 6c 6f 6e     'An extra lon
19b0: 67 20 73 74 72 69 6e 67 2e 20 46 61 72 20 74 6f  g string. Far to
19c0: 6f 20 6c 6f 6e 67 20 74 6f 20 62 65 20 73 74 6f  o long to be sto
19d0: 72 65 64 20 69 6e 20 4e 42 46 53 20 62 79 74 65  red in NBFS byte
19e0: 73 2e 27 0a 20 20 29 3b 0a 7d 0a 0a 64 6f 5f 73  s.'.  );.}..do_s
19f0: 74 6d 74 5f 74 65 73 74 20 31 20 22 53 45 4c 45  tmt_test 1 "SELE
1a00: 43 54 20 2a 20 46 52 4f 4d 20 74 62 6c 22 0a 0a  CT * FROM tbl"..
1a10: 73 71 6c 69 74 65 5f 6d 61 6c 6c 6f 63 5f 66 61  sqlite_malloc_fa
1a20: 69 6c 20 30 0a 66 69 6e 69 73 68 5f 74 65 73 74  il 0.finish_test
1a30: 0a 0a                                            ..