2005-04-22 06:38:37 +04:00
|
|
|
# 2005 April 21
|
|
|
|
#
|
|
|
|
# The author disclaims copyright to this source code. In place of
|
|
|
|
# a legal notice, here is a blessing:
|
|
|
|
#
|
|
|
|
# May you do good and not evil.
|
|
|
|
# May you find forgiveness for yourself and forgive others.
|
|
|
|
# May you share freely, never taking more than you give.
|
|
|
|
#
|
|
|
|
#***********************************************************************
|
|
|
|
# This file implements regression tests for SQLite library. The
|
|
|
|
# focus of this script testing the sqlite_transfer_bindings() API.
|
|
|
|
#
|
2008-03-17 19:23:26 +03:00
|
|
|
# $Id: bindxfer.test,v 1.5 2008/03/17 16:23:27 drh Exp $
|
2005-04-22 06:38:37 +04:00
|
|
|
#
|
|
|
|
|
|
|
|
set testdir [file dirname $argv0]
|
|
|
|
source $testdir/tester.tcl
|
|
|
|
|
|
|
|
proc sqlite_step {stmt VALS COLS} {
|
|
|
|
upvar #0 $VALS vals
|
|
|
|
upvar #0 $COLS cols
|
|
|
|
set vals [list]
|
|
|
|
set cols [list]
|
|
|
|
|
|
|
|
set rc [sqlite3_step $stmt]
|
|
|
|
for {set i 0} {$i < [sqlite3_column_count $stmt]} {incr i} {
|
|
|
|
lappend cols [sqlite3_column_name $stmt $i]
|
|
|
|
}
|
|
|
|
for {set i 0} {$i < [sqlite3_data_count $stmt]} {incr i} {
|
|
|
|
lappend vals [sqlite3_column_text $stmt $i]
|
|
|
|
}
|
|
|
|
|
|
|
|
return $rc
|
|
|
|
}
|
|
|
|
|
|
|
|
do_test bindxfer-1.1 {
|
2006-01-03 03:33:50 +03:00
|
|
|
set DB [sqlite3_connection_pointer db]
|
2005-04-22 06:38:37 +04:00
|
|
|
execsql {CREATE TABLE t1(a,b,c);}
|
|
|
|
set VM1 [sqlite3_prepare $DB {SELECT ?, ?, ?} -1 TAIL]
|
|
|
|
set TAIL
|
|
|
|
} {}
|
|
|
|
do_test bindxfer-1.2 {
|
|
|
|
sqlite3_bind_parameter_count $VM1
|
|
|
|
} 3
|
|
|
|
do_test bindxfer-1.3 {
|
|
|
|
set VM2 [sqlite3_prepare $DB {SELECT ?, ?, ?} -1 TAIL]
|
|
|
|
set TAIL
|
|
|
|
} {}
|
|
|
|
do_test bindxfer-1.4 {
|
|
|
|
sqlite3_bind_parameter_count $VM2
|
|
|
|
} 3
|
|
|
|
do_test bindxfer-1.5 {
|
|
|
|
sqlite_bind $VM1 1 one normal
|
|
|
|
set sqlite_static_bind_value two
|
|
|
|
sqlite_bind $VM1 2 {} static
|
|
|
|
sqlite_bind $VM1 3 {} null
|
|
|
|
sqlite3_transfer_bindings $VM1 $VM2
|
|
|
|
sqlite_step $VM1 VALUES COLNAMES
|
|
|
|
} SQLITE_ROW
|
|
|
|
do_test bindxfer-1.6 {
|
|
|
|
set VALUES
|
|
|
|
} {{} {} {}}
|
|
|
|
do_test bindxfer-1.7 {
|
|
|
|
sqlite_step $VM2 VALUES COLNAMES
|
|
|
|
} SQLITE_ROW
|
|
|
|
do_test bindxfer-1.8 {
|
|
|
|
set VALUES
|
|
|
|
} {one two {}}
|
2008-03-17 19:23:26 +03:00
|
|
|
do_test bindxfer-1.9-misuse {
|
2007-04-04 05:27:44 +04:00
|
|
|
catch {sqlite3_finalize $VM1}
|
|
|
|
catch {sqlite3_finalize $VM2}
|
|
|
|
sqlite3_transfer_bindings $VM1 $VM2
|
|
|
|
} 21 ;# SQLITE_MISUSE
|
|
|
|
do_test bindxfer-1.10 {
|
|
|
|
set VM1 [sqlite3_prepare $DB {SELECT ?, ?, ?} -1 TAIL]
|
|
|
|
set VM2 [sqlite3_prepare $DB {SELECT ?, ?, ?, ?} -1 TAIL]
|
|
|
|
sqlite3_transfer_bindings $VM1 $VM2
|
|
|
|
} 1 ;# SQLITE_ERROR
|
2007-04-05 15:25:58 +04:00
|
|
|
catch {sqlite3_finalize $VM1}
|
|
|
|
catch {sqlite3_finalize $VM2}
|
2007-04-04 05:27:44 +04:00
|
|
|
|
2005-04-22 06:38:37 +04:00
|
|
|
|
|
|
|
finish_test
|