summaryrefslogtreecommitdiff
path: root/mysql-test/suite/perfschema/t/dml_setup_timers.test
blob: 6a90c669bf23c09e1de7eb31eef5529a109669b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# Tests for PERFORMANCE_SCHEMA

--source include/not_embedded.inc
--source include/have_perfschema.inc
--source include/have_timer_cycle.inc

# Set to a known state
update performance_schema.setup_timers
  set timer_name='CYCLE' where name="wait";
update performance_schema.setup_timers
  set timer_name='NANOSECOND' where name="stage";
update performance_schema.setup_timers
  set timer_name='NANOSECOND' where name="statement";
update performance_schema.setup_timers
  set timer_name='MICROSECOND' where name="transaction";
update performance_schema.setup_timers
  set timer_name='MICROSECOND' where name="idle";

select * from performance_schema.setup_timers;

select * from performance_schema.setup_timers
  where name='Wait';

select * from performance_schema.setup_timers
  where timer_name='CYCLE';

--error ER_TABLEACCESS_DENIED_ERROR
insert into performance_schema.setup_timers
  set name='FOO', timer_name='CYCLE';

--error ER_WRONG_PERFSCHEMA_USAGE
update performance_schema.setup_timers
  set name='FOO';

update performance_schema.setup_timers
  set timer_name='MILLISECOND';

select * from performance_schema.setup_timers;

update performance_schema.setup_timers
  set timer_name='CYCLE';

--error ER_TABLEACCESS_DENIED_ERROR
delete from performance_schema.setup_timers;

--error ER_TABLEACCESS_DENIED_ERROR
delete from performance_schema.setup_timers
  where name='Wait';

LOCK TABLES performance_schema.setup_timers READ;
UNLOCK TABLES;

LOCK TABLES performance_schema.setup_timers WRITE;
UNLOCK TABLES;

# Cleanup, restore the default values

update performance_schema.setup_timers
 set timer_name='CYCLE' where name="wait";
update performance_schema.setup_timers
 set timer_name='NANOSECOND' where name="stage";
update performance_schema.setup_timers
 set timer_name='NANOSECOND' where name="statement";
update performance_schema.setup_timers
  set timer_name='MICROSECOND' where name="transaction";
update performance_schema.setup_timers
  set timer_name='MICROSECOND' where name="idle";

select * from performance_schema.setup_timers;

--echo #
--echo # MDEV-25325 column_comment for performance_schema tables
--echo #
select column_name, column_comment 
from information_schema.columns 
where table_schema='performance_schema' and table_name='setup_timers';