2001-10-08 04:58:07 +03:00
|
|
|
# This test doesn't work with the embedded version as this code
|
|
|
|
# assumes that one query is running while we are doing queries on
|
|
|
|
# a second connection.
|
|
|
|
# This would work if mysqltest run would be threaded and handle each
|
|
|
|
# connection in a separate thread.
|
|
|
|
#
|
|
|
|
-- source include/not_embedded.inc
|
|
|
|
|
2001-03-25 01:02:26 +02:00
|
|
|
connect (con1, localhost, root,,);
|
|
|
|
connect (con2, localhost, root,,);
|
2001-03-13 23:07:12 -07:00
|
|
|
|
|
|
|
#remember id of con1
|
|
|
|
connection con1;
|
2003-01-06 01:48:59 +02:00
|
|
|
--disable_warnings
|
2006-01-18 13:48:57 +02:00
|
|
|
drop table if exists t1, t2, t3;
|
2003-01-06 01:48:59 +02:00
|
|
|
--enable_warnings
|
|
|
|
|
2005-08-18 03:12:42 +03:00
|
|
|
--disable_reconnect
|
2001-03-15 03:55:48 +02:00
|
|
|
create table t1 (kill_id int);
|
|
|
|
insert into t1 values(connection_id());
|
2001-03-13 23:07:12 -07:00
|
|
|
|
|
|
|
#kill con1
|
|
|
|
connection con2;
|
2001-03-15 03:55:48 +02:00
|
|
|
select ((@id := kill_id) - kill_id) from t1;
|
2001-03-13 23:07:12 -07:00
|
|
|
kill @id;
|
|
|
|
|
|
|
|
connection con1;
|
2006-01-06 00:47:49 +02:00
|
|
|
--sleep 2
|
2005-03-28 09:59:41 -08:00
|
|
|
|
2006-01-06 00:47:49 +02:00
|
|
|
--disable_query_log
|
|
|
|
--disable_result_log
|
|
|
|
# One of the following statements should fail
|
|
|
|
--error 0,2006,2013
|
2005-03-28 09:59:41 -08:00
|
|
|
select 1;
|
2006-01-06 00:47:49 +02:00
|
|
|
--error 0,2006,2013
|
|
|
|
select 1;
|
|
|
|
--enable_query_log
|
|
|
|
--enable_result_log
|
|
|
|
|
2005-03-28 09:59:41 -08:00
|
|
|
--enable_reconnect
|
|
|
|
# this should work, and we should have a new connection_id()
|
|
|
|
select ((@id := kill_id) - kill_id) from t1;
|
2001-03-15 03:55:48 +02:00
|
|
|
select @id != connection_id();
|
2001-03-13 23:07:12 -07:00
|
|
|
|
|
|
|
#make sure the server is still alive
|
|
|
|
connection con2;
|
|
|
|
select 4;
|
2001-03-15 03:55:48 +02:00
|
|
|
drop table t1;
|
2006-01-18 13:48:57 +02:00
|
|
|
connection default;
|
2005-07-28 03:22:47 +03:00
|
|
|
|
2006-11-02 13:51:43 +01:00
|
|
|
--error ER_NOT_SUPPORTED_YET
|
2006-03-06 18:26:39 +01:00
|
|
|
kill (select count(*) from mysql.user);
|
|
|
|
|
2006-01-18 13:48:57 +02:00
|
|
|
#
|
|
|
|
# BUG#14851: killing long running subquery processed via a temporary table.
|
|
|
|
#
|
|
|
|
create table t1 (id int primary key);
|
|
|
|
create table t2 (id int unsigned not null);
|
|
|
|
|
|
|
|
connect (conn1, localhost, root,,);
|
|
|
|
connection conn1;
|
|
|
|
|
|
|
|
-- disable_result_log
|
|
|
|
-- disable_query_log
|
|
|
|
let $1 = 4096;
|
|
|
|
while ($1)
|
|
|
|
{
|
|
|
|
eval insert into t1 values ($1);
|
|
|
|
dec $1;
|
|
|
|
}
|
|
|
|
-- enable_query_log
|
|
|
|
-- enable_result_log
|
|
|
|
|
|
|
|
insert into t2 select id from t1;
|
|
|
|
|
|
|
|
create table t3 (kill_id int);
|
|
|
|
insert into t3 values(connection_id());
|
|
|
|
|
|
|
|
-- disable_result_log
|
|
|
|
send select id from t1 where id in (select distinct id from t2);
|
|
|
|
-- enable_result_log
|
|
|
|
|
|
|
|
connect (conn2, localhost, root,,);
|
|
|
|
connection conn2;
|
|
|
|
select ((@id := kill_id) - kill_id) from t3;
|
|
|
|
-- sleep 1
|
|
|
|
kill @id;
|
|
|
|
|
|
|
|
connection conn1;
|
2006-02-07 13:45:16 +02:00
|
|
|
-- error 1053,2013
|
2006-01-18 13:48:57 +02:00
|
|
|
reap;
|
|
|
|
|
|
|
|
connection default;
|
|
|
|
|
|
|
|
drop table t1, t2, t3;
|
|
|
|
|
2005-07-28 03:22:47 +03:00
|
|
|
# End of 4.1 tests
|
2005-07-28 17:09:54 +03:00
|
|
|
|
2005-01-20 10:41:37 +02:00
|
|
|
#
|
|
|
|
# test of blocking of sending ERROR after OK or EOF
|
|
|
|
#
|
|
|
|
connection con1;
|
|
|
|
select get_lock("a", 10);
|
|
|
|
connection con2;
|
|
|
|
let $ID= `select connection_id()`;
|
|
|
|
send select get_lock("a", 10);
|
2005-09-01 17:01:23 +02:00
|
|
|
real_sleep 2;
|
2005-01-20 10:41:37 +02:00
|
|
|
connection con1;
|
|
|
|
disable_query_log;
|
|
|
|
eval kill query $ID;
|
|
|
|
enable_query_log;
|
|
|
|
connection con2;
|
|
|
|
reap;
|
|
|
|
select 1;
|
|
|
|
connection con1;
|
|
|
|
select RELEASE_LOCK("a");
|