479 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			479 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
|  | # Can't test with embedded server | ||
|  | -- source include/not_embedded.inc | ||
|  | # Disable concurrent inserts to avoid test failures | ||
|  | set @old_concurrent_insert= @@global.concurrent_insert; | ||
|  | set @@global.concurrent_insert= 0; | ||
|  | 
 | ||
|  | # Save the initial number of concurrent sessions | ||
|  | --source include/count_sessions.inc | ||
|  | 
 | ||
|  | --disable_warnings | ||
|  | drop table if exists t1,t3; | ||
|  | --enable_warnings | ||
|  | delimiter |; | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#4902 Stored procedure with SHOW WARNINGS leads to packet error | ||
|  | # | ||
|  | # Added tests for show grants command | ||
|  | --disable_warnings | ||
|  | drop procedure if exists bug4902| | ||
|  | --enable_warnings | ||
|  | create procedure bug4902() | ||
|  | begin | ||
|  |   show grants for 'root'@'localhost'; | ||
|  | end| | ||
|  | --disable_parsing | ||
|  | show binlog events| | ||
|  | show storage engines| | ||
|  | show master status| | ||
|  | show slave hosts| | ||
|  | show slave status| | ||
|  | --enable_parsing | ||
|  | 
 | ||
|  | call bug4902()| | ||
|  | call bug4902()| | ||
|  | 
 | ||
|  | drop procedure bug4902| | ||
|  | 
 | ||
|  | # We need separate SP for SHOW PROCESSLIST  since we want use replace_column | ||
|  | --disable_warnings | ||
|  | drop procedure if exists bug4902_2| | ||
|  | --enable_warnings | ||
|  | create procedure bug4902_2() | ||
|  | begin | ||
|  |   show processlist; | ||
|  | end| | ||
|  | --disable_result_log | ||
|  | call bug4902_2()| | ||
|  | --enable_result_log | ||
|  | show warnings| | ||
|  | --disable_result_log | ||
|  | call bug4902_2()| | ||
|  | --enable_result_log | ||
|  | show warnings| | ||
|  | drop procedure bug4902_2| | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#3583 query cache doesn't work for stored procedures | ||
|  | # | ||
|  | --disable_warnings | ||
|  | drop table if exists t1| | ||
|  | --enable_warnings | ||
|  | create table t1 ( | ||
|  |     id   char(16) not null default '', | ||
|  |     data int not null | ||
|  | )| | ||
|  | --disable_warnings | ||
|  | drop procedure if exists bug3583| | ||
|  | --enable_warnings | ||
|  | --disable_warnings | ||
|  | drop procedure if exists bug3583| | ||
|  | --enable_warnings | ||
|  | create procedure bug3583() | ||
|  | begin | ||
|  |   declare c int; | ||
|  | 
 | ||
|  |   select * from t1; | ||
|  |   select count(*) into c from t1; | ||
|  |   select c; | ||
|  | end| | ||
|  | 
 | ||
|  | insert into t1 values ("x", 3), ("y", 5)| | ||
|  | set @x = @@query_cache_size| | ||
|  | set global query_cache_size = 10*1024*1024| | ||
|  | 
 | ||
|  | flush status| | ||
|  | flush query cache| | ||
|  | show status like 'Qcache_hits'| | ||
|  | call bug3583()| | ||
|  | show status like 'Qcache_hits'| | ||
|  | call bug3583()| | ||
|  | call bug3583()| | ||
|  | show status like 'Qcache_hits'| | ||
|  | 
 | ||
|  | set global query_cache_size = @x| | ||
|  | flush status| | ||
|  | flush query cache| | ||
|  | delete from t1| | ||
|  | drop procedure bug3583| | ||
|  | drop table t1| | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # 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 ER_QUERY_INTERRUPTED | ||
|  | call bug6807()| | ||
|  | --error ER_QUERY_INTERRUPTED | ||
|  | call bug6807()| | ||
|  | 
 | ||
|  | drop procedure bug6807| | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#10100 function (and stored procedure?) recursivity problem | ||
|  | # | ||
|  | --disable_warnings | ||
|  | drop function if exists bug10100f| | ||
|  | drop procedure if exists bug10100p| | ||
|  | drop procedure if exists bug10100t| | ||
|  | drop procedure if exists bug10100pt| | ||
|  | drop procedure if exists bug10100pv| | ||
|  | drop procedure if exists bug10100pd| | ||
|  | drop procedure if exists bug10100pc| | ||
|  | --enable_warnings | ||
|  | # routines with simple recursion | ||
|  | create function bug10100f(prm int) returns int | ||
|  | begin | ||
|  |   if prm > 1 then | ||
|  |     return prm * bug10100f(prm - 1); | ||
|  |   end if; | ||
|  |   return 1; | ||
|  | end| | ||
|  | create procedure bug10100p(prm int, inout res int) | ||
|  | begin | ||
|  |   set res = res * prm; | ||
|  |   if prm > 1 then | ||
|  |     call bug10100p(prm - 1, res); | ||
|  |   end if; | ||
|  | end| | ||
|  | create procedure bug10100t(prm int) | ||
|  | begin | ||
|  |   declare res int; | ||
|  |   set res = 1; | ||
|  |   call bug10100p(prm, res); | ||
|  |   select res; | ||
|  | end| | ||
|  | 
 | ||
|  | # a procedure which use tables and recursion | ||
|  | create table t3 (a int)| | ||
|  | insert into t3 values (0)| | ||
|  | create view v1 as select a from t3; | ||
|  | create procedure bug10100pt(level int, lim int) | ||
|  | begin | ||
|  |   if level < lim then | ||
|  |     update t3 set a=level; | ||
|  |     FLUSH TABLES; | ||
|  |     call bug10100pt(level+1, lim); | ||
|  |   else | ||
|  |     select * from t3; | ||
|  |   end if; | ||
|  | end| | ||
|  | # view & recursion | ||
|  | create procedure bug10100pv(level int, lim int) | ||
|  | begin | ||
|  |   if level < lim then | ||
|  |     update v1 set a=level; | ||
|  |     FLUSH TABLES; | ||
|  |     call bug10100pv(level+1, lim); | ||
|  |   else | ||
|  |     select * from v1; | ||
|  |   end if; | ||
|  | end| | ||
|  | # dynamic sql & recursion | ||
|  | prepare stmt2 from "select * from t3;"; | ||
|  | create procedure bug10100pd(level int, lim int) | ||
|  | begin | ||
|  |   if level < lim then | ||
|  |     select level; | ||
|  |     prepare stmt1 from "update t3 set a=a+2"; | ||
|  |     execute stmt1; | ||
|  |     FLUSH TABLES; | ||
|  |     execute stmt1; | ||
|  |     FLUSH TABLES; | ||
|  |     execute stmt1; | ||
|  |     FLUSH TABLES; | ||
|  |     deallocate prepare stmt1; | ||
|  |     execute stmt2; | ||
|  |     select * from t3; | ||
|  |     call bug10100pd(level+1, lim); | ||
|  |   else | ||
|  |     execute stmt2; | ||
|  |   end if; | ||
|  | end| | ||
|  | # cursor & recursion | ||
|  | create procedure bug10100pc(level int, lim int) | ||
|  | begin | ||
|  |   declare lv int; | ||
|  |   declare c cursor for select a from t3; | ||
|  |   open c; | ||
|  |   if level < lim then | ||
|  |     select level; | ||
|  |     fetch c into lv; | ||
|  |     select lv; | ||
|  |     update t3 set a=level+lv; | ||
|  |     FLUSH TABLES; | ||
|  |     call bug10100pc(level+1, lim); | ||
|  |   else | ||
|  |     select * from t3; | ||
|  |   end if; | ||
|  |   close c; | ||
|  | end| | ||
|  | 
 | ||
|  | # end of the stack checking | ||
|  | set @@max_sp_recursion_depth=255| | ||
|  | set @var=1| | ||
|  | # disable log because error about stack overrun contains numbers which | ||
|  | # depend on a system | ||
|  | -- disable_result_log | ||
|  | -- error ER_STACK_OVERRUN_NEED_MORE | ||
|  | call bug10100p(255, @var)| | ||
|  | -- error ER_STACK_OVERRUN_NEED_MORE | ||
|  | call bug10100pt(1,255)| | ||
|  | -- error ER_STACK_OVERRUN_NEED_MORE | ||
|  | call bug10100pv(1,255)| | ||
|  | -- error ER_STACK_OVERRUN_NEED_MORE | ||
|  | call bug10100pd(1,255)| | ||
|  | -- error ER_STACK_OVERRUN_NEED_MORE | ||
|  | call bug10100pc(1,255)| | ||
|  | -- enable_result_log | ||
|  | set @@max_sp_recursion_depth=0| | ||
|  | 
 | ||
|  | deallocate prepare stmt2| | ||
|  | 
 | ||
|  | drop function bug10100f| | ||
|  | drop procedure bug10100p| | ||
|  | drop procedure bug10100t| | ||
|  | drop procedure bug10100pt| | ||
|  | drop procedure bug10100pv| | ||
|  | drop procedure bug10100pd| | ||
|  | drop procedure bug10100pc| | ||
|  | drop view v1| | ||
|  | drop table t3| | ||
|  | 
 | ||
|  | delimiter ;| | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#15298 SHOW GRANTS FOR CURRENT_USER: Incorrect output in DEFINER context | ||
|  | # | ||
|  | --disable_warnings | ||
|  | drop procedure if exists bug15298_1; | ||
|  | drop procedure if exists bug15298_2; | ||
|  | --enable_warnings | ||
|  | grant all privileges on test.* to 'mysqltest_1'@'localhost'; | ||
|  | create procedure 15298_1 () sql security definer show grants for current_user; | ||
|  | create procedure 15298_2 () sql security definer show grants; | ||
|  | 
 | ||
|  | connect (con1,localhost,mysqltest_1,,test); | ||
|  | call 15298_1(); | ||
|  | call 15298_2(); | ||
|  | 
 | ||
|  | connection default; | ||
|  | disconnect con1; | ||
|  | drop user mysqltest_1@localhost; | ||
|  | drop procedure 15298_1; | ||
|  | drop procedure 15298_2; | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#29936 Stored Procedure DML ignores low_priority_updates setting | ||
|  | # | ||
|  | 
 | ||
|  | --disable_warnings | ||
|  | drop table if exists t1; | ||
|  | drop procedure if exists p1; | ||
|  | --enable_warnings | ||
|  | 
 | ||
|  | create table t1 (value varchar(15)); | ||
|  | create procedure p1() update t1 set value='updated' where value='old'; | ||
|  | 
 | ||
|  | # load the procedure into sp cache and execute once | ||
|  | call p1(); | ||
|  | 
 | ||
|  | insert into t1 (value) values ("old"); | ||
|  | 
 | ||
|  | connect (rl_holder, localhost, root,,); | ||
|  | connect (rl_acquirer, localhost, root,,); | ||
|  | connect (rl_contender, localhost, root,,); | ||
|  | connect (rl_wait, localhost, root,,); | ||
|  | 
 | ||
|  | connection rl_holder; | ||
|  | select get_lock('b26162',120); | ||
|  | 
 | ||
|  | connection rl_acquirer; | ||
|  | --send select 'rl_acquirer', value from t1 where get_lock('b26162',120); | ||
|  | 
 | ||
|  | # we must wait till this select opens and locks the tables | ||
|  | connection rl_wait; | ||
|  | let $wait_condition= | ||
|  |   select count(*) = 1 from information_schema.processlist | ||
|  |   where state = "User lock" and | ||
|  |   info = "select 'rl_acquirer', value from t1 where get_lock('b26162',120)"; | ||
|  | --source include/wait_condition.inc | ||
|  | 
 | ||
|  | connection default; | ||
|  | set session low_priority_updates=on; | ||
|  | --send call p1(); | ||
|  | 
 | ||
|  | connection rl_wait; | ||
|  | let $wait_condition= | ||
|  |   select count(*) = 1 from information_schema.processlist | ||
|  |   where state = "Locked" and | ||
|  |   info = "update t1 set value='updated' where value='old'"; | ||
|  | --source include/wait_condition.inc | ||
|  | 
 | ||
|  | connection rl_contender; | ||
|  | select 'rl_contender', value from t1; | ||
|  | 
 | ||
|  | connection rl_holder; | ||
|  | select release_lock('b26162'); | ||
|  | 
 | ||
|  | connection rl_acquirer; | ||
|  | --reap | ||
|  | connection default; | ||
|  | --reap | ||
|  | 
 | ||
|  | disconnect rl_holder; | ||
|  | disconnect rl_acquirer; | ||
|  | disconnect rl_wait; | ||
|  | disconnect rl_contender; | ||
|  | drop procedure p1; | ||
|  | drop table t1; | ||
|  | set session low_priority_updates=default; | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#44798 MySQL engine crashes when creating stored procedures with execute_priv=N | ||
|  | # | ||
|  | INSERT INTO mysql.user (Host, User, Password, Select_priv, Insert_priv, Update_priv, | ||
|  | Delete_priv, Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv, File_priv, | ||
|  | Grant_priv, References_priv, Index_priv, Alter_priv, Show_db_priv, Super_priv, | ||
|  | Create_tmp_table_priv, Lock_tables_priv, Execute_priv, Repl_slave_priv, Repl_client_priv, | ||
|  | Create_view_priv, Show_view_priv, Create_routine_priv, Alter_routine_priv, | ||
|  | Create_user_priv, ssl_type, ssl_cipher, x509_issuer, x509_subject, max_questions, | ||
|  | max_updates, max_connections, max_user_connections)  | ||
|  | VALUES('%', 'mysqltest_1', password(''), 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'N', 'N', 'N', | ||
|  | 'N', 'N', 'N', 'Y', 'Y', 'N', 'N', 'Y', 'Y', 'N', 'N', 'N', 'N', 'N', 'Y', 'Y', 'N', '', | ||
|  | '', '', '', '0', '0', '0', '0'); | ||
|  | FLUSH PRIVILEGES; | ||
|  | 
 | ||
|  | connect (con1, localhost, mysqltest_1,,); | ||
|  | connection con1; | ||
|  | CREATE PROCEDURE p1(i INT) BEGIN END; | ||
|  | disconnect con1; | ||
|  | connection default; | ||
|  | DROP PROCEDURE p1; | ||
|  | 
 | ||
|  | DELETE FROM mysql.user WHERE User='mysqltest_1'; | ||
|  | FLUSH PRIVILEGES; | ||
|  | 
 | ||
|  | 
 | ||
|  | --echo # | ||
|  | --echo # Bug#44521 Prepared Statement: CALL p() - crashes: `! thd->main_da.is_sent' failed et.al. | ||
|  | --echo # | ||
|  | SELECT GET_LOCK('Bug44521', 0); | ||
|  | --connect (con1,localhost,root,,) | ||
|  | --echo ** Connection con1 | ||
|  | delimiter $; | ||
|  | CREATE PROCEDURE p() | ||
|  | BEGIN | ||
|  |   SELECT 1; | ||
|  |   SELECT GET_LOCK('Bug44521', 100); | ||
|  |   SELECT 2; | ||
|  | END$ | ||
|  | delimiter ;$ | ||
|  | --send CALL p(); | ||
|  | --connection default | ||
|  | --echo ** Default connection | ||
|  | let $wait_condition= | ||
|  |   SELECT count(*) = 1 FROM information_schema.processlist | ||
|  |   WHERE state = "User lock" AND info = "SELECT GET_LOCK('Bug44521', 100)"; | ||
|  | --source include/wait_condition.inc | ||
|  | let $conid = | ||
|  |   `SELECT id FROM information_schema.processlist | ||
|  |    WHERE state = "User lock" AND info = "SELECT GET_LOCK('Bug44521', 100)"`; | ||
|  | dirty_close con1; | ||
|  | SELECT RELEASE_LOCK('Bug44521'); | ||
|  | let $wait_condition= | ||
|  |   SELECT count(*) = 0 FROM information_schema.processlist | ||
|  |   WHERE id = $conid; | ||
|  | --source include/wait_condition.inc  | ||
|  | DROP PROCEDURE p; | ||
|  | 
 | ||
|  | # | ||
|  | # Bug#47736 killing a select from a view when the view is processing a function, asserts | ||
|  | # | ||
|  | CREATE TABLE t1(a int); | ||
|  | INSERT INTO t1 VALUES (1); | ||
|  | CREATE FUNCTION f1 (inp TEXT) RETURNS INT NO SQL RETURN sleep(60); | ||
|  | CREATE VIEW v1 AS SELECT f1('a') FROM t1; | ||
|  | 
 | ||
|  | --connect (con1, localhost, root,,) | ||
|  | --let $ID_1= `SELECT connection_id()` | ||
|  | --send SELECT * FROM v1; | ||
|  | 
 | ||
|  | --connect (con2, localhost, root,,) | ||
|  | --let $ID_2= `SELECT connection_id()` | ||
|  | --send SELECT * FROM v1 | ||
|  | 
 | ||
|  | --connection default | ||
|  | --disable_query_log | ||
|  | --eval KILL QUERY $ID_2 | ||
|  | --eval KILL QUERY $ID_1 | ||
|  | --enable_query_log | ||
|  | 
 | ||
|  | --connection con1 | ||
|  | --error ER_QUERY_INTERRUPTED | ||
|  | --reap | ||
|  | --connection con2 | ||
|  | --error ER_QUERY_INTERRUPTED | ||
|  | --reap | ||
|  | 
 | ||
|  | --connection default | ||
|  | DROP VIEW v1; | ||
|  | DROP TABLE t1; | ||
|  | DROP FUNCTION f1; | ||
|  | --disconnect con1 | ||
|  | --disconnect con2 | ||
|  | 
 | ||
|  | --echo # | ||
|  | --echo # Bug#11763507 - 56224: FUNCTION NAME IS CASE-SENSITIVE | ||
|  | --echo # | ||
|  | SET @@SQL_MODE = ''; | ||
|  | DELIMITER $; | ||
|  | 
 | ||
|  | CREATE EVENT teste_bug11763507 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR  | ||
|  | DO SELECT 1 $ | ||
|  | 
 | ||
|  | DELIMITER ;$ | ||
|  | # EVENTS | ||
|  | --replace_column 6 # 7 # 8 # 9 # | ||
|  | SHOW EVENTS LIKE 'teste_bug11763507'; | ||
|  | --replace_column 6 # 7 # 8 # 9 # | ||
|  | SHOW EVENTS LIKE 'TESTE_bug11763507'; | ||
|  | 
 | ||
|  | --replace_column 4 #  | ||
|  | SHOW CREATE EVENT teste_bug11763507; | ||
|  | --replace_column 4 #  | ||
|  | SHOW CREATE EVENT TESTE_bug11763507; | ||
|  | 
 | ||
|  | DROP EVENT teste_bug11763507; | ||
|  | --echo #END OF BUG#11763507 test. | ||
|  | 
 | ||
|  | --echo # ------------------------------------------------------------------ | ||
|  | --echo # -- End of 5.1 tests | ||
|  | --echo # ------------------------------------------------------------------ | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # Restore global concurrent_insert value. Keep in the end of the test file. | ||
|  | # | ||
|  | 
 | ||
|  | set @@global.concurrent_insert= @old_concurrent_insert; | ||
|  | 
 | ||
|  | # Wait till all disconnects are completed | ||
|  | --source include/wait_until_count_sessions.inc |