summaryrefslogtreecommitdiff
path: root/usr/src/cmd/svc/configd/sqlite/test/quote.test
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/cmd/svc/configd/sqlite/test/quote.test')
-rw-r--r--usr/src/cmd/svc/configd/sqlite/test/quote.test91
1 files changed, 91 insertions, 0 deletions
diff --git a/usr/src/cmd/svc/configd/sqlite/test/quote.test b/usr/src/cmd/svc/configd/sqlite/test/quote.test
new file mode 100644
index 0000000000..5fb9e85736
--- /dev/null
+++ b/usr/src/cmd/svc/configd/sqlite/test/quote.test
@@ -0,0 +1,91 @@
+
+#pragma ident "%Z%%M% %I% %E% SMI"
+
+# 2001 September 15
+#
+# 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 file is the ability to specify table and column names
+# as quoted strings.
+#
+# $Id: quote.test,v 1.3 2002/05/21 13:43:04 drh Exp $
+
+set testdir [file dirname $argv0]
+source $testdir/tester.tcl
+
+# Create a table with a strange name and with strange column names.
+#
+do_test quote-1.0 {
+ set r [catch {
+ execsql {CREATE TABLE '@abc' ( '#xyz' int, '!pqr' text );}
+ } msg]
+ lappend r $msg
+} {0 {}}
+
+# Insert, update and query the table.
+#
+do_test quote-1.1 {
+ set r [catch {
+ execsql {INSERT INTO '@abc' VALUES(5,'hello')}
+ } msg]
+ lappend r $msg
+} {0 {}}
+do_test quote-1.2 {
+ set r [catch {
+ execsql {SELECT * FROM '@abc'}
+ } msg ]
+ lappend r $msg
+} {0 {5 hello}}
+do_test quote-1.3 {
+ set r [catch {
+ execsql {SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'}
+ } msg ]
+ lappend r $msg
+} {0 {hello 10}}
+do_test quote-1.3.1 {
+ catchsql {
+ SELECT '!pqr', '#xyz'+5 FROM '@abc'
+ }
+} {0 {!pqr 5}}
+do_test quote-1.3.2 {
+ catchsql {
+ SELECT "!pqr", "#xyz"+5 FROM '@abc'
+ }
+} {0 {hello 10}}
+do_test quote-1.3 {
+ set r [catch {
+ execsql {SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'}
+ } msg ]
+ lappend r $msg
+} {0 {hello 10}}
+do_test quote-1.4 {
+ set r [catch {
+ execsql {UPDATE '@abc' SET '#xyz'=11}
+ } msg ]
+ lappend r $msg
+} {0 {}}
+do_test quote-1.5 {
+ set r [catch {
+ execsql {SELECT '@abc'.'!pqr', '@abc'.'#xyz'+5 FROM '@abc'}
+ } msg ]
+ lappend r $msg
+} {0 {hello 16}}
+
+# Drop the table with the strange name.
+#
+do_test quote-1.6 {
+ set r [catch {
+ execsql {DROP TABLE '@abc'}
+ } msg ]
+ lappend r $msg
+} {0 {}}
+
+
+finish_test