blob: 9192eaf512ddea412f3f868e299fc678691471e1 [file] [log] [blame]
drh276fdbf2007-04-30 21:39:16 +00001# 2007 April 25
drh7a521cf2007-04-25 18:23:52 +00002#
3# The author disclaims copyright to this source code. In place of
4# a legal notice, here is a blessing:
5#
6# May you do good and not evil.
7# May you find forgiveness for yourself and forgive others.
8# May you share freely, never taking more than you give.
9#
10#***********************************************************************
11# This file contains additional out-of-memory checks (see malloc.tcl)
12# added to expose a bug in out-of-memory handling for sqlite3_value_text()
13#
drheee4c8c2008-02-18 22:24:57 +000014# $Id: malloc8.test,v 1.7 2008/02/18 22:24:58 drh Exp $
drh7a521cf2007-04-25 18:23:52 +000015
16set testdir [file dirname $argv0]
17source $testdir/tester.tcl
drheee4c8c2008-02-18 22:24:57 +000018source $testdir/malloc_common.tcl
drh7a521cf2007-04-25 18:23:52 +000019
20# Only run these tests if memory debugging is turned on.
21#
drheee4c8c2008-02-18 22:24:57 +000022if {!$MEMDEBUG} {
drh5a3032b2007-09-03 16:12:09 +000023 puts "Skipping malloc8 tests: not compiled with -DSQLITE_MEMDEBUG..."
drh7a521cf2007-04-25 18:23:52 +000024 finish_test
25 return
26}
27
drh7a521cf2007-04-25 18:23:52 +000028
29# The setup is a database with UTF-16 encoding that contains a single
30# large string. We will be running lots of queries against this
31# database. Because we will be extracting the string as UTF-8, there
32# is a type conversion that occurs and thus an opportunity for malloc()
33# to fail and for sqlite3_value_text() to return 0 even though
34# sqlite3_value_type() returns SQLITE_TEXT.
35#
drhed138fb2007-08-22 22:04:37 +000036
37do_malloc_test malloc8-1 -sqlprep {
drh7a521cf2007-04-25 18:23:52 +000038 PRAGMA encoding='UTF-16';
39 CREATE TABLE t1(a);
40 INSERT INTO t1
41 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
drhed138fb2007-08-22 22:04:37 +000042} -sqlbody {
drh7a521cf2007-04-25 18:23:52 +000043 SELECT lower(a), upper(a), quote(a), trim(a), trim('x',a) FROM t1;
44}
drhed138fb2007-08-22 22:04:37 +000045do_malloc_test malloc8-2 -sqlprep {
46 PRAGMA encoding='UTF-16';
47 CREATE TABLE t1(a);
48 INSERT INTO t1
49 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
50} -sqlbody {
drh7a521cf2007-04-25 18:23:52 +000051 SELECT replace(a,'x','y'), replace('x',a,'y'), replace('x','y',a)
52 FROM t1;
53}
drhed138fb2007-08-22 22:04:37 +000054do_malloc_test malloc8-3 -sqlprep {
55 PRAGMA encoding='UTF-16';
56 CREATE TABLE t1(a);
57 INSERT INTO t1
58 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
59} -sqlbody {
drh7a521cf2007-04-25 18:23:52 +000060 SELECT length(a), substr(a, 4, 4) FROM t1;
61}
danielk19774152e672007-09-12 17:01:45 +000062ifcapable datetime {
63 do_malloc_test malloc8-4 -sqlprep {
64 PRAGMA encoding='UTF-16';
65 CREATE TABLE t1(a);
66 INSERT INTO t1
67 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
68 } -sqlbody {
69 SELECT julianday(a,a) FROM t1;
70 }
drh7a521cf2007-04-25 18:23:52 +000071}
drhed138fb2007-08-22 22:04:37 +000072do_malloc_test malloc8-5 -sqlprep {
73 PRAGMA encoding='UTF-16';
74 CREATE TABLE t1(a);
75 INSERT INTO t1
76 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
77} -sqlbody {
drh7a521cf2007-04-25 18:23:52 +000078 SELECT 1 FROM t1 WHERE a LIKE 'hello' ESCAPE NULL;
79}
drhed138fb2007-08-22 22:04:37 +000080do_malloc_test malloc8-6 -sqlprep {
81 PRAGMA encoding='UTF-16';
82 CREATE TABLE t1(a);
83 INSERT INTO t1
84 VALUES('0123456789aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ');
85} -sqlbody {
drh02d85832007-05-07 19:31:15 +000086 SELECT hex(randomblob(100));
87}
drh7a521cf2007-04-25 18:23:52 +000088
89# Ensure that no file descriptors were leaked.
90do_test malloc-99.X {
91 catch {db close}
92 set sqlite_open_file_count
93} {0}
94
drh7a521cf2007-04-25 18:23:52 +000095finish_test