mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	Added proper waiting for thread to enter required state. Also reduced amount of information dumped from processlist.
		
			
				
	
	
		
			202 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			202 lines
		
	
	
		
			4.2 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;
 | |
| let $con1root_id=`SELECT CONNECTION_ID()`;
 | |
| send call bug9486();
 | |
| connection con2root;
 | |
| # There should be call statement in locked state.
 | |
| let $wait_condition=SELECT COUNT(*)=1 FROM information_schema.processlist WHERE
 | |
|                     id=$con1root_id AND state='Waiting for table metadata lock';
 | |
| --source include/wait_condition.inc
 | |
| --replace_result $con1root_id con1root_id
 | |
| eval SELECT state,info FROM information_schema.processlist WHERE id=$con1root_id;
 | |
| 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
 |