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
|
#!/usr/bin/env tarantool
test = require("sqltester")
test:plan(4)
--!./tcltestrunner.lua
-- 2008 September 1
--
-- 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 sql library. The
-- focus of this file is testing the fix for ticket #3357.
--
-- $Id: tkt3357.test,v 1.2 2009/06/05 17:09:12 drh Exp $
-- ["set","testdir",[["file","dirname",["argv0"]]]]
-- ["source",[["testdir"],"\/tester.tcl"]]
test:do_execsql_test(
"tkt3357-1.1",
[[
create table a(id integer primary key, b_id integer, myvalue text);
create table b(id integer primary key, bvalue text);
insert into a values(1, 1,'Test');
insert into a values(2, 1,'Test2');
insert into a values(3, 1,'Test3');
insert into b values(1, 'btest');
]], {
-- <tkt3357-1.1>
-- </tkt3357-1.1>
})
test:do_execsql_test(
"tkt3357-1.2",
[[
SELECT cc.id, cc.b_id, cc.myvalue, dd.bvalue
FROM (
SELECT DISTINCT a.id, a.b_id, a.myvalue FROM a
INNER JOIN b ON a.b_id = b.id WHERE b.bvalue = 'btest'
) cc
LEFT OUTER JOIN b dd ON cc.b_id = dd.id
]], {
-- <tkt3357-1.2>
1, 1, "Test", "btest", 2, 1, "Test2", "btest", 3, 1, "Test3", "btest"
-- </tkt3357-1.2>
})
test:do_execsql_test(
"tkt3357-1.3",
[[
SELECT cc.id, cc.b_id, cc.myvalue
FROM (
SELECT a.id, a.b_id, a.myvalue
FROM a, b WHERE a.b_id = b.id
) cc
LEFT OUTER JOIN b dd ON cc.b_id = dd.id
]], {
-- <tkt3357-1.3>
1, 1, "Test", 2, 1, "Test2", 3, 1, "Test3"
-- </tkt3357-1.3>
})
test:do_execsql_test(
"tkt3357-1.4",
[[
SELECT cc.id, cc.b_id, cc.myvalue
FROM (
SELECT DISTINCT a.id, a.b_id, a.myvalue
FROM a, b WHERE a.b_id = b.id
) cc
LEFT OUTER JOIN b dd ON cc.b_id = dd.id
]], {
-- <tkt3357-1.4>
1, 1, "Test", 2, 1, "Test2", 3, 1, "Test3"
-- </tkt3357-1.4>
})
test:finish_test()
|