Annotation of embedaddon/sqlite3/test/mallocK.test, revision 1.1

1.1     ! misho       1: # 2008 August 01
        !             2: #
        !             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: #
        !            12: # This test script checks malloc failures in WHERE clause analysis.
        !            13: # 
        !            14: # $Id: mallocK.test,v 1.3 2009/01/08 21:00:03 drh Exp $
        !            15: 
        !            16: set testdir [file dirname $argv0]
        !            17: source $testdir/tester.tcl
        !            18: source $testdir/malloc_common.tcl
        !            19: 
        !            20: set sql {SELECT * FROM t1, t2 WHERE (a=1 OR a=2)}
        !            21: for {set x 1} {$x<5} {incr x} {
        !            22:   append sql " AND b=y"
        !            23:   do_malloc_test mallocK-1.$x -sqlbody $sql -sqlprep {
        !            24:     CREATE TABLE t1(a,b);
        !            25:     CREATE TABLE t2(x,y);
        !            26:   }
        !            27: }
        !            28: 
        !            29: set sql {SELECT * FROM t1 WHERE a GLOB 'xyz*' AND (a=1 OR a=2)}
        !            30: for {set x 1} {$x<5} {incr x} {
        !            31:   append sql " AND b!=$x"
        !            32:   do_malloc_test mallocK-2.$x -sqlbody $sql -sqlprep {
        !            33:     CREATE TABLE t1(a,b);
        !            34:   }
        !            35: }
        !            36: 
        !            37: set sql {SELECT * FROM t1 WHERE a BETWEEN 5 AND 10}
        !            38: for {set x 1} {$x<5} {incr x} {
        !            39:   append sql " AND b=$x"
        !            40:   do_malloc_test mallocK-3.$x -sqlbody $sql -sqlprep {
        !            41:     CREATE TABLE t1(a,b);
        !            42:   }
        !            43: }
        !            44: 
        !            45: set sql {SELECT * FROM t1 WHERE b=0}
        !            46: for {set x 1} {$x<5} {incr x} {
        !            47:   set term "(b=$x"
        !            48:   for {set y 0} {$y<$x} {incr y} {
        !            49:     append term " AND a!=$y"
        !            50:   }
        !            51:   append sql " OR $term)"
        !            52:   do_malloc_test mallocK-4.$x -sqlbody $sql -sqlprep {
        !            53:     CREATE TABLE t1(a,b);
        !            54:   }
        !            55: }
        !            56: 
        !            57: ifcapable vtab {
        !            58:   set sql {SELECT * FROM t2 WHERE a MATCH 'xyz'}
        !            59:   for {set x 1} {$x<5} {incr x} {
        !            60:     append sql " AND b!=$x"
        !            61:     do_malloc_test mallocK-5.$x -sqlbody $sql -tclprep {
        !            62:       register_echo_module [sqlite3_connection_pointer db]
        !            63:       db eval {
        !            64:         CREATE TABLE t1(a,b);
        !            65:         CREATE VIRTUAL TABLE t2 USING echo(t1);
        !            66:       }
        !            67:     }
        !            68:   }
        !            69: }
        !            70: 
        !            71: 
        !            72: finish_test

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>