/ Hex Artifact Content
Login

Artifact 14c41572ff52dbc740b1c3303dd313a90dc6084c:


0000: 23 20 32 30 30 38 20 41 70 72 69 6c 20 32 38 0a  # 2008 April 28.
0010: 23 0a 23 20 54 68 65 20 61 75 74 68 6f 72 20 64  #.# The author d
0020: 69 73 63 6c 61 69 6d 73 20 63 6f 70 79 72 69 67  isclaims copyrig
0030: 68 74 20 74 6f 20 74 68 69 73 20 73 6f 75 72 63  ht to this sourc
0040: 65 20 63 6f 64 65 2e 20 20 49 6e 20 70 6c 61 63  e code.  In plac
0050: 65 20 6f 66 0a 23 20 61 20 6c 65 67 61 6c 20 6e  e of.# a legal n
0060: 6f 74 69 63 65 2c 20 68 65 72 65 20 69 73 20 61  otice, here is a
0070: 20 62 6c 65 73 73 69 6e 67 3a 0a 23 0a 23 20 20   blessing:.#.#  
0080: 20 20 4d 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f    May you do goo
0090: 64 20 61 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a  d and not evil..
00a0: 23 20 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e  #    May you fin
00b0: 64 20 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f  d forgiveness fo
00c0: 72 20 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66  r yourself and f
00d0: 6f 72 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 23  orgive others..#
00e0: 20 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72      May you shar
00f0: 65 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20  e freely, never 
0100: 74 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e  taking more than
0110: 20 79 6f 75 20 67 69 76 65 2e 0a 23 0a 23 2a 2a   you give..#.#**
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 0a 23 0a 23 20 54 69 63 6b 65 74  *****.#.# Ticket
0170: 20 23 33 30 36 30 0a 23 0a 23 20 4d 61 6b 65 20   #3060.#.# Make 
0180: 73 75 72 65 20 49 45 45 45 20 66 6c 6f 61 74 69  sure IEEE floati
0190: 6e 67 20 70 6f 69 6e 74 20 4e 61 4e 20 76 61 6c  ng point NaN val
01a0: 75 65 73 20 61 72 65 20 68 61 6e 64 6c 65 64 20  ues are handled 
01b0: 70 72 6f 70 65 72 6c 79 2e 0a 23 20 53 51 4c 69  properly..# SQLi
01c0: 74 65 20 73 68 6f 75 6c 64 20 61 6c 77 61 79 73  te should always
01d0: 20 63 6f 6e 76 65 72 74 20 4e 61 4e 20 69 6e 74   convert NaN int
01e0: 6f 20 4e 55 4c 4c 2e 0a 23 0a 23 20 41 6c 73 6f  o NULL..#.# Also
01f0: 20 76 65 72 69 66 79 20 74 68 61 74 20 74 68 65   verify that the
0200: 20 64 65 63 69 6d 61 6c 20 74 6f 20 49 45 45 45   decimal to IEEE
0210: 37 35 34 20 62 69 6e 61 72 79 20 63 6f 6e 76 65  754 binary conve
0220: 72 73 69 6f 6e 20 72 6f 75 74 69 6e 65 73 0a 23  rsion routines.#
0230: 20 63 6f 72 72 65 63 74 6c 79 20 67 65 6e 65 72   correctly gener
0240: 61 74 65 20 30 2e 30 2c 20 2b 49 6e 66 2c 20 61  ate 0.0, +Inf, a
0250: 6e 64 20 2d 49 6e 66 20 61 73 20 61 70 70 72 6f  nd -Inf as appro
0260: 70 72 69 61 74 65 20 66 6f 72 20 6e 75 6d 62 65  priate for numbe
0270: 72 73 0a 23 20 6f 75 74 20 6f 66 20 72 61 6e 67  rs.# out of rang
0280: 65 2e 0a 23 0a 23 20 24 49 64 3a 20 6e 61 6e 2e  e..#.# $Id: nan.
0290: 74 65 73 74 2c 76 20 31 2e 33 20 32 30 30 38 2f  test,v 1.3 2008/
02a0: 30 35 2f 31 31 20 31 31 3a 30 37 3a 30 37 20 64  05/11 11:07:07 d
02b0: 72 68 20 45 78 70 20 24 0a 23 0a 0a 73 65 74 20  rh Exp $.#..set 
02c0: 74 65 73 74 64 69 72 20 5b 66 69 6c 65 20 64 69  testdir [file di
02d0: 72 6e 61 6d 65 20 24 61 72 67 76 30 5d 0a 73 6f  rname $argv0].so
02e0: 75 72 63 65 20 24 74 65 73 74 64 69 72 2f 74 65  urce $testdir/te
02f0: 73 74 65 72 2e 74 63 6c 0a 0a 0a 64 6f 5f 74 65  ster.tcl...do_te
0300: 73 74 20 6e 61 6e 2d 31 2e 31 20 7b 0a 20 20 64  st nan-1.1 {.  d
0310: 62 20 65 76 61 6c 20 7b 0a 20 20 20 20 50 52 41  b eval {.    PRA
0320: 47 4d 41 20 61 75 74 6f 5f 76 61 63 75 75 6d 3d  GMA auto_vacuum=
0330: 4f 46 46 3b 0a 20 20 20 20 50 52 41 47 4d 41 20  OFF;.    PRAGMA 
0340: 70 61 67 65 5f 73 69 7a 65 3d 31 30 32 34 3b 0a  page_size=1024;.
0350: 20 20 20 20 43 52 45 41 54 45 20 54 41 42 4c 45      CREATE TABLE
0360: 20 74 31 28 78 20 46 4c 4f 41 54 29 3b 0a 20 20   t1(x FLOAT);.  
0370: 7d 0a 20 20 73 65 74 20 3a 3a 53 54 4d 54 20 5b  }.  set ::STMT [
0380: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 20  sqlite3_prepare 
0390: 64 62 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20  db "INSERT INTO 
03a0: 74 31 20 56 41 4c 55 45 53 28 3f 29 22 20 2d 31  t1 VALUES(?)" -1
03b0: 20 54 41 49 4c 5d 0a 20 20 73 71 6c 69 74 65 33   TAIL].  sqlite3
03c0: 5f 62 69 6e 64 5f 64 6f 75 62 6c 65 20 24 3a 3a  _bind_double $::
03d0: 53 54 4d 54 20 31 20 4e 61 4e 0a 20 20 73 71 6c  STMT 1 NaN.  sql
03e0: 69 74 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d  ite3_step $::STM
03f0: 54 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65  T.  sqlite3_rese
0400: 74 20 24 3a 3a 53 54 4d 54 0a 20 20 64 62 20 65  t $::STMT.  db e
0410: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
0420: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
0430: 7d 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c 7d 0a 64 6f  }.} {{} null}.do
0440: 5f 74 65 73 74 20 6e 61 6e 2d 31 2e 32 20 7b 0a  _test nan-1.2 {.
0450: 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64    sqlite3_bind_d
0460: 6f 75 62 6c 65 20 24 3a 3a 53 54 4d 54 20 31 20  ouble $::STMT 1 
0470: 2b 49 6e 66 0a 20 20 73 71 6c 69 74 65 33 5f 73  +Inf.  sqlite3_s
0480: 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20 20 73 71  tep $::STMT.  sq
0490: 6c 69 74 65 33 5f 72 65 73 65 74 20 24 3a 3a 53  lite3_reset $::S
04a0: 54 4d 54 0a 20 20 64 62 20 65 76 61 6c 20 7b 53  TMT.  db eval {S
04b0: 45 4c 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28  ELECT x, typeof(
04c0: 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 7b  x) FROM t1}.} {{
04d0: 7d 20 6e 75 6c 6c 20 69 6e 66 20 72 65 61 6c 7d  } null inf real}
04e0: 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 31 2e 33  .do_test nan-1.3
04f0: 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e   {.  sqlite3_bin
0500: 64 5f 64 6f 75 62 6c 65 20 24 3a 3a 53 54 4d 54  d_double $::STMT
0510: 20 31 20 2d 49 6e 66 0a 20 20 73 71 6c 69 74 65   1 -Inf.  sqlite
0520: 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20  3_step $::STMT. 
0530: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 20 24   sqlite3_reset $
0540: 3a 3a 53 54 4d 54 0a 20 20 64 62 20 65 76 61 6c  ::STMT.  db eval
0550: 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70 65   {SELECT x, type
0560: 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d  of(x) FROM t1}.}
0570: 20 7b 7b 7d 20 6e 75 6c 6c 20 69 6e 66 20 72 65   {{} null inf re
0580: 61 6c 20 2d 69 6e 66 20 72 65 61 6c 7d 0a 64 6f  al -inf real}.do
0590: 5f 74 65 73 74 20 6e 61 6e 2d 31 2e 34 20 7b 0a  _test nan-1.4 {.
05a0: 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64    sqlite3_bind_d
05b0: 6f 75 62 6c 65 20 24 3a 3a 53 54 4d 54 20 31 20  ouble $::STMT 1 
05c0: 2d 4e 61 4e 0a 20 20 73 71 6c 69 74 65 33 5f 73  -NaN.  sqlite3_s
05d0: 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20 20 73 71  tep $::STMT.  sq
05e0: 6c 69 74 65 33 5f 72 65 73 65 74 20 24 3a 3a 53  lite3_reset $::S
05f0: 54 4d 54 0a 20 20 64 62 20 65 76 61 6c 20 7b 53  TMT.  db eval {S
0600: 45 4c 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28  ELECT x, typeof(
0610: 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 7b  x) FROM t1}.} {{
0620: 7d 20 6e 75 6c 6c 20 69 6e 66 20 72 65 61 6c 20  } null inf real 
0630: 2d 69 6e 66 20 72 65 61 6c 20 7b 7d 20 6e 75 6c  -inf real {} nul
0640: 6c 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 31  l}.do_test nan-1
0650: 2e 35 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62  .5 {.  sqlite3_b
0660: 69 6e 64 5f 64 6f 75 62 6c 65 20 24 3a 3a 53 54  ind_double $::ST
0670: 4d 54 20 31 20 4e 61 4e 30 0a 20 20 73 71 6c 69  MT 1 NaN0.  sqli
0680: 74 65 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54  te3_step $::STMT
0690: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74  .  sqlite3_reset
06a0: 20 24 3a 3a 53 54 4d 54 0a 20 20 64 62 20 65 76   $::STMT.  db ev
06b0: 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79  al {SELECT x, ty
06c0: 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d  peof(x) FROM t1}
06d0: 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c 20 69 6e 66 20  .} {{} null inf 
06e0: 72 65 61 6c 20 2d 69 6e 66 20 72 65 61 6c 20 7b  real -inf real {
06f0: 7d 20 6e 75 6c 6c 20 7b 7d 20 6e 75 6c 6c 7d 0a  } null {} null}.
0700: 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 31 2e 35 20  do_test nan-1.5 
0710: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64  {.  sqlite3_bind
0720: 5f 64 6f 75 62 6c 65 20 24 3a 3a 53 54 4d 54 20  _double $::STMT 
0730: 31 20 2d 4e 61 4e 30 0a 20 20 73 71 6c 69 74 65  1 -NaN0.  sqlite
0740: 33 5f 73 74 65 70 20 24 3a 3a 53 54 4d 54 0a 20  3_step $::STMT. 
0750: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 20 24   sqlite3_reset $
0760: 3a 3a 53 54 4d 54 0a 20 20 64 62 20 65 76 61 6c  ::STMT.  db eval
0770: 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70 65   {SELECT x, type
0780: 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d  of(x) FROM t1}.}
0790: 20 7b 7b 7d 20 6e 75 6c 6c 20 69 6e 66 20 72 65   {{} null inf re
07a0: 61 6c 20 2d 69 6e 66 20 72 65 61 6c 20 7b 7d 20  al -inf real {} 
07b0: 6e 75 6c 6c 20 7b 7d 20 6e 75 6c 6c 20 7b 7d 20  null {} null {} 
07c0: 6e 75 6c 6c 7d 0a 64 6f 5f 74 65 73 74 20 6e 61  null}.do_test na
07d0: 6e 2d 31 2e 36 20 7b 0a 20 20 64 62 20 65 76 61  n-1.6 {.  db eva
07e0: 6c 20 7b 0a 20 20 20 20 55 50 44 41 54 45 20 74  l {.    UPDATE t
07f0: 31 20 53 45 54 20 78 3d 78 2d 78 3b 0a 20 20 20  1 SET x=x-x;.   
0800: 20 53 45 4c 45 43 54 20 78 2c 20 74 79 70 65 6f   SELECT x, typeo
0810: 66 28 78 29 20 46 52 4f 4d 20 74 31 3b 0a 20 20  f(x) FROM t1;.  
0820: 7d 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c 20 7b 7d 20  }.} {{} null {} 
0830: 6e 75 6c 6c 20 7b 7d 20 6e 75 6c 6c 20 7b 7d 20  null {} null {} 
0840: 6e 75 6c 6c 20 7b 7d 20 6e 75 6c 6c 20 7b 7d 20  null {} null {} 
0850: 6e 75 6c 6c 7d 0a 0a 64 6f 5f 74 65 73 74 20 6e  null}..do_test n
0860: 61 6e 2d 32 2e 31 20 7b 0a 20 20 64 62 20 65 76  an-2.1 {.  db ev
0870: 61 6c 20 7b 0a 20 20 20 20 44 45 4c 45 54 45 20  al {.    DELETE 
0880: 46 52 4f 4d 20 54 31 3b 0a 20 20 7d 0a 20 20 73  FROM T1;.  }.  s
0890: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62  qlite3_bind_doub
08a0: 6c 65 20 24 3a 3a 53 54 4d 54 20 31 20 4e 61 4e  le $::STMT 1 NaN
08b0: 0a 20 20 73 71 6c 69 74 65 33 5f 73 74 65 70 20  .  sqlite3_step 
08c0: 24 3a 3a 53 54 4d 54 0a 20 20 73 71 6c 69 74 65  $::STMT.  sqlite
08d0: 33 5f 72 65 73 65 74 20 24 3a 3a 53 54 4d 54 0a  3_reset $::STMT.
08e0: 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43    db eval {SELEC
08f0: 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29 20 46  T x, typeof(x) F
0900: 52 4f 4d 20 74 31 7d 0a 7d 20 7b 7b 7d 20 6e 75  ROM t1}.} {{} nu
0910: 6c 6c 7d 0a 73 71 6c 69 74 65 33 5f 66 69 6e 61  ll}.sqlite3_fina
0920: 6c 69 7a 65 20 24 3a 3a 53 54 4d 54 0a 0a 23 20  lize $::STMT..# 
0930: 53 51 4c 69 74 65 20 61 6c 77 61 79 73 20 63 6f  SQLite always co
0940: 6e 76 65 72 74 73 20 4e 61 4e 20 69 6e 74 6f 20  nverts NaN into 
0950: 4e 55 4c 4c 20 73 6f 20 69 74 20 69 73 20 6e 6f  NULL so it is no
0960: 74 20 70 6f 73 73 69 62 6c 65 20 74 6f 20 77 72  t possible to wr
0970: 69 74 65 0a 23 20 61 20 4e 61 4e 20 76 61 6c 75  ite.# a NaN valu
0980: 65 20 69 6e 74 6f 20 74 68 65 20 64 61 74 61 62  e into the datab
0990: 61 73 65 20 66 69 6c 65 20 75 73 69 6e 67 20 53  ase file using S
09a0: 51 4c 69 74 65 2e 20 20 54 68 65 20 66 6f 6c 6c  QLite.  The foll
09b0: 6f 77 69 6e 67 20 73 65 72 69 65 73 0a 23 20 6f  owing series.# o
09c0: 66 20 74 65 73 74 73 20 77 72 69 74 65 73 20 61  f tests writes a
09d0: 20 6e 6f 72 6d 61 6c 20 66 6c 6f 61 74 69 6e 67   normal floating
09e0: 20 70 6f 69 6e 74 20 76 61 6c 75 65 20 28 30 2e   point value (0.
09f0: 35 29 20 69 6e 74 6f 20 74 68 65 20 64 61 74 61  5) into the data
0a00: 62 61 73 65 2c 0a 23 20 74 68 65 6e 20 77 72 69  base,.# then wri
0a10: 74 65 73 20 64 69 72 65 63 74 6c 79 20 69 6e 74  tes directly int
0a20: 6f 20 74 68 65 20 64 61 74 61 62 61 73 65 20 66  o the database f
0a30: 69 6c 65 20 74 6f 20 63 68 61 6e 67 65 20 74 68  ile to change th
0a40: 65 20 30 2e 35 20 69 6e 74 6f 20 4e 61 4e 2e 0a  e 0.5 into NaN..
0a50: 23 20 54 68 65 6e 20 69 74 20 72 65 61 64 73 20  # Then it reads 
0a60: 74 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68 65  the value of the
0a70: 20 64 61 74 61 62 61 73 65 20 74 6f 20 76 65 72   database to ver
0a80: 69 66 79 20 69 74 20 69 73 20 63 6f 6e 76 65 72  ify it is conver
0a90: 74 65 64 20 69 6e 74 6f 0a 23 20 4e 55 4c 4c 2e  ted into.# NULL.
0aa0: 0a 23 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 33  .#.do_test nan-3
0ab0: 2e 31 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b  .1 {.  db eval {
0ac0: 0a 20 20 20 20 44 45 4c 45 54 45 20 46 52 4f 4d  .    DELETE FROM
0ad0: 20 74 31 3b 0a 20 20 20 20 49 4e 53 45 52 54 20   t1;.    INSERT 
0ae0: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 30  INTO t1 VALUES(0
0af0: 2e 35 29 3b 0a 20 20 20 20 50 52 41 47 4d 41 20  .5);.    PRAGMA 
0b00: 61 75 74 6f 5f 76 61 63 75 75 6d 3d 4f 46 46 3b  auto_vacuum=OFF;
0b10: 0a 20 20 20 20 50 52 41 47 4d 41 20 70 61 67 65  .    PRAGMA page
0b20: 5f 73 69 7a 65 3d 31 30 32 34 3b 0a 20 20 20 20  _size=1024;.    
0b30: 56 41 43 55 55 4d 3b 0a 20 20 7d 0a 20 20 68 65  VACUUM;.  }.  he
0b40: 78 69 6f 5f 72 65 61 64 20 74 65 73 74 2e 64 62  xio_read test.db
0b50: 20 32 30 34 30 20 38 0a 7d 20 7b 33 46 45 30 30   2040 8.} {3FE00
0b60: 30 30 30 30 30 30 30 30 30 30 30 7d 0a 64 6f 5f  00000000000}.do_
0b70: 74 65 73 74 20 6e 61 6e 2d 33 2e 32 20 7b 0a 20  test nan-3.2 {. 
0b80: 20 64 62 20 65 76 61 6c 20 7b 0a 20 20 20 20 53   db eval {.    S
0b90: 45 4c 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28  ELECT x, typeof(
0ba0: 78 29 20 46 52 4f 4d 20 74 31 0a 20 20 7d 0a 7d  x) FROM t1.  }.}
0bb0: 20 7b 30 2e 35 20 72 65 61 6c 7d 0a 64 6f 5f 74   {0.5 real}.do_t
0bc0: 65 73 74 20 6e 61 6e 2d 33 2e 33 20 7b 0a 20 20  est nan-3.3 {.  
0bd0: 64 62 20 63 6c 6f 73 65 0a 20 20 68 65 78 69 6f  db close.  hexio
0be0: 5f 77 72 69 74 65 20 74 65 73 74 2e 64 62 20 32  _write test.db 2
0bf0: 30 34 30 20 46 46 46 38 30 30 30 30 30 30 30 30  040 FFF800000000
0c00: 30 30 30 30 0a 20 20 73 71 6c 69 74 65 33 20 64  0000.  sqlite3 d
0c10: 62 20 74 65 73 74 2e 64 62 0a 20 20 64 62 20 65  b test.db.  db e
0c20: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
0c30: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
0c40: 7d 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c 7d 0a 64 6f  }.} {{} null}.do
0c50: 5f 74 65 73 74 20 6e 61 6e 2d 33 2e 34 20 7b 0a  _test nan-3.4 {.
0c60: 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 68 65 78    db close.  hex
0c70: 69 6f 5f 77 72 69 74 65 20 74 65 73 74 2e 64 62  io_write test.db
0c80: 20 32 30 34 30 20 37 46 46 38 30 30 30 30 30 30   2040 7FF8000000
0c90: 30 30 30 30 30 30 0a 20 20 73 71 6c 69 74 65 33  000000.  sqlite3
0ca0: 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20 64 62   db test.db.  db
0cb0: 20 65 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c   eval {SELECT x,
0cc0: 20 74 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20   typeof(x) FROM 
0cd0: 74 31 7d 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c 7d 0a  t1}.} {{} null}.
0ce0: 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 33 2e 35 20  do_test nan-3.5 
0cf0: 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20 20 68  {.  db close.  h
0d00: 65 78 69 6f 5f 77 72 69 74 65 20 74 65 73 74 2e  exio_write test.
0d10: 64 62 20 32 30 34 30 20 46 46 46 46 46 46 46 46  db 2040 FFFFFFFF
0d20: 46 46 46 46 46 46 46 46 0a 20 20 73 71 6c 69 74  FFFFFFFF.  sqlit
0d30: 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a 20 20  e3 db test.db.  
0d40: 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43 54 20  db eval {SELECT 
0d50: 78 2c 20 74 79 70 65 6f 66 28 78 29 20 46 52 4f  x, typeof(x) FRO
0d60: 4d 20 74 31 7d 0a 7d 20 7b 7b 7d 20 6e 75 6c 6c  M t1}.} {{} null
0d70: 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 33 2e  }.do_test nan-3.
0d80: 36 20 7b 0a 20 20 64 62 20 63 6c 6f 73 65 0a 20  6 {.  db close. 
0d90: 20 68 65 78 69 6f 5f 77 72 69 74 65 20 74 65 73   hexio_write tes
0da0: 74 2e 64 62 20 32 30 34 30 20 37 46 46 46 46 46  t.db 2040 7FFFFF
0db0: 46 46 46 46 46 46 46 46 46 46 0a 20 20 73 71 6c  FFFFFFFFFF.  sql
0dc0: 69 74 65 33 20 64 62 20 74 65 73 74 2e 64 62 0a  ite3 db test.db.
0dd0: 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43    db eval {SELEC
0de0: 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29 20 46  T x, typeof(x) F
0df0: 52 4f 4d 20 74 31 7d 0a 7d 20 7b 7b 7d 20 6e 75  ROM t1}.} {{} nu
0e00: 6c 6c 7d 0a 0a 23 20 56 65 72 69 66 79 20 74 68  ll}..# Verify th
0e10: 61 74 20 74 68 65 20 73 71 6c 69 74 65 33 41 74  at the sqlite3At
0e20: 6f 46 20 72 6f 75 74 69 6e 65 20 69 73 20 61 62  oF routine is ab
0e30: 6c 65 20 74 6f 20 68 61 6e 64 6c 65 20 65 78 74  le to handle ext
0e40: 72 65 6d 65 0a 23 20 6e 75 6d 62 65 72 73 2e 0a  reme.# numbers..
0e50: 23 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e  #.do_test nan-4.
0e60: 31 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44  1 {.  db eval {D
0e70: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20  ELETE FROM t1}. 
0e80: 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54   db eval "INSERT
0e90: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
0ea0: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
0eb0: 20 33 30 37 5d 2e 30 29 22 0a 20 20 64 62 20 65   307].0)".  db e
0ec0: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
0ed0: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
0ee0: 7d 0a 7d 20 7b 31 65 2b 33 30 37 20 72 65 61 6c  }.} {1e+307 real
0ef0: 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e  }.do_test nan-4.
0f00: 32 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44  2 {.  db eval {D
0f10: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20  ELETE FROM t1}. 
0f20: 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54   db eval "INSERT
0f30: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
0f40: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
0f50: 20 33 30 38 5d 2e 30 29 22 0a 20 20 64 62 20 65   308].0)".  db e
0f60: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
0f70: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
0f80: 7d 0a 7d 20 7b 31 65 2b 33 30 38 20 72 65 61 6c  }.} {1e+308 real
0f90: 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e  }.do_test nan-4.
0fa0: 33 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44  3 {.  db eval {D
0fb0: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20  ELETE FROM t1}. 
0fc0: 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54   db eval "INSERT
0fd0: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
0fe0: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
0ff0: 20 33 30 39 5d 2e 30 29 22 0a 20 20 64 62 20 65   309].0)".  db e
1000: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
1010: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
1020: 7d 0a 7d 20 7b 69 6e 66 20 72 65 61 6c 7d 0a 64  }.} {inf real}.d
1030: 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e 34 20 7b  o_test nan-4.4 {
1040: 0a 20 20 64 62 20 65 76 61 6c 20 7b 44 45 4c 45  .  db eval {DELE
1050: 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20 20 64 62  TE FROM t1}.  db
1060: 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20 49 4e   eval "INSERT IN
1070: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 2d 5b 73  TO t1 VALUES(-[s
1080: 74 72 69 6e 67 20 72 65 70 65 61 74 20 39 20 33  tring repeat 9 3
1090: 30 37 5d 2e 30 29 22 0a 20 20 64 62 20 65 76 61  07].0)".  db eva
10a0: 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70  l {SELECT x, typ
10b0: 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a  eof(x) FROM t1}.
10c0: 7d 20 7b 2d 31 65 2b 33 30 37 20 72 65 61 6c 7d  } {-1e+307 real}
10d0: 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e 35  .do_test nan-4.5
10e0: 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44 45   {.  db eval {DE
10f0: 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20 20  LETE FROM t1}.  
1100: 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20  db eval "INSERT 
1110: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 2d  INTO t1 VALUES(-
1120: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
1130: 20 33 30 38 5d 2e 30 29 22 0a 20 20 64 62 20 65   308].0)".  db e
1140: 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74  val {SELECT x, t
1150: 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31  ypeof(x) FROM t1
1160: 7d 0a 7d 20 7b 2d 31 65 2b 33 30 38 20 72 65 61  }.} {-1e+308 rea
1170: 6c 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34  l}.do_test nan-4
1180: 2e 36 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b  .6 {.  db eval {
1190: 44 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a  DELETE FROM t1}.
11a0: 20 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52    db eval "INSER
11b0: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
11c0: 28 2d 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74  (-[string repeat
11d0: 20 39 20 33 30 39 5d 2e 30 29 22 0a 20 20 64 62   9 309].0)".  db
11e0: 20 65 76 61 6c 20 7b 53 45 4c 45 43 54 20 78 2c   eval {SELECT x,
11f0: 20 74 79 70 65 6f 66 28 78 29 20 46 52 4f 4d 20   typeof(x) FROM 
1200: 74 31 7d 0a 7d 20 7b 2d 69 6e 66 20 72 65 61 6c  t1}.} {-inf real
1210: 7d 0a 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e  }.do_test nan-4.
1220: 37 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44  7 {.  db eval {D
1230: 45 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20  ELETE FROM t1}. 
1240: 20 73 65 74 20 62 69 67 20 2d 5b 73 74 72 69 6e   set big -[strin
1250: 67 20 72 65 70 65 61 74 20 30 20 31 30 30 30 30  g repeat 0 10000
1260: 5d 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20  ][string repeat 
1270: 39 20 33 30 38 5d 2e 5b 73 74 72 69 6e 67 20 72  9 308].[string r
1280: 65 70 65 61 74 20 30 20 31 30 30 30 30 5d 0a 20  epeat 0 10000]. 
1290: 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54   db eval "INSERT
12a0: 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28   INTO t1 VALUES(
12b0: 24 62 69 67 29 22 0a 20 20 64 62 20 65 76 61 6c  $big)".  db eval
12c0: 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70 65   {SELECT x, type
12d0: 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d  of(x) FROM t1}.}
12e0: 20 7b 2d 31 65 2b 33 30 38 20 72 65 61 6c 7d 0a   {-1e+308 real}.
12f0: 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e 38 20  do_test nan-4.8 
1300: 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44 45 4c  {.  db eval {DEL
1310: 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20 20 73  ETE FROM t1}.  s
1320: 65 74 20 62 69 67 20 5b 73 74 72 69 6e 67 20 72  et big [string r
1330: 65 70 65 61 74 20 30 20 31 30 30 30 30 5d 5b 73  epeat 0 10000][s
1340: 74 72 69 6e 67 20 72 65 70 65 61 74 20 39 20 33  tring repeat 9 3
1350: 30 38 5d 2e 5b 73 74 72 69 6e 67 20 72 65 70 65  08].[string repe
1360: 61 74 20 30 20 31 30 30 30 30 5d 0a 20 20 64 62  at 0 10000].  db
1370: 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20 49 4e   eval "INSERT IN
1380: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24 62 69  TO t1 VALUES($bi
1390: 67 29 22 0a 20 20 64 62 20 65 76 61 6c 20 7b 53  g)".  db eval {S
13a0: 45 4c 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28  ELECT x, typeof(
13b0: 78 29 20 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 31  x) FROM t1}.} {1
13c0: 65 2b 33 30 38 20 72 65 61 6c 7d 0a 0a 0a 64 6f  e+308 real}...do
13d0: 5f 74 65 73 74 20 6e 61 6e 2d 34 2e 31 30 20 7b  _test nan-4.10 {
13e0: 0a 20 20 64 62 20 65 76 61 6c 20 7b 44 45 4c 45  .  db eval {DELE
13f0: 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20 20 64 62  TE FROM t1}.  db
1400: 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20 49 4e   eval "INSERT IN
1410: 54 4f 20 74 31 20 56 41 4c 55 45 53 28 31 32 33  TO t1 VALUES(123
1420: 34 2e 35 5b 73 74 72 69 6e 67 20 72 65 70 65 61  4.5[string repea
1430: 74 20 30 20 31 30 30 30 30 5d 31 32 33 34 35 29  t 0 10000]12345)
1440: 22 0a 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c  ".  db eval {SEL
1450: 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29  ECT x, typeof(x)
1460: 20 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 31 32 33   FROM t1}.} {123
1470: 34 2e 35 20 72 65 61 6c 7d 0a 64 6f 5f 74 65 73  4.5 real}.do_tes
1480: 74 20 6e 61 6e 2d 34 2e 31 31 20 7b 0a 20 20 64  t nan-4.11 {.  d
1490: 62 20 65 76 61 6c 20 7b 44 45 4c 45 54 45 20 46  b eval {DELETE F
14a0: 52 4f 4d 20 74 31 7d 0a 20 20 64 62 20 65 76 61  ROM t1}.  db eva
14b0: 6c 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  l "INSERT INTO t
14c0: 31 20 56 41 4c 55 45 53 28 2d 31 32 33 34 2e 35  1 VALUES(-1234.5
14d0: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 30  [string repeat 0
14e0: 20 31 30 30 30 30 5d 31 32 33 34 35 29 22 0a 20   10000]12345)". 
14f0: 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45 43 54   db eval {SELECT
1500: 20 78 2c 20 74 79 70 65 6f 66 28 78 29 20 46 52   x, typeof(x) FR
1510: 4f 4d 20 74 31 7d 0a 7d 20 7b 2d 31 32 33 34 2e  OM t1}.} {-1234.
1520: 35 20 72 65 61 6c 7d 0a 64 6f 5f 74 65 73 74 20  5 real}.do_test 
1530: 6e 61 6e 2d 34 2e 31 32 20 7b 0a 20 20 64 62 20  nan-4.12 {.  db 
1540: 65 76 61 6c 20 7b 44 45 4c 45 54 45 20 46 52 4f  eval {DELETE FRO
1550: 4d 20 74 31 7d 0a 20 20 73 65 74 20 73 6d 61 6c  M t1}.  set smal
1560: 6c 20 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74  l [string repeat
1570: 20 30 20 31 30 30 30 30 5d 2e 5b 73 74 72 69 6e   0 10000].[strin
1580: 67 20 72 65 70 65 61 74 20 30 20 33 32 33 5d 5b  g repeat 0 323][
1590: 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39 20  string repeat 9 
15a0: 31 30 30 30 30 5d 0a 20 20 64 62 20 65 76 61 6c  10000].  db eval
15b0: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31   "INSERT INTO t1
15c0: 20 56 41 4c 55 45 53 28 24 73 6d 61 6c 6c 29 22   VALUES($small)"
15d0: 0a 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45  .  db eval {SELE
15e0: 43 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29 20  CT x, typeof(x) 
15f0: 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 39 2e 38 38  FROM t1}.} {9.88
1600: 31 33 31 32 39 31 36 38 32 34 39 33 65 2d 33 32  131291682493e-32
1610: 34 20 72 65 61 6c 7d 0a 64 6f 5f 74 65 73 74 20  4 real}.do_test 
1620: 6e 61 6e 2d 34 2e 31 33 20 7b 0a 20 20 64 62 20  nan-4.13 {.  db 
1630: 65 76 61 6c 20 7b 44 45 4c 45 54 45 20 46 52 4f  eval {DELETE FRO
1640: 4d 20 74 31 7d 0a 20 20 73 65 74 20 73 6d 61 6c  M t1}.  set smal
1650: 6c 20 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74  l [string repeat
1660: 20 30 20 31 30 30 30 30 5d 2e 5b 73 74 72 69 6e   0 10000].[strin
1670: 67 20 72 65 70 65 61 74 20 30 20 33 32 34 5d 5b  g repeat 0 324][
1680: 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39 20  string repeat 9 
1690: 31 30 30 30 30 5d 0a 20 20 64 62 20 65 76 61 6c  10000].  db eval
16a0: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31   "INSERT INTO t1
16b0: 20 56 41 4c 55 45 53 28 24 73 6d 61 6c 6c 29 22   VALUES($small)"
16c0: 0a 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c 45  .  db eval {SELE
16d0: 43 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29 20  CT x, typeof(x) 
16e0: 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 30 2e 30 20  FROM t1}.} {0.0 
16f0: 72 65 61 6c 7d 0a 64 6f 5f 74 65 73 74 20 6e 61  real}.do_test na
1700: 6e 2d 34 2e 31 34 20 7b 0a 20 20 64 62 20 65 76  n-4.14 {.  db ev
1710: 61 6c 20 7b 44 45 4c 45 54 45 20 46 52 4f 4d 20  al {DELETE FROM 
1720: 74 31 7d 0a 20 20 73 65 74 20 73 6d 61 6c 6c 20  t1}.  set small 
1730: 5c 0a 20 20 20 20 20 20 2d 5b 73 74 72 69 6e 67  \.      -[string
1740: 20 72 65 70 65 61 74 20 30 20 31 30 30 30 30 5d   repeat 0 10000]
1750: 2e 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20  .[string repeat 
1760: 30 20 33 32 33 5d 5b 73 74 72 69 6e 67 20 72 65  0 323][string re
1770: 70 65 61 74 20 39 20 31 30 30 30 30 5d 0a 20 20  peat 9 10000].  
1780: 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52 54 20  db eval "INSERT 
1790: 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53 28 24  INTO t1 VALUES($
17a0: 73 6d 61 6c 6c 29 22 0a 20 20 64 62 20 65 76 61  small)".  db eva
17b0: 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70  l {SELECT x, typ
17c0: 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a  eof(x) FROM t1}.
17d0: 7d 20 7b 2d 39 2e 38 38 31 33 31 32 39 31 36 38  } {-9.8813129168
17e0: 32 34 39 33 65 2d 33 32 34 20 72 65 61 6c 7d 0a  2493e-324 real}.
17f0: 64 6f 5f 74 65 73 74 20 6e 61 6e 2d 34 2e 31 35  do_test nan-4.15
1800: 20 7b 0a 20 20 64 62 20 65 76 61 6c 20 7b 44 45   {.  db eval {DE
1810: 4c 45 54 45 20 46 52 4f 4d 20 74 31 7d 0a 20 20  LETE FROM t1}.  
1820: 73 65 74 20 73 6d 61 6c 6c 20 5c 0a 20 20 20 20  set small \.    
1830: 20 20 2d 5b 73 74 72 69 6e 67 20 72 65 70 65 61    -[string repea
1840: 74 20 30 20 31 30 30 30 30 5d 2e 5b 73 74 72 69  t 0 10000].[stri
1850: 6e 67 20 72 65 70 65 61 74 20 30 20 33 32 34 5d  ng repeat 0 324]
1860: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
1870: 20 31 30 30 30 30 5d 0a 20 20 64 62 20 65 76 61   10000].  db eva
1880: 6c 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 74  l "INSERT INTO t
1890: 31 20 56 41 4c 55 45 53 28 24 73 6d 61 6c 6c 29  1 VALUES($small)
18a0: 22 0a 20 20 64 62 20 65 76 61 6c 20 7b 53 45 4c  ".  db eval {SEL
18b0: 45 43 54 20 78 2c 20 74 79 70 65 6f 66 28 78 29  ECT x, typeof(x)
18c0: 20 46 52 4f 4d 20 74 31 7d 0a 7d 20 7b 30 2e 30   FROM t1}.} {0.0
18d0: 20 72 65 61 6c 7d 0a 0a 64 6f 5f 74 65 73 74 20   real}..do_test 
18e0: 6e 61 6e 2d 34 2e 32 30 20 7b 0a 20 20 64 62 20  nan-4.20 {.  db 
18f0: 65 76 61 6c 20 7b 44 45 4c 45 54 45 20 46 52 4f  eval {DELETE FRO
1900: 4d 20 74 31 7d 0a 20 20 73 65 74 20 62 69 67 20  M t1}.  set big 
1910: 5b 73 74 72 69 6e 67 20 72 65 70 65 61 74 20 39  [string repeat 9
1920: 20 31 30 30 30 30 5d 2e 30 65 2d 39 30 30 30 0a   10000].0e-9000.
1930: 20 20 64 62 20 65 76 61 6c 20 22 49 4e 53 45 52    db eval "INSER
1940: 54 20 49 4e 54 4f 20 74 31 20 56 41 4c 55 45 53  T INTO t1 VALUES
1950: 28 24 62 69 67 29 22 0a 20 20 64 62 20 65 76 61  ($big)".  db eva
1960: 6c 20 7b 53 45 4c 45 43 54 20 78 2c 20 74 79 70  l {SELECT x, typ
1970: 65 6f 66 28 78 29 20 46 52 4f 4d 20 74 31 7d 0a  eof(x) FROM t1}.
1980: 7d 20 7b 7b 7d 20 6e 75 6c 6c 7d 0a 0a 0a 0a 66  } {{} null}....f
1990: 69 6e 69 73 68 5f 74 65 73 74 0a                 inish_test.