xref: /sqlite-3.40.0/test/alterqf.test (revision 697c50b9)
1# 2021 March 16
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. This
12# script focuses on testing internal function sqlite_rename_quotefix().
13#
14
15
16set testdir [file dirname $argv0]
17source $testdir/tester.tcl
18set testprefix alterqf
19
20# If SQLITE_OMIT_ALTERTABLE is defined, omit this file.
21ifcapable !altertable {
22  finish_test
23  return
24}
25
26
27sqlite3_test_control SQLITE_TESTCTRL_INTERNAL_FUNCTIONS db
28sqlite3_db_config db SQLITE_DBCONFIG_DQS_DDL 1
29sqlite3_db_config db SQLITE_DBCONFIG_DQS_DML 1
30
31do_execsql_test 1.0 {
32  CREATE TABLE t1(a, b, c);
33}
34
35foreach {tn before after} {
36  1 {CREATE VIEW v1 AS SELECT "a", "b", "notacolumn!", "c" FROM t1}
37    {CREATE VIEW v1 AS SELECT "a", "b", 'notacolumn!', "c" FROM t1}
38
39  2 {CREATE VIEW v1 AS SELECT "a", "b", "not'a'column!", "c" FROM t1}
40    {CREATE VIEW v1 AS SELECT "a", "b", 'not''a''column!', "c" FROM t1}
41
42  3 {CREATE VIEW v1 AS SELECT "a", "b", "not""a""column!", "c" FROM t1}
43    {CREATE VIEW v1 AS SELECT "a", "b", 'not"a"column!', "c" FROM t1}
44
45  4 {CREATE VIEW v1 AS SELECT "val", count("b") FROM t1 GROUP BY "abc"}
46    {CREATE VIEW v1 AS SELECT 'val', count("b") FROM t1 GROUP BY 'abc'}
47
48  5 {CREATE TABLE xyz(a CHECK (a!="str"), b AS (a||"str"))}
49    {CREATE TABLE xyz(a CHECK (a!='str'), b AS (a||'str'))}
50
51  6 {CREATE INDEX i1 ON t1(a || "str", "b", "val")}
52    {CREATE INDEX i1 ON t1(a || 'str', "b", 'val')}
53
54  7 {CREATE TRIGGER tr AFTER INSERT ON t1 BEGIN SELECT "abcd"; END}
55    {CREATE TRIGGER tr AFTER INSERT ON t1 BEGIN SELECT 'abcd'; END}
56
57  8 {CREATE VIEW v1 AS SELECT "string"'alias' FROM t1}
58    {CREATE VIEW v1 AS SELECT 'string' 'alias' FROM t1}
59
60  9 {CREATE INDEX i1 ON t1(a) WHERE "b"="bb"}
61    {CREATE INDEX i1 ON t1(a) WHERE "b"='bb'}
62
63 10 {CREATE TABLE t2(abc, xyz CHECK (xyz != "123"))}
64    {CREATE TABLE t2(abc, xyz CHECK (xyz != '123'))}
65
66 11 {
67    CREATE TRIGGER ott AFTER UPDATE ON t1 BEGIN
68      SELECT max("str", new."a") FROM t1
69          WHERE group_concat("b", ",") OVER (ORDER BY c||"str");
70      UPDATE t1 SET c= b + "str";
71      DELETE FROM t1 WHERE EXISTS (
72        SELECT 1 FROM t1 AS o WHERE o."a" = "o.a" AND t1.b IN("t1.b")
73      );
74    END;
75 } {
76    CREATE TRIGGER ott AFTER UPDATE ON t1 BEGIN
77      SELECT max('str', new."a") FROM t1
78          WHERE group_concat("b", ',') OVER (ORDER BY c||'str');
79      UPDATE t1 SET c= b + 'str';
80      DELETE FROM t1 WHERE EXISTS (
81        SELECT 1 FROM t1 AS o WHERE o."a" = 'o.a' AND t1.b IN('t1.b')
82      );
83    END;
84 }
85
86} {
87  do_execsql_test 1.$tn {
88    SELECT sqlite_rename_quotefix('main', $before)
89  } [list $after]
90}
91
92#-------------------------------------------------------------------------
93reset_db
94sqlite3_db_config db SQLITE_DBCONFIG_DQS_DDL 1
95sqlite3_db_config db SQLITE_DBCONFIG_DQS_DML 1
96do_execsql_test 2.0 {
97  CREATE TABLE x1(
98      one, two, three, PRIMARY KEY(one),
99      CHECK (three!="xyz"), CHECK (two!="one")
100  ) WITHOUT ROWID;
101  CREATE INDEX x1i ON x1(one+"two"+"four") WHERE "five";
102  CREATE TEMP TRIGGER AFTER INSERT ON x1 BEGIN
103    UPDATE x1 SET two=new.three || "new" WHERE one=new.one||"";
104  END;
105}
106
107do_execsql_test 2.1 {
108  ALTER TABLE x1 RENAME two TO 'four';
109  SELECT sql FROM sqlite_schema;
110  SELECT sql FROM sqlite_temp_schema;
111} {{CREATE TABLE x1(
112      one, "four", three, PRIMARY KEY(one),
113      CHECK (three!='xyz'), CHECK ("four"!="one")
114  ) WITHOUT ROWID}
115  {CREATE INDEX x1i ON x1(one+"four"+'four') WHERE 'five'}
116  {CREATE TRIGGER AFTER INSERT ON x1 BEGIN
117    UPDATE x1 SET "four"=new.three || 'new' WHERE one=new.one||'';
118  END}
119}
120
121
122finish_test
123