mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 01:04:19 +01:00
209 lines
7.6 KiB
Text
209 lines
7.6 KiB
Text
# Tests for PERFORMANCE_SCHEMA
|
|
# Miscelaneous
|
|
|
|
--source include/not_embedded.inc
|
|
--source include/have_perfschema.inc
|
|
--source include/have_innodb.inc
|
|
--source include/no_protocol.inc
|
|
|
|
#
|
|
# Bug#12790483 OBJECTS_SUMMARY_GLOBAL_BY_TYPE AND RENAME TABLE
|
|
#
|
|
# Rename table leaves old tables names behind in
|
|
# performance_schema.objects_summary_global_by_type
|
|
#
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
CREATE TABLE test.t_before(a INT);
|
|
INSERT INTO test.t_before VALUES (1);
|
|
|
|
# The new table should appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE.
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
RENAME TABLE test.t_before TO test.t_after;
|
|
|
|
# The renamed table should appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE, but only
|
|
# after it is accessed.
|
|
|
|
SELECT COUNT(*) FROM test.t_after;
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
DROP TABLE test.t_after;
|
|
|
|
# The renamed table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE.
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
#
|
|
# Verify table views are ignored by the table io instrumentation.
|
|
#
|
|
|
|
CREATE TABLE test.t1(a INT);
|
|
INSERT INTO test.t1 VALUES (1);
|
|
CREATE VIEW test.v1 AS SELECT * FROM test.t1;
|
|
SELECT COUNT(*) FROM test.v1;
|
|
|
|
# Verify that a PFS table share was not created for the view.
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
DROP VIEW test.v1;
|
|
DROP TABLE test.t1;
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
|
|
#
|
|
# Bug#45496 Performance schema: assertion fails in
|
|
# ha_perfschema::rnd_init:223
|
|
#
|
|
|
|
--disable_result_log
|
|
SELECT EVENT_ID FROM performance_schema.events_waits_current
|
|
WHERE THREAD_ID IN
|
|
(SELECT THREAD_ID FROM performance_schema.threads)
|
|
AND EVENT_NAME IN
|
|
(SELECT NAME FROM performance_schema.setup_instruments
|
|
WHERE NAME LIKE "wait/synch/%")
|
|
LIMIT 1;
|
|
--enable_result_log
|
|
|
|
#
|
|
# Bug#45088 Should not be able to create tables of engine PERFORMANCE_SCHEMA
|
|
#
|
|
|
|
--error ER_CANT_CREATE_TABLE
|
|
create table test.t1(a int) engine=performance_schema;
|
|
|
|
# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
#
|
|
# Bug#44897 Performance Schema: can create a ghost table in another database
|
|
#
|
|
|
|
--error ER_CANT_CREATE_TABLE
|
|
create table test.t1 like performance_schema.events_waits_current;
|
|
|
|
# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
#
|
|
# Bug#44898 PerformanceSchema: can create a table in db performance_schema, cannot insert
|
|
#
|
|
|
|
--error ER_TABLEACCESS_DENIED_ERROR
|
|
create table performance_schema.t1(a int);
|
|
|
|
# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE
|
|
|
|
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
|
|
WHERE object_schema='test';
|
|
|
|
#
|
|
# Bug#51447 performance schema evil twin files
|
|
#
|
|
|
|
--disable_warnings
|
|
drop table if exists test.ghost;
|
|
--enable_warnings
|
|
|
|
create table test.ghost (a int, b int);
|
|
alter table test.ghost add index index_a(a);
|
|
alter table test.ghost add index index_b(b);
|
|
insert into test.ghost values (1, 3);
|
|
insert into test.ghost values (2, 4);
|
|
select * from test.ghost;
|
|
|
|
drop table test.ghost;
|
|
|
|
# Shoud return nothing
|
|
select * from performance_schema.file_instances
|
|
where file_name like "%ghost%";
|
|
|
|
#
|
|
# Bug#52586 Misleading error message on attempt to access
|
|
# a P_S table using a wrong name
|
|
|
|
--error ER_NO_SUCH_TABLE
|
|
select * from performance_schema.no_such_table;
|
|
|
|
#
|
|
# Bug#12370950 - 60905: TABLE_IO_WAITS_SUMMARY_BY_INDEX_USAGE AGGREGATES NON-INSERT DML WRONGLY
|
|
#
|
|
|
|
--disable_warnings
|
|
DROP TABLE IF EXISTS t_60905;
|
|
--enable_warnings
|
|
CREATE TABLE t_60905 (i INT, j INT, KEY(i)) ENGINE = InnoDB;
|
|
INSERT INTO t_60905 VALUES
|
|
(1,2), (3,4), (5,6), (7,8), (9,10);
|
|
|
|
# should delete with a "single" PRIMARY lookup (2 PRIMARY fetch, 1 PRIMARY delete)
|
|
DELETE FROM t_60905 WHERE i = 1;
|
|
|
|
# should delete with a full scan (5 NULL fetch, 1 NULL delete)
|
|
DELETE FROM t_60905 WHERE j = 8;
|
|
|
|
# show the instrument data
|
|
SELECT object_schema,
|
|
object_name,
|
|
index_name,
|
|
count_fetch,
|
|
count_insert,
|
|
count_update,
|
|
count_delete
|
|
FROM performance_schema.table_io_waits_summary_by_index_usage
|
|
WHERE object_schema = 'test'
|
|
AND object_name = 't_60905';
|
|
|
|
DROP TABLE t_60905;
|
|
|
|
|
|
#
|
|
# Bug#11929832 - EVENTS_STATEMENTS_HISTORY HAS ERRORS=0 WHEN THERE ARE ERRORS
|
|
#
|
|
# Verify that SQL errors are properly counted.
|
|
|
|
use test;
|
|
truncate performance_schema.events_statements_history;
|
|
truncate performance_schema.events_statements_history_long;
|
|
|
|
--error ER_NO_SUCH_TABLE
|
|
select * from t1;
|
|
|
|
--echo
|
|
select mysql_errno, returned_sqlstate, message_text, errors, warnings
|
|
from performance_schema.events_statements_history where errors > 0;
|
|
|
|
--echo
|
|
select mysql_errno, returned_sqlstate, message_text, errors, warnings from
|
|
performance_schema.events_statements_history_long where errors > 0;
|
|
|
|
#
|
|
# Bug#20519832 - TRUNCATED SQL_TEXT values are not suffixed with '...'
|
|
#
|
|
# Verify that truncated SQL statements are suffixed with '...'
|
|
|
|
use performance_schema;
|
|
truncate performance_schema.events_statements_history;
|
|
|
|
# Should truncate at 1024 bytes (1024 characters)
|
|
select 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' AS A;
|
|
|
|
# Should truncate at 1024 bytes (487 characters)
|
|
|
|
select _utf8mb4 'ваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑваÑÑ' as B;
|
|
|
|
select count(*) from events_statements_history where sql_text like "%...";
|