Commit 2cdf8a93 authored by Sergei Golubchik's avatar Sergei Golubchik

MDEV-23752 SHOW EXPLAIN FOR thd waits for sleep

fix main.processlist_notembedded test

* before EXPLAINing `select sleep` wait for select to start
  (fixes "Target is not running an EXPLAINable command")
* after killing sleep, wait for it to die
  (fixes test failures on --repeat when old sleep shows on a test rerun)

* unify with 10.3, copy minor changes from there
  (`--echo End of 5.5` vs `--echo # End of 5.5`, etc)
parent 22709897
# #
# MDEV-20466: SHOW PROCESSLIST truncates query text on \0 bytes # MDEV-20466: SHOW PROCESSLIST truncates query text on \0 bytes
# #
connect con1,localhost,root,,; connect con1,localhost,root;
connection con1; connection con1;
SET DEBUG_SYNC= 'before_join_optimize SIGNAL in_sync WAIT_FOR go'; SET DEBUG_SYNC= 'before_join_optimize SIGNAL in_sync WAIT_FOR go';
connection default; connection default;
...@@ -13,17 +13,22 @@ user ...@@ -13,17 +13,22 @@ user
disconnect con1; disconnect con1;
connection default; connection default;
SET DEBUG_SYNC = 'RESET'; SET DEBUG_SYNC = 'RESET';
End of 5.5 tests #
# End of 5.5 tests
#
# #
# MDEV-23752: SHOW EXPLAIN FOR thd waits for sleep # MDEV-23752: SHOW EXPLAIN FOR thd waits for sleep
# #
connect con1,localhost,root,,; connect con1,localhost,root;
select sleep(100000);; select sleep(100000);
connection default; connection default;
SHOW EXPLAIN FOR con_id; SHOW EXPLAIN FOR $con_id;
id select_type table type possible_keys key key_len ref rows Extra id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used 1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
Warnings: Warnings:
Note 1003 select sleep(100000) Note 1003 select sleep(100000)
KILL QUERY con_id; KILL QUERY $con_id;
disconnect con1;
#
# End of 10.2 tests # End of 10.2 tests
#
source include/have_debug.inc;
source include/have_debug_sync.inc; source include/have_debug_sync.inc;
source include/not_embedded.inc; source include/not_embedded.inc;
source include/count_sessions.inc; source include/count_sessions.inc;
...@@ -7,7 +6,7 @@ source include/count_sessions.inc; ...@@ -7,7 +6,7 @@ source include/count_sessions.inc;
--echo # MDEV-20466: SHOW PROCESSLIST truncates query text on \0 bytes --echo # MDEV-20466: SHOW PROCESSLIST truncates query text on \0 bytes
--echo # --echo #
connect (con1,localhost,root,,); connect con1,localhost,root;
connection con1; connection con1;
...@@ -37,24 +36,26 @@ connection default; ...@@ -37,24 +36,26 @@ connection default;
SET DEBUG_SYNC = 'RESET'; SET DEBUG_SYNC = 'RESET';
source include/wait_until_count_sessions.inc; --echo #
--echo # End of 5.5 tests
--echo End of 5.5 tests --echo #
--echo # --echo #
--echo # MDEV-23752: SHOW EXPLAIN FOR thd waits for sleep --echo # MDEV-23752: SHOW EXPLAIN FOR thd waits for sleep
--echo # --echo #
--connect (con1,localhost,root,,) --connect con1,localhost,root
--let $con_id = `SELECT CONNECTION_ID()` --let $con_id = `SELECT CONNECTION_ID()`
--send select sleep(100000); --send select sleep(100000)
--connection default --connection default
let $wait_condition= SELECT COUNT(*)=1 FROM information_schema.processlist where state='User sleep';
source include/wait_condition.inc;
evalp SHOW EXPLAIN FOR $con_id;
evalp KILL QUERY $con_id;
disconnect con1;
source include/wait_until_count_sessions.inc;
--replace_result $con_id con_id --echo #
eval SHOW EXPLAIN FOR $con_id;
--replace_result $con_id con_id
eval KILL QUERY $con_id;
--echo # End of 10.2 tests --echo # End of 10.2 tests
--echo #
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment