mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
Create 'main' test directory and move 't' and 'r' there
This commit is contained in:
201
mysql-test/main/sp-threads.test
Normal file
201
mysql-test/main/sp-threads.test
Normal file
@ -0,0 +1,201 @@
|
||||
# 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
|
Reference in New Issue
Block a user