1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
#!/usr/bin/env tarantool
test = require("sqltester")
test:plan(5)
--!./tcltestrunner.lua
-- 2014-03-04
--
-- 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 tests to verify that ticket [4ef7e3cfca] has been
-- fixed.
--
-- ["set","testdir",[["file","dirname",["argv0"]]]]
-- ["source",[["testdir"],"\/tester.tcl"]]
testprefix = "tkt-4ef7e3cfca"
test:do_catchsql_test(
1.1,
[[
CREATE TABLE x(a INT primary key);
CREATE TRIGGER t AFTER INSERT ON x FOR EACH ROW BEGIN
SELECT * FROM x WHERE abc.a = 1;
END;
INSERT INTO x VALUES('assert');
]], {
-- <1.1>
1, "Field 'A' was not found in space 'ABC' format"
-- </1.1>
})
test:execsql("DROP TABLE x;");
--reset_db()
test:do_execsql_test(
2.1,
[[
CREATE TABLE w(a INT primary key);
CREATE TABLE x(a INT primary key);
CREATE TABLE y(a INT primary key);
CREATE TABLE z(a INT primary key);
INSERT INTO x(a) VALUES(5);
INSERT INTO y(a) VALUES(10);
CREATE TRIGGER t AFTER INSERT ON w FOR EACH ROW BEGIN
INSERT INTO z
SELECT (SELECT x.a + y.a FROM y) FROM x;
END;
INSERT INTO w VALUES(1);
]])
test:do_execsql_test(
2.2,
[[
SELECT * FROM z;
]], {
-- <2.2>
15
-- </2.2>
})
test:execsql([[
DROP TABLE x;
DROP TABLE w;
DROP TABLE y;
DROP TABLE z;
]]);
--reset_db()
test:do_execsql_test(
3.1,
[[
CREATE TABLE w(a INT primary key);
CREATE TABLE x(b INT primary key);
CREATE TABLE y(a INT primary key);
CREATE TABLE z(a INT primary key);
INSERT INTO x(b) VALUES(5);
INSERT INTO y(a) VALUES(10);
CREATE TRIGGER t AFTER INSERT ON w FOR EACH ROW BEGIN
INSERT INTO z
SELECT (SELECT x.b + y.a FROM y) FROM x;
END;
INSERT INTO w VALUES(2);
]])
test:do_execsql_test(
3.2,
[[
SELECT * FROM z;
]], {
-- <3.2>
15
-- </3.2>
})
test:finish_test()
|