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 77 78 79 80 81 82 83
|
--source include/have_null_audit_plugin.inc
--source include/no_protocol.inc
call mtr.add_suppression("Event 'MYSQL_AUDIT_GENERAL_ERROR' cannot be aborted.");
--replace_regex /\.dll/.so/
eval INSTALL PLUGIN null_audit SONAME '$AUDIT_NULL';
--echo #############
--echo ## PREPARE ##
--echo #############
SET @@null_audit_event_order_check = 'MYSQL_AUDIT_COMMAND_START;command_id="3";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="99";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_ERROR;;ABORT_RET';
--error ER_NO_SUCH_TABLE
PREPARE stmt FROM 'SELECT * FROM mysql.non_existing_table';
SELECT @@null_audit_event_order_check;
--echo #############
--echo ## EXECUTE ##
--echo #############
CREATE TABLE test.test_table(a INT);
PREPARE stmt FROM 'SELECT * FROM test.test_table';
DROP TABLE test.test_table;
SET @@null_audit_event_order_check = 'MYSQL_AUDIT_COMMAND_START;command_id="3";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="100";;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="0";;'
'MYSQL_AUDIT_GENERAL_ERROR;;ABORT_RET';
--error ER_NO_SUCH_TABLE
EXECUTE stmt;
SELECT @@null_audit_event_order_check;
DROP PREPARE stmt;
--echo #######################################
--echo ## ABORT GENERAL LOG WITH MY_MESSAGE ##
--echo #######################################
SET @@null_audit_abort_message = "Abort with my_message.";
SET @@null_audit_event_order_check = 'MYSQL_AUDIT_COMMAND_START;command_id="3";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="99";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_ERROR;;ABORT_RET';
--error ER_NO_SUCH_TABLE
PREPARE stmt FROM 'SELECT * FROM mysql.non_existing_table';
SELECT @@null_audit_event_order_check;
CREATE TABLE test.test_table(a INT);
PREPARE stmt FROM 'SELECT * FROM test.test_table';
DROP TABLE test.test_table;
SET @@null_audit_abort_message = "Abort with my_message.";
SET @@null_audit_event_order_check = 'MYSQL_AUDIT_COMMAND_START;command_id="3";;'
'MYSQL_AUDIT_PARSE_PREPARSE;;;'
'MYSQL_AUDIT_PARSE_POSTPARSE;;;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="100";;'
'MYSQL_AUDIT_GENERAL_LOG;;;'
'MYSQL_AUDIT_QUERY_START;sql_command_id="0";;'
'MYSQL_AUDIT_GENERAL_ERROR;;ABORT_RET';
--error ER_NO_SUCH_TABLE
EXECUTE stmt;
SELECT @@null_audit_event_order_check;
DROP PREPARE stmt;
UNINSTALL PLUGIN null_audit;
|