mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
3f24932124
Collect all tables and SPs refered by a statement, and open all tables with an implicit LOCK TABLES. Do find things refered by triggers and views, we open them first (and then repeat this until nothing new is found), before doing the actual lock tables. mysql-test/r/information_schema.result: Updated result for WL#2130. mysql-test/r/lock.result: Updated result for WL#2130. mysql-test/r/sp-error.result: Updated result for WL#2130. mysql-test/r/sp.result: Updated result for WL#2130. mysql-test/r/view.result: Updated result for WL#2130. mysql-test/t/information_schema.test: Disabled one test case due to a bug involving LOCK TABLES, which shows up with WL#2130. mysql-test/t/lock.test: New error message with WL#2130. This change is under debate and might change in the future, but will do for now. mysql-test/t/sp-error.test: Updated for WL#2130. Some tests are voided when table access does work from functions. mysql-test/t/sp.test: Updated for WL#2130. mysql-test/t/view.test: Updated for WL#2130. sql/item_func.cc: We now have to set net.no_send_ok for functions too, with WL#2130. sql/share/errmsg.txt: Reused an error code since the old use was voided by WL#2130, but a new one was needed instead (similar, but more specific restriction). sql/sp.cc: Fixed error handling and collection of used tables for WL#2130. sql/sp.h: Fixed error handling and collection of used tables for WL#2130. sql/sp_head.cc: Added support functions for collecting and merging hash tables and lists of used tables from SPs and substatements, for WL#2130. sql/sp_head.h: Added support functions for collecting and merging hash tables and lists of used tables from SPs and substatements, for WL#2130. sql/sql_base.cc: Changed the way table->query_id is tested and set during with locked tables in effect. This makes some SP test cases work with WL#2130, but has a side effect on some error cases with explicit LOCK TABLES. It's still debated if this is the correct way, so it might change. sql/sql_class.h: Added flags for circumventing some interference between WL#2130 and mysql_make_view(). sql/sql_derived.cc: Added some missing initializations. (Potential bugs.) sql/sql_lex.cc: Clear the new hash tables for WL#2130. sql/sql_lex.h: Added hash tables for procedures and tables too (as for functions), for WL#2130. sql/sql_parse.cc: WL#2130: Make table accesses from stored functions work by adding an implicit LOCK TABLES around (most) executed statements. To do this, we have to go through a loop where we collect all SPs and tables in mysql_execute_statement. sql/sql_prepare.cc: Cache both functions and procedures for WL#2130. sql/sql_show.cc: Added some missing initializations. (Potential bugs.) sql/sql_view.cc: Shortcut mysql_make_view() if thd->shortcut_make_view is true during the pre-open phase for collecting tables in WL#2130. Otherwise, the similar mechanism here causes interference. sql/sql_yacc.yy: For WL#2130, added caching of procedures and disallowed LOCK/UNLOCK TABLES in SPs.
647 lines
9.9 KiB
Text
647 lines
9.9 KiB
Text
#
|
|
# Stored PROCEDURE error tests
|
|
#
|
|
|
|
# Make sure we don't have any procedures left.
|
|
delete from mysql.proc;
|
|
|
|
delimiter |;
|
|
|
|
# This should give three syntax errors (sometimes crashed; bug #643)
|
|
# (Unfortunately, this is not a 100% test, on some platforms this
|
|
# passed despite the bug.)
|
|
--error 1064
|
|
create procedure syntaxerror(t int)|
|
|
--error 1064
|
|
create procedure syntaxerror(t int)|
|
|
--error 1064
|
|
create procedure syntaxerror(t int)|
|
|
|
|
# Check that we get the right error, i.e. UDF declaration parses correctly,
|
|
# but foo.so doesn't exist.
|
|
# This generates an error message containing a misleading errno which
|
|
# might vary between systems (it usually doesn't have anything to do with
|
|
# the actual failing dlopen()).
|
|
#--error 1126
|
|
#create function foo returns real soname "foo.so"|
|
|
|
|
|
|
--disable_warnings
|
|
drop table if exists t3|
|
|
--enable_warnings
|
|
create table t3 ( x int )|
|
|
insert into t3 values (2), (3)|
|
|
|
|
create procedure bad_into(out param int)
|
|
select x from t3 into param|
|
|
|
|
--error 1172
|
|
call bad_into(@x)|
|
|
|
|
drop procedure bad_into|
|
|
drop table t3|
|
|
|
|
|
|
create procedure proc1()
|
|
set @x = 42|
|
|
|
|
create function func1() returns int
|
|
return 42|
|
|
|
|
# Can't create recursively
|
|
--error 1303
|
|
create procedure foo()
|
|
create procedure bar() set @x=3|
|
|
--error 1303
|
|
create procedure foo()
|
|
create function bar() returns double return 2.3|
|
|
|
|
# Already exists
|
|
--error 1304
|
|
create procedure proc1()
|
|
set @x = 42|
|
|
--error 1304
|
|
create function func1() returns int
|
|
return 42|
|
|
|
|
drop procedure proc1|
|
|
drop function func1|
|
|
|
|
# Does not exist
|
|
--error 1305
|
|
alter procedure foo|
|
|
--error 1305
|
|
alter function foo|
|
|
--error 1305
|
|
drop procedure foo|
|
|
--error 1305
|
|
drop function foo|
|
|
--error 1305
|
|
call foo()|
|
|
drop procedure if exists foo|
|
|
--error 1305
|
|
show create procedure foo|
|
|
--error 1305
|
|
show create function foo|
|
|
|
|
# LEAVE/ITERATE/GOTO with no match
|
|
--error 1308
|
|
create procedure foo()
|
|
foo: loop
|
|
leave bar;
|
|
end loop|
|
|
--error 1308
|
|
create procedure foo()
|
|
foo: loop
|
|
iterate bar;
|
|
end loop|
|
|
--error 1308
|
|
create procedure foo()
|
|
foo: begin
|
|
iterate foo;
|
|
end|
|
|
--error 1308
|
|
create procedure foo()
|
|
begin
|
|
goto foo;
|
|
end|
|
|
--error 1308
|
|
create procedure foo()
|
|
begin
|
|
begin
|
|
label foo;
|
|
end;
|
|
goto foo;
|
|
end|
|
|
--error 1308
|
|
create procedure foo()
|
|
begin
|
|
goto foo;
|
|
begin
|
|
label foo;
|
|
end;
|
|
end|
|
|
--error 1308
|
|
create procedure foo()
|
|
begin
|
|
begin
|
|
goto foo;
|
|
end;
|
|
begin
|
|
label foo;
|
|
end;
|
|
end|
|
|
--error 1308
|
|
create procedure foo()
|
|
begin
|
|
begin
|
|
label foo;
|
|
end;
|
|
begin
|
|
goto foo;
|
|
end;
|
|
end|
|
|
|
|
# Redefining label
|
|
--error 1309
|
|
create procedure foo()
|
|
foo: loop
|
|
foo: loop
|
|
set @x=2;
|
|
end loop foo;
|
|
end loop foo|
|
|
|
|
# End label mismatch
|
|
--error 1310
|
|
create procedure foo()
|
|
foo: loop
|
|
set @x=2;
|
|
end loop bar|
|
|
|
|
# RETURN in FUNCTION only
|
|
--error 1313
|
|
create procedure foo()
|
|
return 42|
|
|
|
|
# Wrong number of arguments
|
|
create procedure p(x int)
|
|
set @x = x|
|
|
create function f(x int) returns int
|
|
return x+42|
|
|
|
|
--error 1318
|
|
call p()|
|
|
--error 1318
|
|
call p(1, 2)|
|
|
--error 1318
|
|
select f()|
|
|
--error 1318
|
|
select f(1, 2)|
|
|
|
|
drop procedure p|
|
|
drop function f|
|
|
|
|
--error 1319
|
|
create procedure p(val int, out res int)
|
|
begin
|
|
declare x int default 0;
|
|
declare continue handler for foo set x = 1;
|
|
|
|
insert into test.t1 values (val);
|
|
if (x) then
|
|
set res = 0;
|
|
else
|
|
set res = 1;
|
|
end if;
|
|
end|
|
|
|
|
--error 1319
|
|
create procedure p(val int, out res int)
|
|
begin
|
|
declare x int default 0;
|
|
declare foo condition for 1146;
|
|
declare continue handler for bar set x = 1;
|
|
|
|
insert into test.t1 values (val);
|
|
if (x) then
|
|
set res = 0;
|
|
else
|
|
set res = 1;
|
|
end if;
|
|
end|
|
|
|
|
--error 1320
|
|
create function f(val int) returns int
|
|
begin
|
|
declare x int;
|
|
|
|
set x = val+3;
|
|
end|
|
|
|
|
create function f(val int) returns int
|
|
begin
|
|
declare x int;
|
|
|
|
set x = val+3;
|
|
if x < 4 then
|
|
return x;
|
|
end if;
|
|
end|
|
|
|
|
--error 1321
|
|
select f(10)|
|
|
|
|
drop function f|
|
|
|
|
--error 1322
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for insert into test.t1 values ("foo", 42);
|
|
|
|
open c;
|
|
close c;
|
|
end|
|
|
|
|
--error 1323
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare c cursor for select * into x from test.t limit 1;
|
|
|
|
open c;
|
|
close c;
|
|
end|
|
|
|
|
--error 1324
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for select * from test.t;
|
|
|
|
open cc;
|
|
close c;
|
|
end|
|
|
|
|
--disable_warnings
|
|
drop table if exists t1|
|
|
--enable_warnings
|
|
create table t1 (val int)|
|
|
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for select * from test.t1;
|
|
|
|
open c;
|
|
open c;
|
|
close c;
|
|
end|
|
|
--error 1325
|
|
call p()|
|
|
drop procedure p|
|
|
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for select * from test.t1;
|
|
|
|
open c;
|
|
close c;
|
|
close c;
|
|
end|
|
|
--error 1326
|
|
call p()|
|
|
drop procedure p|
|
|
|
|
--error 1305
|
|
alter procedure bar3 sql security invoker|
|
|
|
|
drop table t1|
|
|
|
|
--disable_warnings
|
|
drop table if exists t1|
|
|
--enable_warnings
|
|
create table t1 (val int, x float)|
|
|
insert into t1 values (42, 3.1), (19, 1.2)|
|
|
|
|
--error 1327
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare c cursor for select * from t1;
|
|
|
|
open c;
|
|
fetch c into x, y;
|
|
close c;
|
|
end|
|
|
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare c cursor for select * from t1;
|
|
|
|
open c;
|
|
fetch c into x;
|
|
close c;
|
|
end|
|
|
--error 1328
|
|
call p()|
|
|
drop procedure p|
|
|
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare y float;
|
|
declare z int;
|
|
declare c cursor for select * from t1;
|
|
|
|
open c;
|
|
fetch c into x, y, z;
|
|
close c;
|
|
end|
|
|
--error 1328
|
|
call p()|
|
|
drop procedure p|
|
|
|
|
--error 1330
|
|
create procedure p(in x int, x char(10))
|
|
begin
|
|
end|
|
|
--error 1330
|
|
create function p(x int, x char(10))
|
|
begin
|
|
end|
|
|
|
|
--error 1331
|
|
create procedure p()
|
|
begin
|
|
declare x float;
|
|
declare x int;
|
|
end|
|
|
|
|
--error 1332
|
|
create procedure p()
|
|
begin
|
|
declare c condition for 1064;
|
|
declare c condition for 1065;
|
|
end|
|
|
|
|
--error 1333
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for select * from t1;
|
|
declare c cursor for select field from t1;
|
|
end|
|
|
|
|
# USE is not allowed
|
|
--error 1336
|
|
create procedure u()
|
|
use sptmp|
|
|
|
|
# Enforced standard order of declarations
|
|
--error 1337
|
|
create procedure p()
|
|
begin
|
|
declare c cursor for select * from t1;
|
|
declare x int;
|
|
end|
|
|
--error 1337
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare continue handler for sqlstate '42S99' set x = 1;
|
|
declare foo condition for sqlstate '42S99';
|
|
end|
|
|
|
|
--error 1338
|
|
create procedure p()
|
|
begin
|
|
declare x int;
|
|
declare continue handler for sqlstate '42S99' set x = 1;
|
|
declare c cursor for select * from t1;
|
|
end|
|
|
|
|
--error 1358
|
|
create procedure p()
|
|
begin
|
|
declare continue handler for sqlexception
|
|
begin
|
|
goto L1;
|
|
end;
|
|
|
|
select field from t1;
|
|
label L1;
|
|
end|
|
|
|
|
#
|
|
# BUG#1965
|
|
#
|
|
create procedure bug1965()
|
|
begin
|
|
declare c cursor for select val from t1 order by valname;
|
|
open c;
|
|
close c;
|
|
end|
|
|
|
|
--error 1054
|
|
call bug1965()|
|
|
drop procedure bug1965|
|
|
|
|
#
|
|
# BUG#1966
|
|
#
|
|
--error 1327
|
|
select 1 into a|
|
|
|
|
#
|
|
# BUG#1653
|
|
#
|
|
--disable_warnings
|
|
drop table if exists t3|
|
|
--enable_warnings
|
|
create table t3 (column_1_0 int)|
|
|
|
|
create procedure bug1653()
|
|
update t3 set column_1 = 0|
|
|
|
|
--error 1054
|
|
call bug1653()|
|
|
drop table t3|
|
|
create table t3 (column_1 int)|
|
|
call bug1653()|
|
|
|
|
drop procedure bug1653|
|
|
drop table t3|
|
|
|
|
#
|
|
# BUG#2259
|
|
#
|
|
# Note: When this bug existed, it did not necessarily cause a crash
|
|
# in all builds, but valgrind did give warnings.
|
|
create procedure bug2259()
|
|
begin
|
|
declare v1 int;
|
|
declare c1 cursor for select s1 from t1;
|
|
|
|
fetch c1 into v1;
|
|
end|
|
|
|
|
--error 1326
|
|
call bug2259()|
|
|
drop procedure bug2259|
|
|
|
|
#
|
|
# BUG#2272
|
|
#
|
|
create procedure bug2272()
|
|
begin
|
|
declare v int;
|
|
|
|
update t1 set v = 42;
|
|
end|
|
|
|
|
insert into t1 values (666, 51.3)|
|
|
--error 1054
|
|
call bug2272()|
|
|
delete from t1|
|
|
drop procedure bug2272|
|
|
|
|
#
|
|
# BUG#2329
|
|
#
|
|
create procedure bug2329_1()
|
|
begin
|
|
declare v int;
|
|
|
|
insert into t1 (v) values (5);
|
|
end|
|
|
|
|
create procedure bug2329_2()
|
|
begin
|
|
declare v int;
|
|
|
|
replace t1 set v = 5;
|
|
end|
|
|
|
|
--error 1054
|
|
call bug2329_1()|
|
|
--error 1054
|
|
call bug2329_2()|
|
|
drop procedure bug2329_1|
|
|
drop procedure bug2329_2|
|
|
|
|
#
|
|
# BUG#3287
|
|
#
|
|
create function bug3287() returns int
|
|
begin
|
|
declare v int default null;
|
|
|
|
case
|
|
when v is not null then return 1;
|
|
end case;
|
|
return 2;
|
|
end|
|
|
--error 1339
|
|
select bug3287()|
|
|
drop function bug3287|
|
|
|
|
create procedure bug3287(x int)
|
|
case x
|
|
when 0 then
|
|
insert into test.t1 values (x, 0.1);
|
|
when 1 then
|
|
insert into test.t1 values (x, 1.1);
|
|
end case|
|
|
--error 1339
|
|
call bug3287(2)|
|
|
drop procedure bug3287|
|
|
|
|
#
|
|
# BUG#3297
|
|
#
|
|
--disable_warnings
|
|
drop table if exists t3|
|
|
--enable_warnings
|
|
create table t3 (s1 int, primary key (s1))|
|
|
insert into t3 values (5),(6)|
|
|
|
|
create procedure bug3279(out y int)
|
|
begin
|
|
declare x int default 0;
|
|
begin
|
|
declare exit handler for sqlexception set x = x+1;
|
|
insert into t3 values (5);
|
|
end;
|
|
if x < 2 then
|
|
set x = x+1;
|
|
insert into t3 values (6);
|
|
end if;
|
|
set y = x;
|
|
end|
|
|
|
|
set @x = 0|
|
|
--error 1062
|
|
call bug3279(@x)|
|
|
select @x|
|
|
drop procedure bug3279|
|
|
drop table t3|
|
|
|
|
#
|
|
# BUG#3339
|
|
#
|
|
--error 1049
|
|
create procedure nodb.bug3339() begin end|
|
|
|
|
#
|
|
# BUG#2653
|
|
#
|
|
create procedure bug2653_1(a int, out b int)
|
|
set b = aa|
|
|
|
|
create procedure bug2653_2(a int, out b int)
|
|
begin
|
|
if aa < 0 then
|
|
set b = - a;
|
|
else
|
|
set b = a;
|
|
end if;
|
|
end|
|
|
|
|
--error 1054
|
|
call bug2653_1(1, @b)|
|
|
--error 1054
|
|
call bug2653_2(2, @b)|
|
|
|
|
drop procedure bug2653_1|
|
|
drop procedure bug2653_2|
|
|
|
|
#
|
|
# BUG#4344
|
|
#
|
|
--error 1357
|
|
create procedure bug4344() drop procedure bug4344|
|
|
--error 1357
|
|
create procedure bug4344() drop function bug4344|
|
|
|
|
#
|
|
# BUG#3294: Stored procedure crash if table dropped before use
|
|
# (Actually, when an error occurs within an error handler.)
|
|
--disable_warnings
|
|
drop procedure if exists bug3294|
|
|
--enable_warnings
|
|
create procedure bug3294()
|
|
begin
|
|
declare continue handler for sqlexception drop table t5;
|
|
drop table t5;
|
|
drop table t5;
|
|
end|
|
|
|
|
create table t5 (x int)|
|
|
--error 1051
|
|
call bug3294()|
|
|
drop procedure bug3294|
|
|
|
|
#
|
|
# BUG#6807: Stored procedure crash if CREATE PROCEDURE ... KILL QUERY
|
|
#
|
|
--disable_warnings
|
|
drop procedure if exists bug6807|
|
|
--enable_warnings
|
|
create procedure bug6807()
|
|
begin
|
|
declare id int;
|
|
|
|
set id = connection_id();
|
|
kill query id;
|
|
select 'Not reached';
|
|
end|
|
|
|
|
--error 1317
|
|
call bug6807()|
|
|
--error 1317
|
|
call bug6807()|
|
|
|
|
drop procedure bug6807|
|
|
|
|
|
|
drop table t1|
|
|
|
|
delimiter ;|
|