xref: /sqlite-3.40.0/test/fuzz_malloc.test (revision 9afe689e)
1#
2# 2007 May 10
3#
4# The author disclaims copyright to this source code.  In place of
5# a legal notice, here is a blessing:
6#
7#    May you do good and not evil.
8#    May you find forgiveness for yourself and forgive others.
9#    May you share freely, never taking more than you give.
10#
11#***********************************************************************
12#
13# This file tests malloc failures in concert with fuzzy SQL generation.
14#
15# $Id: fuzz_malloc.test,v 1.2 2007/05/31 08:20:44 danielk1977 Exp $
16
17set testdir [file dirname $argv0]
18source $testdir/tester.tcl
19source $testdir/fuzz_common.tcl
20source $testdir/malloc_common.tcl
21
22set ::REPEATS 20
23
24#
25# Usage: do_fuzzy_malloc_test <testname> ?<options>?
26#
27#     -template
28#     -sqlprep
29#     -repeats
30#
31proc do_fuzzy_malloc_test {testname args} {
32  set ::fuzzyopts(-repeats) $::REPEATS
33  set ::fuzzyopts(-sqlprep) {}
34  array set ::fuzzyopts $args
35
36  sqlite_malloc_fail 0
37  db close
38  file delete test.db test.db-journal
39  sqlite3 db test.db
40  set ::prep $::fuzzyopts(-sqlprep)
41  execsql $::prep
42
43  for {set ii 0} {$ii < $::fuzzyopts(-repeats)} {incr ii} {
44    set ::sql [subst $::fuzzyopts(-template)]
45    foreach {rc res} [catchsql "$::sql"] {}
46    if {$rc==0} {
47      do_malloc_test $testname-$ii -sqlbody $::sql -sqlprep $::prep
48    } else {
49      incr ii -1
50    }
51  }
52}
53
54#----------------------------------------------------------------
55# Test malloc failure during parsing (and execution) of a fuzzily
56# generated expressions.
57#
58do_fuzzy_malloc_test fuzzy_malloc-1 -template {Select [Expr]}
59do_fuzzy_malloc_test fuzzy_malloc-2 -template {[Select]}
60
61set ::SQLPREP {
62  BEGIN;
63    CREATE TABLE abc(a, b, c);
64    CREATE TABLE def(a, b, c);
65    CREATE TABLE ghi(a, b, c);
66    INSERT INTO abc VALUES(1.5, 3, 'a short string');
67    INSERT INTO def VALUES(NULL, X'ABCDEF',
68        'a longer string. Long enough that it doesn''t fit in Mem.zShort');
69    INSERT INTO ghi VALUES(zeroblob(1000), 'hello world', -1257900987654321);
70  COMMIT;
71}
72set ::TableList  [list abc def ghi]
73set ::ColumnList [list a b c]
74
75do_fuzzy_malloc_test fuzzy_malloc-3 \
76  -template {[Select]}              \
77  -sqlprep $::SQLPREP
78
79sqlite_malloc_fail 0
80finish_test
81
82