199 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			199 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| 
								 | 
							
								# This test should work in embedded server after mysqltest is fixed
							 | 
						||
| 
								 | 
							
								-- source include/not_embedded.inc
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Testing stored procedures with multiple connections,
							 | 
						||
| 
								 | 
							
								# except security/privilege tests, they go to sp-security.test
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Save the initial number of concurrent sessions
							 | 
						||
| 
								 | 
							
								--source include/count_sessions.inc
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connect (con1root,localhost,root,,);
							 | 
						||
| 
								 | 
							
								connect (con2root,localhost,root,,);
							 | 
						||
| 
								 | 
							
								connect (con3root,localhost,root,,);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								use test;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop table if exists t1;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								create table t1 (s1 int, s2 int, s3 int);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								delimiter //;
							 | 
						||
| 
								 | 
							
								create procedure bug4934()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								   insert into t1 values (1,0,1);
							 | 
						||
| 
								 | 
							
								end//
							 | 
						||
| 
								 | 
							
								delimiter ;//
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								use test;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								call bug4934();
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								create table t1 (s1 int, s2 int, s3 int);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								drop procedure bug4934;
							 | 
						||
| 
								 | 
							
								delimiter //;
							 | 
						||
| 
								 | 
							
								create procedure bug4934()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								end//
							 | 
						||
| 
								 | 
							
								delimiter ;//
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								call bug4934();
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								drop procedure bug4934;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#9486 Can't perform multi-update in stored procedure
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug9486;
							 | 
						||
| 
								 | 
							
								drop table if exists t1, t2;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								create table t1 (id1 int, val int);
							 | 
						||
| 
								 | 
							
								create table t2 (id2 int);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								create procedure bug9486()
							 | 
						||
| 
								 | 
							
								  update t1, t2 set val= 1 where id1=id2;
							 | 
						||
| 
								 | 
							
								call bug9486();
							 | 
						||
| 
								 | 
							
								# Let us check that SP invocation requires write lock for t2.
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								lock tables t2 write;
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								send call bug9486();
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								--sleep 2
							 | 
						||
| 
								 | 
							
								# There should be call statement in locked state.
							 | 
						||
| 
								 | 
							
								--replace_column 1 # 3 localhost 6 #
							 | 
						||
| 
								 | 
							
								show processlist;
							 | 
						||
| 
								 | 
							
								unlock tables;
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								reap;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								drop procedure bug9486;
							 | 
						||
| 
								 | 
							
								drop table t1, t2;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#11158 Can't perform multi-delete in stored procedure
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug11158;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								create procedure bug11158() delete t1 from t1, t2 where t1.id = t2.id;
							 | 
						||
| 
								 | 
							
								create table t1 (id int, j int);
							 | 
						||
| 
								 | 
							
								insert into t1 values (1, 1), (2, 2);
							 | 
						||
| 
								 | 
							
								create table t2 (id int);
							 | 
						||
| 
								 | 
							
								insert into t2 values (1);
							 | 
						||
| 
								 | 
							
								# Procedure should work and cause proper effect (delete only first row)
							 | 
						||
| 
								 | 
							
								call bug11158();
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								# Also let us test that we obtain only read (and thus non exclusive) lock
							 | 
						||
| 
								 | 
							
								# for table from which we are not going to delete rows.
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								lock tables t2 read;
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								call bug11158();
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								unlock tables;
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								# Clean-up
							 | 
						||
| 
								 | 
							
								drop procedure bug11158;
							 | 
						||
| 
								 | 
							
								drop table t1, t2;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#11554 Server crashes on statement indirectly using non-cached function
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop function if exists bug11554;
							 | 
						||
| 
								 | 
							
								drop view if exists v1;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								create table t1 (i int);
							 | 
						||
| 
								 | 
							
								create function bug11554 () returns int return 1;
							 | 
						||
| 
								 | 
							
								create view v1 as select bug11554() as f;
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								# This should not crash server
							 | 
						||
| 
								 | 
							
								insert into t1 (select f from v1);
							 | 
						||
| 
								 | 
							
								# Clean-up
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								drop function bug11554;
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								drop view v1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Bug#12228 Crash happens during calling specific SP in multithread environment
							 | 
						||
| 
								 | 
							
								--disable_warnings
							 | 
						||
| 
								 | 
							
								drop procedure if exists p1;
							 | 
						||
| 
								 | 
							
								drop procedure if exists p2;
							 | 
						||
| 
								 | 
							
								--enable_warnings
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								delimiter |;
							 | 
						||
| 
								 | 
							
								create table t1 (s1 int)|
							 | 
						||
| 
								 | 
							
								create procedure p1() select * from t1|
							 | 
						||
| 
								 | 
							
								create procedure p2()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								  insert into t1 values (1);
							 | 
						||
| 
								 | 
							
								  call p1();
							 | 
						||
| 
								 | 
							
								  select * from t1;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								delimiter ;|
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								use test;
							 | 
						||
| 
								 | 
							
								lock table t1 write;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								send call p2();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con3root;
							 | 
						||
| 
								 | 
							
								use test;
							 | 
						||
| 
								 | 
							
								drop procedure p1;
							 | 
						||
| 
								 | 
							
								create procedure p1() select * from t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con2root;
							 | 
						||
| 
								 | 
							
								unlock tables;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection con1root;
							 | 
						||
| 
								 | 
							
								# Crash will be here if we hit Bug#12228
							 | 
						||
| 
								 | 
							
								reap;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								drop procedure p1;
							 | 
						||
| 
								 | 
							
								drop procedure p2;
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#NNNN New bug synopsis
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								#--disable_warnings
							 | 
						||
| 
								 | 
							
								#drop procedure if exists bugNNNN;
							 | 
						||
| 
								 | 
							
								#--enable_warnings
							 | 
						||
| 
								 | 
							
								#create procedure bugNNNN...
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								connection default;
							 | 
						||
| 
								 | 
							
								disconnect con1root;
							 | 
						||
| 
								 | 
							
								disconnect con2root;
							 | 
						||
| 
								 | 
							
								disconnect con3root;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Wait till we reached the initial number of concurrent sessions
							 | 
						||
| 
								 | 
							
								--source include/wait_until_count_sessions.inc
							 |