Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
8f9168df
Commit
8f9168df
authored
Aug 11, 2007
by
kostja@bodhi.(none)
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
A fix for Bug#30212 events_logs_tests not deterministic; SLEEP(2), others
Make the test deterministic.
parent
3ecef8c0
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
138 additions
and
196 deletions
+138
-196
mysql-test/r/events_logs_tests.result
mysql-test/r/events_logs_tests.result
+66
-96
mysql-test/t/events_logs_tests.test
mysql-test/t/events_logs_tests.test
+72
-100
No files found.
mysql-test/r/events_logs_tests.result
View file @
8f9168df
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 '%alabala%';
END|
"Check General Query Log"
CALL select_general_log();
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%';
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 CREATE procedure select_general_log()
BEGIN
SELECT user_host, argument FROM mysql.general_log WHERE argument LIKE '%alabala%';
END
SET GLOBAL event_scheduler=on;
TRUNCATE mysql.general_log;
CREATE EVENT log_general ON SCHEDULE EVERY 1 MINUTE DO SELECT 'alabala', SLEEP(1) FROM DUAL;
"Wait the scheduler to start"
"Should see 2 rows - the 'SELECT' is in the middle. The other two are selects from general_log"
CALL select_general_log();
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 log_general ON SCHEDULE EVERY 1 MINUTE DO SELECT 'alabala', SLEEP(1) FROM DUAL
USER_HOST SELECT 'alabala', SLEEP(1) FROM DUAL
DROP PROCEDURE select_general_log;
DROP EVENT log_general;
SET GLOBAL event_scheduler=off;
"Check slow query log"
"Save the values"
SET @old_global_long_query_time:=(select get_value());
SET @old_session_long_query_time:=@@long_query_time;
SHOW VARIABLES LIKE 'log_slow_queries';
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 'log_slow_queries';
Variable_name Value
log_slow_queries ON
DROP FUNCTION get_value;
"Make it quite long"
SET SESSION long_query_time=300;
TRUNCATE mysql.slow_log;
SELECT user_host, query_time, db, sql_text FROM mysql.slow_log;
user_host query_time db sql_text
"Set new values"
SET GLOBAL long_query_time=4;
SET SESSION long_query_time=0.5;
"Check that logging is working"
SELECT SLEEP(2);
SLEEP(2)
0
SELECT user_host, query_time, db, sql_text FROM mysql.slow_log;
user_host query_time db sql_text
USER_HOST SLEEPVAL events_test SELECT SLEEP(2)
SET SESSION long_query_time=300;
"Make it quite long"
TRUNCATE mysql.slow_log;
CREATE TABLE slow_event_test (slo_val tinyint, val tinyint);
SET SESSION long_query_time=1;
"This won't go to the slow log"
SELECT * FROM slow_event_test;
slo_val val
SET SESSION long_query_time=1;
SET GLOBAL event_scheduler=on;
SET GLOBAL long_query_time=20;
CREATE EVENT long_event ON SCHEDULE EVERY 1 MINUTE DO INSERT INTO slow_event_test SELECT @@long_query_time, SLEEP(1.5);
"Sleep some more time than the actual event run will take"
SHOW VARIABLES LIKE 'event_scheduler';
Variable_name Value
event_scheduler ON
"Check our table. Should see 1 row"
SELECT * FROM slow_event_test;
slo_val val
20 0
"Check slow log. Should not see anything because 1.5 is under the threshold of 20 for GLOBAL, though over SESSION which is 1"
"This should show that the GLOBAL value is regarded and not the SESSION one of the current connection"
SELECT user_host, query_time, db, sql_text FROM mysql.slow_log;
user_host query_time db sql_text
"Another test to show that GLOBAL is regarded and not SESSION."
"This should go to the slow log"
SET SESSION long_query_time=10;
DROP EVENT long_event;
SET GLOBAL long_query_time=1;
CREATE EVENT long_event2 ON SCHEDULE EVERY 1 MINUTE DO INSERT INTO slow_event_test SELECT @@long_query_time, SLEEP(2);
"Sleep some more time than the actual event run will take"
"Check our table. Should see 2 rows"
SELECT * FROM slow_event_test;
slo_val val
20 0
1 0
"Check slow log. Should see 1 row because 2 is over the threshold of 1 for GLOBAL, though under SESSION which is 10"
SELECT user_host, query_time, db, sql_text FROM mysql.slow_log;
user_host query_time db sql_text
USER_HOST SLEEPVAL events_test INSERT INTO slow_event_test SELECT @@long_query_time, SLEEP(2)
DROP EVENT long_event2;
"Make it quite long"
SET SESSION long_query_time=300;
TRUNCATE mysql.slow_log;
DROP TABLE slow_event_test;
SET GLOBAL long_query_time =@old_global_long_query_time;
SET SESSION long_query_time =@old_session_long_query_time;
DROP DATABASE events_test;
SET GLOBAL event_scheduler=off;
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 not like 'create event%';
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 not like 'create event%';
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=default;
set @@session.long_query_time=default;
mysql-test/t/events_logs_tests.test
View file @
8f9168df
# Can't test with embedded server that doesn't support grants
--
source
include
/
not_embedded
.
inc
CREATE
DATABASE
IF
NOT
EXISTS
events_test
;
USE
events_test
;
--
echo
"We use procedure here because its statements won't be logged into the general log"
--
echo
"If we had used normal select that are logged in different ways depending on whether"
--
echo
"the test suite is run in normal mode or with --ps-protocol"
--
disable_warnings
drop
database
if
exists
events_test
;
--
enable_warnings
create
database
if
not
exists
events_test
;
use
events_test
;
--
echo
--
echo
We
use
procedure
here because its statements won't be
--echo logged into the general log. If we had used normal select
--echo that are logged in different ways depending on whether the
--echo test suite is run in normal mode or with --ps-protocol
--echo
delimiter |
;
CREATE
procedure
select_general_log
()
BEGIN
SELECT
user_host
,
argument
FROM
mysql
.
general_log
WHERE
argument
LIKE
'%alabala%'
;
END
|
create
procedure
select_general_log
()
begin
select
user_host
,
argument
from
mysql
.
general_log
where
argument
like
'%events_logs_test%'
;
end
|
delimiter
;
|
--
echo
"Check General Query Log"
--
echo
--
echo
Check
that
general
query
log
works
,
but
sub
-
statements
--
echo
of
the
stored
procedure
do
not
leave
traces
in
it
.
--
echo
truncate
mysql
.
general_log
;
# Logging format in ps protocol is slightly different
--
disable_ps_protocol
select
'events_logs_tests'
as
outside_event
;
--
enable_ps_protocol
--
replace_column
1
USER_HOST
CALL
select_general_log
();
SET
GLOBAL
event_scheduler
=
on
;
TRUNCATE
mysql
.
general_log
;
CREATE
EVENT
log_general
ON
SCHEDULE
EVERY
1
MINUTE
DO
SELECT
'alabala'
,
SLEEP
(
1
)
FROM
DUAL
;
--
echo
"Wait the scheduler to start"
--
sleep
1.5
--
echo
"Should see 2 rows - the 'SELECT' is in the middle. The other two are selects from general_log"
call
select_general_log
();
--
echo
--
echo
Check
that
unlike
sub
-
statements
of
stored
procedures
,
--
echo
sub
-
statements
of
events
are
present
in
the
general
log
.
--
echo
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
;
--
let
$wait_condition
=
select
count
(
*
)
=
0
from
information_schema
.
events
where
event_name
=
'ev_log_general'
--
source
include
/
wait_condition
.
inc
--
replace_column
1
USER_HOST
CALL
select_general_log
();
DROP
PROCEDURE
select_general_log
;
DROP
EVENT
log_general
;
SET
GLOBAL
event_scheduler
=
off
;
call
select_general_log
();
--
echo
"Check slow query log"
--
disable_query_log
DELIMITER
|
;
CREATE
FUNCTION
get_value
()
returns
INT
deterministic
BEGIN
DECLARE
var_name
CHAR
(
255
);
DECLARE
var_val
INT
;
DECLARE
done
INT
DEFAULT
0
;
DECLARE
cur1
CURSOR
FOR
SHOW
GLOBAL
VARIABLES
LIKE
'long_query_time'
;
DECLARE
CONTINUE
HANDLER
FOR
SQLSTATE
'02000'
SET
done
=
1
;
OPEN
cur1
;
FETCH
cur1
INTO
var_name
,
var_val
;
CLOSE
cur1
;
RETURN
var_val
;
end
|
DELIMITER
;
|
--
enable_query_log
--
echo
"Save the values"
SET
@
old_global_long_query_time
:=
(
select
get_value
());
SET
@
old_session_long_query_time
:=@@
long_query_time
;
SHOW
VARIABLES
LIKE
'log_slow_queries'
;
DROP
FUNCTION
get_value
;
--
echo
"Make it quite long"
SET
SESSION
long_query_time
=
300
;
TRUNCATE
mysql
.
slow_log
;
--
echo
--
echo
Check
slow
query
log
--
echo
--
echo
Ensure
that
slow
logging
is
on
show
variables
like
'log_slow_queries'
;
--
echo
--
echo
Demonstrate
that
session
value
has
no
effect
--
echo
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
);
--
let
$wait_condition
=
select
count
(
*
)
=
0
from
information_schema
.
events
where
event_name
=
'ev_log_general'
--
source
include
/
wait_condition
.
inc
--
echo
--
echo
Nothing
should
be
logged
--
echo
--
replace_column
1
USER_HOST
SELECT
user_host
,
query_time
,
db
,
sql_text
FROM
mysql
.
slow_log
;
--
echo
"Set new values"
SET
GLOBAL
long_query_time
=
4
;
SET
SESSION
long_query_time
=
0.5
;
--
echo
"Check that logging is working"
SELECT
SLEEP
(
2
);
--
replace_column
1
USER_HOST
2
SLEEPVAL
SELECT
user_host
,
query_time
,
db
,
sql_text
FROM
mysql
.
slow_log
;
SET
SESSION
long_query_time
=
300
;
--
echo
"Make it quite long"
TRUNCATE
mysql
.
slow_log
;
CREATE
TABLE
slow_event_test
(
slo_val
tinyint
,
val
tinyint
);
SET
SESSION
long_query_time
=
1
;
--
echo
"This won't go to the slow log"
SELECT
*
FROM
slow_event_test
;
SET
SESSION
long_query_time
=
1
;
SET
GLOBAL
event_scheduler
=
on
;
SET
GLOBAL
long_query_time
=
20
;
CREATE
EVENT
long_event
ON
SCHEDULE
EVERY
1
MINUTE
DO
INSERT
INTO
slow_event_test
SELECT
@@
long_query_time
,
SLEEP
(
1.5
);
--
echo
"Sleep some more time than the actual event run will take"
--
sleep
2
SHOW
VARIABLES
LIKE
'event_scheduler'
;
--
echo
"Check our table. Should see 1 row"
SELECT
*
FROM
slow_event_test
;
--
echo
"Check slow log. Should not see anything because 1.5 is under the threshold of 20 for GLOBAL, though over SESSION which is 1"
--
echo
"This should show that the GLOBAL value is regarded and not the SESSION one of the current connection"
SELECT
user_host
,
query_time
,
db
,
sql_text
FROM
mysql
.
slow_log
;
--
echo
"Another test to show that GLOBAL is regarded and not SESSION."
--
echo
"This should go to the slow log"
SET
SESSION
long_query_time
=
10
;
DROP
EVENT
long_event
;
SET
GLOBAL
long_query_time
=
1
;
CREATE
EVENT
long_event2
ON
SCHEDULE
EVERY
1
MINUTE
DO
INSERT
INTO
slow_event_test
SELECT
@@
long_query_time
,
SLEEP
(
2
);
--
echo
"Sleep some more time than the actual event run will take"
let
$wait_timeout
=
30
;
let
$wait_condition
=
SELECT
COUNT
(
*
)
=
1
FROM
mysql
.
slow_log
;
select
user_host
,
db
,
sql_text
from
mysql
.
slow_log
where
sql_text
not
like
'create event%'
;
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
);
--
let
$wait_condition
=
select
count
(
*
)
=
0
from
information_schema
.
events
where
event_name
=
'ev_log_general'
--
source
include
/
wait_condition
.
inc
--
echo
"Check our table. Should see 2 rows"
SELECT
*
FROM
slow_event_test
;
--
echo
"Check slow log. Should see 1 row because 2 is over the threshold of 1 for GLOBAL, though under SESSION which is 10"
--
replace_column
1
USER_HOST
2
SLEEPVAL
SELECT
user_host
,
query_time
,
db
,
sql_text
FROM
mysql
.
slow_log
;
DROP
EVENT
long_event2
;
--
echo
"Make it quite long"
SET
SESSION
long_query_time
=
300
;
TRUNCATE
mysql
.
slow_log
;
DROP
TABLE
slow_event_test
;
SET
GLOBAL
long_query_time
=@
old_global_long_query_time
;
SET
SESSION
long_query_time
=@
old_session_long_query_time
;
DROP
DATABASE
events_test
;
--
echo
--
echo
Event
sub
-
statement
should
be
logged
.
--
echo
--
replace_column
1
USER_HOST
select
user_host
,
db
,
sql_text
from
mysql
.
slow_log
where
sql_text
not
like
'create event%'
;
SET
GLOBAL
event_scheduler
=
off
;
drop
database
events_test
;
set
global
event_scheduler
=
off
;
set
@@
global
.
long_query_time
=
default
;
set
@@
session
.
long_query_time
=
default
;
#
# Safety
#
let
$wait_condition
=
select
count
(
*
)
=
0
from
information_schema
.
processlist
where
db
=
'events_test'
and
command
=
'Connect'
and
user
=
current_user
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment