blob: 9a02b742e831ae21bda8aaca9d414afb849bac99 [file] [log] [blame]
drhb19a2bc2001-09-16 00:13:26 +00001# 2001 September 15
drhed7c8552001-04-11 14:29:21 +00002#
drhb19a2bc2001-09-16 00:13:26 +00003# The author disclaims copyright to this source code. In place of
4# a legal notice, here is a blessing:
drhed7c8552001-04-11 14:29:21 +00005#
drhb19a2bc2001-09-16 00:13:26 +00006# 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.
drhed7c8552001-04-11 14:29:21 +00009#
10#***********************************************************************
11# This file attempts to check the library in an out-of-memory situation.
12# When compiled with -DMEMORY_DEBUG=1, the SQLite library accepts a special
drh6d4abfb2001-10-22 02:58:08 +000013# command (sqlite_malloc_fail N) which causes the N-th malloc to fail. This
drhed7c8552001-04-11 14:29:21 +000014# special feature is used to see what happens in the library if a malloc
15# were to really fail due to an out-of-memory situation.
16#
drh6d4abfb2001-10-22 02:58:08 +000017# $Id: malloc.test,v 1.4 2001/10/22 02:58:11 drh Exp $
drhed7c8552001-04-11 14:29:21 +000018
19set testdir [file dirname $argv0]
20source $testdir/tester.tcl
21
22# Only run these tests if memory debugging is turned on.
23#
24if {[info command sqlite_malloc_fail]==""} {
25 puts "Skipping malloc tests: not compiled with -DMEMORY_DEBUG..."
26 finish_test
27 return
28}
29
30for {set go 1; set i 1} {$go} {incr i} {
31 do_test malloc-1.$i {
32 sqlite_malloc_fail 0
drh6d4abfb2001-10-22 02:58:08 +000033 catch {db close}
34 catch {file delete -force test.db}
35 catch {file delete -force test.db-journal}
drhed7c8552001-04-11 14:29:21 +000036 sqlite_malloc_fail $i
drh6d4abfb2001-10-22 02:58:08 +000037 set v [catch {sqlite db test.db} msg]
38 if {$v} {
39 set msg ""
40 } else {
41 set v [catch {execsql {
42 CREATE TABLE t1(
43 a int, b float, c double, d text, e varchar(20),
44 primary key(a,b,c)
45 );
46 CREATE INDEX i1 ON t1(a,b);
47 INSERT INTO t1 VALUES(1,2.3,4.5,'hi','there');
48 INSERT INTO t1 VALUES(6,7.0,0.8,'hello','out yonder');
49 SELECT * FROM t1;
50 SELECT avg(b) FROM t1 GROUP BY a HAVING b>20.0;
51 DELETE FROM t1 WHERE a IN (SELECT min(a) FROM t1);
52 SELECT count(*) FROM t1;
53 }} msg]
54 }
55 set leftover [lindex [sqlite_malloc_stat] 2]
56 if {$leftover>0} {
57 if {$leftover>1} {puts "\nLeftover: $leftover\nReturn=$v Message=$msg"}
drhed7c8552001-04-11 14:29:21 +000058 set ::go 0
59 set v {1 1}
60 } else {
drh6d4abfb2001-10-22 02:58:08 +000061 set v2 [expr {$msg=="" || $msg=="out of memory"}]
62 if {!$v2} {puts "\nError message returned: $msg"}
63 lappend v $v2
drhed7c8552001-04-11 14:29:21 +000064 }
65 } {1 1}
66}
drhd4007282001-04-12 23:21:58 +000067
drh6d4abfb2001-10-22 02:58:08 +000068finish_test
69return
70
71
drhd4007282001-04-12 23:21:58 +000072set fd [open ./data.tmp w]
drh6d4abfb2001-10-22 02:58:08 +000073for {set i 1} {$i<=20} {incr i} {
74 puts $fd "$i\t[expr {$i*$i}]\t[expr {100-$i}] abcdefghijklmnopqrstuvwxyz"
drhd4007282001-04-12 23:21:58 +000075}
76close $fd
77
78for {set go 1; set i 1} {$go} {incr i} {
79 do_test malloc-2.$i {
80 sqlite_malloc_fail 0
drh6d4abfb2001-10-22 02:58:08 +000081 catch {db close}
82 catch {file delete -force test.db}
83 catch {file delete -force test.db-journal}
drhd4007282001-04-12 23:21:58 +000084 sqlite_malloc_fail $i
drh6d4abfb2001-10-22 02:58:08 +000085 set v [catch {sqlite db test.db} msg]
86 if {$v} {
87 set msg ""
88 } else {
89 set v [catch {execsql {
90 CREATE TABLE t1(a int, b int, c int);
91 CREATE INDEX i1 ON t1(a,b);
92 COPY t1 FROM 'data.tmp';
93 SELECT 'stuff', count(*) as 'other stuff', max(a+10) FROM t1;
94 UPDATE t1 SET b=b||b||b||b;
95 UPDATE t1 SET b=a WHERE a in (10,12,22);
96 INSERT INTO t1(c,b,a) VALUES(20,10,5);
97 INSERT INTO t1 SELECT * FROM t1
98 WHERE a IN (SELECT a FROM t1 WHERE a<10);
99 DELETE FROM t1 WHERE a>=10;
100 DROP INDEX i1;
101 DELETE FROM t1;
102 }} msg]
103 }
104 set leftover [lindex [sqlite_malloc_stat] 2]
105 if {$leftover>0} {
106 if {$leftover>1} {puts "\nLeftover: $leftover\nReturn=$v Message=$msg"}
drhd4007282001-04-12 23:21:58 +0000107 set ::go 0
108 set v {1 1}
109 } else {
drh6d4abfb2001-10-22 02:58:08 +0000110 set v2 [expr {$msg=="" || $msg=="out of memory"}]
111 if {!$v2} {puts "\nError message returned: $msg"}
112 lappend v $v2
113 }
114 } {1 1}
115}
116
117set fd [open ./data.tmp w]
118for {set i 1} {$i<=10} {incr i} {
119 puts $fd "$i\t[expr {$i*$i}]\t[expr {100-$i}]"
120}
121close $fd
122
123for {set go 1; set i 1} {$go} {incr i} {
124 do_test malloc-3.$i {
125 sqlite_malloc_fail 0
126 catch {db close}
127 catch {file delete -force test.db}
128 catch {file delete -force test.db-journal}
129 sqlite_malloc_fail $i
130 set v [catch {sqlite db test.db} msg]
131 if {$v} {
132 set msg ""
133 } else {
134 set v [catch {execsql {
135 BEGIN TRANSACTION;
136 CREATE TABLE t1(a int, b int, c int);
137 CREATE INDEX i1 ON t1(a,b);
138 COPY t1 FROM 'data.tmp';
139 INSERT INTO t1(c,b,a) VALUES(20,10,5);
140 DELETE FROM t1 WHERE a>=10;
141 DROP INDEX i1;
142 DELETE FROM t1;
143 ROLLBACK;
144 }} msg]
145 }
146 set leftover [lindex [sqlite_malloc_stat] 2]
147 if {$leftover>0} {
148 if {$leftover>1} {puts "\nLeftover: $leftover\nReturn=$v Message=$msg"}
149 set ::go 0
150 set v {1 1}
151 } else {
152 set v2 [expr {$msg=="" || $msg=="out of memory"}]
153 if {!$v2} {puts "\nError message returned: $msg"}
154 lappend v $v2
155 }
156 } {1 1}
157}
158for {set go 1; set i 1} {$go} {incr i} {
159 do_test malloc-4.$i {
160 sqlite_malloc_fail 0
161 catch {db close}
162 catch {file delete -force test.db}
163 catch {file delete -force test.db-journal}
164 sqlite_malloc_fail $i
165 set v [catch {sqlite db test.db} msg]
166 if {$v} {
167 set msg ""
168 } else {
169 set v [catch {execsql {
170 BEGIN TRANSACTION;
171 CREATE TABLE t1(a int, b int, c int);
172 CREATE INDEX i1 ON t1(a,b);
173 COPY t1 FROM 'data.tmp';
174 UPDATE t1 SET b=a WHERE a in (10,12,22);
175 INSERT INTO t1 SELECT * FROM t1
176 WHERE a IN (SELECT a FROM t1 WHERE a<10);
177 DROP INDEX i1;
178 DELETE FROM t1;
179 COMMIT;
180 }} msg]
181 }
182 set leftover [lindex [sqlite_malloc_stat] 2]
183 if {$leftover>0} {
184 if {$leftover>1} {puts "\nLeftover: $leftover\nReturn=$v Message=$msg"}
185 set ::go 0
186 set v {1 1}
187 } else {
188 set v2 [expr {$msg=="" || $msg=="out of memory"}]
189 if {!$v2} {puts "\nError message returned: $msg"}
190 lappend v $v2
drhd4007282001-04-12 23:21:58 +0000191 }
192 } {1 1}
193}
drhed7c8552001-04-11 14:29:21 +0000194sqlite_malloc_fail 0
195finish_test