2013-06-13 20:19:32 +02:00
|
|
|
#
|
|
|
|
# MDEV-4578 information_schema.processlist reports incorrect value for Time (2147483647)
|
|
|
|
#
|
|
|
|
|
2015-01-06 16:32:41 +01:00
|
|
|
source include/have_debug.inc;
|
2013-06-13 20:19:32 +02:00
|
|
|
source include/have_debug_sync.inc;
|
|
|
|
|
2014-10-22 13:51:33 +02:00
|
|
|
let $tid= `SELECT CONNECTION_ID()`;
|
2013-06-13 20:19:32 +02:00
|
|
|
SET DEBUG_SYNC = 'dispatch_command_before_set_time WAIT_FOR do_set_time';
|
|
|
|
send SELECT 1;
|
|
|
|
|
|
|
|
connect (con1,localhost,root,,);
|
|
|
|
|
|
|
|
SET DEBUG_SYNC = 'fill_schema_processlist_after_unow SIGNAL do_set_time WAIT_FOR fill_schema_proceed';
|
2014-10-22 13:51:33 +02:00
|
|
|
--replace_result $tid TID
|
|
|
|
send_eval SELECT ID, TIME,TIME_MS FROM INFORMATION_SCHEMA.PROCESSLIST WHERE CONCAT(":", ID, ":") = ":$tid:";
|
2013-06-13 20:19:32 +02:00
|
|
|
|
|
|
|
connection default;
|
|
|
|
reap;
|
|
|
|
SET DEBUG_SYNC = 'now SIGNAL fill_schema_proceed';
|
|
|
|
|
|
|
|
connection con1;
|
2014-10-22 13:51:33 +02:00
|
|
|
--replace_result $tid TID
|
2013-06-13 20:19:32 +02:00
|
|
|
reap;
|
2015-01-06 16:32:41 +01:00
|
|
|
set debug_sync='reset';
|
2013-07-01 12:02:44 +02:00
|
|
|
connection default;
|
|
|
|
|
|
|
|
#
|
|
|
|
# MDEV-4683 query start_time not reset when going to sleep
|
|
|
|
#
|
|
|
|
|
|
|
|
connection con1;
|
2015-01-06 16:32:41 +01:00
|
|
|
# This DBUG insertion triggers a DEBUG_SYNC signal "query_done" once
|
|
|
|
# the below SELECT SLEEP(5) has gone from "Query" to "Sleep" command
|
|
|
|
# state. (We cannot just set the DEBUG_SYNC directly here, because
|
|
|
|
# then it can trigger at the end of the SET DEBUG_SYNC statement (or
|
|
|
|
# at the end of the Prepare step of the SELECT, if --ps-protocol),
|
|
|
|
# thus occuring too early).
|
|
|
|
SET debug_dbug="+d,sleep_inject_query_done_debug_sync";
|
2013-07-01 12:02:44 +02:00
|
|
|
select sleep(5); #run a query that will take some time
|
|
|
|
connection default;
|
|
|
|
|
2014-10-22 13:51:33 +02:00
|
|
|
# Need to ensure that the previous query has really completed. Otherwise,
|
|
|
|
# the select could see the previous query still in "Query" stage in the
|
|
|
|
# processlist.
|
|
|
|
SET DEBUG_SYNC = 'now WAIT_FOR query_done';
|
|
|
|
|
2013-07-01 12:02:44 +02:00
|
|
|
# verify that the time in COM_SLEEP doesn't include the query run time
|
|
|
|
select command, time < 5 from information_schema.processlist where id != connection_id();
|
|
|
|
|
2013-06-13 20:19:32 +02:00
|
|
|
disconnect con1;
|
2015-05-07 22:34:06 +02:00
|
|
|
connection default;
|
2014-01-27 12:10:53 +01:00
|
|
|
set debug_sync='reset';
|
2015-05-07 22:34:06 +02:00
|
|
|
|
2019-10-14 16:45:51 +02:00
|
|
|
--echo End of 5.5 tests
|
2015-05-07 22:34:06 +02:00
|
|
|
|
|
|
|
--echo #
|
|
|
|
--echo # 10.1 tests
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
--echo #
|
|
|
|
--echo # MDEV-7807 information_schema.processlist truncates queries with binary strings
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
SET NAMES utf8;
|
|
|
|
--vertical_results
|
|
|
|
SELECT INFO, INFO_BINARY, 'xxx😎yyy' AS utf8mb4_string FROM INFORMATION_SCHEMA.PROCESSLIST WHERE INFO LIKE '%xxx%yyy%';
|
|
|
|
--horizontal_results
|
|
|
|
|
|
|
|
--echo #
|
|
|
|
--echo # End of 10.1 tests
|
|
|
|
--echo #
|