mirror of
https://github.com/MariaDB/server.git
synced 2025-01-16 12:02:42 +01:00
aeca826c5f
Write a log event to the general log before executing a statemment in PS mode This change fixes failure of the test main.log_tables when it is run in PS mode Updated the test main.events_logs_tests to query mysql.general_log for the command_type 'Query' and 'Execute' in order to have consistent test result both in case the test is run with --ps-protocol and without it
74 lines
2.5 KiB
Text
74 lines
2.5 KiB
Text
set @save_long_query_time=@@long_query_time;
|
|
drop database if exists events_test;
|
|
create database if not exists events_test;
|
|
use events_test;
|
|
|
|
We use procedure here because its statements won't be
|
|
logged into the general log. If we had used normal select
|
|
that are logged in different ways depending on whether the
|
|
test suite is run in normal mode or with --ps-protocol
|
|
|
|
create procedure select_general_log()
|
|
begin
|
|
select user_host, argument from mysql.general_log
|
|
where argument like '%events_logs_test%' AND
|
|
(command_type = 'Query' OR command_type = 'Execute');
|
|
end|
|
|
|
|
Check that general query log works, but sub-statements
|
|
of the stored procedure do not leave traces in it.
|
|
|
|
truncate mysql.general_log;
|
|
select 'events_logs_tests' as outside_event;
|
|
outside_event
|
|
events_logs_tests
|
|
call select_general_log();
|
|
user_host argument
|
|
USER_HOST select 'events_logs_tests' as outside_event
|
|
|
|
Check that unlike sub-statements of stored procedures,
|
|
sub-statements of events are present in the general log.
|
|
|
|
set global event_scheduler=on;
|
|
truncate mysql.general_log;
|
|
create event ev_log_general on schedule at now() on completion not preserve do select 'events_logs_test' as inside_event;
|
|
call select_general_log();
|
|
user_host argument
|
|
USER_HOST create event ev_log_general on schedule at now() on completion not preserve do select 'events_logs_test' as inside_event
|
|
USER_HOST select 'events_logs_test' as inside_event
|
|
|
|
Check slow query log
|
|
|
|
Ensure that slow logging is on
|
|
show variables like 'slow_query_log';
|
|
Variable_name Value
|
|
slow_query_log ON
|
|
|
|
Demonstrate that session value has no effect
|
|
|
|
set @@session.long_query_time=1;
|
|
set @@global.long_query_time=300;
|
|
truncate mysql.slow_log;
|
|
create event ev_log_general on schedule at now() on completion not preserve
|
|
do select 'events_logs_test' as inside_event, sleep(1.5);
|
|
|
|
Nothing should be logged
|
|
|
|
select user_host, db, sql_text from mysql.slow_log
|
|
where sql_text like 'select \'events_logs_test\'%';
|
|
user_host db sql_text
|
|
set @@global.long_query_time=1;
|
|
truncate mysql.slow_log;
|
|
create event ev_log_general on schedule at now() on completion not preserve
|
|
do select 'events_logs_test' as inside_event, sleep(1.5);
|
|
|
|
Event sub-statement should be logged.
|
|
|
|
select user_host, db, sql_text from mysql.slow_log
|
|
where sql_text like 'select \'events_logs_test\'%';
|
|
user_host db sql_text
|
|
USER_HOST events_test select 'events_logs_test' as inside_event, sleep(1.5)
|
|
drop database events_test;
|
|
set global event_scheduler=off;
|
|
set @@global.long_query_time=@save_long_query_time;
|
|
set @@session.long_query_time=@save_long_query_time;
|