Annotation of embedaddon/sqlite3/test/vtab9.test, revision 1.1.1.1

1.1       misho       1: # 2006 August 29
                      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: # This file implements regression tests for SQLite library.  The
                     12: # focus of this file inserting into virtual tables from a SELECT
                     13: # statement.
                     14: #
                     15: # $Id: vtab9.test,v 1.2 2007/04/16 15:06:26 danielk1977 Exp $
                     16: 
                     17: set testdir [file dirname $argv0]
                     18: source $testdir/tester.tcl
                     19: 
                     20: ifcapable !vtab {
                     21:   finish_test
                     22:   return
                     23: }
                     24: 
                     25: do_test vtab9-1.1 {
                     26:   register_echo_module [sqlite3_connection_pointer db]
                     27:   execsql {
                     28:     CREATE TABLE t0(a);
                     29:     CREATE VIRTUAL TABLE t1 USING echo(t0);
                     30:     INSERT INTO t1 SELECT 'hello';
                     31:     SELECT rowid, * FROM t1;
                     32:   }
                     33: } {1 hello}
                     34: 
                     35: do_test vtab9-1.2 {
                     36:   execsql {
                     37:     CREATE TABLE t2(a,b,c);
                     38:     CREATE VIRTUAL TABLE t3 USING echo(t2);
                     39:     CREATE TABLE d1(a,b,c);
                     40:     INSERT INTO d1 VALUES(1,2,3);
                     41:     INSERT INTO d1 VALUES('a','b','c');
                     42:     INSERT INTO d1 VALUES(NULL,'x',123.456);
                     43:     INSERT INTO d1 VALUES(x'6869',123456789,-12345);
                     44:     INSERT INTO t3(a,b,c) SELECT * FROM d1;
                     45:     SELECT rowid, * FROM t3;
                     46:   }
                     47: } {1 1 2 3 2 a b c 3 {} x 123.456 4 hi 123456789 -12345}
                     48: 
                     49: # do_test vtab9-2.1 {
                     50: #   execsql {
                     51: #     CREATE TABLE t4(a);
                     52: #     CREATE VIRTUAL TABLE t5 USING echo(t4);
                     53: #     INSERT INTO t4 VALUES('hello');
                     54: #     SELECT rowid, a FROM t5;
                     55: #   }
                     56: # } {1 hello}
                     57: # do_test vtab9-2.2 {
                     58: #   execsql {
                     59: #     INSERT INTO t5(rowid, a) VALUES(1, 'goodbye');
                     60: #   }
                     61: # } {1 hello}
                     62: # do_test vtab9-2.3 {
                     63: #   execsql {
                     64: #     REPLACE INTO t5(rowid, a) VALUES(1, 'goodbye');
                     65: #     SELECT * FROM t5;
                     66: #   }
                     67: # } {1 goodbye}
                     68: 
                     69: unset -nocomplain echo_module_begin_fail
                     70: finish_test

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